Files
jaengseung-made/app/page.tsx
gahusb 835c154c01 copy(hero): 애플식 카피 — 단언·간결·제품 중심
- 홈/팩 상세 Hero 통일
- Main: '한 줄이면, 노래가 됩니다.' (한 문장)
- Sub: 구성 요약 1문장으로 압축
2026-04-16 04:03:39 +09:00

311 lines
14 KiB
TypeScript

'use client';
import { useState } from 'react';
import Link from 'next/link';
import Image from 'next/image';
import ContactModal from './components/ContactModal';
import { trackCTAClick } from '../lib/gtag';
/* ═══════════════════════════════════════════════════
쟁승메이드 홈 v6 — AI Music Creator Landing
참조: Downloads/stitch_ai_mv/ai_music_creator_landing_page
═══════════════════════════════════════════════════ */
const BEFORE = [
'작곡 공부에만 최소 6개월 소요',
'영상 편집 프로그램 학습의 높은 장벽',
'항상 불안한 저작권 위반 위험',
'곡 하나 완성에 드는 수백만 원의 외주비',
];
const AFTER = [
'단 1시간 만에 프로급 음원 & 영상 완성',
'드래그 앤 드롭 수준의 직관적인 워크플로우',
'가이드대로 따라하면 완벽한 저작권 해결',
'커피 한 잔 가격으로 무한대 콘텐츠 생산',
];
export default function Home() {
const [modalOpen, setModalOpen] = useState(false);
return (
<div className="relative overflow-x-hidden">
<ContactModal
isOpen={modalOpen}
onClose={() => setModalOpen(false)}
service="일반 문의"
checklist={['연락처/이메일', '원하는 작업 범위', '희망 일정']}
/>
{/* 1. Hero */}
<section className="relative px-6 py-24 lg:py-32 overflow-hidden">
<Image
src="/hero_back.webp"
alt=""
fill
priority
sizes="100vw"
className="object-cover object-center pointer-events-none select-none"
style={{ opacity: 0.35 }}
/>
<div
className="absolute inset-0 pointer-events-none"
style={{
background:
'radial-gradient(circle at 50% 30%, rgba(156,72,234,0.28) 0%, transparent 60%), linear-gradient(180deg, rgba(6,14,32,0.35) 0%, rgba(6,14,32,0.85) 75%, var(--kx-surface) 100%)',
}}
/>
<div className="max-w-7xl mx-auto text-center relative z-10">
<span className="kx-label inline-block mb-6">AI Music Pack · 2026</span>
<h1 className="kx-display text-4xl md:text-6xl lg:text-7xl font-bold mb-6 leading-[1.05]" style={{ wordBreak: 'keep-all', letterSpacing: '-0.02em' }}>
,
<br />
<span className="kx-gradient-text"> .</span>
</h1>
<p className="text-lg md:text-xl mb-10 max-w-2xl mx-auto leading-relaxed" style={{ color: 'var(--kx-on-variant)' }}>
.
<br className="sm:hidden" />
{' '}AI .
</p>
<div className="flex flex-col sm:flex-row justify-center gap-4 mb-16">
<Link
href="/services/music#pricing"
onClick={() => trackCTAClick('home_v6_hero_primary')}
className="kx-btn-primary px-8 py-4 rounded-full text-base inline-flex items-center justify-center gap-2"
>
39,000
</Link>
<Link
href="/services/music/samples"
className="px-8 py-4 rounded-full text-base font-bold inline-flex items-center justify-center"
style={{
background: 'rgba(25,37,64,0.4)',
border: '1px solid rgba(64,72,93,0.3)',
color: 'var(--kx-secondary)',
backdropFilter: 'blur(8px)',
textDecoration: 'none',
}}
>
</Link>
</div>
{/* Price tier mini summary */}
<div className="flex flex-col sm:flex-row sm:flex-wrap justify-center items-stretch sm:items-center gap-2 sm:gap-3 mb-16 text-sm max-w-md mx-auto sm:max-w-none">
<span
className="px-4 py-2 rounded-full"
style={{ background: 'rgba(25,37,64,0.5)', border: '1px solid rgba(255,255,255,0.06)', color: 'var(--kx-on-variant)' }}
>
<strong style={{ color: 'var(--kx-on-surface)' }}>39,000</strong>
</span>
<span
className="px-4 py-2 rounded-full"
style={{
background: 'rgba(156,72,234,0.15)',
border: '1px solid rgba(204,151,255,0.4)',
color: 'var(--kx-on-surface)',
boxShadow: '0 0 20px rgba(156,72,234,0.25)',
}}
>
🔥 <strong>99,000</strong> <span style={{ color: 'var(--kx-primary)' }}> </span>
</span>
<span
className="px-4 py-2 rounded-full"
style={{ background: 'rgba(25,37,64,0.5)', border: '1px solid rgba(255,255,255,0.06)', color: 'var(--kx-on-variant)' }}
>
<strong style={{ color: 'var(--kx-on-surface)' }}>149,000</strong>
</span>
</div>
{/* Demo Showcase Card */}
<div
className="relative max-w-5xl mx-auto overflow-hidden"
style={{
borderRadius: '0.75rem 0.75rem 0.125rem 0.125rem',
border: '1px solid rgba(64,72,93,0.15)',
background: 'var(--kx-surface-low)',
boxShadow: '0 20px 80px 0 rgba(156,72,234,0.15)',
}}
>
<div className="aspect-video relative flex items-center justify-center group cursor-pointer">
{/* 배경 그라디언트 + 그리드 */}
<div
className="absolute inset-0"
style={{
background:
'linear-gradient(135deg, #0b0b2b 0%, #1a0840 50%, #061228 100%)',
opacity: 0.9,
}}
/>
<svg className="absolute inset-0 w-full h-full opacity-30" preserveAspectRatio="none" viewBox="0 0 1200 500">
<defs>
<linearGradient id="wg" x1="0%" x2="100%">
<stop offset="0%" stopColor="#cc97ff" />
<stop offset="100%" stopColor="#53ddfc" />
</linearGradient>
</defs>
{[...Array(40)].map((_, i) => (
<rect
key={i}
x={i * 30 + 10}
y={Number((250 - Math.abs(Math.sin(i * 0.6) * 120)).toFixed(3))}
width="10"
height={Number((Math.abs(Math.sin(i * 0.6) * 240) + 20).toFixed(3))}
fill="url(#wg)"
opacity={Number((0.4 + Math.sin(i * 0.3) * 0.3).toFixed(3))}
/>
))}
</svg>
<div
className="relative z-10 p-8 rounded-full border group-hover:scale-110 transition-transform"
style={{
background: 'rgba(204,151,255,0.15)',
borderColor: 'rgba(204,151,255,0.5)',
backdropFilter: 'blur(20px)',
}}
>
<svg className="w-12 h-12" fill="currentColor" viewBox="0 0 24 24" style={{ color: 'var(--kx-primary)' }}>
<path d="M8 5v14l11-7z" />
</svg>
</div>
<div
className="absolute bottom-0 left-0 right-0 p-6 text-left"
style={{
background: 'linear-gradient(to top, var(--kx-surface), transparent)',
}}
>
<span className="kx-label block mb-2">DEMO SHOWCASE</span>
<h3 className="kx-display text-xl md:text-2xl font-bold" style={{ color: 'var(--kx-on-surface)' }}>
K-POP MV
</h3>
</div>
</div>
</div>
</div>
</section>
{/* 2. Before / After */}
<section className="py-24 px-6" style={{ background: 'var(--kx-surface)' }}>
<div className="max-w-7xl mx-auto">
<h2 className="kx-display text-3xl md:text-4xl font-bold text-center mb-16" style={{ color: 'var(--kx-on-surface)' }}>
</h2>
<div className="grid grid-cols-1 md:grid-cols-2 gap-8">
<div className="kx-glass kx-folder relative" style={{ borderTop: '2px solid rgba(255,110,132,0.4)' }}>
<span className="kx-label absolute top-4 right-4" style={{ color: '#d73357' }}>MANUAL PROCESS</span>
<h3 className="kx-display text-2xl font-bold mb-6 flex items-center gap-2" style={{ color: '#ff6e84' }}>
Before
</h3>
<ul className="space-y-3">
{BEFORE.map((t) => (
<li key={t} className="flex items-start gap-3 text-sm" style={{ color: 'var(--kx-on-variant)' }}>
<span style={{ color: '#d73357' }}></span>
<span>{t}</span>
</li>
))}
</ul>
</div>
<div className="kx-glass kx-folder kx-glow relative" style={{ borderTop: '2px solid rgba(83,221,252,0.4)' }}>
<span className="kx-label absolute top-4 right-4">AI POWERED</span>
<h3 className="kx-display text-2xl font-bold mb-6 flex items-center gap-2" style={{ color: 'var(--kx-secondary)' }}>
After
</h3>
<ul className="space-y-3">
{AFTER.map((t) => (
<li key={t} className="flex items-start gap-3 text-sm" style={{ color: 'var(--kx-on-surface)' }}>
<span style={{ color: 'var(--kx-secondary)' }}></span>
<span>{t}</span>
</li>
))}
</ul>
</div>
</div>
</div>
</section>
{/* 3. Other Products + CTA */}
<section className="py-24 px-6" style={{ background: 'var(--kx-surface-low)' }}>
<div className="max-w-7xl mx-auto">
<div className="text-center mb-12">
<span className="kx-label">OTHER PRODUCTS</span>
<h2 className="kx-display text-3xl md:text-4xl font-bold mt-2" style={{ color: 'var(--kx-on-surface)' }}>
</h2>
<p className="mt-3 text-sm max-w-xl mx-auto" style={{ color: 'var(--kx-on-variant)' }}>
. ·CS도 .
</p>
</div>
<div className="grid md:grid-cols-2 gap-5 mb-16">
<Link
href="/services/blog"
className="p-8 transition-all hover:-translate-y-1"
style={{
background: 'var(--kx-surface-high)',
borderTop: '2px solid var(--kx-secondary)',
borderRadius: '0.75rem 0.75rem 0.125rem 0.125rem',
textDecoration: 'none',
}}
>
<span className="kx-label" style={{ color: 'var(--kx-secondary)' }}>DIGITAL PACK · 29,000</span>
<h3 className="kx-display text-2xl font-bold mt-3 mb-2" style={{ color: 'var(--kx-on-surface)' }}> </h3>
<p className="text-sm" style={{ color: 'var(--kx-on-variant)' }}>
+ 릿 PDF + . · .
</p>
</Link>
<Link
href="/saju"
className="p-8 transition-all hover:-translate-y-1"
style={{
background: 'var(--kx-surface-high)',
borderTop: '2px solid #40ceed',
borderRadius: '0.75rem 0.75rem 0.125rem 0.125rem',
textDecoration: 'none',
}}
>
<span className="kx-label" style={{ color: '#40ceed' }}>FREE TOOL</span>
<h3 className="kx-display text-2xl font-bold mt-3 mb-2" style={{ color: 'var(--kx-on-surface)' }}>AI </h3>
<p className="text-sm" style={{ color: 'var(--kx-on-variant)' }}>
+ Gemini . .
</p>
</Link>
</div>
{/* Final CTA — 음악 팩 단일 전환 */}
<div
className="text-center p-10 kx-glass"
style={{ border: '1px solid rgba(204,151,255,0.12)' }}
>
<span className="kx-label">START TODAY</span>
<h3 className="kx-display text-2xl md:text-3xl font-bold mt-2 mb-3" style={{ color: 'var(--kx-on-surface)' }}>
, AI
</h3>
<p className="text-sm mb-6 max-w-xl mx-auto" style={{ color: 'var(--kx-on-variant)' }}>
39,000 . 1 + 릿 + .
</p>
<Link
href="/services/music#pricing"
onClick={() => trackCTAClick('home_v6_final_music')}
className="kx-btn-primary px-8 py-3.5 rounded-full text-sm inline-flex"
>
39,000
</Link>
<div className="mt-5 text-xs" style={{ color: 'var(--kx-on-variant)' }}>
<button
onClick={() => {
trackCTAClick('home_v6_final_contact');
setModalOpen(true);
}}
className="underline underline-offset-4 hover:text-white transition"
>
·
</button>
</div>
</div>
</div>
</section>
</div>
);
}