This repository has been archived on 2026-04-03. You can view files and clone it, but cannot push or open issues or pull requests.
nyx/tenants/loop42/pages/HomePage.vue
Nico 42c6079755 Multi-tenant build system with K8s namespace separation
Build-time tenant config via VITE_TENANT env var (--mode loop42/dev).
Content pages moved to tenants/{name}/pages/ with dynamic imports and
loop42 fallback. Feature-gated routing (viewer/devTools per tenant).
Dockerfile parameterized with TENANT build arg. Deployed to separate
K8s namespaces: loop42.de → ns/loop42, loop42.dev → ns/dev.

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-04-01 17:09:22 +02:00

195 lines
4.3 KiB
Vue

<template>
<div class="company-page">
<div class="hero">
<h1>Wir bauen<br>agentische <em>Produkte</em>.</h1>
<p>Eigene Plattform. Eigene Infrastruktur. Eigene Regeln.</p>
</div>
<section id="plattform">
<div class="section-label">Plattform</div>
<h2>Was dahintersteht.</h2>
<div class="cards">
<div class="card">
<h3>Das Wesentliche</h3>
<p>Jedes Produkt kennt seinen Bereich und bleibt darin. Tiefe schlägt Breite verlässlich, jeden Tag. Keine Extras, die niemand braucht.</p>
</div>
<div class="card">
<h3>Produkte für Teams</h3>
<p>Ein Produkt für das ganze Team. Alle arbeiten mit demselben Zugang in eigenen Sitzungen, mit voller Kontrolle darüber, wer was sieht.</p>
</div>
<div class="card">
<h3>Sicher & konform</h3>
<p>Alle Daten liegen in Deutschland. Mandantentrennung auf Containerebene, DSGVO-konforme Verarbeitung, Auftragsverarbeitung inklusive.</p>
</div>
</div>
</section>
<section id="produkte">
<div class="section-label">Produkte</div>
<h2>Woran wir gerade bauen.</h2>
<div class="cards">
<div class="card">
<h3>Frühkindliche Bildung</h3>
<p>Fachkräfte sagen, was sie brauchen unser Produkt baut daraus fertige Bildungsangebote. Passend zur Einrichtung, zur Altersgruppe, zum Alltag.</p>
</div>
<div class="card">
<h3>Erwachsenen-Grundbildung</h3>
<p>Lehrkräfte an Bildungseinrichtungen bekommen Unterstützung bei der Erstellung von Lernangeboten strukturiert, lehrplannah, sofort einsetzbar.</p>
</div>
</div>
</section>
<div class="cta">
<h2>nyx</h2>
<p>Produkte kennenlernen, ausprobieren, Zugang einrichten direkt hier, direkt mit nyx.</p>
<router-link to="/nyx" class="btn">nyx öffnen</router-link>
</div>
<footer>
<span>© 2026 loop42 GmbH</span>
</footer>
</div>
</template>
<style scoped>
.company-page {
color: var(--text);
}
.hero {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
text-align: center;
padding: 6rem 2rem 4rem;
min-height: 60vh;
}
.hero h1 {
font-size: clamp(2rem, 5vw, 3.5rem);
font-weight: 300;
letter-spacing: 0.05em;
margin: 0 0 1.5rem;
line-height: 1.15;
}
.hero h1 em {
font-style: normal;
color: var(--accent);
}
.hero p {
font-size: 1.1rem;
color: var(--text-dim);
max-width: 480px;
margin: 0 auto 2.5rem;
}
.divider {
border: none;
border-top: 1px solid var(--border, #1e1e1e);
margin: 0;
}
section {
padding: 4rem 2rem;
max-width: 860px;
margin: 0 auto;
}
.section-label {
font-size: 0.75rem;
letter-spacing: 0.15em;
text-transform: uppercase;
color: var(--accent);
margin-bottom: 1rem;
}
section h2 {
font-size: clamp(1.5rem, 3vw, 2.2rem);
font-weight: 300;
margin: 0 0 1rem;
}
.cards {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
gap: 1.5rem;
margin-top: 2rem;
}
.card {
background: var(--panel-bg);
border: 1px solid var(--border, #1e1e1e);
border-radius: 10px;
padding: 1.5rem;
}
.card h3 {
font-size: 1rem;
font-weight: 500;
margin: 0 0 0.75rem;
}
.card p {
font-size: 0.9rem;
color: var(--text-dim);
margin: 0;
line-height: 1.6;
}
.cta {
text-align: center;
padding: 4rem 2rem;
background: color-mix(in srgb, var(--accent) 12%, transparent);
border-top: 1px solid var(--border, #1e1e1e);
border-bottom: 1px solid var(--border, #1e1e1e);
}
.cta h2 {
font-size: clamp(1.5rem, 3vw, 2rem);
font-weight: 300;
margin: 0 0 1rem;
}
.cta p {
color: var(--text-dim);
margin: 0 auto 2rem;
max-width: 480px;
}
.btn {
display: inline-block;
padding: 0.75rem 2rem;
background: var(--accent);
color: #fff;
border-radius: 6px;
font-size: 0.9rem;
letter-spacing: 0.05em;
transition: opacity 0.2s;
text-decoration: none;
}
.btn:hover { opacity: 0.85; }
footer {
text-align: center;
padding: 2rem;
font-size: 0.8rem;
color: var(--text-dim);
border-top: 1px solid var(--border, #1e1e1e);
display: flex;
flex-direction: column;
gap: 0.75rem;
}
@media (max-width: 600px) {
section { padding: 3rem 1.25rem; }
.hero { padding: 4rem 1.25rem 3rem; }
.cta { padding: 3rem 1.25rem; }
}
</style>