398 lines
31 KiB
TypeScript
398 lines
31 KiB
TypeScript
import { prisma } from '@innungsapp/shared'
|
||
import { notFound } from 'next/navigation'
|
||
import Link from 'next/link'
|
||
|
||
function jsonToText(value: unknown): string {
|
||
if (value == null) {
|
||
return ''
|
||
}
|
||
|
||
if (typeof value === 'string') {
|
||
return value
|
||
}
|
||
|
||
if (Array.isArray(value)) {
|
||
return value
|
||
.map((item) => (typeof item === 'string' ? item : JSON.stringify(item)))
|
||
.join('\n')
|
||
}
|
||
|
||
return JSON.stringify(value)
|
||
}
|
||
|
||
export default async function TenantLandingPage({
|
||
params,
|
||
}: {
|
||
params: Promise<{ slug: string }>
|
||
}) {
|
||
const { slug } = await params
|
||
|
||
// Exclude dashboard routes
|
||
if (slug === 'dashboard' || slug === 'login' || slug === 'superadmin') {
|
||
return notFound()
|
||
}
|
||
|
||
const org = await prisma.organization.findUnique({
|
||
where: { slug }
|
||
})
|
||
|
||
if (!org) {
|
||
return notFound()
|
||
}
|
||
|
||
const primaryColor = org.primaryColor || '#E63946'
|
||
const secondaryColor = org.secondaryColor || undefined
|
||
const title = org.landingPageTitle || org.name || 'Zukunft durch Handwerk'
|
||
const text = org.landingPageText || 'Wir sind Ihre lokale Vertretung des Handwerks. Mit starker Gemeinschaft und klaren Zielen setzen wir uns für die Betriebe in unserer Region ein.'
|
||
const features = jsonToText(org.landingPageFeatures) || '✅ Exzellente Ausbildung\n✅ Starke Gemeinschaft\n✅ Politische Interessenvertretung'
|
||
const footer = jsonToText(org.landingPageFooter) || `© ${new Date().getFullYear()} ${org.name}`
|
||
const sectionTitle = org.landingPageSectionTitle || `${org.name || 'Ihre Innung'} – Gemeinsam stark fürs Handwerk`
|
||
const buttonText = org.landingPageButtonText || 'Jetzt App laden'
|
||
|
||
return (
|
||
<div className="w-full h-full bg-white overflow-y-auto font-sans flex flex-col relative selection:bg-gray-900 selection:text-white" style={{ '--color-brand-primary': primaryColor } as React.CSSProperties}>
|
||
{/* Header */}
|
||
<header className="px-8 py-6 flex items-center justify-between sticky top-0 z-50 shadow-sm" style={{
|
||
background: `linear-gradient(to right, #ffffff 0%, ${primaryColor}20 50%, ${primaryColor} 100%)`
|
||
}}>
|
||
<div className="flex items-center gap-4">
|
||
{org.logoUrl ? (
|
||
<img src={org.logoUrl} alt="Logo" className="h-10 object-contain" />
|
||
) : (
|
||
<div className="w-10 h-10 bg-white rounded-lg flex items-center justify-center text-xs font-bold text-gray-400 shadow-sm">LOGO</div>
|
||
)}
|
||
<span className="font-bold text-lg text-gray-800">{org.name || 'Innungs-Logo'}</span>
|
||
</div>
|
||
<nav className="flex gap-6 text-sm font-medium text-gray-800 hidden md:flex">
|
||
<a href="#about" className="hover:text-black">Über uns</a>
|
||
<a href="#leistungen" className="hover:text-black">Leistungen</a>
|
||
<a href="#app" className="hover:text-black">App</a>
|
||
</nav>
|
||
<Link
|
||
href={`/login`}
|
||
className="px-5 py-2.5 rounded-full bg-white font-semibold text-sm cursor-pointer shadow-md hover:bg-gray-50 transition-all"
|
||
style={{ color: primaryColor }}
|
||
>
|
||
Mitglieder verwalten
|
||
</Link>
|
||
</header>
|
||
|
||
{/* Hero Section */}
|
||
<section id="about" className="relative px-8 py-20 flex flex-col items-center justify-center text-center overflow-hidden min-h-[400px]">
|
||
{/* Background Image / Pattern */}
|
||
{org.landingPageHeroImage ? (
|
||
<div className="absolute inset-0 z-0">
|
||
<img src={org.landingPageHeroImage} alt="Hero Background" className="w-full h-full object-cover" />
|
||
<div
|
||
className="absolute inset-0 bg-white"
|
||
// If you have a specific overlay opacity field you could use it here. Defaulting to 0.5.
|
||
style={{ opacity: 0.5 }}
|
||
></div>
|
||
<div className="absolute inset-0 bg-gradient-to-b from-white/30 via-transparent to-white/90"></div>
|
||
</div>
|
||
) : (
|
||
<div className="absolute inset-0 z-0 opacity-[0.03]" style={{ backgroundImage: 'radial-gradient(#000 1px, transparent 1px)', backgroundSize: '24px 24px' }}></div>
|
||
)}
|
||
|
||
<div className="relative z-10 max-w-3xl mx-auto space-y-6">
|
||
<div className="inline-block px-4 py-1.5 rounded-full text-xs font-bold tracking-wider uppercase mb-2 shadow-sm" style={{ backgroundColor: `${primaryColor}15`, color: primaryColor }}>
|
||
{org.name || 'Ihre Innung'}
|
||
</div>
|
||
<h1 className="text-4xl md:text-5xl font-black text-gray-900 tracking-tight leading-[1.1]">
|
||
{title}
|
||
</h1>
|
||
<p className="text-lg text-gray-600 leading-relaxed max-w-2xl mx-auto font-medium">
|
||
{text}
|
||
</p>
|
||
<div className="pt-6 flex gap-4 justify-center">
|
||
<a
|
||
href="#apps"
|
||
className="px-8 py-3.5 rounded-full text-white font-semibold shadow-lg hover:opacity-90 transition-all cursor-pointer transform hover:-translate-y-0.5 block"
|
||
style={{ backgroundColor: primaryColor }}
|
||
>
|
||
{buttonText}
|
||
</a>
|
||
<a
|
||
href="#leistungen"
|
||
className="px-8 py-3.5 rounded-full font-semibold border shadow-sm transition-all cursor-pointer block hover:opacity-80"
|
||
style={{
|
||
backgroundColor: 'white',
|
||
borderColor: secondaryColor || '#e5e7eb',
|
||
color: secondaryColor || '#374151'
|
||
}}
|
||
>
|
||
Mehr erfahren
|
||
</a>
|
||
</div>
|
||
</div>
|
||
</section>
|
||
|
||
{/* Features / Benefits */}
|
||
<section id="leistungen" className="px-8 py-16" style={{ backgroundColor: secondaryColor ? `${secondaryColor}08` : '#f9fafb' }}>
|
||
<div className="max-w-5xl mx-auto">
|
||
<h2 className="text-2xl font-bold text-center mb-12 text-gray-800">Ihre Vorteile als Mitglied</h2>
|
||
<div className="grid grid-cols-1 md:grid-cols-3 gap-8">
|
||
{features.split('\n').filter((f: string) => f.trim() !== '').map((feature: string, idx: number) => (
|
||
<div key={idx} className="bg-white p-6 rounded-2xl shadow-sm border border-gray-100 flex flex-col items-center text-center space-y-4 hover:shadow-md transition-shadow">
|
||
<div className="w-12 h-12 rounded-full flex items-center justify-center" style={{ backgroundColor: secondaryColor ? `${secondaryColor}15` : `${primaryColor}15`, color: secondaryColor || primaryColor }}>
|
||
<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 24 24" strokeWidth={2} stroke="currentColor" className="w-6 h-6">
|
||
<path strokeLinecap="round" strokeLinejoin="round" d="M9 12.75 11.25 15 15 9.75M21 12a9 9 0 1 1-18 0 9 9 0 0 1 18 0Z" />
|
||
</svg>
|
||
</div>
|
||
<h3 className="font-semibold text-gray-800">{feature.replace(/^[-\*\✅\ ]+/, '')}</h3>
|
||
</div>
|
||
))}
|
||
</div>
|
||
</div>
|
||
</section>
|
||
|
||
{/* App Features Grid */}
|
||
<section id="app" className="px-8 py-20 bg-white">
|
||
<div className="max-w-6xl mx-auto">
|
||
<div className="text-center mb-16 space-y-4">
|
||
<div className="inline-flex items-center gap-2 px-3 py-1 rounded-full text-sm font-semibold mb-2" style={{ backgroundColor: `${primaryColor}10`, color: primaryColor }}>
|
||
<svg className="w-4 h-4" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}><path strokeLinecap="round" strokeLinejoin="round" d="M13 10V3L4 14h7v7l9-11h-7z" /></svg>
|
||
Alles in einer App
|
||
</div>
|
||
<h2 className="text-3xl md:text-4xl font-black text-gray-900">{sectionTitle}</h2>
|
||
<p className="text-lg text-gray-500 max-w-2xl mx-auto">
|
||
Verpassen Sie keine wichtigen Branchen-Updates mehr. Vernetzen Sie sich mit anderen Betrieben und verwalten Sie Termine bequem auf dem Smartphone.
|
||
</p>
|
||
</div>
|
||
|
||
<div className="grid grid-cols-1 sm:grid-cols-2 lg:grid-cols-3 gap-6">
|
||
{/* Feature 1: Aktuelles */}
|
||
<div className="p-8 rounded-[2rem] border border-gray-100 bg-white shadow-sm hover:shadow-xl hover:-translate-y-1 transition-all duration-300 group">
|
||
<div className="w-14 h-14 rounded-2xl bg-gray-50 flex items-center justify-center mb-6 group-hover:scale-110 transition-transform duration-300" style={{ color: primaryColor }}>
|
||
<svg className="w-7 h-7" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={1.5}><path strokeLinecap="round" strokeLinejoin="round" d="M19 20H5a2 2 0 01-2-2V6a2 2 0 012-2h10a2 2 0 012 2v1m2 13a2 2 0 01-2-2V7m2 13a2 2 0 002-2V9a2 2 0 00-2-2h-2m-4-3H9M7 16h6M7 8h6v4H7V8z" /></svg>
|
||
</div>
|
||
<h3 className="text-xl font-bold text-gray-900 mb-3">Aktuelles</h3>
|
||
<p className="text-gray-500 leading-relaxed">
|
||
Lesen Sie die wichtigsten Branchen-News und bleiben Sie immer auf dem aktuellsten Stand.
|
||
</p>
|
||
</div>
|
||
|
||
{/* Feature 2: Termine */}
|
||
<div className="p-8 rounded-[2rem] border border-gray-100 bg-white shadow-sm hover:shadow-xl hover:-translate-y-1 transition-all duration-300 group">
|
||
<div className="w-14 h-14 rounded-2xl bg-gray-50 flex items-center justify-center mb-6 group-hover:scale-110 transition-transform duration-300" style={{ color: primaryColor }}>
|
||
<svg className="w-7 h-7" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={1.5}><path strokeLinecap="round" strokeLinejoin="round" d="M8 7V3m8 4V3m-9 8h10M5 21h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v12a2 2 0 002 2z" /></svg>
|
||
</div>
|
||
<h3 className="text-xl font-bold text-gray-900 mb-3">Termine</h3>
|
||
<p className="text-gray-500 leading-relaxed">
|
||
Verwalten Sie Veranstaltungen, Fortbildungen und Innungsversammlungen direkt in Ihrem Kalender.
|
||
</p>
|
||
</div>
|
||
|
||
{/* Feature 3: Stellen */}
|
||
<div className="p-8 rounded-[2rem] border border-gray-100 bg-white shadow-sm hover:shadow-xl hover:-translate-y-1 transition-all duration-300 group">
|
||
<div className="w-14 h-14 rounded-2xl bg-gray-50 flex items-center justify-center mb-6 group-hover:scale-110 transition-transform duration-300" style={{ color: primaryColor }}>
|
||
<svg className="w-7 h-7" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={1.5}><path strokeLinecap="round" strokeLinejoin="round" d="M21 13.255A23.931 23.931 0 0112 15c-3.183 0-6.22-.62-9-1.745M16 6V4a2 2 0 00-2-2h-4a2 2 0 00-2 2v2m4 6h.01M5 20h14a2 2 0 002-2V8a2 2 0 00-2-2H5a2 2 0 00-2 2v10a2 2 0 002 2z" /></svg>
|
||
</div>
|
||
<h3 className="text-xl font-bold text-gray-900 mb-3">Stellenbörse</h3>
|
||
<p className="text-gray-500 leading-relaxed">
|
||
Finden Sie neue Fachkräfte oder Auszubildende. Veröffentlichen Sie Ihre offenen Stellenangebote branchenintern.
|
||
</p>
|
||
</div>
|
||
|
||
{/* Feature 4: Nachrichten */}
|
||
<div className="p-8 rounded-[2rem] border border-gray-100 bg-white shadow-sm hover:shadow-xl hover:-translate-y-1 transition-all duration-300 group">
|
||
<div className="w-14 h-14 rounded-2xl bg-gray-50 flex items-center justify-center mb-6 group-hover:scale-110 transition-transform duration-300" style={{ color: primaryColor }}>
|
||
<svg className="w-7 h-7" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={1.5}><path strokeLinecap="round" strokeLinejoin="round" d="M8 12h.01M12 12h.01M16 12h.01M21 12c0 4.418-4.03 8-9 8a9.863 9.863 0 01-4.255-.949L3 20l1.395-3.72C3.512 15.042 3 13.574 3 12c0-4.418 4.03-8 9-8s9 3.582 9 8z" /></svg>
|
||
</div>
|
||
<h3 className="text-xl font-bold text-gray-900 mb-3">Nachrichten</h3>
|
||
<p className="text-gray-500 leading-relaxed">
|
||
Tauschen Sie sich mit anderen Betrieben aus. Schnelle Kontaktaufnahme über direkte Einzel- und Gruppenchats.
|
||
</p>
|
||
</div>
|
||
|
||
{/* Feature 5: Profil */}
|
||
<div className="p-8 rounded-[2rem] border border-gray-100 bg-white shadow-sm hover:shadow-xl hover:-translate-y-1 transition-all duration-300 group">
|
||
<div className="w-14 h-14 rounded-2xl bg-gray-50 flex items-center justify-center mb-6 group-hover:scale-110 transition-transform duration-300" style={{ color: primaryColor }}>
|
||
<svg className="w-7 h-7" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={1.5}><path strokeLinecap="round" strokeLinejoin="round" d="M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z" /></svg>
|
||
</div>
|
||
<h3 className="text-xl font-bold text-gray-900 mb-3">Profil & Ausweis</h3>
|
||
<p className="text-gray-500 leading-relaxed">
|
||
Ihr digitaler Mitgliedsausweis immer griffbereit. Verwalten Sie das Profil Ihres Betriebs komfortabel in der App.
|
||
</p>
|
||
</div>
|
||
|
||
{/* Feature 6: Partner */}
|
||
<div className="p-8 rounded-[2rem] border border-gray-100 bg-white shadow-sm hover:shadow-xl hover:-translate-y-1 transition-all duration-300 group">
|
||
<div className="w-14 h-14 rounded-2xl bg-gray-50 flex items-center justify-center mb-6 group-hover:scale-110 transition-transform duration-300" style={{ color: primaryColor }}>
|
||
<svg className="w-7 h-7" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={1.5}><path strokeLinecap="round" strokeLinejoin="round" d="M13.828 10.172a4 4 0 00-5.656 0l-4 4a4 4 0 105.656 5.656l1.102-1.101m-.758-4.899a4 4 0 005.656 0l4-4a4 4 0 00-5.656-5.656l-1.1 1.1" /></svg>
|
||
</div>
|
||
<h3 className="text-xl font-bold text-gray-900 mb-3">Netzwerk</h3>
|
||
<p className="text-gray-500 leading-relaxed">
|
||
Profitieren Sie von starken Kooperationen und Angeboten ausgewählter Partnerbetriebe in der Region.
|
||
</p>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</section>
|
||
|
||
{/* Application Mock */}
|
||
<section id="apps" className="px-8 py-32 relative overflow-hidden" style={{
|
||
background: `linear-gradient(to bottom, #ffffff 0%, ${primaryColor} 40%, #111827 100%)`
|
||
}}>
|
||
|
||
{/* Decorative background elements */}
|
||
<div className="absolute inset-0 opacity-10" style={{ backgroundImage: 'radial-gradient(circle at 2px 2px, white 1px, transparent 0)', backgroundSize: '40px 40px' }}></div>
|
||
<div className="absolute top-0 right-0 -mr-40 -mt-40 w-[500px] h-[500px] rounded-full bg-white/20 blur-[100px] pointer-events-none"></div>
|
||
<div className="absolute bottom-0 left-0 -ml-40 -mb-40 w-[500px] h-[500px] rounded-full border-[40px] border-white/5 pointer-events-none"></div>
|
||
|
||
<div className="max-w-6xl mx-auto flex flex-col md:flex-row items-center gap-16 relative z-10">
|
||
<div className="flex-1 text-left space-y-8 text-white">
|
||
<div className="inline-flex items-center gap-2 px-4 py-2 rounded-full bg-white/10 backdrop-blur-md border border-white/20 text-sm font-medium">
|
||
<span className="w-2 h-2 rounded-full bg-green-400 animate-pulse"></span>
|
||
Jetzt verfügbar
|
||
</div>
|
||
<h2 className="text-4xl md:text-5xl font-black leading-tight">
|
||
Laden Sie unsere App herunter
|
||
</h2>
|
||
<p className="text-white/80 text-xl leading-relaxed max-w-lg">
|
||
Bleiben Sie immer auf dem Laufenden mit der {org.name || 'Innungs'}-App für Mitglieder. Alle News, Termine und Ihr digitaler Mitgliedsausweis direkt auf Ihrem Smartphone.
|
||
</p>
|
||
|
||
<div className="flex flex-wrap gap-4 pt-4">
|
||
{(!org.appStoreUrl && !org.playStoreUrl) || org.appStoreUrl ? (
|
||
<a href={org.appStoreUrl || "#"} target="_blank" rel="noreferrer" className="bg-black hover:bg-black/80 text-white px-8 py-4 rounded-2xl cursor-pointer transition-all flex items-center gap-4 shadow-xl hover:shadow-2xl transform hover:-translate-y-1">
|
||
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 384 512" className="w-8 h-8 fill-current"><path d="M318.7 268.7c-.2-36.7 16.4-64.4 50-84.8-18.8-26.9-47.2-41.7-84.7-44.6-35.5-2.8-74.3 20.7-88.5 20.7-15 0-49.4-19.7-76.4-19.7C63.3 141.2 4 184.8 4 273.5q0 39.3 14.4 81.2c12.8 36.7 59 126.7 107.2 125.2 25.2-.6 43-17.9 75.8-17.9 31.8 0 48.3 17.9 76.4 17.9 48.6-.7 90.4-82.5 102.6-119.3-65.2-30.7-61.7-90-61.7-91.9zm-56.6-164.2c27.3-32.4 24.8-61.9 24-72.5-24.1 1.4-52 16.4-67.9 34.9-17.5 19.8-27.8 44.3-25.6 71.9 26.1 2 49.9-11.4 69.5-34.3z" /></svg>
|
||
<div>
|
||
<div className="text-xs text-white/70">Download on the</div>
|
||
<div className="text-lg font-semibold leading-none">App Store</div>
|
||
</div>
|
||
</a>
|
||
) : null}
|
||
{(!org.appStoreUrl && !org.playStoreUrl) || org.playStoreUrl ? (
|
||
<a href={org.playStoreUrl || "#"} target="_blank" rel="noreferrer" className="bg-black hover:bg-black/80 text-white px-8 py-4 rounded-2xl cursor-pointer transition-all flex items-center gap-4 shadow-xl hover:shadow-2xl transform hover:-translate-y-1">
|
||
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512" className="w-8 h-8 fill-current"><path d="M325.3 234.3L104.6 13l280.8 161.2-60.1 60.1zM47 0C34 6.8 25.3 19.2 25.3 35.3v441.3c0 16.1 8.7 28.5 21.7 35.3l256.6-256L47 0zm425.2 225.6l-58.9-34.1-65.7 64.5 65.7 64.5 60.1-34.1c18-14.3 18-46.5-1.2-60.8zM104.6 499l280.8-161.2-60.1-60.1L104.6 499z" /></svg>
|
||
<div>
|
||
<div className="text-xs text-white/70">GET IT ON</div>
|
||
<div className="text-lg font-semibold leading-none">Google Play</div>
|
||
</div>
|
||
</a>
|
||
) : null}
|
||
</div>
|
||
</div>
|
||
|
||
<div className="flex-1 w-full flex justify-center mt-12 md:mt-0 perspective-[2000px]">
|
||
<div className="relative w-[280px] h-[580px] rounded-[3rem] border-[12px] border-black bg-black shadow-2xl overflow-hidden transform rotate-y-[-15deg] rotate-x-[10deg] rotate-z-[5deg] hover:rotate-y-[0deg] hover:rotate-x-[0deg] hover:rotate-z-[0deg] transition-all duration-700 ease-out">
|
||
{/* Notch */}
|
||
<div className="absolute top-0 left-1/2 -translate-x-1/2 w-32 h-6 bg-black rounded-b-3xl z-20"></div>
|
||
|
||
{/* App Screenshot Mockup */}
|
||
<div className="w-full h-full bg-gray-50 flex flex-col pt-6">
|
||
{/* App Header */}
|
||
<div className="px-5 py-4 flex items-center justify-between bg-white border-b border-gray-100">
|
||
<div className="flex items-center gap-3">
|
||
{org.logoUrl ? (
|
||
<img src={org.logoUrl} alt="Logo" className="w-8 h-8 object-contain" />
|
||
) : (
|
||
<div className="w-8 h-8 rounded-full flex items-center justify-center text-white font-bold text-xs shadow-sm" style={{ backgroundColor: primaryColor }}>
|
||
{org.name ? org.name.charAt(0).toUpperCase() : 'I'}
|
||
</div>
|
||
)}
|
||
<div className="font-bold text-sm text-gray-800 truncate w-28">{org.name || 'Ihre Innung'}</div>
|
||
</div>
|
||
<div className="w-8 h-8 rounded-full bg-gray-100 flex items-center justify-center">
|
||
<svg className="w-4 h-4 text-gray-500" fill="none" viewBox="0 0 24 24" stroke="currentColor"><path strokeLinecap="round" strokeLinejoin="round" strokeWidth={2} d="M15 17h5l-1.405-1.405A2.032 2.032 0 0118 14.158V11a6.002 6.002 0 00-4-5.659V5a2 2 0 10-4 0v.341C7.67 6.165 6 8.388 6 11v3.159c0 .538-.214 1.055-.595 1.436L4 17h5m6 0v1a3 3 0 11-6 0v-1m6 0H9" /></svg>
|
||
</div>
|
||
</div>
|
||
{/* App Content */}
|
||
<div className="p-5 space-y-6 flex-1 overflow-hidden">
|
||
<div className="w-full h-32 rounded-2xl relative overflow-hidden flex items-end p-4 shadow-sm" style={{ backgroundColor: primaryColor }}>
|
||
<div className="absolute inset-0 bg-black/10"></div>
|
||
<div className="absolute -top-10 -right-10 w-32 h-32 bg-white/10 rounded-full blur-2xl"></div>
|
||
<div className="relative z-10 text-white font-bold text-lg leading-tight">Willkommen,<br />Max Mustermann</div>
|
||
</div>
|
||
|
||
<div className="space-y-4">
|
||
<div className="flex items-center justify-between">
|
||
<div className="text-sm font-bold text-gray-800">Aktuelle News</div>
|
||
<div className="text-xs text-gray-400 font-medium">Alle ansehen</div>
|
||
</div>
|
||
<div className="space-y-3">
|
||
<div className="bg-white rounded-xl border border-gray-100 p-3 flex gap-3 shadow-sm items-center">
|
||
<div className="w-12 h-12 rounded-lg flex-shrink-0" style={{ backgroundColor: `${primaryColor}15` }}></div>
|
||
<div className="flex-1 space-y-2">
|
||
<div className="h-3 w-5/6 bg-gray-200 rounded-full"></div>
|
||
<div className="h-2 w-full bg-gray-100 rounded-full"></div>
|
||
</div>
|
||
</div>
|
||
<div className="bg-white rounded-xl border border-gray-100 p-3 flex gap-3 shadow-sm items-center">
|
||
<div className="w-12 h-12 rounded-lg flex-shrink-0" style={{ backgroundColor: `${primaryColor}15` }}></div>
|
||
<div className="flex-1 space-y-2">
|
||
<div className="h-3 w-2/3 bg-gray-200 rounded-full"></div>
|
||
<div className="h-2 w-4/5 bg-gray-100 rounded-full"></div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
{/* App Bottom Nav */}
|
||
<div className="h-[72px] bg-white border-t border-gray-100 flex items-center justify-between px-4 pb-2 pt-2 shadow-[0_-4px_20px_rgba(0,0,0,0.03)] z-20">
|
||
<div className="flex flex-col items-center gap-1 w-1/6">
|
||
<svg className="w-5 h-5" style={{ color: primaryColor }} fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}><path strokeLinecap="round" strokeLinejoin="round" d="M3 12l2-2m0 0l7-7 7 7M5 10v10a1 1 0 001 1h3m10-11l2 2m-2-2v10a1 1 0 01-1 1h-3m-6 0a1 1 0 001-1v-4a1 1 0 011-1h2a1 1 0 011 1v4a1 1 0 001 1m-6 0h6" /></svg>
|
||
<span className="text-[9px] font-semibold" style={{ color: primaryColor }}>Start</span>
|
||
</div>
|
||
<div className="flex flex-col items-center gap-1 text-gray-400 w-1/6">
|
||
<svg className="w-5 h-5" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}><path strokeLinecap="round" strokeLinejoin="round" d="M19 20H5a2 2 0 01-2-2V6a2 2 0 012-2h10a2 2 0 012 2v1m2 13a2 2 0 01-2-2V7m2 13a2 2 0 002-2V9a2 2 0 00-2-2h-2m-4-3H9M7 16h6M7 8h6v4H7V8z" /></svg>
|
||
<span className="text-[9px] font-medium">Aktuelles</span>
|
||
</div>
|
||
<div className="flex flex-col items-center gap-1 text-gray-400 w-1/6">
|
||
<svg className="w-5 h-5" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}><path strokeLinecap="round" strokeLinejoin="round" d="M8 7V3m8 4V3m-9 8h10M5 21h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v12a2 2 0 002 2z" /></svg>
|
||
<span className="text-[9px] font-medium">Termine</span>
|
||
</div>
|
||
<div className="flex flex-col items-center gap-1 text-gray-400 w-1/6">
|
||
<svg className="w-5 h-5" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}><path strokeLinecap="round" strokeLinejoin="round" d="M21 13.255A23.931 23.931 0 0112 15c-3.183 0-6.22-.62-9-1.745M16 6V4a2 2 0 00-2-2h-4a2 2 0 00-2 2v2m4 6h.01M5 20h14a2 2 0 002-2V8a2 2 0 00-2-2H5a2 2 0 00-2 2v10a2 2 0 002 2z" /></svg>
|
||
<span className="text-[9px] font-medium">Stellen</span>
|
||
</div>
|
||
<div className="flex flex-col items-center gap-1 text-gray-400 w-1/6">
|
||
<svg className="w-5 h-5" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}><path strokeLinecap="round" strokeLinejoin="round" d="M8 12h.01M12 12h.01M16 12h.01M21 12c0 4.418-4.03 8-9 8a9.863 9.863 0 01-4.255-.949L3 20l1.395-3.72C3.512 15.042 3 13.574 3 12c0-4.418 4.03-8 9-8s9 3.582 9 8z" /></svg>
|
||
<span className="text-[9px] font-medium">Nachricht..</span>
|
||
</div>
|
||
<div className="flex flex-col items-center gap-1 text-gray-400 w-1/6">
|
||
<svg className="w-5 h-5" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}><path strokeLinecap="round" strokeLinejoin="round" d="M16 7a4 4 0 11-8 0 4 4 0 018 0zM12 14a7 7 0 00-7 7h14a7 7 0 00-7-7z" /></svg>
|
||
<span className="text-[9px] font-medium">Profil</span>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
</section>
|
||
|
||
{/* CTA Section */}
|
||
<section id="mitglied-werden" className="px-8 py-24 bg-gray-50 text-center relative z-20">
|
||
<div className="max-w-3xl mx-auto space-y-8">
|
||
<h2 className="text-3xl md:text-4xl font-bold text-gray-900">Werden Sie jetzt Teil der Gemeinschaft</h2>
|
||
<p className="text-lg text-gray-600">
|
||
Profitieren Sie von unserem starken Netzwerk, exklusiven Brancheninformationen und unserer digitalen Innungs-App.
|
||
</p>
|
||
<a
|
||
href="#apps"
|
||
className="inline-block px-10 py-4 rounded-full text-white font-bold text-lg shadow-xl hover:shadow-2xl hover:-translate-y-1 transition-all"
|
||
style={{ backgroundColor: primaryColor }}
|
||
>
|
||
Jetzt Mitglied werden
|
||
</a>
|
||
</div>
|
||
</section>
|
||
|
||
{/* Footer */}
|
||
<footer className="bg-gray-900 text-gray-400 py-12 px-8 text-center text-sm">
|
||
<div className="max-w-4xl mx-auto space-y-4">
|
||
<div className="text-gray-300 font-bold text-lg mb-6">{org.name || 'Innungs-Logo'}</div>
|
||
<div className="whitespace-pre-wrap">{footer}</div>
|
||
<div className="pt-8 border-t border-gray-800 flex justify-center gap-6">
|
||
<Link href="/impressum" className="hover:text-white transition-colors">Impressum</Link>
|
||
<Link href="/datenschutz" className="hover:text-white transition-colors">Datenschutz</Link>
|
||
<Link href="/kontakt" className="hover:text-white transition-colors">Kontakt</Link>
|
||
</div>
|
||
</div>
|
||
</footer>
|
||
</div>
|
||
)
|
||
}
|