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>
195 lines
4.3 KiB
Vue
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>
|