634 lines
36 KiB
HTML
634 lines
36 KiB
HTML
<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
|
<title>LemonLink | Homelab & Services</title>
|
|
<link rel="preconnect" href="https://fonts.googleapis.com">
|
|
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
|
|
<link href="https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Space+Grotesk:wght@400;500;600;700&display=swap" rel="stylesheet">
|
|
<link rel="stylesheet" href="styles.css">
|
|
<link rel="icon" href="data:image/svg+xml,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'><text y='.9em' font-size='90'>🍋</text></svg>">
|
|
</head>
|
|
<body>
|
|
<!-- Animated Background -->
|
|
<div class="bg-animation">
|
|
<div class="bg-blob blob-1"></div>
|
|
<div class="bg-blob blob-2"></div>
|
|
<div class="bg-blob blob-3"></div>
|
|
<div class="bg-grid"></div>
|
|
</div>
|
|
|
|
<!-- Navigation -->
|
|
<nav class="navbar">
|
|
<div class="nav-container">
|
|
<a href="#" class="logo">
|
|
<span class="logo-icon">🍋</span>
|
|
<span class="logo-text">Lemon<span class="logo-highlight">Link</span></span>
|
|
</a>
|
|
<ul class="nav-links">
|
|
<li><a href="#homelab" class="nav-link">Homelab</a></li>
|
|
<li><a href="#services" class="nav-link">Services</a></li>
|
|
<li><a href="#projects" class="nav-link">Projects</a></li>
|
|
<li><a href="#network" class="nav-link">Network</a></li>
|
|
<li><a href="#contact" class="nav-link nav-cta">Get in Touch</a></li>
|
|
</ul>
|
|
<button class="mobile-menu-btn" aria-label="Toggle menu">
|
|
<span></span>
|
|
<span></span>
|
|
<span></span>
|
|
</button>
|
|
</div>
|
|
</nav>
|
|
|
|
<!-- Hero Section -->
|
|
<section class="hero">
|
|
<div class="hero-content">
|
|
<div class="hero-badge">
|
|
<span class="badge-dot"></span>
|
|
<span>Systems Online</span>
|
|
</div>
|
|
<h1 class="hero-title">
|
|
<span class="title-line">Welcome to</span>
|
|
<span class="title-line title-gradient">LemonLink</span>
|
|
</h1>
|
|
<p class="hero-subtitle">
|
|
A powerful homelab ecosystem running on enterprise-grade hardware.
|
|
Hosting 50+ services across dual Xeon servers and Raspberry Pi 5.
|
|
Built by ImpulsiveFPS with passion for self-hosting.
|
|
</p>
|
|
<div class="hero-stats">
|
|
<div class="stat-item">
|
|
<span class="stat-number" data-target="99.9">0</span>
|
|
<span class="stat-suffix">%</span>
|
|
<span class="stat-label">Uptime</span>
|
|
</div>
|
|
<div class="stat-item">
|
|
<span class="stat-number" data-target="24">0</span>
|
|
<span class="stat-suffix">/7</span>
|
|
<span class="stat-label">Monitoring</span>
|
|
</div>
|
|
<div class="stat-item">
|
|
<span class="stat-number" data-target="50">0</span>
|
|
<span class="stat-suffix">+</span>
|
|
<span class="stat-label">Containers</span>
|
|
</div>
|
|
</div>
|
|
<div class="hero-cta">
|
|
<a href="#services" class="btn btn-primary">
|
|
<span>Explore Services</span>
|
|
<svg class="btn-icon" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
|
|
<path d="M5 12h14M12 5l7 7-7 7"/>
|
|
</svg>
|
|
</a>
|
|
<a href="#homelab" class="btn btn-secondary">
|
|
<span>View Homelab</span>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
<div class="hero-visual">
|
|
<div class="server-rack">
|
|
<div class="server-unit">
|
|
<div class="server-lights">
|
|
<span class="light green"></span>
|
|
<span class="light blue"></span>
|
|
<span class="light amber"></span>
|
|
</div>
|
|
<div class="server-vents"></div>
|
|
</div>
|
|
<div class="server-unit">
|
|
<div class="server-lights">
|
|
<span class="light green"></span>
|
|
<span class="light blue"></span>
|
|
<span class="light amber"></span>
|
|
</div>
|
|
<div class="server-vents"></div>
|
|
</div>
|
|
<div class="server-unit">
|
|
<div class="server-lights">
|
|
<span class="light green"></span>
|
|
<span class="light blue"></span>
|
|
<span class="light amber"></span>
|
|
</div>
|
|
<div class="server-vents"></div>
|
|
</div>
|
|
<div class="server-unit">
|
|
<div class="server-lights">
|
|
<span class="light green"></span>
|
|
<span class="light blue"></span>
|
|
<span class="light amber"></span>
|
|
</div>
|
|
<div class="server-vents"></div>
|
|
</div>
|
|
</div>
|
|
<div class="floating-cards">
|
|
<div class="float-card card-1">
|
|
<span class="card-icon">🐳</span>
|
|
<span>Docker</span>
|
|
</div>
|
|
<div class="float-card card-2">
|
|
<span class="card-icon">☸️</span>
|
|
<span>K8s</span>
|
|
</div>
|
|
<div class="float-card card-3">
|
|
<span class="card-icon">🔒</span>
|
|
<span>Secure</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
|
|
<!-- Homelab Section -->
|
|
<section id="homelab" class="section homelab-section">
|
|
<div class="section-container">
|
|
<div class="section-header">
|
|
<span class="section-badge">🏠 Infrastructure</span>
|
|
<h2 class="section-title">The Homelab</h2>
|
|
<p class="section-desc">A powerful self-hosted ecosystem running on enterprise-grade hardware</p>
|
|
</div>
|
|
|
|
<div class="homelab-grid">
|
|
<div class="infra-card featured">
|
|
<div class="infra-visual">
|
|
<div class="rack-animation">
|
|
<div class="rack-unit active">
|
|
<div class="unit-leds">
|
|
<span></span><span></span><span></span><span></span>
|
|
</div>
|
|
</div>
|
|
<div class="rack-unit active">
|
|
<div class="unit-leds">
|
|
<span></span><span></span><span></span><span></span>
|
|
</div>
|
|
</div>
|
|
<div class="rack-unit active">
|
|
<div class="unit-leds">
|
|
<span></span><span></span><span></span><span></span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="infra-content">
|
|
<h3>Proxmox Server</h3>
|
|
<p>Dell PowerEdge with dual Xeon processors running Proxmox VE with 50+ containers and VMs</p>
|
|
<div class="infra-specs">
|
|
<span class="spec">24 Cores</span>
|
|
<span class="spec">96 GB RAM</span>
|
|
<span class="spec">2x Xeon E5645</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="infra-card">
|
|
<div class="infra-icon">🖧</div>
|
|
<div class="infra-content">
|
|
<h3>Network Stack</h3>
|
|
<p>1 Gbps fiber internet with managed switching and Tailscale mesh VPN</p>
|
|
<div class="infra-specs">
|
|
<span class="spec">1 Gbps</span>
|
|
<span class="spec">Tailscale</span>
|
|
<span class="spec">NPM</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="infra-card">
|
|
<div class="infra-icon">💾</div>
|
|
<div class="infra-content">
|
|
<h3>Storage Array</h3>
|
|
<p>TrueNAS SCALE with 12TB raw storage for media, backups, and datasets</p>
|
|
<div class="infra-specs">
|
|
<span class="spec">12 TB Raw</span>
|
|
<span class="spec">9 TB Usable</span>
|
|
<span class="spec">SCALE</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="infra-card">
|
|
<div class="infra-icon">🍓</div>
|
|
<div class="infra-content">
|
|
<h3>RPi 5 Node</h3>
|
|
<p>Raspberry Pi 5 running Docker containers and Portainer for edge workloads</p>
|
|
<div class="infra-specs">
|
|
<span class="spec">ARM64</span>
|
|
<span class="spec">Docker</span>
|
|
<span class="spec">Portainer</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="tech-stack">
|
|
<h3 class="stack-title">Powered By</h3>
|
|
<div class="stack-marquee">
|
|
<div class="stack-track">
|
|
<span class="tech-item">Proxmox</span>
|
|
<span class="tech-item">Docker</span>
|
|
<span class="tech-item">Kubernetes</span>
|
|
<span class="tech-item">TrueNAS</span>
|
|
<span class="tech-item">UniFi</span>
|
|
<span class="tech-item">Nginx</span>
|
|
<span class="tech-item">Traefik</span>
|
|
<span class="tech-item">Prometheus</span>
|
|
<span class="tech-item">Grafana</span>
|
|
<span class="tech-item">Portainer</span>
|
|
<span class="tech-item">Proxmox</span>
|
|
<span class="tech-item">Docker</span>
|
|
<span class="tech-item">Kubernetes</span>
|
|
<span class="tech-item">TrueNAS</span>
|
|
<span class="tech-item">UniFi</span>
|
|
<span class="tech-item">Nginx</span>
|
|
<span class="tech-item">Traefik</span>
|
|
<span class="tech-item">Prometheus</span>
|
|
<span class="tech-item">Grafana</span>
|
|
<span class="tech-item">Portainer</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
|
|
<!-- Services Section -->
|
|
<section id="services" class="section services-section">
|
|
<div class="section-container">
|
|
<div class="section-header">
|
|
<span class="section-badge">⚡ Available Now</span>
|
|
<h2 class="section-title">Services</h2>
|
|
<p class="section-desc">Self-hosted applications and services available on the network</p>
|
|
</div>
|
|
|
|
<div class="services-grid">
|
|
<a href="https://cloud.lemonlink.eu" class="service-card" target="_blank" rel="noopener">
|
|
<div class="service-glow"></div>
|
|
<div class="service-icon" style="--icon-color: #0082c9;">
|
|
<svg viewBox="0 0 24 24" fill="currentColor"><path d="M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-1 17.93c-3.95-.49-7-3.85-7-7.93 0-.62.08-1.21.21-1.79L9 15v1c0 1.1.9 2 2 2v1.93zm6.9-2.54c-.26-.81-1-1.39-1.9-1.39h-1v-3c0-.55-.45-1-1-1H8v-2h2c.55 0 1-.45 1-1V7h2c1.1 0 2-.9 2-2v-.41c2.93 1.19 5 4.06 5 7.41 0 2.08-.8 3.97-2.1 5.39z"/></svg>
|
|
</div>
|
|
<h3 class="service-name">Nextcloud</h3>
|
|
<p class="service-desc">Private cloud storage, files, and collaboration</p>
|
|
<div class="service-status online">
|
|
<span class="status-dot"></span>
|
|
<span>Online</span>
|
|
</div>
|
|
<div class="service-arrow">
|
|
<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
|
|
<path d="M7 17L17 7M17 7H7M17 7V17"/>
|
|
</svg>
|
|
</div>
|
|
</a>
|
|
|
|
<a href="https://git.lemonlink.eu" class="service-card" target="_blank" rel="noopener">
|
|
<div class="service-glow"></div>
|
|
<div class="service-icon" style="--icon-color: #609926;">
|
|
<svg viewBox="0 0 24 24" fill="currentColor"><path d="M12 2C6.477 2 2 6.477 2 12c0 4.42 2.865 8.166 6.839 9.489.5.092.682-.217.682-.482 0-.237-.008-.866-.013-1.7-2.782.603-3.369-1.341-3.369-1.341-.454-1.155-1.11-1.463-1.11-1.463-.908-.62.069-.608.069-.608 1.003.07 1.531 1.03 1.531 1.03.892 1.529 2.341 1.087 2.91.831.092-.646.35-1.086.636-1.336-2.22-.253-4.555-1.11-4.555-4.943 0-1.091.39-1.984 1.029-2.683-.103-.253-.446-1.27.098-2.647 0 0 .84-.269 2.75 1.025A9.578 9.578 0 0112 6.836c.85.004 1.705.114 2.504.336 1.909-1.294 2.747-1.025 2.747-1.025.546 1.377.203 2.394.1 2.647.64.699 1.028 1.592 1.028 2.683 0 3.842-2.339 4.687-4.566 4.935.359.309.678.919.678 1.852 0 1.336-.012 2.415-.012 2.743 0 .267.18.578.688.48C19.138 20.163 22 16.418 22 12c0-5.523-4.477-10-10-10z"/></svg>
|
|
</div>
|
|
<h3 class="service-name">Gitea</h3>
|
|
<p class="service-desc">Self-hosted Git service for code repositories</p>
|
|
<div class="service-status online">
|
|
<span class="status-dot"></span>
|
|
<span>Online</span>
|
|
</div>
|
|
<div class="service-arrow">
|
|
<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
|
|
<path d="M7 17L17 7M17 7H7M17 7V17"/>
|
|
</svg>
|
|
</div>
|
|
</a>
|
|
|
|
<a href="https://stats.lemonlink.eu" class="service-card" target="_blank" rel="noopener">
|
|
<div class="service-glow"></div>
|
|
<div class="service-icon" style="--icon-color: #00ab44;">
|
|
<svg viewBox="0 0 24 24" fill="currentColor"><path d="M3 3v18h18v-2H5V3H3zm11 12.5l-4-4-5 5L4 16l5-5 4 4 6.5-6.5 1.5 1.5-8 8z"/></svg>
|
|
</div>
|
|
<h3 class="service-name">Netdata</h3>
|
|
<p class="service-desc">Real-time system monitoring and metrics</p>
|
|
<div class="service-status online">
|
|
<span class="status-dot"></span>
|
|
<span>Online</span>
|
|
</div>
|
|
<div class="service-arrow">
|
|
<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
|
|
<path d="M7 17L17 7M17 7H7M17 7V17"/>
|
|
</svg>
|
|
</div>
|
|
</a>
|
|
|
|
<a href="https://photos.lemonlink.eu" class="service-card" target="_blank" rel="noopener">
|
|
<div class="service-glow"></div>
|
|
<div class="service-icon" style="--icon-color: #ad5c5c;">
|
|
<svg viewBox="0 0 24 24" fill="currentColor"><path d="M21 19V5c0-1.1-.9-2-2-2H5c-1.1 0-2 .9-2 2v14c0 1.1.9 2 2 2h14c1.1 0 2-.9 2-2zM8.5 13.5l2.5 3.01L14.5 12l4.5 6H5l3.5-4.5z"/></svg>
|
|
</div>
|
|
<h3 class="service-name">Immich</h3>
|
|
<p class="service-desc">Self-hosted photo and video backup solution</p>
|
|
<div class="service-status online">
|
|
<span class="status-dot"></span>
|
|
<span>Online</span>
|
|
</div>
|
|
<div class="service-arrow">
|
|
<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
|
|
<path d="M7 17L17 7M17 7H7M17 7V17"/>
|
|
</svg>
|
|
</div>
|
|
</a>
|
|
|
|
<a href="https://dash.lemonlink.eu" class="service-card" target="_blank" rel="noopener">
|
|
<div class="service-glow"></div>
|
|
<div class="service-icon" style="--icon-color: #ff5c5c;">
|
|
<svg viewBox="0 0 24 24" fill="currentColor"><path d="M3 13h8V3H3v10zm0 8h8v-6H3v6zm10 0h8V11h-8v10zm0-18v6h8V3h-8z"/></svg>
|
|
</div>
|
|
<h3 class="service-name">Homarr</h3>
|
|
<p class="service-desc">Customizable dashboard for all your services</p>
|
|
<div class="service-status online">
|
|
<span class="status-dot"></span>
|
|
<span>Online</span>
|
|
</div>
|
|
<div class="service-arrow">
|
|
<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
|
|
<path d="M7 17L17 7M17 7H7M17 7V17"/>
|
|
</svg>
|
|
</div>
|
|
</a>
|
|
|
|
<a href="https://vpn.lemonlink.eu" class="service-card" target="_blank" rel="noopener">
|
|
<div class="service-glow"></div>
|
|
<div class="service-icon" style="--icon-color: #7b68ee;">
|
|
<svg viewBox="0 0 24 24" fill="currentColor"><path d="M12 1L3 5v6c0 5.55 3.84 10.74 9 12 5.16-1.26 9-6.45 9-12V5l-9-4zm0 10.99h7c-.53 4.12-3.28 7.79-7 8.94V12H5V6.3l7-3.11v8.8z"/></svg>
|
|
</div>
|
|
<h3 class="service-name">Tailscale</h3>
|
|
<p class="service-desc">Zero-config VPN for secure remote access</p>
|
|
<div class="service-status online">
|
|
<span class="status-dot"></span>
|
|
<span>Online</span>
|
|
</div>
|
|
<div class="service-arrow">
|
|
<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
|
|
<path d="M7 17L17 7M17 7H7M17 7V17"/>
|
|
</svg>
|
|
</div>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
|
|
<!-- Projects Section -->
|
|
<section id="projects" class="section projects-section">
|
|
<div class="section-container">
|
|
<div class="section-header">
|
|
<span class="section-badge">🚀 Creations</span>
|
|
<h2 class="section-title">Projects</h2>
|
|
<p class="section-desc">Things I've built and contributed to</p>
|
|
</div>
|
|
|
|
<div class="projects-showcase">
|
|
<div class="project-card large">
|
|
<div class="project-image">
|
|
<div class="project-visual">
|
|
<div class="code-window">
|
|
<div class="window-header">
|
|
<span class="win-btn red"></span>
|
|
<span class="win-btn yellow"></span>
|
|
<span class="win-btn green"></span>
|
|
</div>
|
|
<div class="window-content">
|
|
<div class="code-line"><span class="code-keyword">const</span> <span class="code-var">project</span> = {</div>
|
|
<div class="code-line"> name: <span class="code-string">"Awesome App"</span>,</div>
|
|
<div class="code-line"> status: <span class="code-string">"Production"</span>,</div>
|
|
<div class="code-line"> stars: <span class="code-number">1337</span></div>
|
|
<div class="code-line">};</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="project-info">
|
|
<div class="project-tags">
|
|
<span class="tag">React</span>
|
|
<span class="tag">TypeScript</span>
|
|
<span class="tag">Node.js</span>
|
|
</div>
|
|
<h3 class="project-name">LemonLink Infrastructure</h3>
|
|
<p class="project-desc">A comprehensive homelab setup running 50+ Docker containers across dual Xeon servers and Raspberry Pi 5. Features automated deployments, monitoring, and a complete self-hosted ecosystem.</p>
|
|
<div class="project-links">
|
|
<a href="https://git.lemonlink.eu/impulsivefps" class="project-link" target="_blank">
|
|
<svg viewBox="0 0 24 24" fill="currentColor"><path d="M12 0c-6.626 0-12 5.373-12 12 0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23.957-.266 1.983-.399 3.003-.404 1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576 4.765-1.589 8.199-6.086 8.199-11.386 0-6.627-5.373-12-12-12z"/></svg>
|
|
<span>View on Gitea</span>
|
|
</a>
|
|
<a href="https://dash.lemonlink.eu" class="project-link" target="_blank">
|
|
<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
|
|
<path d="M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6M15 3h6v6M10 14L21 3"/>
|
|
</svg>
|
|
<span>Dashboard</span>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="projects-small">
|
|
<div class="project-card small">
|
|
<div class="project-tags">
|
|
<span class="tag">Docker</span>
|
|
<span class="tag">Proxmox</span>
|
|
</div>
|
|
<h3 class="project-name">Container Platform</h3>
|
|
<p class="project-desc">50+ containers managed via Portainer on Proxmox and RPi5</p>
|
|
<a href="https://git.lemonlink.eu/impulsivefps" class="project-link" target="_blank">
|
|
<svg viewBox="0 0 24 24" fill="currentColor"><path d="M12 0c-6.626 0-12 5.373-12 12 0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23.957-.266 1.983-.399 3.003-.404 1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576 4.765-1.589 8.199-6.086 8.199-11.386 0-6.627-5.373-12-12-12z"/></svg>
|
|
</a>
|
|
</div>
|
|
|
|
<div class="project-card small">
|
|
<div class="project-tags">
|
|
<span class="tag">NAS</span>
|
|
<span class="tag">ZFS</span>
|
|
</div>
|
|
<h3 class="project-name">TrueNAS SCALE</h3>
|
|
<p class="project-desc">12TB storage array with 9TB usable for media and backups</p>
|
|
<a href="https://git.lemonlink.eu/impulsivefps" class="project-link" target="_blank">
|
|
<svg viewBox="0 0 24 24" fill="currentColor"><path d="M12 0c-6.626 0-12 5.373-12 12 0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23.957-.266 1.983-.399 3.003-.404 1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576 4.765-1.589 8.199-6.086 8.199-11.386 0-6.627-5.373-12-12-12z"/></svg>
|
|
</a>
|
|
</div>
|
|
|
|
<div class="project-card small">
|
|
<div class="project-tags">
|
|
<span class="tag">VPN</span>
|
|
<span class="tag">Mesh</span>
|
|
</div>
|
|
<h3 class="project-name">Tailscale Network</h3>
|
|
<p class="project-desc">Zero-config mesh VPN connecting all nodes securely</p>
|
|
<a href="https://git.lemonlink.eu/impulsivefps" class="project-link" target="_blank">
|
|
<svg viewBox="0 0 24 24" fill="currentColor"><path d="M12 0c-6.626 0-12 5.373-12 12 0 5.302 3.438 9.8 8.207 11.387.599.111.793-.261.793-.577v-2.234c-3.338.726-4.033-1.416-4.033-1.416-.546-1.387-1.333-1.756-1.333-1.756-1.089-.745.083-.729.083-.729 1.205.084 1.839 1.237 1.839 1.237 1.07 1.834 2.807 1.304 3.492.997.107-.775.418-1.305.762-1.604-2.665-.305-5.467-1.334-5.467-5.931 0-1.311.469-2.381 1.236-3.221-.124-.303-.535-1.524.117-3.176 0 0 1.008-.322 3.301 1.23.957-.266 1.983-.399 3.003-.404 1.02.005 2.047.138 3.006.404 2.291-1.552 3.297-1.23 3.297-1.23.653 1.653.242 2.874.118 3.176.77.84 1.235 1.911 1.235 3.221 0 4.609-2.807 5.624-5.479 5.921.43.372.823 1.102.823 2.222v3.293c0 .319.192.694.801.576 4.765-1.589 8.199-6.086 8.199-11.386 0-6.627-5.373-12-12-12z"/></svg>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
|
|
<!-- Network Section -->
|
|
<section id="network" class="section network-section">
|
|
<div class="section-container">
|
|
<div class="section-header">
|
|
<span class="section-badge">🌐 Sub-Domains</span>
|
|
<h2 class="section-title">Network</h2>
|
|
<p class="section-desc">Explore the LemonLink ecosystem</p>
|
|
</div>
|
|
|
|
<div class="network-map">
|
|
<div class="domain-hub">
|
|
<div class="hub-center">
|
|
<span class="hub-icon">🍋</span>
|
|
<span class="hub-text">lemonlink.eu</span>
|
|
</div>
|
|
<div class="hub-connections">
|
|
<svg class="connections-svg" viewBox="0 0 800 400" preserveAspectRatio="xMidYMid meet">
|
|
<defs>
|
|
<linearGradient id="line-gradient" x1="0%" y1="0%" x2="100%" y2="0%">
|
|
<stop offset="0%" style="stop-color:rgba(234,179,8,0.2)"/>
|
|
<stop offset="50%" style="stop-color:rgba(234,179,8,0.8)"/>
|
|
<stop offset="100%" style="stop-color:rgba(234,179,8,0.2)"/>
|
|
</linearGradient>
|
|
</defs>
|
|
</svg>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="domains-grid">
|
|
<a href="https://cloud.lemonlink.eu" class="domain-node" target="_blank">
|
|
<div class="node-pulse"></div>
|
|
<span class="node-name">cloud</span>
|
|
<span class="node-desc">Nextcloud Storage</span>
|
|
</a>
|
|
<a href="https://git.lemonlink.eu" class="domain-node" target="_blank">
|
|
<div class="node-pulse"></div>
|
|
<span class="node-name">git</span>
|
|
<span class="node-desc">Gitea Repositories</span>
|
|
</a>
|
|
<a href="https://stats.lemonlink.eu" class="domain-node" target="_blank">
|
|
<div class="node-pulse"></div>
|
|
<span class="node-name">stats</span>
|
|
<span class="node-desc">Netdata Monitoring</span>
|
|
</a>
|
|
<a href="https://photos.lemonlink.eu" class="domain-node" target="_blank">
|
|
<div class="node-pulse"></div>
|
|
<span class="node-name">photos</span>
|
|
<span class="node-desc">Immich Gallery</span>
|
|
</a>
|
|
<a href="https://dash.lemonlink.eu" class="domain-node" target="_blank">
|
|
<div class="node-pulse"></div>
|
|
<span class="node-name">dash</span>
|
|
<span class="node-desc">Homarr Dashboard</span>
|
|
</a>
|
|
<a href="https://vpn.lemonlink.eu" class="domain-node" target="_blank">
|
|
<div class="node-pulse"></div>
|
|
<span class="node-name">vpn</span>
|
|
<span class="node-desc">Tailscale Access</span>
|
|
</a>
|
|
<a href="https://lemonlink.eu" class="domain-node" target="_blank">
|
|
<div class="node-pulse"></div>
|
|
<span class="node-name">www</span>
|
|
<span class="node-desc">This Website</span>
|
|
</a>
|
|
<a href="https://git.lemonlink.eu/impulsivefps" class="domain-node" target="_blank">
|
|
<div class="node-pulse"></div>
|
|
<span class="node-name">projects</span>
|
|
<span class="node-desc">My Code</span>
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
|
|
<!-- Contact Section -->
|
|
<section id="contact" class="section contact-section">
|
|
<div class="section-container">
|
|
<div class="contact-card">
|
|
<div class="contact-content">
|
|
<span class="section-badge">👋 Let's Connect</span>
|
|
<h2 class="contact-title">ImpulsiveFPS</h2>
|
|
<p class="contact-desc">Homelab enthusiast running 50+ services on dual Xeon hardware. Passionate about self-hosting, networking, and building reliable infrastructure. This site showcases my journey into the world of self-hosted solutions.</p>
|
|
<div class="contact-actions">
|
|
<a href="https://git.lemonlink.eu/impulsivefps" class="btn btn-primary btn-large" target="_blank">
|
|
<svg viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2">
|
|
<path d="M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z"/>
|
|
<polyline points="22,6 12,13 2,6"/>
|
|
</svg>
|
|
<span>View My Gitea</span>
|
|
</a>
|
|
</div>
|
|
<div class="social-links" style="display: none;">
|
|
<!-- Social links hidden until set up -->
|
|
</div>
|
|
</div>
|
|
<div class="contact-visual">
|
|
<div class="terminal">
|
|
<div class="terminal-header">
|
|
<span class="terminal-dot red"></span>
|
|
<span class="terminal-dot yellow"></span>
|
|
<span class="terminal-dot green"></span>
|
|
</div>
|
|
<div class="terminal-body">
|
|
<div class="terminal-line">
|
|
<span class="prompt">➜</span>
|
|
<span class="path">~</span>
|
|
<span class="command">whoami</span>
|
|
</div>
|
|
<div class="terminal-output">lemon_admin</div>
|
|
<div class="terminal-line">
|
|
<span class="prompt">➜</span>
|
|
<span class="path">~</span>
|
|
<span class="command">uptime</span>
|
|
</div>
|
|
<div class="terminal-output">99.9% availability</div>
|
|
<div class="terminal-line">
|
|
<span class="prompt">➜</span>
|
|
<span class="path">~</span>
|
|
<span class="cursor">|</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
|
|
<!-- Footer -->
|
|
<footer class="footer">
|
|
<div class="footer-container">
|
|
<div class="footer-brand">
|
|
<a href="#" class="logo">
|
|
<span class="logo-icon">🍋</span>
|
|
<span class="logo-text">Lemon<span class="logo-highlight">Link</span></span>
|
|
</a>
|
|
<p class="footer-tagline">Built by ImpulsiveFPS with 💛 and lots of ☕</p>
|
|
</div>
|
|
<div class="footer-links">
|
|
<div class="footer-col">
|
|
<h4>Navigation</h4>
|
|
<a href="#homelab">Homelab</a>
|
|
<a href="#services">Services</a>
|
|
<a href="#projects">Projects</a>
|
|
<a href="#network">Network</a>
|
|
</div>
|
|
<div class="footer-col">
|
|
<h4>Services</h4>
|
|
<a href="https://cloud.lemonlink.eu" target="_blank">Nextcloud</a>
|
|
<a href="https://media.lemonlink.eu" target="_blank">Jellyfin</a>
|
|
<a href="https://git.lemonlink.eu" target="_blank">GitLab</a>
|
|
<a href="https://monitor.lemonlink.eu" target="_blank">Monitoring</a>
|
|
</div>
|
|
<div class="footer-col">
|
|
<h4>Connect</h4>
|
|
<a href="https://git.lemonlink.eu/impulsivefps">Gitea</a>
|
|
<a href="https://dash.lemonlink.eu">Dashboard</a>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="footer-bottom">
|
|
<p>© 2024 LemonLink. All rights reserved.</p>
|
|
<p class="footer-made">Powered by 2x Xeon E5645 | 96GB RAM | TrueNAS SCALE</p>
|
|
</div>
|
|
</footer>
|
|
|
|
<script src="script.js"></script>
|
|
</body>
|
|
</html>
|