Compare commits
2 Commits
developmen
...
developmen
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
6d6cbd115a | ||
|
|
3c9823bf80 |
@@ -1,6 +1,5 @@
|
|||||||
import type { ReactNode } from "react";
|
import type { ReactNode } from "react";
|
||||||
import { Button } from "@/components/ui/button";
|
import { ArrowRight } from "lucide-react";
|
||||||
import { ArrowRightIcon } from "@radix-ui/react-icons";
|
|
||||||
import { cn } from "@/lib/utils";
|
import { cn } from "@/lib/utils";
|
||||||
|
|
||||||
const BentoGrid = ({
|
const BentoGrid = ({
|
||||||
@@ -64,12 +63,13 @@ const BentoCard = ({
|
|||||||
"pointer-events-none absolute bottom-0 flex w-full translate-y-10 transform-gpu flex-row items-center p-4 opacity-0 transition-all duration-300 group-hover:translate-y-0 group-hover:opacity-100",
|
"pointer-events-none absolute bottom-0 flex w-full translate-y-10 transform-gpu flex-row items-center p-4 opacity-0 transition-all duration-300 group-hover:translate-y-0 group-hover:opacity-100",
|
||||||
)}
|
)}
|
||||||
>
|
>
|
||||||
<Button variant="ghost" asChild size="sm" className="pointer-events-auto">
|
<a
|
||||||
<a href={href}>
|
href={href}
|
||||||
{cta}
|
className="pointer-events-auto inline-flex items-center gap-2 text-sm font-medium text-neutral-600 transition-colors hover:text-sky-700"
|
||||||
<ArrowRightIcon className="ml-2 h-4 w-4" />
|
>
|
||||||
</a>
|
{cta}
|
||||||
</Button>
|
<ArrowRight className="h-4 w-4" />
|
||||||
|
</a>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -34,7 +34,7 @@ export function Dropdown({ buttonContent, items }: DropdownProps) {
|
|||||||
<div className="py-1">
|
<div className="py-1">
|
||||||
{items.map((item) => (
|
{items.map((item) => (
|
||||||
<Menu.Item key={item.href}>
|
<Menu.Item key={item.href}>
|
||||||
{({ active }) => (
|
{({ active }: { active: boolean }) => (
|
||||||
<Link
|
<Link
|
||||||
to={item.href}
|
to={item.href}
|
||||||
className={`
|
className={`
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
import { AnimatedSection } from '../../components/AnimatedSection'
|
import { AnimatedSection } from '../../components/AnimatedSection'
|
||||||
import { AgentsHero } from './AgentsHero'
|
|
||||||
import { DeploySection } from './DeploySection'
|
import { DeploySection } from './DeploySection'
|
||||||
import { GallerySection } from './GallerySection'
|
import { GallerySection } from './GallerySection'
|
||||||
import { Companies } from './Companies'
|
import { Companies } from './Companies'
|
||||||
|
|||||||
92
src/pages/cloud/CloudArchitecture.tsx
Normal file
92
src/pages/cloud/CloudArchitecture.tsx
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const architectureSections = [
|
||||||
|
{
|
||||||
|
title: 'Decentralized Infrastructure',
|
||||||
|
description:
|
||||||
|
'Clusters launch across the ThreeFold Grid with direct node access and encrypted connectivity.',
|
||||||
|
bullets: [
|
||||||
|
'Unique Mycelium IP addresses assigned to every node.',
|
||||||
|
'Peer-to-peer mesh networking links services across nodes.',
|
||||||
|
'End-to-end encryption keeps traffic sealed inside the fabric.',
|
||||||
|
'No public IP exposure—everything is addressable via Mycelium IPs.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Network Flow',
|
||||||
|
description:
|
||||||
|
'Traffic moves through the Mycelium mesh, maintaining sovereignty without sacrificing reach.',
|
||||||
|
bullets: [
|
||||||
|
'User requests enter through the encrypted Mycelium network.',
|
||||||
|
'Traffic routes directly to cluster nodes without intermediate hops.',
|
||||||
|
'Services answer over the same mesh—no ingress controller required.',
|
||||||
|
'Operational visibility without exposing public attack surface.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Kubernetes Management',
|
||||||
|
description:
|
||||||
|
'Lightweight K3s orchestration delivers HA clusters with automated lifecycle management.',
|
||||||
|
bullets: [
|
||||||
|
'Full K3s deployment and lifecycle management built-in.',
|
||||||
|
'IPv6-native networking ensures deterministic service discovery.',
|
||||||
|
'Multi-master topologies with automatic failover for resilience.',
|
||||||
|
'Drift-free upgrades orchestrated through smart contracts.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function CloudArchitecture() {
|
||||||
|
return (
|
||||||
|
<section className="bg-white py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-500">
|
||||||
|
Technical Architecture
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
Built on a sovereign, encrypted delivery mesh.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
Mycelium Cloud rides on the ThreeFold Grid, pairing encrypted mesh
|
||||||
|
networking with deterministic K3s orchestration. Every layer is
|
||||||
|
designed to keep workloads sovereign, observable, and effortless to
|
||||||
|
operate.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-3">
|
||||||
|
{architectureSections.map((section) => (
|
||||||
|
<div
|
||||||
|
key={section.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-slate-200 bg-white p-8 shadow-sm transition hover:-translate-y-1 hover:border-cyan-300 hover:shadow-lg"
|
||||||
|
>
|
||||||
|
<div className="flex items-center gap-3">
|
||||||
|
<span className="inline-flex size-10 items-center justify-center rounded-full bg-cyan-500/10 text-base font-semibold uppercase tracking-[0.3em] text-cyan-600">
|
||||||
|
•
|
||||||
|
</span>
|
||||||
|
<h3 className="text-xl font-semibold text-gray-900">
|
||||||
|
{section.title}
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-600">
|
||||||
|
{section.description}
|
||||||
|
</p>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-600">
|
||||||
|
{section.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-100 bg-cyan-50/60 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-500" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -7,13 +7,16 @@ export function CloudCTA() {
|
|||||||
<Container className="relative">
|
<Container className="relative">
|
||||||
<div className="mx-auto max-w-3xl text-center">
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
<p className="text-sm font-semibold uppercase tracking-[0.3em] text-cyan-500">
|
<p className="text-sm font-semibold uppercase tracking-[0.3em] text-cyan-500">
|
||||||
Ready Today
|
Launch Today
|
||||||
</p>
|
</p>
|
||||||
<h2 className="mt-6 text-3xl font-semibold tracking-tight text-gray-900 lg:text-5xl">
|
<h2 className="mt-6 text-3xl font-semibold tracking-tight text-gray-900 lg:text-5xl">
|
||||||
Join thousands of developers and DevOps engineers who trust Mycelium Cloud for their production workloads.
|
Put sovereign Kubernetes into production on the ThreeFold Grid.
|
||||||
</h2>
|
</h2>
|
||||||
<p className="mt-6 text-lg text-gray-600">
|
<p className="mt-6 text-lg text-gray-600">
|
||||||
Revolutionary Kubernetes automation, deterministic compute, and quantum-safe storage—delivered as a turnkey platform so your team can deploy, scale, and operate cloud-native applications with confidence.
|
Provision multi-master clusters, integrate quantum-safe storage, and
|
||||||
|
expose services worldwide without leaving the Mycelium mesh. Our
|
||||||
|
team will help you launch deterministic workloads that stay private,
|
||||||
|
compliant, and always-on.
|
||||||
</p>
|
</p>
|
||||||
<div className="mt-10 flex justify-center">
|
<div className="mt-10 flex justify-center">
|
||||||
<Button
|
<Button
|
||||||
|
|||||||
125
src/pages/cloud/CloudFeatures.tsx
Normal file
125
src/pages/cloud/CloudFeatures.tsx
Normal file
@@ -0,0 +1,125 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P, Small } from '../../components/Texts'
|
||||||
|
|
||||||
|
const featureSections = [
|
||||||
|
{
|
||||||
|
title: 'Mycelium Networking',
|
||||||
|
description:
|
||||||
|
'Ultra-fast, decentralized networking inspired by nature to keep services reachable without exposing surfaces.',
|
||||||
|
bullets: [
|
||||||
|
'End-to-end encrypted mesh connectivity between every node.',
|
||||||
|
'Direct node communication without centralized intermediaries.',
|
||||||
|
'Self-optimizing routes that heal around failures automatically.',
|
||||||
|
'Secure peer-to-peer communication across the entire grid.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Zero-Image Technology',
|
||||||
|
description:
|
||||||
|
'Metadata-first zero-images shrink artifacts up to 100x, reducing deployment time and bandwidth.',
|
||||||
|
bullets: [
|
||||||
|
'Deterministic deployments verified cryptographically.',
|
||||||
|
'Run containers, VMs, and Linux workloads with secure boot.',
|
||||||
|
'Smart contract orchestration manages every workload lifecycle.',
|
||||||
|
'Minimal artifact footprint accelerates delivery everywhere.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Quantum-Safe Storage (QSS)',
|
||||||
|
description:
|
||||||
|
'Quantum-resistant encryption secures data beyond the application layer for complete ownership.',
|
||||||
|
bullets: [
|
||||||
|
'Self-healing storage recovers instantly from corruption or failure.',
|
||||||
|
'Serve the same data via IPFS, S3, WebDAV, HTTP, and native FS.',
|
||||||
|
'Geo-aware placement enforces residency and redundancy policies.',
|
||||||
|
'Autonomous replication keeps data resilient across the globe.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Multi-Master Clusters',
|
||||||
|
description:
|
||||||
|
'High-availability Kubernetes with automatic failover and leadership orchestration.',
|
||||||
|
bullets: [
|
||||||
|
'Multi-master topologies orchestrated with zero downtime.',
|
||||||
|
'Automatic failover keeps control planes healthy and responsive.',
|
||||||
|
'HA operations managed without manual intervention or scripts.',
|
||||||
|
'Upgrades roll out seamlessly with continuous verification.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Effortless Load Balancing & Scaling',
|
||||||
|
description:
|
||||||
|
'Adaptive automation balances traffic and scales workloads based on demand.',
|
||||||
|
bullets: [
|
||||||
|
'Built-in autoscaling that responds to real-time usage.',
|
||||||
|
'Native load balancing distributes traffic globally.',
|
||||||
|
'High availability delivered without custom controllers.',
|
||||||
|
'Elastic scaling keeps costs aligned with workload demand.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Simple Web Gateway Access',
|
||||||
|
description:
|
||||||
|
'Expose services to the public web with declarative Kubernetes resources.',
|
||||||
|
bullets: [
|
||||||
|
'One resource publishes services without complex ingress rules.',
|
||||||
|
'Domain and prefix-based routing built into the platform.',
|
||||||
|
'No need to manage dedicated ingress controllers.',
|
||||||
|
'Consistent configuration across every cluster and region.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function CloudFeatures() {
|
||||||
|
return (
|
||||||
|
<section className="bg-gray-50 py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-500">
|
||||||
|
Core Features
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
Infrastructure that verifies, heals, and scales itself.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
From mesh networking to quantum-safe storage, every capability in
|
||||||
|
Mycelium Cloud is designed for sovereign control and autonomous
|
||||||
|
operations—so your teams focus on shipping workloads instead of
|
||||||
|
wiring infrastructure.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 md:grid-cols-2 xl:grid-cols-3">
|
||||||
|
{featureSections.map((feature) => (
|
||||||
|
<div
|
||||||
|
key={feature.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-slate-200 bg-white p-8 shadow-sm transition hover:-translate-y-1 hover:border-cyan-300 hover:shadow-lg"
|
||||||
|
>
|
||||||
|
<div>
|
||||||
|
<Small className="text-xs uppercase tracking-[0.3em] text-cyan-500">
|
||||||
|
Capability
|
||||||
|
</Small>
|
||||||
|
<h3 className="mt-4 text-xl font-semibold text-gray-900">
|
||||||
|
{feature.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-600">
|
||||||
|
{feature.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-600">
|
||||||
|
{feature.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-100 bg-cyan-50/60 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-500" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
138
src/pages/cloud/CloudGettingStarted.tsx
Normal file
138
src/pages/cloud/CloudGettingStarted.tsx
Normal file
@@ -0,0 +1,138 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P, Small } from '../../components/Texts'
|
||||||
|
|
||||||
|
type Step = {
|
||||||
|
number: string
|
||||||
|
title: string
|
||||||
|
description: string
|
||||||
|
bullets: string[]
|
||||||
|
codes?: string[]
|
||||||
|
}
|
||||||
|
|
||||||
|
const steps: Step[] = [
|
||||||
|
{
|
||||||
|
number: '01',
|
||||||
|
title: 'Account Setup',
|
||||||
|
description: 'Create and prepare your Mycelium Cloud account.',
|
||||||
|
bullets: [
|
||||||
|
'Sign up through the Mycelium Cloud portal and verify your email.',
|
||||||
|
'Add credits in the dashboard so resources can be provisioned.',
|
||||||
|
'Upload your SSH public key to enable secure node access.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
number: '02',
|
||||||
|
title: 'Deploy Your First Cluster',
|
||||||
|
description:
|
||||||
|
'Use the dashboard to define topology, resources, and deployment targets.',
|
||||||
|
bullets: [
|
||||||
|
'Open the Deploy Cluster workflow from your dashboard.',
|
||||||
|
'Choose CPU, memory, and storage for master and worker nodes.',
|
||||||
|
'Select ThreeFold Grid nodes that match your residency policies.',
|
||||||
|
'Review the configuration and launch the cluster.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
number: '03',
|
||||||
|
title: 'Access Your Cluster',
|
||||||
|
description:
|
||||||
|
'Connect through kubeconfig and the Mycelium mesh to manage workloads.',
|
||||||
|
bullets: [
|
||||||
|
'Download the kubeconfig from the Clusters view and export `KUBECONFIG`.',
|
||||||
|
'Validate connectivity with `kubectl get nodes`.',
|
||||||
|
'Install the Mycelium client and join the provided peer list.',
|
||||||
|
'SSH directly to each node over its assigned Mycelium IP address.',
|
||||||
|
],
|
||||||
|
codes: [
|
||||||
|
`export KUBECONFIG=/path/to/config
|
||||||
|
kubectl get nodes`,
|
||||||
|
`wget https://github.com/threefoldtech/mycelium/releases/latest/download/mycelium-private-x86_64-unknown-linux-musl.tar.gz
|
||||||
|
tar -xzf mycelium-private-x86_64-unknown-linux-musl.tar.gz
|
||||||
|
sudo chmod +x mycelium-private
|
||||||
|
sudo mv mycelium-private /usr/local/bin/mycelium`,
|
||||||
|
`sudo mycelium --peers \\
|
||||||
|
tcp://188.40.132.242:9651 \\
|
||||||
|
tcp://136.243.47.186:9651 \\
|
||||||
|
tcp://185.69.166.7:9651 \\
|
||||||
|
tcp://185.69.166.8:9651 \\
|
||||||
|
tcp://65.21.231.58:9651 \\
|
||||||
|
tcp://65.109.18.113:9651 \\
|
||||||
|
tcp://209.159.146.190:9651 \\
|
||||||
|
tcp://5.78.122.16:9651 \\
|
||||||
|
tcp://5.223.43.251:9651 \\
|
||||||
|
tcp://142.93.217.194:9651`,
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function CloudGettingStarted() {
|
||||||
|
return (
|
||||||
|
<section
|
||||||
|
id="getting-started"
|
||||||
|
className="relative overflow-hidden bg-gray-900 py-24 sm:py-32"
|
||||||
|
>
|
||||||
|
<div className="absolute inset-0 bg-[radial-gradient(circle_at_top,_rgba(34,211,238,0.12),_transparent_60%)]" />
|
||||||
|
<Container className="relative">
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-300">
|
||||||
|
Getting Started
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" color="light" className="mt-6">
|
||||||
|
Launch, connect, and operate in three steps.
|
||||||
|
</SectionHeader>
|
||||||
|
<P color="lightSecondary" className="mt-6">
|
||||||
|
Follow the workflow from account creation to mesh connectivity.
|
||||||
|
You’ll have a production-ready K3s cluster running on the
|
||||||
|
ThreeFold Grid in minutes.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-10 lg:grid-cols-3">
|
||||||
|
{steps.map((step) => (
|
||||||
|
<div
|
||||||
|
key={step.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-white/10 bg-white/[0.03] p-8 backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-300/50 hover:bg-white/[0.06]"
|
||||||
|
>
|
||||||
|
<div className="flex items-center justify-between">
|
||||||
|
<Small className="text-xs uppercase tracking-[0.4em] text-cyan-300">
|
||||||
|
{step.number}
|
||||||
|
</Small>
|
||||||
|
<span className="inline-flex size-10 items-center justify-center rounded-full border border-cyan-300/40 text-sm font-semibold uppercase tracking-[0.25em] text-cyan-200">
|
||||||
|
Go
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<h3 className="mt-6 text-xl font-semibold text-white">
|
||||||
|
{step.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
||||||
|
{step.description}
|
||||||
|
</p>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-300">
|
||||||
|
{step.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-500/10 bg-cyan-500/5 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-300" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
{step.codes && (
|
||||||
|
<div className="mt-6 space-y-4">
|
||||||
|
{step.codes.map((code) => (
|
||||||
|
<pre
|
||||||
|
key={code}
|
||||||
|
className="overflow-x-auto rounded-2xl border border-white/10 bg-black/70 p-4 text-xs text-cyan-100"
|
||||||
|
>
|
||||||
|
<code>{code}</code>
|
||||||
|
</pre>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
)}
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -2,6 +2,7 @@ import { useId } from 'react'
|
|||||||
|
|
||||||
import { Button } from '../../components/Button'
|
import { Button } from '../../components/Button'
|
||||||
import { Container } from '../../components/Container'
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
function BackgroundIllustration(props: React.ComponentPropsWithoutRef<'div'>) {
|
function BackgroundIllustration(props: React.ComponentPropsWithoutRef<'div'>) {
|
||||||
const id = useId()
|
const id = useId()
|
||||||
@@ -78,20 +79,36 @@ export function CloudHero() {
|
|||||||
<Container>
|
<Container>
|
||||||
<div className="flex flex-col-reverse gap-y-16 lg:grid lg:grid-cols-12 lg:gap-x-8 lg:gap-y-20">
|
<div className="flex flex-col-reverse gap-y-16 lg:grid lg:grid-cols-12 lg:gap-x-8 lg:gap-y-20">
|
||||||
<div className="relative z-10 mx-auto max-w-2xl lg:col-span-7 lg:max-w-none lg:pt-6 xl:col-span-6">
|
<div className="relative z-10 mx-auto max-w-2xl lg:col-span-7 lg:max-w-none lg:pt-6 xl:col-span-6">
|
||||||
<h1 className="text-4xl font-medium tracking-tight text-gray-900 lg:text-6xl">
|
<Eyebrow className="tracking-[0.35em] uppercase text-cyan-500">
|
||||||
Mycelium Cloud
|
Mycelium Cloud
|
||||||
</h1>
|
</Eyebrow>
|
||||||
<h2 className="mt-6 text-xl leading-normal tracking-tight text-gray-600 lg:text-2xl">
|
<SectionHeader as="h1" className="mt-6 text-gray-900">
|
||||||
Own every workload with certainty.
|
Deploy sovereign Kubernetes clusters on decentralized
|
||||||
</h2>
|
infrastructure.
|
||||||
<p className="mt-6 text-lg text-gray-600 leading-tight lg:text-xl lg:leading-normal">
|
</SectionHeader>
|
||||||
Mycelium Cloud blends deterministic compute with quantum-safe storage, delivering a sovereign platform built for zero-ops automation.
|
<P className="mt-6 text-gray-600">
|
||||||
</p>
|
Mycelium Cloud turns the ThreeFold Grid into a programmable
|
||||||
<div className="mt-8 flex flex-wrap gap-x-6 gap-y-4">
|
substrate for K3s. Launch verifiable clusters with nature-inspired
|
||||||
<Button to="https://myceliumcloud.tf" variant="solid" color="cyan">
|
networking, quantum-safe storage, and zero-image delivery that
|
||||||
Start Deployment
|
keeps every workload deterministic.
|
||||||
|
</P>
|
||||||
|
<P className="mt-6 italic text-gray-500">
|
||||||
|
Developer guide to decentralized cloud computing.
|
||||||
|
</P>
|
||||||
|
<div className="mt-10 flex flex-wrap gap-4">
|
||||||
|
<Button
|
||||||
|
to="https://myceliumcloud.tf"
|
||||||
|
as="a"
|
||||||
|
variant="solid"
|
||||||
|
color="cyan"
|
||||||
|
target="_blank"
|
||||||
|
rel="noreferrer"
|
||||||
|
>
|
||||||
|
Launch a Cluster
|
||||||
|
</Button>
|
||||||
|
<Button to="#getting-started" as="a" variant="outline" color="cyan">
|
||||||
|
View Getting Started
|
||||||
</Button>
|
</Button>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div className="relative mt-0 lg:mt-10 lg:col-span-5 lg:row-span-2 xl:col-span-6">
|
<div className="relative mt-0 lg:mt-10 lg:col-span-5 lg:row-span-2 xl:col-span-6">
|
||||||
|
|||||||
@@ -1,61 +1,78 @@
|
|||||||
import { CircleBackground } from '../../components/CircleBackground'
|
import { CircleBackground } from '../../components/CircleBackground'
|
||||||
import { Container } from '../../components/Container'
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P, Small } from '../../components/Texts'
|
||||||
|
|
||||||
const focusAreas = [
|
const focusAreas = [
|
||||||
{
|
{
|
||||||
title: 'Sovereign by Design',
|
label: 'Overview',
|
||||||
|
title: 'Decentralized Kubernetes on the ThreeFold Grid',
|
||||||
description:
|
description:
|
||||||
'Control jurisdiction, residency, and governance for every workload with transparent, verifiable operations.',
|
'Mycelium Cloud provides a comprehensive platform for deploying and managing K3s clusters across global, sovereign infrastructure.',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: 'Secure by Default',
|
label: 'Core Concept',
|
||||||
|
title: 'Sovereign, self-managing operations',
|
||||||
description:
|
description:
|
||||||
'Cryptographic verification, secure boot, and zero-image delivery protect the entire lifecycle automatically.',
|
'Deterministic networking, quantum-safe storage, and zero-image delivery keep every workload verifiable and autonomous from day zero.',
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: 'Ready to Scale',
|
label: 'Developer Experience',
|
||||||
|
title: 'K3s-native workflows with full control',
|
||||||
description:
|
description:
|
||||||
'Autonomous orchestration keeps the platform elastic, cost-efficient, and always available across the globe.',
|
'Provision multi-master clusters, govern residency, and observe node health from a single programmable control plane.',
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|
||||||
export function CloudOverview() {
|
export function CloudOverview() {
|
||||||
return (
|
return (
|
||||||
<section className="relative overflow-hidden bg-gray-900 py-24 lg:py-32">
|
<section className="relative overflow-hidden bg-gray-950 py-24 sm:py-32">
|
||||||
<div className="pointer-events-none absolute inset-0">
|
<div className="pointer-events-none absolute inset-0">
|
||||||
<CircleBackground
|
<CircleBackground
|
||||||
color="#06b6d4"
|
color="#06b6d4"
|
||||||
className="absolute left-1/2 top-full -translate-x-1/2 -translate-y-1/2 opacity-40"
|
className="absolute left-1/2 top-full h-[520px] w-[520px] -translate-x-1/2 -translate-y-1/2 opacity-30 blur-3xl"
|
||||||
/>
|
/>
|
||||||
<CircleBackground
|
<CircleBackground
|
||||||
color="#22d3ee"
|
color="#22d3ee"
|
||||||
className="absolute -top-24 right-1/4 h-[420px] w-[420px] opacity-30 sm:opacity-40"
|
className="absolute -top-24 right-1/4 h-[420px] w-[420px] opacity-25 blur-3xl sm:opacity-40"
|
||||||
/>
|
/>
|
||||||
|
<div className="absolute inset-0 bg-[radial-gradient(circle_at_top,_rgba(15,118,110,0.18),_transparent_55%)]" />
|
||||||
</div>
|
</div>
|
||||||
<Container className="relative">
|
<Container className="relative">
|
||||||
<div className="mx-auto max-w-3xl text-center">
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
<p className="text-sm font-semibold uppercase tracking-[0.3em] text-cyan-400">
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-400">
|
||||||
Mycelium Cloud
|
Platform Overview
|
||||||
</p>
|
</Eyebrow>
|
||||||
<h2 className="mt-6 text-3xl font-medium tracking-tight text-white lg:text-5xl">
|
<SectionHeader as="h2" color="light" className="mt-6 font-medium">
|
||||||
A sovereign, self-healing cloud built for trusted automation.
|
A decentralized cloud that operates itself.
|
||||||
</h2>
|
</SectionHeader>
|
||||||
<p className="mt-6 text-lg text-gray-300">
|
<P color="lightSecondary" className="mt-6">
|
||||||
Run critical workloads on a programmable substrate that keeps data private, compute deterministic, and operations autonomous.
|
Mycelium Cloud orchestrates Kubernetes clusters on the ThreeFold
|
||||||
</p>
|
Grid with cryptographic certainty. Networking, storage, and
|
||||||
|
orchestration are all built-in so developers can deploy critical
|
||||||
|
workloads without wrestling infrastructure.
|
||||||
|
</P>
|
||||||
|
<P color="lightSecondary" className="mt-6 italic">
|
||||||
|
Declarative, sovereign, and ready for production workloads anywhere.
|
||||||
|
</P>
|
||||||
</div>
|
</div>
|
||||||
<div className="mt-16 grid gap-8 lg:grid-cols-3">
|
<div className="mt-16 grid gap-8 lg:grid-cols-3">
|
||||||
{focusAreas.map((item) => (
|
{focusAreas.map((item) => (
|
||||||
<div
|
<div
|
||||||
key={item.title}
|
key={item.title}
|
||||||
className="rounded-3xl p-8 text-left transition hover:-translate-y-1"
|
className="group relative overflow-hidden rounded-3xl border border-white/10 bg-white/[0.03] p-8 text-left backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-300/50 hover:bg-white/[0.07]"
|
||||||
>
|
>
|
||||||
<div className="text-lg font-semibold text-white">
|
<div className="absolute inset-0 bg-gradient-to-br from-cyan-500/0 via-white/[0.04] to-cyan-300/15 opacity-0 transition group-hover:opacity-100" />
|
||||||
{item.title}
|
<div className="relative">
|
||||||
|
<Small className="text-xs uppercase tracking-[0.35em] text-cyan-300">
|
||||||
|
{item.label}
|
||||||
|
</Small>
|
||||||
|
<div className="mt-4 text-lg font-semibold text-white">
|
||||||
|
{item.title}
|
||||||
|
</div>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
||||||
|
{item.description}
|
||||||
|
</p>
|
||||||
</div>
|
</div>
|
||||||
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
|
||||||
{item.description}
|
|
||||||
</p>
|
|
||||||
</div>
|
</div>
|
||||||
))}
|
))}
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -1,22 +1,33 @@
|
|||||||
import { AnimatedSection } from '../../components/AnimatedSection'
|
import { AnimatedSection } from '../../components/AnimatedSection'
|
||||||
import { CloudHero } from './CloudHero'
|
import { CloudHero } from './CloudHero'
|
||||||
import { CloudOverview } from './CloudOverview'
|
import { CloudOverview } from './CloudOverview'
|
||||||
import { ComputeStorageSplit } from './ComputeStorageSplit'
|
import { CloudArchitecture } from './CloudArchitecture'
|
||||||
|
import { CloudFeatures } from './CloudFeatures'
|
||||||
|
import { CloudGettingStarted } from './CloudGettingStarted'
|
||||||
|
import { CloudUseCases } from './CloudUseCases'
|
||||||
import { SecurityPillars } from './SecurityPillars'
|
import { SecurityPillars } from './SecurityPillars'
|
||||||
import { CloudCTA } from './CloudCTA'
|
import { CloudCTA } from './CloudCTA'
|
||||||
import { CloudHeroAlt } from './CloudHeroAlt'
|
|
||||||
|
|
||||||
export default function CloudPage() {
|
export default function CloudPage() {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<AnimatedSection>
|
<AnimatedSection>
|
||||||
<CloudHeroAlt />
|
<CloudHero />
|
||||||
</AnimatedSection>
|
</AnimatedSection>
|
||||||
<AnimatedSection>
|
<AnimatedSection>
|
||||||
<CloudOverview />
|
<CloudOverview />
|
||||||
</AnimatedSection>
|
</AnimatedSection>
|
||||||
<AnimatedSection>
|
<AnimatedSection>
|
||||||
<ComputeStorageSplit />
|
<CloudArchitecture />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<CloudFeatures />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<CloudGettingStarted />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<CloudUseCases />
|
||||||
</AnimatedSection>
|
</AnimatedSection>
|
||||||
<AnimatedSection>
|
<AnimatedSection>
|
||||||
<SecurityPillars />
|
<SecurityPillars />
|
||||||
|
|||||||
90
src/pages/cloud/CloudUseCases.tsx
Normal file
90
src/pages/cloud/CloudUseCases.tsx
Normal file
@@ -0,0 +1,90 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P, Small } from '../../components/Texts'
|
||||||
|
|
||||||
|
const useCases = [
|
||||||
|
{
|
||||||
|
title: 'AI / ML Training',
|
||||||
|
description:
|
||||||
|
'Run GPU-accelerated workloads for deep learning, data science, and inference on demand.',
|
||||||
|
bullets: ['GPU acceleration', 'Scalable compute', 'Cost optimization'],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Enterprise Kubernetes',
|
||||||
|
description:
|
||||||
|
'Operate production-grade clusters with complete control and no vendor lock-in.',
|
||||||
|
bullets: ['High availability', 'Security', 'Compliance'],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Edge & IoT',
|
||||||
|
description:
|
||||||
|
'Leverage global nodes for low-latency workloads and connected device deployments.',
|
||||||
|
bullets: ['Low latency', 'Global distribution', 'Real-time processing'],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'DigitalMe Blueprint',
|
||||||
|
description:
|
||||||
|
'Launch a full digital workspace on Mycelium Cloud with pre-integrated services.',
|
||||||
|
bullets: [
|
||||||
|
'Cryptpad • Encrypted collaboration',
|
||||||
|
'Elements • Matrix chat',
|
||||||
|
'Stallwart • Mail, calendar, contacts',
|
||||||
|
'Gitea • Git hosting',
|
||||||
|
'Nextcloud • File storage and sync',
|
||||||
|
'LiveKit / Jitsi • Real-time video',
|
||||||
|
'Single Sign-On backed by Gitea',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function CloudUseCases() {
|
||||||
|
return (
|
||||||
|
<section className="bg-white py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-500">
|
||||||
|
Use Cases
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
Built for intelligent workloads across every edge.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
Mycelium Cloud unifies compute, storage, and networking so teams can
|
||||||
|
launch anything from GPU inference farms to global collaboration
|
||||||
|
suites with deterministic outcomes.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-2">
|
||||||
|
{useCases.map((useCase) => (
|
||||||
|
<div
|
||||||
|
key={useCase.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-slate-200 bg-white p-8 shadow-sm transition hover:-translate-y-1 hover:border-cyan-300 hover:shadow-lg"
|
||||||
|
>
|
||||||
|
<div className="flex items-center justify-between">
|
||||||
|
<h3 className="text-xl font-semibold text-gray-900">
|
||||||
|
{useCase.title}
|
||||||
|
</h3>
|
||||||
|
<Small className="text-xs uppercase tracking-[0.3em] text-cyan-500">
|
||||||
|
Scenario
|
||||||
|
</Small>
|
||||||
|
</div>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-600">
|
||||||
|
{useCase.description}
|
||||||
|
</p>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-600">
|
||||||
|
{useCase.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-100 bg-cyan-50/60 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-500" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -1,7 +1,26 @@
|
|||||||
import { CircleBackground } from '../../components/CircleBackground'
|
import { CircleBackground } from '../../components/CircleBackground'
|
||||||
import { Container } from '../../components/Container'
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P, Small } from '../../components/Texts'
|
||||||
|
|
||||||
const pillars = [
|
const differentiators = [
|
||||||
|
{
|
||||||
|
title: 'Sovereign by Design',
|
||||||
|
description:
|
||||||
|
'Control jurisdiction, residency, and governance for every workload with transparent, verifiable operations.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Secure by Default',
|
||||||
|
description:
|
||||||
|
'Cryptographic verification, secure boot, and zero-image delivery protect the entire lifecycle automatically.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Ready to Scale',
|
||||||
|
description:
|
||||||
|
'Autonomous orchestration keeps the platform elastic, cost-efficient, and always available across the globe.',
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
const securityPillars = [
|
||||||
{
|
{
|
||||||
title: 'Provable Sovereignty',
|
title: 'Provable Sovereignty',
|
||||||
description:
|
description:
|
||||||
@@ -21,31 +40,51 @@ const pillars = [
|
|||||||
|
|
||||||
export function SecurityPillars() {
|
export function SecurityPillars() {
|
||||||
return (
|
return (
|
||||||
<section className="relative overflow-hidden bg-gray-900 py-24 lg:py-32">
|
<section className="relative overflow-hidden bg-gray-950 py-24 sm:py-32">
|
||||||
<div className="pointer-events-none absolute inset-0">
|
<div className="pointer-events-none absolute inset-0">
|
||||||
<CircleBackground
|
<CircleBackground
|
||||||
color="#22d3ee"
|
color="#22d3ee"
|
||||||
className="absolute -top-20 left-1/2 h-[520px] w-[520px] -translate-x-1/2 opacity-30"
|
className="absolute -top-24 left-1/2 h-[520px] w-[520px] -translate-x-1/2 opacity-30 blur-3xl"
|
||||||
/>
|
/>
|
||||||
<div className="absolute inset-x-0 bottom-0 h-40 bg-gradient-to-t from-gray-900 to-transparent" />
|
<div className="absolute inset-0 bg-[radial-gradient(circle_at_bottom,_rgba(8,145,178,0.14),_transparent_60%)]" />
|
||||||
</div>
|
</div>
|
||||||
<Container className="relative">
|
<Container className="relative">
|
||||||
<div className="mx-auto max-w-3xl text-center">
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
<p className="text-sm font-semibold uppercase tracking-[0.3em] text-cyan-400">
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-300">
|
||||||
Sovereign Architecture
|
Security Architecture
|
||||||
</p>
|
</Eyebrow>
|
||||||
<h2 className="mt-6 text-3xl font-medium tracking-tight text-white lg:text-5xl">
|
<SectionHeader as="h2" color="light" className="mt-6">
|
||||||
Built for security, trust, and unstoppable continuity.
|
Provable trust from substrate to service.
|
||||||
</h2>
|
</SectionHeader>
|
||||||
<p className="mt-6 text-lg text-gray-300">
|
<P color="lightSecondary" className="mt-6">
|
||||||
Every control surface is auditable and automated, enabling critical workloads to run with confidence.
|
Mycelium Cloud enforces sovereignty, security, and resilience at the
|
||||||
</p>
|
protocol level. The platform continuously verifies state, heals
|
||||||
|
itself, and keeps workloads operating even when regions go dark.
|
||||||
|
</P>
|
||||||
</div>
|
</div>
|
||||||
<div className="mt-16 grid gap-8 lg:grid-cols-3">
|
<div className="mt-16 grid gap-8 lg:grid-cols-3">
|
||||||
{pillars.map((pillar) => (
|
{differentiators.map((item) => (
|
||||||
|
<div
|
||||||
|
key={item.title}
|
||||||
|
className="rounded-3xl border border-white/10 bg-white/[0.04] p-8 text-left backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-300/50 hover:bg-white/[0.08]"
|
||||||
|
>
|
||||||
|
<Small className="text-xs uppercase tracking-[0.35em] text-cyan-200">
|
||||||
|
Key Differentiator
|
||||||
|
</Small>
|
||||||
|
<div className="mt-4 text-lg font-semibold text-white">
|
||||||
|
{item.title}
|
||||||
|
</div>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
||||||
|
{item.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-3">
|
||||||
|
{securityPillars.map((pillar) => (
|
||||||
<div
|
<div
|
||||||
key={pillar.title}
|
key={pillar.title}
|
||||||
className="rounded-3xl p-8 text-left transition hover:-translate-y-1"
|
className="rounded-3xl border border-white/10 bg-white/[0.03] p-8 text-left backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-300/50 hover:bg-white/[0.07]"
|
||||||
>
|
>
|
||||||
<div className="text-lg font-semibold text-white">
|
<div className="text-lg font-semibold text-white">
|
||||||
{pillar.title}
|
{pillar.title}
|
||||||
|
|||||||
92
src/pages/compute/ComputeArchitecture.tsx
Normal file
92
src/pages/compute/ComputeArchitecture.tsx
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const architectureSections = [
|
||||||
|
{
|
||||||
|
title: 'Deterministic Computing',
|
||||||
|
description:
|
||||||
|
'Every computational step is predictable and provable before it ever executes.',
|
||||||
|
bullets: [
|
||||||
|
'Cryptographic verification precedes every operation.',
|
||||||
|
'State determinism ensures identical results from identical inputs.',
|
||||||
|
'Tamper resistance surfaces any modification instantly.',
|
||||||
|
'Comprehensive audit trails verify the full execution history.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Stateless Infrastructure',
|
||||||
|
description:
|
||||||
|
'A global substrate that scales and recovers without hardware-bound state.',
|
||||||
|
bullets: [
|
||||||
|
'No persistent state coupled to specific hardware or regions.',
|
||||||
|
'Global distribution makes compute available wherever it is needed.',
|
||||||
|
'Auto-scaling allocates the right resources at the right time.',
|
||||||
|
'Fault-tolerant orchestration provides automatic failover.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Zero-Image System',
|
||||||
|
description:
|
||||||
|
'Metadata-first delivery keeps deployments lightweight and instantly repeatable.',
|
||||||
|
bullets: [
|
||||||
|
'Images represented as metadata instead of heavyweight artifacts.',
|
||||||
|
'Instant deployment for rapid workload startup.',
|
||||||
|
'Efficient storage with minimal footprint for artifacts.',
|
||||||
|
'Bandwidth-optimized transfers shrink delivery times.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function ComputeArchitecture() {
|
||||||
|
return (
|
||||||
|
<section className="bg-gray-50 py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.28em] uppercase text-cyan-500">
|
||||||
|
Technical Architecture
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
Infrastructure engineered for provable outcomes.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
Deterministic computing, stateless orchestration, and metadata-first
|
||||||
|
delivery combine to create a compute fabric you can trust with your
|
||||||
|
most sensitive workloads.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-3">
|
||||||
|
{architectureSections.map((section) => (
|
||||||
|
<div
|
||||||
|
key={section.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-cyan-100 bg-white p-8 shadow-sm transition hover:-translate-y-1 hover:border-cyan-300 hover:shadow-lg"
|
||||||
|
>
|
||||||
|
<div className="flex items-center gap-3">
|
||||||
|
<span className="inline-flex size-10 items-center justify-center rounded-full bg-cyan-500/10 text-sm font-semibold uppercase tracking-[0.25em] text-cyan-600">
|
||||||
|
•
|
||||||
|
</span>
|
||||||
|
<h3 className="text-xl font-semibold text-gray-900">
|
||||||
|
{section.title}
|
||||||
|
</h3>
|
||||||
|
</div>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-600">
|
||||||
|
{section.description}
|
||||||
|
</p>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-600">
|
||||||
|
{section.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-slate-200 bg-slate-50 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-500" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
114
src/pages/compute/ComputeDeveloperExperience.tsx
Normal file
114
src/pages/compute/ComputeDeveloperExperience.tsx
Normal file
@@ -0,0 +1,114 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const codeSamples = [
|
||||||
|
{
|
||||||
|
title: 'Simple Deployment',
|
||||||
|
description:
|
||||||
|
'Define deterministic workloads with familiar manifests that execute exactly as declared anywhere on the fabric.',
|
||||||
|
language: 'yaml',
|
||||||
|
code: `# Basic compute workload
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: deterministic-app
|
||||||
|
spec:
|
||||||
|
replicas: 3
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: deterministic-app
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: deterministic-app
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: app
|
||||||
|
image: ubuntu:latest
|
||||||
|
command: ["echo", "Deterministic deployment"]`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Zero-Image Deployment',
|
||||||
|
description:
|
||||||
|
'Use metadata-only images to launch workloads instantly with zero heavy artifacts to distribute.',
|
||||||
|
language: 'yaml',
|
||||||
|
code: `# Using zero-image technology
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Pod
|
||||||
|
metadata:
|
||||||
|
name: zero-image-pod
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: app
|
||||||
|
image: "zero-image://ubuntu-latest" # Metadata-only image
|
||||||
|
command: ["echo", "Running on zero-image"]`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Smart Contract Orchestration',
|
||||||
|
description:
|
||||||
|
'Automate workload lifecycles through cryptographically signed contracts that govern execution.',
|
||||||
|
language: 'yaml',
|
||||||
|
code: `# Smart contract orchestrated deployment
|
||||||
|
apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: deployment-contract
|
||||||
|
data:
|
||||||
|
contract: |
|
||||||
|
smart_contract:
|
||||||
|
signature: "cryptographically_signed_deployment"
|
||||||
|
workload_spec:
|
||||||
|
image: "ubuntu-latest"
|
||||||
|
replicas: 3
|
||||||
|
verification_hash: "sha256_hash_of_workload"`,
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function ComputeDeveloperExperience() {
|
||||||
|
return (
|
||||||
|
<section className="bg-white py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.28em] uppercase text-cyan-500">
|
||||||
|
Developer Experience
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
Declarative workflows, deterministic results.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
Ship workloads using the same declarative patterns you already
|
||||||
|
trust. Mycelium Compute verifies and enforces every detail, from
|
||||||
|
classic deployments to zero-image launches and smart contract
|
||||||
|
upgrades.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-3">
|
||||||
|
{codeSamples.map((sample) => (
|
||||||
|
<div
|
||||||
|
key={sample.title}
|
||||||
|
className="flex h-full flex-col overflow-hidden rounded-3xl border border-slate-200 bg-slate-50"
|
||||||
|
>
|
||||||
|
<div className="p-8">
|
||||||
|
<p className="text-sm font-semibold uppercase tracking-[0.24em] text-cyan-500">
|
||||||
|
{sample.language}
|
||||||
|
</p>
|
||||||
|
<h3 className="mt-4 text-xl font-semibold text-gray-900">
|
||||||
|
{sample.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-3 text-sm leading-relaxed text-gray-600">
|
||||||
|
{sample.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<div className="mt-auto bg-gray-900 p-6">
|
||||||
|
<pre className="overflow-auto text-left text-xs leading-relaxed text-cyan-100">
|
||||||
|
<code>{sample.code}</code>
|
||||||
|
</pre>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
68
src/pages/compute/ComputeDifferentiators.tsx
Normal file
68
src/pages/compute/ComputeDifferentiators.tsx
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const differentiators = [
|
||||||
|
{
|
||||||
|
title: 'Deterministic Guarantee',
|
||||||
|
description:
|
||||||
|
'Every computation is cryptographically verified to ensure consistent, repeatable outcomes across environments.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Autonomous Operations',
|
||||||
|
description:
|
||||||
|
'Infrastructure monitors, scales, and heals itself with zero human intervention required.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Smart Contract Security',
|
||||||
|
description:
|
||||||
|
'Workload orchestration flows through cryptographically signed, tamper-proof contracts.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Multi-Platform Support',
|
||||||
|
description:
|
||||||
|
'Run containers, VMs, or native Linux workloads with the same deterministic guarantees.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Secure Boot Verification',
|
||||||
|
description:
|
||||||
|
'Hardware-level attestation validates every deployment path before workloads execute.',
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function ComputeDifferentiators() {
|
||||||
|
return (
|
||||||
|
<section className="bg-white py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.3em] uppercase text-cyan-500">
|
||||||
|
Key Differentiators
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
Why teams choose Mycelium Compute.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
Deterministic execution, contract-grade governance, and hardware
|
||||||
|
attestation make Mycelium Compute the most trusted substrate for
|
||||||
|
sensitive workloads.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-6 md:grid-cols-2 lg:grid-cols-3">
|
||||||
|
{differentiators.map((item) => (
|
||||||
|
<div
|
||||||
|
key={item.title}
|
||||||
|
className="rounded-3xl border border-slate-200 bg-slate-50 p-8 transition hover:-translate-y-1 hover:border-cyan-300 hover:bg-white hover:shadow-lg"
|
||||||
|
>
|
||||||
|
<h3 className="text-lg font-semibold text-gray-900">
|
||||||
|
{item.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-600">
|
||||||
|
{item.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
106
src/pages/compute/ComputeFeatures.tsx
Normal file
106
src/pages/compute/ComputeFeatures.tsx
Normal file
@@ -0,0 +1,106 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P, Small } from '../../components/Texts'
|
||||||
|
|
||||||
|
const featureGroups = [
|
||||||
|
{
|
||||||
|
title: 'Deterministic Deployments',
|
||||||
|
description:
|
||||||
|
'Cryptographic verification ensures every workload deploys exactly as specified—no tampering, no drift.',
|
||||||
|
listTitle: 'Benefits',
|
||||||
|
bullets: [
|
||||||
|
'Cryptographic verification of every workload component',
|
||||||
|
'Zero configuration drift across environments',
|
||||||
|
'Immediate detection of unauthorized changes',
|
||||||
|
'Complete reproducibility for every deployment',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Self-Managing & Stateless Infrastructure',
|
||||||
|
description:
|
||||||
|
'Infrastructure that scales and heals autonomously across the ThreeFold Grid with no manual intervention.',
|
||||||
|
listTitle: 'Capabilities',
|
||||||
|
bullets: [
|
||||||
|
'Autonomous operations that self-orchestrate workloads',
|
||||||
|
'Global scaling sewn into the fabric of the platform',
|
||||||
|
'Stateless design removes hardware dependencies',
|
||||||
|
'Self-healing recovery from failures and anomalies',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Smart Contract-Based Deployment',
|
||||||
|
description:
|
||||||
|
'Cryptographically signed contracts orchestrate every workload lifecycle with transparent, tamper-proof execution.',
|
||||||
|
listTitle: 'Benefits',
|
||||||
|
bullets: [
|
||||||
|
'Every deployment contract cryptographically signed',
|
||||||
|
'Fully auditable, transparent execution of operations',
|
||||||
|
'Tamper-proof orchestration that cannot be rewritten',
|
||||||
|
'Smart contracts automate the entire workload lifecycle',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Multi-Workload Compatibility with Secure Boot',
|
||||||
|
description:
|
||||||
|
'Run containers, VMs, and native Linux workloads anywhere with stateless secure boot and continuous verification.',
|
||||||
|
listTitle: 'Capabilities',
|
||||||
|
bullets: [
|
||||||
|
'Full compatibility with Kubernetes and Docker workloads',
|
||||||
|
'Securely run virtual machines with attested boot paths',
|
||||||
|
'Native Linux applications verified end-to-end',
|
||||||
|
'Continuous verification maintains trusted execution',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function ComputeFeatures() {
|
||||||
|
return (
|
||||||
|
<section className="bg-white py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.28em] uppercase text-cyan-500">
|
||||||
|
Core Features
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
Precision infrastructure that verifies itself.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
Every layer is designed for determinism, from how workloads are
|
||||||
|
declared to the way they scale, protect, and govern themselves on
|
||||||
|
the grid.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 md:grid-cols-2">
|
||||||
|
{featureGroups.map((feature) => (
|
||||||
|
<div
|
||||||
|
key={feature.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-slate-200 bg-white p-10 shadow-sm transition hover:-translate-y-1 hover:shadow-xl"
|
||||||
|
>
|
||||||
|
<div>
|
||||||
|
<Small className="text-xs uppercase tracking-[0.3em] text-cyan-500">
|
||||||
|
{feature.listTitle}
|
||||||
|
</Small>
|
||||||
|
<h3 className="mt-4 text-2xl font-semibold text-gray-900">
|
||||||
|
{feature.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-600">
|
||||||
|
{feature.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-600">
|
||||||
|
{feature.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-100/40 bg-cyan-50/40 p-3 text-left leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-500" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
74
src/pages/compute/ComputeOverview.tsx
Normal file
74
src/pages/compute/ComputeOverview.tsx
Normal file
@@ -0,0 +1,74 @@
|
|||||||
|
import { CircleBackground } from '../../components/CircleBackground'
|
||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const overviewCards = [
|
||||||
|
{
|
||||||
|
label: 'Overview',
|
||||||
|
title: 'Built for sovereign, verifiable operations',
|
||||||
|
copy: `Mycelium Compute provides a sovereign, deterministic compute fabric that enables developers to launch workloads with cryptographic certainty and autonomous operations. Built on decentralized infrastructure, it keeps environments transparent, verifiable, and free from manual intervention.`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Core Concept',
|
||||||
|
title: 'Deterministic compute fabric',
|
||||||
|
copy: `Every workload deploys exactly as intended through cryptographic verification—eliminating tampering and configuration drift while maintaining complete operational autonomy.`,
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function ComputeOverview() {
|
||||||
|
return (
|
||||||
|
<section className="relative overflow-hidden bg-gray-950 py-24 sm:py-32">
|
||||||
|
<div className="pointer-events-none absolute inset-0">
|
||||||
|
<CircleBackground
|
||||||
|
color="#06b6d4"
|
||||||
|
className="absolute -top-40 left-1/2 h-[520px] w-[520px] -translate-x-1/2 opacity-30 blur-3xl sm:opacity-40"
|
||||||
|
/>
|
||||||
|
<CircleBackground
|
||||||
|
color="#22d3ee"
|
||||||
|
className="absolute bottom-[-18rem] left-[15%] h-[420px] w-[420px] opacity-25 blur-3xl sm:opacity-40"
|
||||||
|
/>
|
||||||
|
<div className="absolute inset-0 bg-[radial-gradient(circle_at_top,_rgba(15,118,110,0.1),_transparent_55%)]" />
|
||||||
|
</div>
|
||||||
|
<Container className="relative">
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow color="accent" className="tracking-[0.35em] uppercase">
|
||||||
|
Mycelium Compute
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" color="light" className="mt-6 font-medium">
|
||||||
|
Deterministic compute fabric for autonomous workloads.
|
||||||
|
</SectionHeader>
|
||||||
|
<P color="lightSecondary" className="mt-6">
|
||||||
|
Mycelium Compute delivers predictable, sovereign performance—free
|
||||||
|
from lock-in and drift. Deploy any workload with cryptographic
|
||||||
|
precision, knowing the platform verifies, scales, and heals itself
|
||||||
|
on your behalf.
|
||||||
|
</P>
|
||||||
|
<P color="lightSecondary" className="mt-4 italic">
|
||||||
|
Deterministic. Self-managing. Stateless by design.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-6 lg:grid-cols-2">
|
||||||
|
{overviewCards.map((card) => (
|
||||||
|
<div
|
||||||
|
key={card.title}
|
||||||
|
className="group relative overflow-hidden rounded-3xl border border-white/10 bg-white/[0.03] p-10 backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-300/40 hover:bg-white/[0.06]"
|
||||||
|
>
|
||||||
|
<div className="absolute inset-0 bg-gradient-to-br from-cyan-500/0 via-white/[0.04] to-cyan-300/10 opacity-0 transition group-hover:opacity-100" />
|
||||||
|
<div className="relative">
|
||||||
|
<p className="text-[0.7rem] font-semibold uppercase tracking-[0.35em] text-cyan-300">
|
||||||
|
{card.label}
|
||||||
|
</p>
|
||||||
|
<h3 className="mt-4 text-xl font-semibold text-white">
|
||||||
|
{card.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
||||||
|
{card.copy}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -1,5 +1,12 @@
|
|||||||
import { AnimatedSection } from '../../components/AnimatedSection'
|
import { AnimatedSection } from '../../components/AnimatedSection'
|
||||||
import { ComputeHero } from './ComputeHero'
|
import { ComputeHero } from './ComputeHero'
|
||||||
|
import { ComputeOverview } from './ComputeOverview'
|
||||||
|
import { ComputeFeatures } from './ComputeFeatures'
|
||||||
|
import { ComputeZeroImage } from './ComputeZeroImage'
|
||||||
|
import { ComputeArchitecture } from './ComputeArchitecture'
|
||||||
|
import { ComputeDeveloperExperience } from './ComputeDeveloperExperience'
|
||||||
|
import { ComputeUseCases } from './ComputeUseCases'
|
||||||
|
import { ComputeDifferentiators } from './ComputeDifferentiators'
|
||||||
import { CallToAction } from './CallToAction'
|
import { CallToAction } from './CallToAction'
|
||||||
|
|
||||||
export default function ComputePage() {
|
export default function ComputePage() {
|
||||||
@@ -8,6 +15,27 @@ export default function ComputePage() {
|
|||||||
<AnimatedSection>
|
<AnimatedSection>
|
||||||
<ComputeHero />
|
<ComputeHero />
|
||||||
</AnimatedSection>
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<ComputeOverview />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<ComputeFeatures />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<ComputeZeroImage />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<ComputeArchitecture />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<ComputeDeveloperExperience />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<ComputeUseCases />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<ComputeDifferentiators />
|
||||||
|
</AnimatedSection>
|
||||||
<AnimatedSection>
|
<AnimatedSection>
|
||||||
<CallToAction />
|
<CallToAction />
|
||||||
</AnimatedSection>
|
</AnimatedSection>
|
||||||
|
|||||||
135
src/pages/compute/ComputeUseCases.tsx
Normal file
135
src/pages/compute/ComputeUseCases.tsx
Normal file
@@ -0,0 +1,135 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const primaryUseCases = [
|
||||||
|
{
|
||||||
|
title: 'AI / ML Training',
|
||||||
|
bullets: [
|
||||||
|
'Deterministic training pipelines for reproducible experiments.',
|
||||||
|
'Cryptographically verified model artifacts end-to-end.',
|
||||||
|
'Autonomous scaling for distributed training runs.',
|
||||||
|
'Zero-drift environments that remain consistent over time.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Application Hosting',
|
||||||
|
bullets: [
|
||||||
|
'Transparent deployments with verifiable execution.',
|
||||||
|
'Auto-scaling that allocates resources on demand.',
|
||||||
|
'Instant global distribution across the ThreeFold Grid.',
|
||||||
|
'Cryptographically secured runtime environments.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Data Processing',
|
||||||
|
bullets: [
|
||||||
|
'Deterministic pipelines that document every transformation.',
|
||||||
|
'Secure computation with cryptographic verification.',
|
||||||
|
'Auto-scaling resources for fluctuating workloads.',
|
||||||
|
'Global processing placement to minimize latency.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Scientific Computing',
|
||||||
|
bullets: [
|
||||||
|
'Reproducible research environments for shared experiments.',
|
||||||
|
'Secure workloads with verifiable execution paths.',
|
||||||
|
'Dynamic scaling for compute-intensive tasks.',
|
||||||
|
'Global collaboration with sovereign resource control.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
const computeSpecific = [
|
||||||
|
{
|
||||||
|
title: 'Deterministic Training Environments',
|
||||||
|
bullets: [
|
||||||
|
'Reproducible ML experiments with identical conditions every run.',
|
||||||
|
'Verifiable computational research for scientific collaboration.',
|
||||||
|
'Auditable financial modelling workflows with traceable outputs.',
|
||||||
|
'Consistent IoT edge processing with predictable performance.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Multi-Platform Application Hosting',
|
||||||
|
bullets: [
|
||||||
|
'Kubernetes orchestration with deterministic deployment pipelines.',
|
||||||
|
'Virtual machines launched with hardware-attested secure boot.',
|
||||||
|
'Native Linux workloads with cryptographic assurance.',
|
||||||
|
'Hybrid topologies mixing containers, VMs, and bare metal.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Auto-Scaling Workloads',
|
||||||
|
bullets: [
|
||||||
|
'Demand-based scaling that reacts instantly to load.',
|
||||||
|
'Global distribution across the ThreeFold Grid.',
|
||||||
|
'Automated failover that restores services without intervention.',
|
||||||
|
'Cost optimization through intelligent resource allocation.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function ComputeUseCases() {
|
||||||
|
return (
|
||||||
|
<section className="bg-gray-950 py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow color="accent" className="tracking-[0.32em] uppercase">
|
||||||
|
Use Cases
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" color="light" className="mt-6">
|
||||||
|
Purpose-built for reproducibility, security, and scale.
|
||||||
|
</SectionHeader>
|
||||||
|
<P color="lightSecondary" className="mt-6">
|
||||||
|
From sovereign AI training loops to globally distributed
|
||||||
|
applications, Mycelium Compute keeps environments verifiable and
|
||||||
|
self-orchestrating so teams can focus on building.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-2">
|
||||||
|
<div className="space-y-6">
|
||||||
|
{primaryUseCases.map((useCase) => (
|
||||||
|
<div
|
||||||
|
key={useCase.title}
|
||||||
|
className="rounded-3xl border border-white/10 bg-white/5 p-8 backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-200/40 hover:bg-white/10"
|
||||||
|
>
|
||||||
|
<h3 className="text-xl font-semibold text-white">
|
||||||
|
{useCase.title}
|
||||||
|
</h3>
|
||||||
|
<ul className="mt-4 space-y-3 text-sm text-gray-200">
|
||||||
|
{useCase.bullets.map((bullet) => (
|
||||||
|
<li key={bullet} className="flex items-start gap-3 leading-relaxed">
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-400" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
<div className="space-y-6">
|
||||||
|
{computeSpecific.map((useCase) => (
|
||||||
|
<div
|
||||||
|
key={useCase.title}
|
||||||
|
className="rounded-3xl border border-cyan-400/20 bg-gradient-to-br from-cyan-500/10 via-cyan-500/5 to-transparent p-8 backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-200/40 hover:from-cyan-400/20 hover:via-cyan-400/10"
|
||||||
|
>
|
||||||
|
<h3 className="text-xl font-semibold text-white">
|
||||||
|
{useCase.title}
|
||||||
|
</h3>
|
||||||
|
<ul className="mt-4 space-y-3 text-sm text-cyan-100">
|
||||||
|
{useCase.bullets.map((bullet) => (
|
||||||
|
<li key={bullet} className="flex items-start gap-3 leading-relaxed">
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-white/80" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
50
src/pages/compute/ComputeZeroImage.tsx
Normal file
50
src/pages/compute/ComputeZeroImage.tsx
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const zeroImageBenefits = [
|
||||||
|
'Metadata-only artifacts replace heavy images for ultra-fast delivery.',
|
||||||
|
'Instant startup times accelerate workload initialization anywhere.',
|
||||||
|
'Bandwidth consumption drops dramatically with minimal transfers.',
|
||||||
|
'Deploy workloads globally across the ThreeFold Grid without friction.',
|
||||||
|
]
|
||||||
|
|
||||||
|
export function ComputeZeroImage() {
|
||||||
|
return (
|
||||||
|
<section className="relative overflow-hidden bg-gradient-to-b from-cyan-950 via-gray-950 to-gray-950 py-24 sm:py-32">
|
||||||
|
<div className="pointer-events-none absolute inset-0">
|
||||||
|
<div className="absolute -top-32 right-1/4 h-72 w-72 rounded-full bg-cyan-500/30 blur-[120px]" />
|
||||||
|
<div className="absolute bottom-0 left-1/3 h-96 w-96 rounded-full bg-cyan-400/10 blur-[140px]" />
|
||||||
|
<div className="absolute inset-0 bg-[radial-gradient(circle_at_left,_rgba(8,145,178,0.18),_transparent_55%)]" />
|
||||||
|
</div>
|
||||||
|
<Container className="relative">
|
||||||
|
<div className="grid items-center gap-12 lg:grid-cols-[0.85fr_1.15fr]">
|
||||||
|
<div>
|
||||||
|
<Eyebrow color="accent" className="tracking-[0.32em] uppercase">
|
||||||
|
Zero-Image Integration
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" color="light" className="mt-6">
|
||||||
|
Ultra-efficient deployments that move at the speed of metadata.
|
||||||
|
</SectionHeader>
|
||||||
|
<P color="lightSecondary" className="mt-6">
|
||||||
|
Mycelium Compute integrates natively with Mycelium Storage's
|
||||||
|
Zero-Image system. Deployments ship as metadata descriptors rather
|
||||||
|
than bulky artifacts, enabling consistent, deterministic
|
||||||
|
environments delivered on demand.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<ul className="space-y-4 text-sm text-cyan-100">
|
||||||
|
{zeroImageBenefits.map((benefit) => (
|
||||||
|
<li
|
||||||
|
key={benefit}
|
||||||
|
className="flex items-start gap-3 rounded-3xl border border-cyan-400/20 bg-white/5 p-5 backdrop-blur-sm transition hover:border-cyan-200/40 hover:bg-white/10"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-flex size-3 flex-none rounded-full bg-cyan-300 shadow-[0_0_12px_rgba(45,212,191,0.6)]" />
|
||||||
|
<span className="leading-relaxed">{benefit}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -14,23 +14,30 @@ export function CallToAction() {
|
|||||||
<Container className="relative">
|
<Container className="relative">
|
||||||
<div className="mx-auto max-w-2xl text-center">
|
<div className="mx-auto max-w-2xl text-center">
|
||||||
<h2 className="text-3xl lg:text-4xl font-medium tracking-tight text-white sm:text-4xl">
|
<h2 className="text-3xl lg:text-4xl font-medium tracking-tight text-white sm:text-4xl">
|
||||||
Get Started Today
|
Bring sovereign GPU acceleration to production.
|
||||||
</h2>
|
</h2>
|
||||||
<p className="mt-6 text-lg text-gray-300">
|
<p className="mt-6 text-lg text-gray-300">
|
||||||
Download the Mycelium app and step into the future of secure, peer-to-peer networking; fast, private, and decentralized.
|
Work with the Mycelium team to deploy GPU workloads that remain
|
||||||
|
verifiable, performant, and cost-transparent from edge to core.
|
||||||
</p>
|
</p>
|
||||||
<div className="mt-10 flex flex-wrap justify-center gap-x-6 gap-y-4">
|
<div className="mt-10 flex flex-wrap justify-center gap-x-6 gap-y-4">
|
||||||
<Button to="/download" variant="solid" color="white">
|
<Button
|
||||||
Get Mycelium Connector
|
to="https://myceliumcloud.tf"
|
||||||
|
as="a"
|
||||||
|
variant="solid"
|
||||||
|
color="white"
|
||||||
|
target="_blank"
|
||||||
|
rel="noreferrer"
|
||||||
|
>
|
||||||
|
Talk to our team
|
||||||
</Button>
|
</Button>
|
||||||
<Button
|
<Button
|
||||||
to="https://threefold.info/mycelium_network/docs/"
|
to="#gpu-architecture"
|
||||||
as="a"
|
as="a"
|
||||||
target="_blank"
|
|
||||||
variant="outline"
|
variant="outline"
|
||||||
color="white"
|
color="white"
|
||||||
>
|
>
|
||||||
Read Docs
|
Review architecture
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
75
src/pages/gpu/GpuArchitecture.tsx
Normal file
75
src/pages/gpu/GpuArchitecture.tsx
Normal file
@@ -0,0 +1,75 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const architectureSections = [
|
||||||
|
{
|
||||||
|
title: 'Distributed GPU Mesh',
|
||||||
|
description:
|
||||||
|
'A peer-to-peer fabric connects GPU nodes across the ThreeFold Grid, exposing them through the Mycelium network.',
|
||||||
|
bullets: [
|
||||||
|
'GPU nodes distributed globally for on-demand acceleration.',
|
||||||
|
'Mycelium network provides encrypted peer-to-peer connectivity.',
|
||||||
|
'Smart contract orchestration allocates and governs resources.',
|
||||||
|
'Real-time monitoring tracks utilization and health.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Performance Characteristics',
|
||||||
|
description:
|
||||||
|
'Consistency and transparency are built into the fabric so workloads behave predictably anywhere on the planet.',
|
||||||
|
bullets: [
|
||||||
|
'Edge-to-core deployment flexibility for every workload profile.',
|
||||||
|
'Adaptive intelligence optimizes allocation automatically.',
|
||||||
|
'Deterministic performance guarantees availability when booked.',
|
||||||
|
'Transparent cost tracking for every GPU cycle consumed.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function GpuArchitecture() {
|
||||||
|
return (
|
||||||
|
<section id="gpu-architecture" className="bg-white py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-500">
|
||||||
|
Technical Architecture
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
A peer-to-peer mesh purpose-built for acceleration.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
Mycelium GPU treats every node as part of a sovereign mesh. Encrypted
|
||||||
|
networking, smart contract orchestration, and transparent monitoring
|
||||||
|
ensure your workloads receive precisely the power they request.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-2">
|
||||||
|
{architectureSections.map((section) => (
|
||||||
|
<div
|
||||||
|
key={section.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-slate-200 bg-white p-8 shadow-sm transition hover:-translate-y-1 hover:border-cyan-300 hover:shadow-lg"
|
||||||
|
>
|
||||||
|
<h3 className="text-xl font-semibold text-gray-900">
|
||||||
|
{section.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-600">
|
||||||
|
{section.description}
|
||||||
|
</p>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-600">
|
||||||
|
{section.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-100 bg-cyan-50/60 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-500" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
85
src/pages/gpu/GpuDifferentiators.tsx
Normal file
85
src/pages/gpu/GpuDifferentiators.tsx
Normal file
@@ -0,0 +1,85 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const differentiators = [
|
||||||
|
{
|
||||||
|
title: 'Unified Fabric',
|
||||||
|
description:
|
||||||
|
'Transforms fragmented GPU resources into a single, standard interface accessible anywhere.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Sovereign Control',
|
||||||
|
description:
|
||||||
|
'Operate without vendor lock-in or geographic restrictions—govern policies entirely through code.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Code-Driven Orchestration',
|
||||||
|
description:
|
||||||
|
'APIs and smart contracts automate allocation, attestation, and lifecycle management.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Deterministic Performance',
|
||||||
|
description:
|
||||||
|
'Guaranteed GPU allocation delivers the compute you reserve with consistent performance characteristics.',
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
const costEfficiency = [
|
||||||
|
'Transparent pricing with no hidden fees.',
|
||||||
|
'Pay only for the GPU cycles you consume.',
|
||||||
|
'Global optimization locates the most cost-effective nodes.',
|
||||||
|
'Avoid premium lock-in from centralized providers.',
|
||||||
|
]
|
||||||
|
|
||||||
|
export function GpuDifferentiators() {
|
||||||
|
return (
|
||||||
|
<section className="bg-gray-950 py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-300">
|
||||||
|
Key Differentiators
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" color="light" className="mt-6">
|
||||||
|
GPU acceleration with sovereignty and clarity.
|
||||||
|
</SectionHeader>
|
||||||
|
<P color="lightSecondary" className="mt-6">
|
||||||
|
Mycelium GPU delivers verifiable access to power when you need it.
|
||||||
|
Control stays in your hands, from allocation policies to cost
|
||||||
|
structure.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 md:grid-cols-2">
|
||||||
|
{differentiators.map((item) => (
|
||||||
|
<div
|
||||||
|
key={item.title}
|
||||||
|
className="rounded-3xl border border-white/10 bg-white/[0.04] p-8 backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-300/50 hover:bg-white/[0.08]"
|
||||||
|
>
|
||||||
|
<h3 className="text-lg font-semibold text-white">{item.title}</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
||||||
|
{item.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 rounded-3xl border border-white/10 bg-white/[0.03] p-8 text-left backdrop-blur-sm">
|
||||||
|
<h3 className="text-xl font-semibold text-white">Cost Efficiency</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
||||||
|
Transparent economics makes capacity planning simple while keeping
|
||||||
|
budgets predictable.
|
||||||
|
</p>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-300">
|
||||||
|
{costEfficiency.map((item) => (
|
||||||
|
<li
|
||||||
|
key={item}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-500/10 bg-cyan-500/5 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-300" />
|
||||||
|
<span>{item}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
103
src/pages/gpu/GpuGettingStarted.tsx
Normal file
103
src/pages/gpu/GpuGettingStarted.tsx
Normal file
@@ -0,0 +1,103 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P, Small } from '../../components/Texts'
|
||||||
|
|
||||||
|
const steps = [
|
||||||
|
{
|
||||||
|
number: '01',
|
||||||
|
title: 'Account Setup',
|
||||||
|
description:
|
||||||
|
'Create your Mycelium account and ensure GPU access is enabled.',
|
||||||
|
bullets: [
|
||||||
|
'Sign up and verify your account credentials.',
|
||||||
|
'Enable GPU access or request it from the Mycelium team.',
|
||||||
|
'Configure billing to align usage with your budget.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
number: '02',
|
||||||
|
title: 'Request GPU Resources',
|
||||||
|
description: 'Use the Mycelium GPU API to allocate the acceleration you need.',
|
||||||
|
bullets: [
|
||||||
|
'Describe the GPU profile (memory, cores, region) your workload requires.',
|
||||||
|
'Let smart contracts reserve and attest the selected hardware.',
|
||||||
|
'Receive deterministic allocation details for orchestration.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
number: '03',
|
||||||
|
title: 'Deploy & Monitor',
|
||||||
|
description:
|
||||||
|
'Launch your workload, integrate storage, and monitor performance from the dashboard.',
|
||||||
|
bullets: [
|
||||||
|
'Deploy via Kubernetes, containers, or custom runtimes.',
|
||||||
|
'Bind to Quantum-Safe Storage for datasets and checkpoints.',
|
||||||
|
'Track GPU utilization, cost, and health in real time.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
const workflow = 'Application → Mycelium GPU API → GPU Resource Allocation → Workload Execution'
|
||||||
|
|
||||||
|
export function GpuGettingStarted() {
|
||||||
|
return (
|
||||||
|
<section
|
||||||
|
id="gpu-getting-started"
|
||||||
|
className="relative overflow-hidden bg-gray-900 py-24 sm:py-32"
|
||||||
|
>
|
||||||
|
<div className="absolute inset-0 bg-[radial-gradient(circle_at_top,_rgba(34,211,238,0.12),_transparent_60%)]" />
|
||||||
|
<Container className="relative">
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-300">
|
||||||
|
Getting Started
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" color="light" className="mt-6">
|
||||||
|
Allocate, run, and observe in three moves.
|
||||||
|
</SectionHeader>
|
||||||
|
<P color="lightSecondary" className="mt-6">
|
||||||
|
Mycelium GPU keeps onboarding simple—declare what you need, deploy
|
||||||
|
your workload, and let the mesh guarantee performance with full
|
||||||
|
transparency.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-10 lg:grid-cols-3">
|
||||||
|
{steps.map((step) => (
|
||||||
|
<div
|
||||||
|
key={step.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-white/10 bg-white/[0.03] p-8 backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-300/50 hover:bg-white/[0.06]"
|
||||||
|
>
|
||||||
|
<div className="flex items-center justify-between">
|
||||||
|
<Small className="text-xs uppercase tracking-[0.4em] text-cyan-300">
|
||||||
|
{step.number}
|
||||||
|
</Small>
|
||||||
|
<span className="inline-flex size-10 items-center justify-center rounded-full border border-cyan-300/40 text-sm font-semibold uppercase tracking-[0.25em] text-cyan-200">
|
||||||
|
Go
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<h3 className="mt-6 text-xl font-semibold text-white">{step.title}</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
||||||
|
{step.description}
|
||||||
|
</p>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-300">
|
||||||
|
{step.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-500/10 bg-cyan-500/5 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-300" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 rounded-3xl border border-white/10 bg-white/[0.03] p-6 text-center backdrop-blur-sm">
|
||||||
|
<p className="text-sm font-medium uppercase tracking-[0.3em] text-cyan-200">
|
||||||
|
Basic Workflow
|
||||||
|
</p>
|
||||||
|
<p className="mt-4 text-base text-gray-100">{workflow}</p>
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -1,31 +1,42 @@
|
|||||||
'use client'
|
'use client'
|
||||||
|
|
||||||
import { Button } from '../../components/Button'
|
import { Button } from '../../components/Button'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
export function GpuHero() {
|
export function GpuHero() {
|
||||||
return (
|
return (
|
||||||
<div className="relative bg-white">
|
<div className="relative bg-white">
|
||||||
<div className="relative h-80 overflow-hidden bg-transparent md:absolute md:right-0 md:h-full md:w-1/3 lg:w-1/2">
|
<div className="relative h-80 overflow-hidden bg-transparent md:absolute md:right-0 md:h-full md:w-1/3 lg:w-1/2">
|
||||||
<img
|
<img
|
||||||
alt=""
|
alt="Mycelium GPU nebula illustration"
|
||||||
src="/images/gpuhero.png"
|
src="/images/gpuhero.png"
|
||||||
className="size-full object-cover"
|
className="size-full object-cover"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div className="relative mx-auto max-w-7xl py-24 sm:py-32 lg:px-8 lg:py-40">
|
<div className="relative mx-auto max-w-7xl py-24 sm:py-32 lg:px-8 lg:py-40">
|
||||||
<div className="pr-6 pl-6 md:mr-auto md:w-2/3 md:pr-16 lg:w-1/2 lg:pl-0 lg:pr-24 xl:pr-32">
|
<div className="pr-6 pl-6 md:mr-auto md:w-2/3 md:pr-16 lg:w-1/2 lg:pl-0 lg:pr-24 xl:pr-32">
|
||||||
<h2 className="text-base/7 font-semibold text-cyan-500">GPU</h2>
|
<Eyebrow className="tracking-[0.35em] uppercase text-cyan-500">
|
||||||
<h1 className="mt-2 text-4xl font-semibold tracking-tight text-gray-900 sm:text-5xl">Unify Distributed GPU Power. Run Intelligence Anywhere.</h1>
|
Mycelium GPU
|
||||||
<p className="mt-6 text-base/7 text-gray-600">
|
</Eyebrow>
|
||||||
Mycelium GPU transforms fragmented GPU resources into a single sovereign fabric for running AI, ML, and rendering workloads — from edge to core, with deterministic performance and transparent cost.
|
<SectionHeader as="h1" className="mt-4 text-gray-900">
|
||||||
</p>
|
Unify distributed GPU power into a sovereign acceleration fabric.
|
||||||
<div className="mt-8 flex items-center gap-x-4">
|
</SectionHeader>
|
||||||
<Button to="/docs" variant="solid" color="cyan">
|
<P className="mt-6 text-gray-600">
|
||||||
Get Started →
|
Mycelium GPU transforms fragmented hardware across the ThreeFold
|
||||||
|
Grid into one adaptive intelligence layer. Run AI, ML, rendering,
|
||||||
|
and high-performance workloads anywhere—from edge devices to
|
||||||
|
planetary clusters—with deterministic performance and transparent
|
||||||
|
cost.
|
||||||
|
</P>
|
||||||
|
<P className="mt-4 italic text-gray-500">
|
||||||
|
The energy behind intelligence, orchestrated entirely through code.
|
||||||
|
</P>
|
||||||
|
<div className="mt-10 flex flex-wrap gap-4">
|
||||||
|
<Button to="#gpu-getting-started" as="a" variant="solid" color="cyan">
|
||||||
|
Start with GPU Access
|
||||||
</Button>
|
</Button>
|
||||||
<Button to="#architecture" variant="outline" color="cyan">
|
<Button to="#gpu-architecture" as="a" variant="outline" color="cyan">
|
||||||
Explore Architecture →
|
Explore the Mesh
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
81
src/pages/gpu/GpuIntegration.tsx
Normal file
81
src/pages/gpu/GpuIntegration.tsx
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const integrationPoints = [
|
||||||
|
'Unified Mycelium networking provides secure access to GPU nodes.',
|
||||||
|
'Zero-trust security model extends to GPU operations automatically.',
|
||||||
|
'Quantum-safe storage available directly to GPU workloads.',
|
||||||
|
'Native Kubernetes support exposes GPUs through familiar resources.',
|
||||||
|
]
|
||||||
|
|
||||||
|
const yamlExample = `apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: gpu-workload
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: gpu-compute
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: gpu-compute
|
||||||
|
spec:
|
||||||
|
containers:
|
||||||
|
- name: gpu-compute
|
||||||
|
image: tensorflow/tensorflow:latest-gpu
|
||||||
|
resources:
|
||||||
|
limits:
|
||||||
|
nvidia.com/gpu: 1
|
||||||
|
env:
|
||||||
|
- name: MYCELIUM_GPU_REGION
|
||||||
|
value: "auto"`
|
||||||
|
|
||||||
|
export function GpuIntegration() {
|
||||||
|
return (
|
||||||
|
<section className="bg-gray-950 py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-300">
|
||||||
|
Cloud Integration
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" color="light" className="mt-6">
|
||||||
|
Seamless with Mycelium Cloud infrastructure.
|
||||||
|
</SectionHeader>
|
||||||
|
<P color="lightSecondary" className="mt-6">
|
||||||
|
GPU workloads plug directly into the same mesh that powers Mycelium
|
||||||
|
Cloud. Networking, security, and storage policies flow with every
|
||||||
|
deployment.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-10 lg:grid-cols-2">
|
||||||
|
<div className="space-y-4 rounded-3xl border border-white/10 bg-white/[0.04] p-8 text-left backdrop-blur-sm">
|
||||||
|
<h3 className="text-lg font-semibold text-white">
|
||||||
|
Platform alignment
|
||||||
|
</h3>
|
||||||
|
<ul className="space-y-3 text-sm text-gray-300">
|
||||||
|
{integrationPoints.map((point) => (
|
||||||
|
<li
|
||||||
|
key={point}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-500/10 bg-cyan-500/5 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-300" />
|
||||||
|
<span>{point}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
<div className="rounded-3xl border border-white/10 bg-white/[0.04] p-8 backdrop-blur-sm">
|
||||||
|
<h3 className="text-lg font-semibold text-white">
|
||||||
|
Kubernetes deployment example
|
||||||
|
</h3>
|
||||||
|
<pre className="mt-6 overflow-x-auto rounded-2xl border border-white/10 bg-black/70 p-4 text-xs text-cyan-100">
|
||||||
|
<code>{yamlExample}</code>
|
||||||
|
</pre>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -1,56 +1,108 @@
|
|||||||
import { CodeBracketSquareIcon, CubeTransparentIcon, LockClosedIcon, Squares2X2Icon } from '@heroicons/react/24/outline'
|
import {
|
||||||
|
CodeBracketSquareIcon,
|
||||||
|
CubeTransparentIcon,
|
||||||
|
LockClosedIcon,
|
||||||
|
Squares2X2Icon,
|
||||||
|
} from '@heroicons/react/24/outline'
|
||||||
|
|
||||||
const features = [
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P, Small } from '../../components/Texts'
|
||||||
|
|
||||||
|
const overviewCards = [
|
||||||
|
{
|
||||||
|
label: 'Overview',
|
||||||
|
title: 'Unified GPU acceleration across the ThreeFold Grid',
|
||||||
|
description:
|
||||||
|
'Mycelium GPU aggregates distributed hardware into a single fabric, delivering sovereign acceleration for AI, ML, and rendering workloads.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Core Concept',
|
||||||
|
title: 'Sovereign intelligence layer',
|
||||||
|
description:
|
||||||
|
'No silos, no intermediaries—just raw, verifiable GPU power orchestrated through smart contracts and APIs you control.',
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
const principles = [
|
||||||
{
|
{
|
||||||
name: 'No Silos',
|
name: 'No Silos',
|
||||||
description: 'All GPU resources accessible through a single interface.',
|
description: 'Every GPU resource is accessible through a single interface.',
|
||||||
icon: Squares2X2Icon,
|
icon: Squares2X2Icon,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'No Intermediaries',
|
name: 'No Intermediaries',
|
||||||
description: 'Direct access to GPU resources without centralized control.',
|
description: 'Direct access to hardware without centralized brokers.',
|
||||||
icon: CubeTransparentIcon,
|
icon: CubeTransparentIcon,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'Verifiable Power',
|
name: 'Verifiable Power',
|
||||||
description: 'Every GPU cycle cryptographically verified.',
|
description: 'Every GPU cycle is attested and cryptographically verified.',
|
||||||
icon: LockClosedIcon,
|
icon: LockClosedIcon,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
name: 'Code-Orchestrated',
|
name: 'Code-Orchestrated',
|
||||||
description: 'Managed entirely through APIs and smart contracts.',
|
description: 'Smart contracts and APIs automate allocation and policy.',
|
||||||
icon: CodeBracketSquareIcon,
|
icon: CodeBracketSquareIcon,
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
|
|
||||||
export function GpuOverview() {
|
export function GpuOverview() {
|
||||||
return (
|
return (
|
||||||
<div className="bg-[#171717] py-24 sm:py-32">
|
<section className="bg-gray-950 py-24 sm:py-32">
|
||||||
<div className="mx-auto max-w-7xl px-6 lg:px-8">
|
<Container>
|
||||||
<div className="mx-auto grid max-w-2xl grid-cols-1 gap-16 sm:gap-y-20 lg:mx-0 lg:max-w-none lg:grid-cols-5">
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
<div className="lg:col-span-2">
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-300">
|
||||||
<h2 className="text-4xl font-semibold tracking-tight text-pretty text-white sm:text-5xl">
|
Platform Overview
|
||||||
Unified GPU Acceleration Across the Grid
|
</Eyebrow>
|
||||||
</h2>
|
<SectionHeader as="h2" color="light" className="mt-6 font-medium">
|
||||||
<p className="mt-4 text-base/7 text-gray-300">
|
The sovereign acceleration layer for intelligent workloads.
|
||||||
Mycelium GPU provides unified access to distributed GPU acceleration across the ThreeFold Grid. It transforms fragmented GPU resources into a single adaptive intelligence layer — enabling you to run AI, ML, and rendering workloads anywhere, anytime, with verifiable performance and transparent costs.
|
</SectionHeader>
|
||||||
</p>
|
<P color="lightSecondary" className="mt-6">
|
||||||
</div>
|
Mycelium GPU makes distributed acceleration feel like one machine.
|
||||||
<dl className="col-span-3 grid grid-cols-1 gap-x-8 gap-y-16 sm:grid-cols-2">
|
Harness global GPUs with deterministic performance, transparent
|
||||||
{features.map((feature) => (
|
costs, and end-to-end verification.
|
||||||
<div key={feature.name}>
|
</P>
|
||||||
<dt className="text-base/7 font-semibold text-white">
|
|
||||||
<div className="mb-6 flex size-10 items-center justify-center rounded-lg">
|
|
||||||
<feature.icon aria-hidden="true" className="size-8 text-cyan-500" />
|
|
||||||
</div>
|
|
||||||
{feature.name}
|
|
||||||
</dt>
|
|
||||||
<dd className="mt-1 text-base/7 text-gray-400">{feature.description}</dd>
|
|
||||||
</div>
|
|
||||||
))}
|
|
||||||
</dl>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
<div className="mt-16 grid gap-8 lg:grid-cols-2">
|
||||||
</div>
|
{overviewCards.map((card) => (
|
||||||
|
<div
|
||||||
|
key={card.title}
|
||||||
|
className="group relative overflow-hidden rounded-3xl border border-white/10 bg-white/[0.04] p-8 backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-300/50 hover:bg-white/[0.08]"
|
||||||
|
>
|
||||||
|
<div className="absolute inset-0 bg-gradient-to-br from-cyan-500/0 via-white/[0.05] to-cyan-300/20 opacity-0 transition group-hover:opacity-100" />
|
||||||
|
<div className="relative">
|
||||||
|
<Small className="text-xs uppercase tracking-[0.35em] text-cyan-200">
|
||||||
|
{card.label}
|
||||||
|
</Small>
|
||||||
|
<h3 className="mt-4 text-lg font-semibold text-white">
|
||||||
|
{card.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
||||||
|
{card.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 sm:grid-cols-2 lg:grid-cols-4">
|
||||||
|
{principles.map((principle) => (
|
||||||
|
<div
|
||||||
|
key={principle.name}
|
||||||
|
className="rounded-3xl border border-white/10 bg-white/[0.04] p-6 text-left transition hover:-translate-y-1 hover:border-cyan-300/50 hover:bg-white/[0.08]"
|
||||||
|
>
|
||||||
|
<div className="mb-6 flex size-12 items-center justify-center rounded-full bg-cyan-500/15">
|
||||||
|
<principle.icon aria-hidden="true" className="size-6 text-cyan-300" />
|
||||||
|
</div>
|
||||||
|
<h3 className="text-base font-semibold text-white">
|
||||||
|
{principle.name}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-3 text-sm leading-relaxed text-gray-300">
|
||||||
|
{principle.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,20 +1,40 @@
|
|||||||
import { AnimatedSection } from '../../components/AnimatedSection'
|
import { AnimatedSection } from '../../components/AnimatedSection'
|
||||||
import { GpuHero } from './GpuHero'
|
import { GpuHero } from './GpuHero'
|
||||||
import { CallToAction } from './CallToAction'
|
|
||||||
import { GpuOverview } from './GpuOverview'
|
import { GpuOverview } from './GpuOverview'
|
||||||
|
import { GpuArchitecture } from './GpuArchitecture'
|
||||||
|
import { GpuIntegration } from './GpuIntegration'
|
||||||
|
import { GpuUseCases } from './GpuUseCases'
|
||||||
|
import { GpuGettingStarted } from './GpuGettingStarted'
|
||||||
|
import { GpuDifferentiators } from './GpuDifferentiators'
|
||||||
|
import { CallToAction } from './CallToAction'
|
||||||
|
|
||||||
export default function GpuPage() {
|
export default function GpuPage() {
|
||||||
return (
|
return (
|
||||||
<div>
|
<>
|
||||||
<AnimatedSection>
|
<AnimatedSection>
|
||||||
<GpuHero />
|
<GpuHero />
|
||||||
</AnimatedSection>
|
</AnimatedSection>
|
||||||
<AnimatedSection>
|
<AnimatedSection>
|
||||||
<GpuOverview />
|
<GpuOverview />
|
||||||
</AnimatedSection>
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<GpuArchitecture />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<GpuIntegration />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<GpuUseCases />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<GpuGettingStarted />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<GpuDifferentiators />
|
||||||
|
</AnimatedSection>
|
||||||
<AnimatedSection>
|
<AnimatedSection>
|
||||||
<CallToAction />
|
<CallToAction />
|
||||||
</AnimatedSection>
|
</AnimatedSection>
|
||||||
</div>
|
</>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|||||||
81
src/pages/gpu/GpuUseCases.tsx
Normal file
81
src/pages/gpu/GpuUseCases.tsx
Normal file
@@ -0,0 +1,81 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const useCases = [
|
||||||
|
{
|
||||||
|
title: 'AI / ML Training',
|
||||||
|
description:
|
||||||
|
'Scale training, fine-tuning, and inference workloads anywhere on the grid.',
|
||||||
|
bullets: ['GPU acceleration', 'Scalable compute', 'Cost optimization'],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Rendering & Visualization',
|
||||||
|
description:
|
||||||
|
'Drive high-performance graphics pipelines for media, science, and immersive experiences.',
|
||||||
|
bullets: [
|
||||||
|
'Distributed 3D rendering',
|
||||||
|
'Scientific visualization',
|
||||||
|
'Real-time VR / AR processing',
|
||||||
|
'Digital twin simulations',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'General GPU Computing',
|
||||||
|
description:
|
||||||
|
'Harness sovereign acceleration for simulations, finance, blockchain, and research.',
|
||||||
|
bullets: [
|
||||||
|
'Scientific simulations',
|
||||||
|
'Financial modeling',
|
||||||
|
'Blockchain processing',
|
||||||
|
'Protein folding and discovery',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function GpuUseCases() {
|
||||||
|
return (
|
||||||
|
<section className="bg-white py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-500">
|
||||||
|
Use Cases
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
Acceleration for every intelligent workload.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
From deep learning to immersive visualization, Mycelium GPU delivers
|
||||||
|
deterministic access to the power you need without the waitlists or
|
||||||
|
markups of centralized clouds.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-3">
|
||||||
|
{useCases.map((useCase) => (
|
||||||
|
<div
|
||||||
|
key={useCase.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-slate-200 bg-white p-8 shadow-sm transition hover:-translate-y-1 hover:border-cyan-300 hover:shadow-lg"
|
||||||
|
>
|
||||||
|
<h3 className="text-xl font-semibold text-gray-900">
|
||||||
|
{useCase.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-600">
|
||||||
|
{useCase.description}
|
||||||
|
</p>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-600">
|
||||||
|
{useCase.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-100 bg-cyan-50/60 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-500" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -1,6 +1,5 @@
|
|||||||
import { cn } from "@/lib/utils";
|
|
||||||
import createGlobe from "cobe";
|
import createGlobe from "cobe";
|
||||||
import { useEffect, useRef, type ReactNode } from "react";
|
import { useEffect, useRef } from "react";
|
||||||
import { motion } from "motion/react";
|
import { motion } from "motion/react";
|
||||||
import { IconBrandYoutubeFilled } from "@tabler/icons-react";
|
import { IconBrandYoutubeFilled } from "@tabler/icons-react";
|
||||||
import { H2, P } from '@/components/Texts'
|
import { H2, P } from '@/components/Texts'
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
import { AnimatedSection } from '../../components/AnimatedSection'
|
import { AnimatedSection } from '../../components/AnimatedSection'
|
||||||
import { HomeAurora } from './HomeAurora'
|
import { HomeAurora } from './HomeAurora'
|
||||||
import { HomeFeaturesDark } from './HomeFeaturesDark'
|
|
||||||
import { StackSectionLight } from './StackSection'
|
import { StackSectionLight } from './StackSection'
|
||||||
import { WorldMap } from './HomeGlobe'
|
import { WorldMap } from './HomeGlobe'
|
||||||
import { HomeBenefits } from './HomeBenefits'
|
import { HomeBenefits } from './HomeBenefits'
|
||||||
|
|||||||
@@ -1,8 +1,7 @@
|
|||||||
"use client";
|
"use client";
|
||||||
|
|
||||||
import React from "react";
|
|
||||||
import { Carousel, Card } from "@/components/ui/apple-cards-carousel";
|
import { Carousel, Card } from "@/components/ui/apple-cards-carousel";
|
||||||
import { H2, H3, P } from "@/components/Texts";
|
import { H3, P } from "@/components/Texts";
|
||||||
|
|
||||||
export function HomeSlider() {
|
export function HomeSlider() {
|
||||||
const cards = data.map((card) => (
|
const cards = data.map((card) => (
|
||||||
|
|||||||
@@ -14,23 +14,31 @@ export function CallToAction() {
|
|||||||
<Container className="relative">
|
<Container className="relative">
|
||||||
<div className="mx-auto max-w-2xl text-center">
|
<div className="mx-auto max-w-2xl text-center">
|
||||||
<h2 className="text-3xl lg:text-4xl font-medium tracking-tight text-white sm:text-4xl">
|
<h2 className="text-3xl lg:text-4xl font-medium tracking-tight text-white sm:text-4xl">
|
||||||
Get Started Today
|
Bring sovereign storage into your stack.
|
||||||
</h2>
|
</h2>
|
||||||
<p className="mt-6 text-lg text-gray-300">
|
<p className="mt-6 text-lg text-gray-300">
|
||||||
Download the Mycelium app and step into the future of secure, peer-to-peer networking; fast, private, and decentralized.
|
Partner with the Mycelium team to design quantum-safe, compliant
|
||||||
|
storage that meets your residency, redundancy, and performance
|
||||||
|
requirements across the globe.
|
||||||
</p>
|
</p>
|
||||||
<div className="mt-10 flex flex-wrap justify-center gap-x-6 gap-y-4">
|
<div className="mt-10 flex flex-wrap justify-center gap-x-6 gap-y-4">
|
||||||
<Button to="/download" variant="solid" color="white">
|
<Button
|
||||||
Get Mycelium Connector
|
to="https://myceliumcloud.tf"
|
||||||
|
as="a"
|
||||||
|
variant="solid"
|
||||||
|
color="white"
|
||||||
|
target="_blank"
|
||||||
|
rel="noreferrer"
|
||||||
|
>
|
||||||
|
Talk to our team
|
||||||
</Button>
|
</Button>
|
||||||
<Button
|
<Button
|
||||||
to="https://threefold.info/mycelium_network/docs/"
|
to="#storage-developer-experience"
|
||||||
as="a"
|
as="a"
|
||||||
target="_blank"
|
|
||||||
variant="outline"
|
variant="outline"
|
||||||
color="white"
|
color="white"
|
||||||
>
|
>
|
||||||
Read Docs
|
Explore developer workflow
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
97
src/pages/storage/StorageArchitecture.tsx
Normal file
97
src/pages/storage/StorageArchitecture.tsx
Normal file
@@ -0,0 +1,97 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const architecture = [
|
||||||
|
{
|
||||||
|
title: 'Quantum-Safe Data Protection',
|
||||||
|
description:
|
||||||
|
'Post-quantum encryption and cryptographic verification protect every storage operation end-to-end.',
|
||||||
|
bullets: [
|
||||||
|
'Algorithms selected to resist quantum computing attacks.',
|
||||||
|
'Protection applied beneath the application layer.',
|
||||||
|
'All writes and reads verified cryptographically.',
|
||||||
|
'Future-proof design for long-lived data sets.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Autonomous Self-Healing',
|
||||||
|
description:
|
||||||
|
'Storage monitors itself, heals corruption, and restores replicas without human intervention.',
|
||||||
|
bullets: [
|
||||||
|
'Continuous detection of failures or anomalies.',
|
||||||
|
'Instant recovery without service interruption.',
|
||||||
|
'Integrity checks keep replicas in lockstep.',
|
||||||
|
'24/7 autonomy removes the pager from the loop.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Multi-Protocol Fabric',
|
||||||
|
description:
|
||||||
|
'A single data plane serves every protocol so workloads can mix and migrate freely.',
|
||||||
|
bullets: [
|
||||||
|
'Protocol adapters sit in front of the same storage core.',
|
||||||
|
'Applications choose the protocol that fits their workflow.',
|
||||||
|
'No data duplication needed to support multiple interfaces.',
|
||||||
|
'Consistent governance across all access patterns.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Geo-Aware Data Governance',
|
||||||
|
description:
|
||||||
|
'Data placement policies enforce sovereignty, redundancy, and compliance requirements.',
|
||||||
|
bullets: [
|
||||||
|
'Pin workloads to specific jurisdictions or providers.',
|
||||||
|
'Define redundancy at the dataset or workload level.',
|
||||||
|
'Automatic zone-to-zone replication hardens resilience.',
|
||||||
|
'Global distribution optimized across the ThreeFold Grid.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function StorageArchitecture() {
|
||||||
|
return (
|
||||||
|
<section className="bg-gray-50 py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-500">
|
||||||
|
Technical Architecture
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
Autonomous governance for planetary-scale storage.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
The Mycelium Storage data plane is designed to protect data at the
|
||||||
|
cryptographic layer, operate without manual intervention, and meet
|
||||||
|
jurisdictional requirements anywhere in the world.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-2">
|
||||||
|
{architecture.map((item) => (
|
||||||
|
<div
|
||||||
|
key={item.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-slate-200 bg-white p-8 shadow-sm transition hover:-translate-y-1 hover:border-cyan-300 hover:shadow-lg"
|
||||||
|
>
|
||||||
|
<h3 className="text-xl font-semibold text-gray-900">
|
||||||
|
{item.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-600">
|
||||||
|
{item.description}
|
||||||
|
</p>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-600">
|
||||||
|
{item.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-100 bg-cyan-50/60 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-500" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
120
src/pages/storage/StorageDeveloperExperience.tsx
Normal file
120
src/pages/storage/StorageDeveloperExperience.tsx
Normal file
@@ -0,0 +1,120 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
type Experience = {
|
||||||
|
title: string
|
||||||
|
description: string
|
||||||
|
code: string
|
||||||
|
language: string
|
||||||
|
}
|
||||||
|
|
||||||
|
const experiences: Experience[] = [
|
||||||
|
{
|
||||||
|
title: 'S3-Compatible Access',
|
||||||
|
description:
|
||||||
|
'Use familiar AWS SDKs to read and write data against the Mycelium Storage endpoint.',
|
||||||
|
language: 'python',
|
||||||
|
code: `import boto3
|
||||||
|
|
||||||
|
s3_client = boto3.client(
|
||||||
|
's3',
|
||||||
|
endpoint_url='https://storage.mycelium.com',
|
||||||
|
aws_access_key_id='your_access_key',
|
||||||
|
aws_secret_access_key='your_secret_key'
|
||||||
|
)
|
||||||
|
|
||||||
|
s3_client.upload_file('local_file.txt', 'my-bucket', 'remote_file.txt')
|
||||||
|
s3_client.download_file('my-bucket', 'remote_file.txt', 'downloaded_file.txt')`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'WebDAV Mount',
|
||||||
|
description:
|
||||||
|
'Mount storage as a filesystem for desktop workflows and legacy integrations.',
|
||||||
|
language: 'bash',
|
||||||
|
code: `mount -t davfs https://storage.mycelium.com/dav /mnt/storage
|
||||||
|
cp /mnt/storage/data.txt ./
|
||||||
|
echo "Data updated" > /mnt/storage/updated.txt`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'IPFS Integration',
|
||||||
|
description:
|
||||||
|
'Leverage IPFS for decentralized addressability without duplicating datasets.',
|
||||||
|
language: 'python',
|
||||||
|
code: `import ipfshttpclient
|
||||||
|
|
||||||
|
client = ipfshttpclient.connect('/ip4/127.0.0.1/tcp/5001')
|
||||||
|
result = client.add('data.txt')
|
||||||
|
print(f"File available at: {result['Hash']}")`,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Geo-Aware Placement Policy',
|
||||||
|
description:
|
||||||
|
'Declare residency, redundancy, and protocol availability in a single configuration.',
|
||||||
|
language: 'yaml',
|
||||||
|
code: `apiVersion: v1
|
||||||
|
kind: ConfigMap
|
||||||
|
metadata:
|
||||||
|
name: storage-config
|
||||||
|
data:
|
||||||
|
placement: |
|
||||||
|
geo_aware_storage:
|
||||||
|
residency: "eu-west"
|
||||||
|
redundancy: 3
|
||||||
|
zones:
|
||||||
|
- "zone-1"
|
||||||
|
- "zone-2"
|
||||||
|
- "zone-3"
|
||||||
|
protocols:
|
||||||
|
- "s3"
|
||||||
|
- "ipfs"
|
||||||
|
- "webdav"`,
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function StorageDeveloperExperience() {
|
||||||
|
return (
|
||||||
|
<section
|
||||||
|
id="storage-developer-experience"
|
||||||
|
className="bg-gray-900 py-24 sm:py-32"
|
||||||
|
>
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-300">
|
||||||
|
Developer Experience
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" color="light" className="mt-6">
|
||||||
|
Build with the interfaces you already know.
|
||||||
|
</SectionHeader>
|
||||||
|
<P color="lightSecondary" className="mt-6">
|
||||||
|
Every protocol rides the same quantum-safe storage fabric, so moving
|
||||||
|
between APIs is as simple as switching adapters. Choose the workflow
|
||||||
|
that fits your stack.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-2">
|
||||||
|
{experiences.map((experience) => (
|
||||||
|
<div
|
||||||
|
key={experience.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-white/10 bg-white/[0.04] p-8 backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-300/50 hover:bg-white/[0.08]"
|
||||||
|
>
|
||||||
|
<div>
|
||||||
|
<h3 className="text-xl font-semibold text-white">
|
||||||
|
{experience.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
||||||
|
{experience.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<pre className="mt-6 overflow-x-auto rounded-2xl border border-white/10 bg-black/70 p-4 text-xs text-cyan-100">
|
||||||
|
<code>{experience.code}</code>
|
||||||
|
</pre>
|
||||||
|
<span className="mt-4 inline-flex w-fit items-center rounded-full border border-cyan-500/40 px-3 py-1 text-[0.65rem] font-semibold uppercase tracking-[0.3em] text-cyan-200">
|
||||||
|
{experience.language}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
65
src/pages/storage/StorageDifferentiators.tsx
Normal file
65
src/pages/storage/StorageDifferentiators.tsx
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const differentiators = [
|
||||||
|
{
|
||||||
|
title: 'Quantum-Safe Protection',
|
||||||
|
description:
|
||||||
|
'Data is encrypted with algorithms that resist quantum attacks, preserving integrity for decades.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Autonomous Self-Healing',
|
||||||
|
description:
|
||||||
|
'Failures and corruption are detected and repaired automatically—no on-call rotations required.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Universal Protocol Support',
|
||||||
|
description:
|
||||||
|
'Serve the same data through IPFS, S3, WebDAV, HTTP, and native file systems without duplication.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Geo-Aware Data Governance',
|
||||||
|
description:
|
||||||
|
'Define residency, redundancy, and distribution policies per workload and enforce them automatically.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Ultra-Efficient Storage',
|
||||||
|
description:
|
||||||
|
'Zero-image technology reduces artifacts by up to 100x, cutting bandwidth and accelerating deployment.',
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function StorageDifferentiators() {
|
||||||
|
return (
|
||||||
|
<section className="bg-gray-950 py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-300">
|
||||||
|
Key Differentiators
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" color="light" className="mt-6">
|
||||||
|
Sovereignty, resilience, and flexibility in one fabric.
|
||||||
|
</SectionHeader>
|
||||||
|
<P color="lightSecondary" className="mt-6">
|
||||||
|
Mycelium Storage blends quantum safety, autonomous operations, and
|
||||||
|
protocol choice into a single platform that meets the most demanding
|
||||||
|
requirements for modern data services.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 md:grid-cols-2">
|
||||||
|
{differentiators.map((item) => (
|
||||||
|
<div
|
||||||
|
key={item.title}
|
||||||
|
className="rounded-3xl border border-white/10 bg-white/[0.04] p-8 backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-300/50 hover:bg-white/[0.08]"
|
||||||
|
>
|
||||||
|
<h3 className="text-lg font-semibold text-white">{item.title}</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
||||||
|
{item.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
113
src/pages/storage/StorageFeatures.tsx
Normal file
113
src/pages/storage/StorageFeatures.tsx
Normal file
@@ -0,0 +1,113 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P, Small } from '../../components/Texts'
|
||||||
|
|
||||||
|
const features = [
|
||||||
|
{
|
||||||
|
title: 'Quantum-Safe Storage (QSS)',
|
||||||
|
description:
|
||||||
|
'Quantum-resistant encryption secures data beyond the application layer so ownership stays yours.',
|
||||||
|
bullets: [
|
||||||
|
'Beyond AES-256 with post-quantum algorithms.',
|
||||||
|
'Multi-layer protection enforced automatically.',
|
||||||
|
'Future-proof against emerging quantum threats.',
|
||||||
|
'Total control of keys, residency, and governance.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Self-Healing Storage System',
|
||||||
|
description:
|
||||||
|
'Autonomous recovery heals failures or corruption instantly with no human intervention.',
|
||||||
|
bullets: [
|
||||||
|
'Instant detection and repair of anomalies.',
|
||||||
|
'Integrity preserved while data is restored.',
|
||||||
|
'Continuous verification validates every replica.',
|
||||||
|
'Zero-ops recovery that runs around the clock.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Multi-Protocol Data Access',
|
||||||
|
description:
|
||||||
|
'Serve the same dataset over IPFS, S3, WebDAV, HTTP, and native file systems.',
|
||||||
|
bullets: [
|
||||||
|
'IPFS for decentralized, content-addressed retrieval.',
|
||||||
|
'S3-compatible API for existing tooling and SDKs.',
|
||||||
|
'WebDAV for mounted filesystem access.',
|
||||||
|
'HTTP and POSIX for direct application integration.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Geo-Aware Placement & Replication',
|
||||||
|
description:
|
||||||
|
'Define residency, redundancy, and distribution on a per-workload basis.',
|
||||||
|
bullets: [
|
||||||
|
'Pin data to specific jurisdictions or zones.',
|
||||||
|
'Custom redundancy policies per dataset.',
|
||||||
|
'Automatic zone-to-zone replication for resilience.',
|
||||||
|
'Global distribution across the ThreeFold Grid.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Ultra-Efficient Zero-Images (Flists)',
|
||||||
|
description:
|
||||||
|
'Metadata-only flists shrink images up to 100x, enabling instant Zero-OS deployments.',
|
||||||
|
bullets: [
|
||||||
|
'Drastically reduced storage footprint for artifacts.',
|
||||||
|
'Metadata-driven delivery accelerates boot times.',
|
||||||
|
'Bandwidth-efficient transfers to any node.',
|
||||||
|
'Perfect for immutable workloads and rapid rollback.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function StorageFeatures() {
|
||||||
|
return (
|
||||||
|
<section id="storage-features" className="bg-white py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-500">
|
||||||
|
Core Features
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
Data services engineered for sovereignty and speed.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
Mycelium Storage combines quantum-safe cryptography, autonomous
|
||||||
|
healing, and universal protocol support. It adapts to every workload
|
||||||
|
without sacrificing control or performance.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 md:grid-cols-2">
|
||||||
|
{features.map((feature) => (
|
||||||
|
<div
|
||||||
|
key={feature.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-slate-200 bg-white p-8 shadow-sm transition hover:-translate-y-1 hover:border-cyan-300 hover:shadow-lg"
|
||||||
|
>
|
||||||
|
<div>
|
||||||
|
<Small className="text-xs uppercase tracking-[0.3em] text-cyan-500">
|
||||||
|
Capability
|
||||||
|
</Small>
|
||||||
|
<h3 className="mt-4 text-xl font-semibold text-gray-900">
|
||||||
|
{feature.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-600">
|
||||||
|
{feature.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-600">
|
||||||
|
{feature.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-100 bg-cyan-50/60 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-500" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -1,29 +1,46 @@
|
|||||||
'use client'
|
'use client'
|
||||||
|
|
||||||
import { Button } from '../../components/Button'
|
import { Button } from '../../components/Button'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
export function StorageHero() {
|
export function StorageHero() {
|
||||||
return (
|
return (
|
||||||
<div className="relative bg-white">
|
<div className="relative bg-white">
|
||||||
<div className="relative h-80 overflow-hidden bg-transparent md:absolute md:right-0 md:h-full md:w-1/3 lg:w-1/2">
|
<div className="relative h-80 overflow-hidden bg-transparent md:absolute md:right-0 md:h-full md:w-1/3 lg:w-1/2">
|
||||||
<img
|
<img
|
||||||
alt=""
|
alt="Mycelium Storage visual"
|
||||||
src="/images/storagehero2.png"
|
src="/images/storagehero2.png"
|
||||||
className="size-full object-cover"
|
className="size-full object-cover"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
<div className="relative mx-auto max-w-7xl py-24 sm:py-32 lg:px-8 lg:py-40">
|
<div className="relative mx-auto max-w-7xl py-24 sm:py-32 lg:px-8 lg:py-40">
|
||||||
<div className="pr-6 pl-6 md:mr-auto md:w-2/3 md:pr-16 lg:w-1/2 lg:pl-0 lg:pr-24 xl:pr-32">
|
<div className="pr-6 pl-6 md:mr-auto md:w-2/3 md:pr-16 lg:w-1/2 lg:pl-0 lg:pr-24 xl:pr-32">
|
||||||
<h2 className="text-base/7 font-semibold text-cyan-500">STORAGE</h2>
|
<Eyebrow className="tracking-[0.35em] uppercase text-cyan-500">
|
||||||
<p className="mt-2 text-4xl font-semibold tracking-tight text-gray-900 sm:text-5xl">If GPUs are the engine, data is the lifeblood of intelligence.</p>
|
Mycelium Storage
|
||||||
<p className="mt-6 text-base/7 text-gray-600">
|
</Eyebrow>
|
||||||
Mycelium interconnects autonomous nodes with unified storage that adapts to every workload — from high-throughput object stores to parallel file systems.
|
<SectionHeader as="h1" className="mt-4 text-gray-900">
|
||||||
Rooted in open standards, it ensures speed, resilience, and true data sovereignty.
|
Quantum-safe, sovereign data plane for every workload.
|
||||||
</p>
|
</SectionHeader>
|
||||||
<div className="mt-8">
|
<P className="mt-6 text-gray-600">
|
||||||
<Button href="#" variant="solid" color="cyan">
|
Mycelium Storage delivers quantum-resistant protection, autonomous
|
||||||
Talk to an expert
|
recovery, and multi-protocol access across the ThreeFold Grid. Place
|
||||||
|
data exactly where you need it while keeping ownership entirely in
|
||||||
|
your hands.
|
||||||
|
</P>
|
||||||
|
<P className="mt-4 italic text-gray-500">
|
||||||
|
Quantum-safe. Self-healing. Universally accessible.
|
||||||
|
</P>
|
||||||
|
<div className="mt-10 flex flex-wrap gap-4">
|
||||||
|
<Button to="#storage-features" as="a" variant="solid" color="cyan">
|
||||||
|
Explore Features
|
||||||
|
</Button>
|
||||||
|
<Button
|
||||||
|
to="#storage-developer-experience"
|
||||||
|
as="a"
|
||||||
|
variant="outline"
|
||||||
|
color="cyan"
|
||||||
|
>
|
||||||
|
View Developer Flow
|
||||||
</Button>
|
</Button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
66
src/pages/storage/StorageOverview.tsx
Normal file
66
src/pages/storage/StorageOverview.tsx
Normal file
@@ -0,0 +1,66 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P, Small } from '../../components/Texts'
|
||||||
|
|
||||||
|
const highlights = [
|
||||||
|
{
|
||||||
|
label: 'Overview',
|
||||||
|
title: 'Quantum-safe, sovereign data management',
|
||||||
|
description:
|
||||||
|
'Mycelium Storage protects data beyond the application layer with autonomous recovery and geo-aware placement across the ThreeFold Grid.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Core Concept',
|
||||||
|
title: 'Unified data plane across every protocol',
|
||||||
|
description:
|
||||||
|
'Serve the same dataset via IPFS, S3, WebDAV, HTTP, or native file systems while maintaining complete control over residency and redundancy.',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: 'Outcome',
|
||||||
|
title: 'Ownership without compromise',
|
||||||
|
description:
|
||||||
|
'Quantum-resistant encryption, self-healing recovery, and programmable governance ensure data remains verifiable, available, and compliant.',
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function StorageOverview() {
|
||||||
|
return (
|
||||||
|
<section className="bg-gray-950 py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-300">
|
||||||
|
Platform Overview
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" color="light" className="mt-6 font-medium">
|
||||||
|
A quantum-safe data plane that heals itself.
|
||||||
|
</SectionHeader>
|
||||||
|
<P color="lightSecondary" className="mt-6">
|
||||||
|
Built on sovereign infrastructure, Mycelium Storage keeps data
|
||||||
|
resilient, verifiable, and instantly accessible. Encryption,
|
||||||
|
replication, and governance are woven directly into the substrate.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-3">
|
||||||
|
{highlights.map((item) => (
|
||||||
|
<div
|
||||||
|
key={item.title}
|
||||||
|
className="group relative overflow-hidden rounded-3xl border border-white/10 bg-white/[0.04] p-8 backdrop-blur-sm transition hover:-translate-y-1 hover:border-cyan-300/50 hover:bg-white/[0.08]"
|
||||||
|
>
|
||||||
|
<div className="absolute inset-0 bg-gradient-to-br from-cyan-500/0 via-white/[0.05] to-cyan-300/20 opacity-0 transition group-hover:opacity-100" />
|
||||||
|
<div className="relative">
|
||||||
|
<Small className="text-xs uppercase tracking-[0.35em] text-cyan-200">
|
||||||
|
{item.label}
|
||||||
|
</Small>
|
||||||
|
<h3 className="mt-4 text-lg font-semibold text-white">
|
||||||
|
{item.title}
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-300">
|
||||||
|
{item.description}
|
||||||
|
</p>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -1,16 +1,40 @@
|
|||||||
import { AnimatedSection } from '../../components/AnimatedSection'
|
import { AnimatedSection } from '../../components/AnimatedSection'
|
||||||
import { StorageHero } from './StorageHero'
|
import { StorageHero } from './StorageHero'
|
||||||
|
import { StorageOverview } from './StorageOverview'
|
||||||
|
import { StorageFeatures } from './StorageFeatures'
|
||||||
|
import { StorageArchitecture } from './StorageArchitecture'
|
||||||
|
import { StorageDeveloperExperience } from './StorageDeveloperExperience'
|
||||||
|
import { StorageUseCases } from './StorageUseCases'
|
||||||
|
import { StorageDifferentiators } from './StorageDifferentiators'
|
||||||
import { CallToAction } from './CallToAction'
|
import { CallToAction } from './CallToAction'
|
||||||
|
|
||||||
export default function StoragePage() {
|
export default function StoragePage() {
|
||||||
return (
|
return (
|
||||||
<div>
|
<>
|
||||||
<AnimatedSection>
|
<AnimatedSection>
|
||||||
<StorageHero />
|
<StorageHero />
|
||||||
</AnimatedSection>
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<StorageOverview />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<StorageFeatures />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<StorageArchitecture />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<StorageDeveloperExperience />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<StorageUseCases />
|
||||||
|
</AnimatedSection>
|
||||||
|
<AnimatedSection>
|
||||||
|
<StorageDifferentiators />
|
||||||
|
</AnimatedSection>
|
||||||
<AnimatedSection>
|
<AnimatedSection>
|
||||||
<CallToAction />
|
<CallToAction />
|
||||||
</AnimatedSection>
|
</AnimatedSection>
|
||||||
</div>
|
</>
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|||||||
155
src/pages/storage/StorageUseCases.tsx
Normal file
155
src/pages/storage/StorageUseCases.tsx
Normal file
@@ -0,0 +1,155 @@
|
|||||||
|
import { Container } from '../../components/Container'
|
||||||
|
import { Eyebrow, SectionHeader, P } from '../../components/Texts'
|
||||||
|
|
||||||
|
const primaryUseCases = [
|
||||||
|
{
|
||||||
|
title: 'Data Sovereignty Applications',
|
||||||
|
bullets: [
|
||||||
|
'Privacy-first products with full control over data location.',
|
||||||
|
'Regulatory compliance for regional or industry mandates.',
|
||||||
|
'Enterprise workloads that demand audit-ready governance.',
|
||||||
|
'DigitalMe applications hosted with complete data ownership.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Multi-Protocol Applications',
|
||||||
|
bullets: [
|
||||||
|
'Support legacy S3, WebDAV, and HTTP workloads simultaneously.',
|
||||||
|
'Enable hybrid architectures that mix centralized and decentralized access.',
|
||||||
|
'Give developers freedom to choose best-fit protocols per service.',
|
||||||
|
'Simplify migrations by keeping data accessible through multiple APIs.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Backup and Recovery',
|
||||||
|
bullets: [
|
||||||
|
'Autonomous backups with continuous verification.',
|
||||||
|
'Cross-zone replication that survives regional outages.',
|
||||||
|
'Integrity monitoring that spots corruption immediately.',
|
||||||
|
'Instant recovery from failures without manual restore steps.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Content Distribution',
|
||||||
|
bullets: [
|
||||||
|
'Global CDN leveraging the breadth of the ThreeFold Grid.',
|
||||||
|
'IPFS integration for decentralized content addressing.',
|
||||||
|
'Serve the same assets over HTTP, S3, or WebDAV.',
|
||||||
|
'Geo-optimized placement keeps content close to users.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
const storageSpecificUseCases = [
|
||||||
|
{
|
||||||
|
title: 'Data Sovereignty & Compliance',
|
||||||
|
bullets: [
|
||||||
|
'Guarantee residency in specific jurisdictions.',
|
||||||
|
'Protect personal or regulated data with audit trails.',
|
||||||
|
'Empower enterprises with region-specific governance.',
|
||||||
|
'Handle cross-border rules without duplicating datasets.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Multi-Protocol Data Solutions',
|
||||||
|
bullets: [
|
||||||
|
'Bridge legacy S3 tooling with decentralized IPFS access.',
|
||||||
|
'Offer WebDAV and HTTP endpoints for collaboration suites.',
|
||||||
|
'Blend centralized and decentralized patterns as needed.',
|
||||||
|
'Let developers change protocols without rewriting storage.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Autonomous Backup & Recovery',
|
||||||
|
bullets: [
|
||||||
|
'Self-healing backups that maintain integrity automatically.',
|
||||||
|
'Zone-aware replication delivers geographic redundancy.',
|
||||||
|
'Instant recovery with continuous verification.',
|
||||||
|
'Keeps backups up-to-date without operator intervention.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'Content Distribution & CDN',
|
||||||
|
bullets: [
|
||||||
|
'Distribute media and assets across a planetary mesh.',
|
||||||
|
'Use IPFS for decentralized caching and retrieval.',
|
||||||
|
'Serve identical content across multiple access protocols.',
|
||||||
|
'Geo-optimize placement for latency-sensitive workloads.',
|
||||||
|
],
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|
||||||
|
export function StorageUseCases() {
|
||||||
|
return (
|
||||||
|
<section className="bg-white py-24 sm:py-32">
|
||||||
|
<Container>
|
||||||
|
<div className="mx-auto max-w-3xl text-center">
|
||||||
|
<Eyebrow className="tracking-[0.32em] uppercase text-cyan-500">
|
||||||
|
Use Cases
|
||||||
|
</Eyebrow>
|
||||||
|
<SectionHeader as="h2" className="mt-6 text-gray-900">
|
||||||
|
Sovereign storage for every data-intensive workload.
|
||||||
|
</SectionHeader>
|
||||||
|
<P className="mt-6 text-gray-600">
|
||||||
|
Mycelium Storage adapts to compliance-driven enterprise data,
|
||||||
|
decentralized content distribution, and everything in between.
|
||||||
|
Choose the pattern that fits your strategy without sacrificing
|
||||||
|
ownership.
|
||||||
|
</P>
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 grid gap-8 lg:grid-cols-2">
|
||||||
|
{primaryUseCases.map((useCase) => (
|
||||||
|
<div
|
||||||
|
key={useCase.title}
|
||||||
|
className="flex h-full flex-col rounded-3xl border border-slate-200 bg-white p-8 shadow-sm transition hover:-translate-y-1 hover:border-cyan-300 hover:shadow-lg"
|
||||||
|
>
|
||||||
|
<h3 className="text-xl font-semibold text-gray-900">
|
||||||
|
{useCase.title}
|
||||||
|
</h3>
|
||||||
|
<ul className="mt-6 space-y-3 text-sm text-gray-600">
|
||||||
|
{useCase.bullets.map((bullet) => (
|
||||||
|
<li
|
||||||
|
key={bullet}
|
||||||
|
className="flex items-start gap-3 rounded-2xl border border-cyan-100 bg-cyan-50/60 p-3 leading-relaxed"
|
||||||
|
>
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-500" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
<div className="mt-16 rounded-3xl border border-slate-200 bg-slate-50 p-10 shadow-sm">
|
||||||
|
<h3 className="text-2xl font-semibold text-gray-900">
|
||||||
|
Storage-Specific Scenarios
|
||||||
|
</h3>
|
||||||
|
<p className="mt-4 text-sm leading-relaxed text-gray-600">
|
||||||
|
These patterns highlight how Mycelium Storage keeps sovereignty,
|
||||||
|
protocol flexibility, and resilience at the center of data strategy.
|
||||||
|
</p>
|
||||||
|
<div className="mt-10 grid gap-8 lg:grid-cols-2">
|
||||||
|
{storageSpecificUseCases.map((useCase) => (
|
||||||
|
<div
|
||||||
|
key={useCase.title}
|
||||||
|
className="rounded-3xl border border-cyan-100 bg-white p-6 leading-relaxed text-gray-600"
|
||||||
|
>
|
||||||
|
<h4 className="text-lg font-semibold text-gray-900">
|
||||||
|
{useCase.title}
|
||||||
|
</h4>
|
||||||
|
<ul className="mt-4 space-y-3 text-sm">
|
||||||
|
{useCase.bullets.map((bullet) => (
|
||||||
|
<li key={bullet} className="flex gap-3">
|
||||||
|
<span className="mt-1 inline-block size-2 rounded-full bg-cyan-500" />
|
||||||
|
<span>{bullet}</span>
|
||||||
|
</li>
|
||||||
|
))}
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
))}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</Container>
|
||||||
|
</section>
|
||||||
|
)
|
||||||
|
}
|
||||||
@@ -5,6 +5,9 @@ import path from 'node:path'
|
|||||||
// https://vite.dev/config/
|
// https://vite.dev/config/
|
||||||
export default defineConfig({
|
export default defineConfig({
|
||||||
plugins: [react()],
|
plugins: [react()],
|
||||||
|
server: {
|
||||||
|
allowedHosts: ['stale-adults-strive.loca.lt'],
|
||||||
|
},
|
||||||
resolve: {
|
resolve: {
|
||||||
alias: {
|
alias: {
|
||||||
'@': path.resolve(__dirname, './src'),
|
'@': path.resolve(__dirname, './src'),
|
||||||
|
|||||||
Reference in New Issue
Block a user