Files
breakpilot-core/pitch-deck/components/slides/GTMSlide.tsx
Benjamin Admin dd6e2f8bd7
All checks were successful
Build pitch-deck / build-push-deploy (push) Successful in 1m11s
CI / go-lint (push) Has been skipped
CI / python-lint (push) Has been skipped
CI / nodejs-lint (push) Has been skipped
CI / test-go-consent (push) Successful in 37s
CI / test-python-voice (push) Successful in 36s
CI / test-bqas (push) Successful in 36s
feat(pitch-deck): MOAT on USP slide + version-aware GTM slide
USP Slide:
- Added 3 MOAT statements as prominent section:
  1. End-to-End Traceability (Law → Obligation → Control → Code)
  2. Continuous Compliance Engine (every change, real-time evidence)
  3. EU-Trust & Governance Stack (sovereign, GDPR/AI Act native)

GTM Slide (version-aware):
- Wandeldarlehen: Founder sales → Content/SEO → Organic growth
  3 phases (Pilot → Organic → Scaling), no AEs in 2027
- 1 Mio: Direct sales + Channel (unchanged)
  3 phases with 5-20 KMU target, 2 AEs from 2027

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-19 17:06:14 +02:00

189 lines
9.0 KiB
TypeScript

'use client'
import { Language } from '@/lib/types'
import { t } from '@/lib/i18n'
import GradientText from '../ui/GradientText'
import FadeInView from '../ui/FadeInView'
import GlassCard from '../ui/GlassCard'
import { Target, Users, Handshake, Megaphone, Building2, GraduationCap } from 'lucide-react'
interface GTMSlideProps {
lang: Language
isWandeldarlehen?: boolean
}
export default function GTMSlide({ lang, isWandeldarlehen }: GTMSlideProps) {
const i = t(lang)
const de = lang === 'de'
const phasesLean = [
{
phase: de ? 'Phase 1: Gründung & Pilot (2026)' : 'Phase 1: Founding & Pilot (2026)',
color: 'border-indigo-500/30 bg-indigo-500/5',
textColor: 'text-indigo-400',
items: [
de ? 'Gründer verkaufen selbst — persönliches Netzwerk' : 'Founders sell themselves — personal network',
de ? 'Fokus: 3-5 Pilotkunden im Maschinenbau' : 'Focus: 3-5 pilot customers in manufacturing',
de ? 'Beratungsumsätze (5k/Mon) finanzieren Anlaufphase' : 'Consulting revenue (5k/month) finances ramp-up',
de ? 'Case Studies und erste Referenzen aufbauen' : 'Build case studies and first references',
],
},
{
phase: de ? 'Phase 2: Organisches Wachstum (2027-2028)' : 'Phase 2: Organic Growth (2027-2028)',
color: 'border-purple-500/30 bg-purple-500/5',
textColor: 'text-purple-400',
items: [
de ? 'Content Marketing: Compliance-Webinare, SEO' : 'Content marketing: Compliance webinars, SEO',
de ? 'Beratung steigt auf 10-20k/Mon (Cashflow)' : 'Consulting grows to 10-20k/month (cashflow)',
de ? 'Erste Vertriebsperson ab September 2028' : 'First salesperson from September 2028',
de ? 'Ziel: 10-20 Bestandskunden organisch' : 'Target: 10-20 active customers organically',
],
},
{
phase: de ? 'Phase 3: Skalierung (2029+)' : 'Phase 3: Scaling (2029+)',
color: 'border-emerald-500/30 bg-emerald-500/5',
textColor: 'text-emerald-400',
items: [
de ? 'Channel-Ansatz mit Bechtle/CANCOM ab Revenue' : 'Channel approach with Bechtle/CANCOM from revenue',
de ? 'Marketing-Person und Customer Success' : 'Marketing hire and customer success',
de ? '50-200+ Kunden, Break-Even erreicht' : '50-200+ customers, break-even reached',
de ? 'Profitables Wachstum ohne weitere Finanzierungsrunde' : 'Profitable growth without further funding round',
],
},
]
const phases1M = [
{
phase: de ? 'Phase 1: Pilot (2026)' : 'Phase 1: Pilot (2026)',
color: 'border-indigo-500/30 bg-indigo-500/5',
textColor: 'text-indigo-400',
items: [
de ? 'Direktvertrieb an 5-20 KMU in DACH' : 'Direct sales to 5-20 SMEs in DACH',
de ? 'Fokus: Maschinen- & Anlagenbau, Automobilindustrie, Elektro- & Digitalindustrie' : 'Focus: Machinery & Plant Eng., Automotive, Electrical & Digital Industry',
de ? 'Persönliches Onboarding, White-Glove-Service' : 'Personal onboarding, white-glove service',
de ? 'Case Studies und Referenzkunden aufbauen' : 'Build case studies and reference customers',
],
},
{
phase: de ? 'Phase 2: Skalierung (2027)' : 'Phase 2: Scale (2027)',
color: 'border-purple-500/30 bg-purple-500/5',
textColor: 'text-purple-400',
items: [
de ? 'Channel-Partnerschaften mit IT-Systemhäusern' : 'Channel partnerships with IT system integrators',
de ? 'IHK- und Handwerkskammer-Kooperationen' : 'Chamber of Commerce & Industry partnerships',
de ? 'Content Marketing: Compliance-Webinare, Whitepaper' : 'Content marketing: Compliance webinars, whitepapers',
de ? 'Zielkunden: 50-200 in regulierten Branchen' : 'Target: 50-200 customers in regulated industries',
],
},
{
phase: de ? 'Phase 3: Expansion (2028+)' : 'Phase 3: Expansion (2028+)',
color: 'border-emerald-500/30 bg-emerald-500/5',
textColor: 'text-emerald-400',
items: [
de ? 'Cloud-Tier für größere Unternehmen (50-500 MA)' : 'Cloud tier for larger companies (50-500 employees)',
de ? 'EU-Expansion: Österreich, Schweiz, Benelux, Nordics' : 'EU expansion: Austria, Switzerland, Benelux, Nordics',
de ? 'OEM/Whitelabel für Steuerberater und Wirtschaftsprüfer' : 'OEM/whitelabel for tax advisors and auditors',
de ? 'Self-Service-Onboarding und PLG-Motion' : 'Self-service onboarding and PLG motion',
],
},
]
const phases = isWandeldarlehen ? phasesLean : phases1M
const channelsLean = [
{ icon: Target, label: de ? 'Gründer-Vertrieb' : 'Founder Sales', pct: '60%', desc: de ? 'Persönliches Netzwerk + Beratung' : 'Personal network + consulting' },
{ icon: Megaphone, label: de ? 'Content & SEO' : 'Content & SEO', pct: '25%', desc: de ? 'Webinare, Whitepaper, Fachbeiträge' : 'Webinars, whitepapers, articles' },
{ icon: Users, label: de ? 'Empfehlungen' : 'Referrals', pct: '15%', desc: de ? 'Zufriedene Pilotkunden' : 'Satisfied pilot customers' },
]
const channels1M = [
{ icon: Target, label: de ? 'Direktvertrieb' : 'Direct Sales', pct: '40%', desc: de ? 'Outbound + Inbound, 2 AEs ab 2027' : 'Outbound + Inbound, 2 AEs from 2027' },
{ icon: Handshake, label: de ? 'Channel-Partner' : 'Channel Partners', pct: '30%', desc: de ? 'IT-Händler, Systemhäuser, MSPs' : 'IT resellers, system integrators, MSPs' },
{ icon: Megaphone, label: de ? 'Content & Events' : 'Content & Events', pct: '20%', desc: de ? 'Webinare, Messen (it-sa), SEO' : 'Webinars, trade shows (it-sa), SEO' },
{ icon: Users, label: de ? 'Empfehlungen' : 'Referrals', pct: '10%', desc: de ? 'Bestandskunden-Empfehlungsprogramm' : 'Customer referral program' },
]
const channels = isWandeldarlehen ? channelsLean : channels1M
const idealCustomer = [
{ icon: Building2, label: de ? '10-250 Mitarbeiter' : '10-250 Employees' },
{ icon: GraduationCap, label: de ? 'Produzierende Industrie (Maschinenbau, Automotive, Elektro, Chemie)' : 'Manufacturing Industry (Machinery, Automotive, Electrical, Chemicals)' },
{ icon: Target, label: de ? 'Kein interner Compliance-Officer oder DSB' : 'No Internal Compliance Officer or DPO' },
]
return (
<div>
<FadeInView className="text-center mb-8">
<p className="text-xs font-mono text-indigo-400/60 uppercase tracking-widest mb-2">
{de ? 'Anhang' : 'Appendix'}
</p>
<h2 className="text-4xl md:text-5xl font-bold mb-3">
<GradientText>{i.annex.gtm.title}</GradientText>
</h2>
<p className="text-lg text-white/50 max-w-2xl mx-auto">{i.annex.gtm.subtitle}</p>
</FadeInView>
{/* ICP */}
<FadeInView delay={0.15}>
<GlassCard hover={false} className="p-4 mb-6">
<p className="text-xs font-semibold text-white/40 uppercase tracking-wider mb-3">
{de ? 'Ideales Kundenprofil (ICP)' : 'Ideal Customer Profile (ICP)'}
</p>
<div className="flex flex-wrap gap-4">
{idealCustomer.map((ic, idx) => {
const Icon = ic.icon
return (
<div key={idx} className="flex items-center gap-2">
<Icon className="w-4 h-4 text-indigo-400" />
<span className="text-sm text-white/70">{ic.label}</span>
</div>
)
})}
</div>
</GlassCard>
</FadeInView>
{/* Phases */}
<div className="grid md:grid-cols-3 gap-4 mb-6">
{phases.map((phase, idx) => (
<FadeInView key={idx} delay={0.2 + idx * 0.1}>
<div className={`border rounded-xl p-4 h-full ${phase.color}`}>
<p className={`text-sm font-bold ${phase.textColor} mb-3`}>{phase.phase}</p>
<ul className="space-y-2">
{phase.items.map((item, iidx) => (
<li key={iidx} className="flex items-start gap-2 text-xs text-white/60">
<span className={`w-1 h-1 rounded-full mt-1.5 ${phase.textColor} bg-current`} />
{item}
</li>
))}
</ul>
</div>
</FadeInView>
))}
</div>
{/* Channel Mix */}
<FadeInView delay={0.5}>
<GlassCard hover={false} className="p-4">
<p className="text-xs font-semibold text-white/40 uppercase tracking-wider mb-3">
{de ? 'Vertriebskanalmix (Ziel 2028)' : 'Channel Mix (Target 2028)'}
</p>
<div className="grid grid-cols-2 md:grid-cols-4 gap-3">
{channels.map((ch, idx) => {
const Icon = ch.icon
return (
<div key={idx} className="text-center">
<Icon className="w-5 h-5 text-indigo-400 mx-auto mb-1" />
<p className="text-lg font-bold text-white">{ch.pct}</p>
<p className="text-xs font-semibold text-white/60 mb-0.5">{ch.label}</p>
<p className="text-[10px] text-white/30">{ch.desc}</p>
</div>
)
})}
</div>
</GlassCard>
</FadeInView>
</div>
)
}