+ {/* 외주 개발 (자동화 포함) */}
+ trackCTAClick('home_v7_cb_card_freelance')}>...
+ {/* 웹사이트 */}
+ trackCTAClick('home_v7_cb_card_website')}>...
+ {/* AI 사주 */}
+ trackCTAClick('home_v7_cb_card_saju')}>...
+ {/* 블로그 자동화 */}
+ trackCTAClick('home_v7_cb_card_blog')}>...
+
+
+ {/* 납품 5건 미리보기 */}
+
+
+ Recent Deliveries
+
+
+ {/* 5 카드 — /work/freelance 의 portfolio 데이터에서 5건 ALSI */}
+
+
+
+ {/* 견적 CTA */}
+
+
+
+
+
+```
+
+5건 납품 사례 데이터: `app/work/freelance/page.tsx`에서 export하는 portfolio array에서 가져옴. 또는 `lib/freelance-portfolio.ts` 에 분리 (재사용성).
+
+### 2.5 Music 섹션 (Section 3)
+
+현 메인의 Features 3-step + 트윗 마퀴 그대로 유지. 풀버전은 `/music/packs` 에서.
+
+### 2.6 Final CTA (Section 5)
+
+```tsx
+
+
어느 쪽이든 시작하세요.
+
+ Music 팩 보기
+
+
+
+```
+
+기존 hero-bg.mp4 풀스크린 final CTA → 더 단순한 텍스트 + 두 분기 CTA로.
+
+## 3. 변경 범위 (파일 단위)
+
+### 3.1 신규 생성
+
+| 파일 | 책임 | 컨텐츠 출처 |
+|---|---|---|
+| `next.config.ts` (또는 modify) | 9 redirects | spec |
+| `app/music/page.tsx` | Music 허브 (3 카드 + 후기 압축) | 신규 |
+| `app/music/packs/page.tsx` | 음악 팩 상세 | 현 `app/services/music/page.tsx` 이동 |
+| `app/music/samples/page.tsx` | 샘플 갤러리 | 현 `app/services/music/samples/page.tsx` 이동 |
+| `app/music/studio/page.tsx` | Suno 스튜디오 | 현 `app/studio/page.tsx` 이동 |
+| `app/music/layout.tsx` (선택) | Music 도메인 메타데이터 | metadata.title 분기 |
+| `app/work/page.tsx` | Custom Build 허브 (4 카드 + 5건 사례 + 견적) | 신규 |
+| `app/work/freelance/page.tsx` | 외주 (자동화 포함, #automation 앵커) | 현 `app/freelance/page.tsx` 이동 + 자동화 섹션 강화 |
+| `app/work/freelance/layout.tsx` | 메타데이터 | 현 `app/freelance/layout.tsx` |
+| `app/work/website/page.tsx` | 웹사이트 제작 | 현 `app/services/website/page.tsx` 이동 |
+| `app/work/website/layout.tsx` | 메타데이터 | 현 `app/services/website/layout.tsx` |
+| `app/work/website/samples/{corporate, bakery, ...}/page.tsx` | 7개 샘플 | 현 `app/services/website/samples/*` 이동 |
+| `app/work/saju/page.tsx` | 사주 입력 | 현 `app/saju/page.tsx` 이동 |
+| `app/work/saju/layout.tsx` | 메타데이터 | 현 `app/saju/layout.tsx` |
+| `app/work/saju/input/page.tsx` | 사주 입력 | 현 `app/saju/input/page.tsx` 이동 |
+| `app/work/saju/result/page.tsx` + `SajuAISection.tsx` + `SajuFortuneSection.tsx` | 결과 + AI | 현 `app/saju/result/*` 이동 |
+| `app/work/blog/page.tsx` | 블로그 자동화 | 현 `app/services/blog/page.tsx` 이동 |
+| `app/work/blog/layout.tsx` | 메타데이터 | 현 `app/services/blog/layout.tsx` |
+| `lib/freelance-portfolio.ts` | 납품 5건 데이터 분리 | 현 `app/freelance/page.tsx`의 portfolio array 추출 |
+
+### 3.2 수정
+
+| 파일 | 변경 |
+|---|---|
+| `app/page.tsx` | 안 2 적용 — Brand Hero + 2-up + Music 섹션 + Custom Build 섹션 + Final CTA |
+| `app/components/TopNav.tsx` | LINKS 5개 → 2개 (Music / Custom Build) |
+| `app/components/PublicShell.tsx` | 푸터 URL 8개 교체 (새 URL) |
+| `app/layout.tsx` | JSON-LD OfferCatalog `url` 필드 새 URL로 |
+| `app/api/saju/save-interpretation/route.ts` 등 | 사주 페이지 내부에서 사용하는 라우트 — Link href만 새 URL로 (라우트 자체는 그대로) |
+
+### 3.3 삭제
+
+원본 페이지 파일 삭제 (컨텐츠는 모두 새 위치로 이동 완료 후):
+
+```
+app/services/music/page.tsx
+app/services/music/samples/page.tsx
+app/services/music/layout.tsx
+app/studio/page.tsx
+app/freelance/page.tsx
+app/freelance/layout.tsx
+app/services/website/page.tsx
+app/services/website/layout.tsx
+app/services/website/samples/{corporate, bakery, ...}/page.tsx ← 7개
+app/services/blog/page.tsx
+app/services/blog/layout.tsx
+app/saju/page.tsx
+app/saju/layout.tsx
+app/saju/input/page.tsx
+app/saju/result/page.tsx
+app/saju/result/SajuAISection.tsx
+app/saju/result/SajuFortuneSection.tsx
+```
+
+총 약 21개 파일 삭제. redirect로 외부 링크/SEO 보존.
+
+## 4. SEO
+
+### 4.1 JSON-LD URL 갱신
+
+`app/layout.tsx` 의 `OfferCatalog.itemListElement` 모든 `url` 필드:
+
+| Offer name | 기존 url | 새 url |
+|---|---|---|
+| 음악 입문/프로/마스터 | `.../services/music` | `.../music/packs` |
+| 블로그 자동화 | `.../services/blog` | `.../work/blog` |
+| AI 사주 분석 | `.../saju` | `.../work/saju` |
+| 맞춤 개발 외주 | `.../freelance` | `.../work/freelance` |
+| 웹사이트 제작 | `.../services/website` | `.../work/website` |
+
+### 4.2 sitemap.xml
+
+`app/sitemap.ts` 존재 시 자동 갱신 (Next.js routes 자동 반영). 없으면 신규 생성 권장 — 새 IA가 정착된 후 별도 task.
+
+### 4.3 robots.txt
+
+`/_next`, `/api` disallow 기존 그대로. 새 URL은 자연 허용.
+
+### 4.4 Google Search Console
+
+배포 후 운영자(CEO) 수동 작업:
+1. URL Inspection으로 새 URL 5-10개 색인 요청 (`/music`, `/work`, `/work/freelance`, `/work/saju` 등 핵심)
+2. 기존 URL의 301 redirect 정상 동작 확인
+
+## 5. 마이그레이션 안전 전략
+
+### 5.1 Phase 분할 (3 phase로 구현 안전성 확보)
+
+**Phase A — 인프라 + 새 페이지 신설 (이번 작업 첫 part)**:
+- `next.config.ts` redirects 8개 ⚠ 이 시점에서 원본 페이지도 살아있음 → 빌드 OK
+- `app/music/*`, `app/work/*` 신규 페이지 생성 (컨텐츠 이동)
+- 원본 페이지는 아직 살림 (Phase B에서 삭제)
+- 빌드 통과: 둘 다 존재해도 OK (redirect는 source가 destination과 다르면 OK)
+
+⚠️ 중요: redirect source `/services/music` + 동일 path의 file system route 존재 시 Next.js 동작:
+- redirect가 파일 시스템 route보다 먼저 평가됨 → 원본 파일이 있어도 redirect 우선
+- 따라서 Phase A 시점에서 원본 파일을 두면 빌드 X 회귀 X, 단지 dead code
+
+**Phase B — 원본 페이지 삭제 + 헤더/메인 변경**:
+- 원본 21개 파일 삭제 (SEO duplicate content 회피)
+- TopNav LINKS 5→2
+- `app/page.tsx` 안 2 적용
+- PublicShell 푸터 URL 새 URL로
+- JSON-LD URL 새 URL로
+
+**Phase C — 검증 + sitemap**:
+- 빌드 + 시각 회귀 + redirect 검증
+- 운영자(CEO) Google Search Console 색인 요청
+
+→ 이 spec은 위 3 phase 모두 포함. 다음 plan에서 phase별 task 분해.
+
+### 5.2 모바일 햄버거 메뉴
+
+TopNav LINKS 5→2이라 햄버거 메뉴도 간소화. P0/P1에서 이미 정돈된 패턴 유지.
+
+### 5.3 `/api/*` 영향
+
+API 라우트는 redirect 대상에 포함 안 함. 사주 페이지 내부에서 호출하는 `/api/saju/analyze`, `/api/saju/save-interpretation`, `/api/saju/lotto` 등은 그대로. 단, Link/fetch 시 absolute path는 변경 X.
+
+## 6. 회귀 방지 체크리스트
+
+이번 P1 작업이 깰 위험 있는 기능들:
+
+- ✅ Phase 2 mypage 다운로드 — `/api/packs/*` 라우트 그대로 영향 없음
+- ⚠️ 사주 AI 해석 — `/work/saju/result` 의 `SajuAISection.tsx`가 `/api/saju/*` 호출. 라우트 그대로 → 영향 없음
+- ⚠️ Music 결제 — `/work/freelance` 또는 `/music/packs`에서 `PurchaseAgreementModal` 작동 확인 (계좌이체 흐름)
+- ⚠️ Vercel 배포 후 외부 검색 인덱스 — 301 redirect 동작 확인
+- ✅ admin 영역 — standalone shell, 영향 없음
+- ⚠️ portfolio/[token], quote/[token] — `/work/freelance`의 sharing 흐름과 연동. URL 변경 확인 필요
+
+## 7. 의도적 제외 (P3+)
+
+- 자체 정가 표 (가격 결정 후)
+- /about 페이지
+- /work/automation 별도 페이지
+- 사주 카탈로그 (49만 코어 + 11 모듈, 재정리 후)
+- Custom Build 라인별 후기/리뷰
+- Brand Hero 영상/모션 재디자인
+- sitemap.xml 자동 생성 (`app/sitemap.ts`)
+- Music/Custom Build 페이지별 hreflang (다국어)
+
+## 8. 다음 단계
+
+1. 이 spec 검토 (사용자)
+2. 승인 후 → `superpowers:writing-plans` 로 implementation plan 작성
+3. plan은 §5.1 Phase A/B/C로 task 분해 (약 15-20 task 예상)
+4. plan 작성 후 → `superpowers:subagent-driven-development` 로 task별 실행
+5. push 시점은 Phase B 완료 후 (전체 정합성 유지)
+
+## 부록 A. 안 2 + 헤더 안 b 와이어프레임 텍스트
+
+```
+═══════════════════════════════════════════════════════
+[TopNav]
+JSM Music Custom Build 로그인 Try now
+═══════════════════════════════════════════════════════
+
+[BRAND HERO — kx-surface 검정 60vh]
+ "현직 엔지니어가 만드는 두 가지."
+ AI 제품, 그리고 맞춤 개발.
+
+═══════════════════════════════════════════════════════
+
+[TWO-UP CARDS]
+┌──Music──────────────┐ ┌──Custom Build──────────┐
+│ hero-bg.mp4 미니 │ │ 타이포 모션 │
+│ AI 음악 제품 │ │ 맞춤 개발 사업부 │
+│ ₩39,000~ │ │ 외주·웹·사주·블로그 │
+│ [Try now] │ │ [견적 문의] │
+└─────────────────────┘ └─────────────────────────┘
+
+═══════════════════════════════════════════════════════
+
+[MUSIC 섹션]
+- Features 3-step (Prompt / Visual / Publish)
+- 트윗 마퀴 (현 메인 데이터 그대로)
+
+═══════════════════════════════════════════════════════
+
+[CUSTOM BUILD 섹션]
+- 4 라인 카드 그리드 (외주 / 웹 / 사주 / 블로그)
+- 납품 5건 미리보기 (lib/freelance-portfolio 데이터)
+- [견적 문의하기] CTA → ContactModal('외주 개발 문의')
+
+═══════════════════════════════════════════════════════
+
+[FINAL CTA]
+"어느 쪽이든 시작하세요."
+[Music 팩 보기] [견적 문의]
+
+═══════════════════════════════════════════════════════
+
+[FOOTER]
+Music Custom Build Legal
+ 팩 상세 외주 개발 이용약관
+ 샘플 웹사이트 제작 개인정보
+ 스튜디오 AI 사주 환불
+ 블로그 자동화
+ 문의하기
+═══════════════════════════════════════════════════════
+```
+
+## 부록 B. 확정 라인 요약표
+
+| 결정 | 값 |
+|---|---|
+| 메인 안 | 안 2 (Brand Hero + 2-up Card) |
+| 헤더 안 | 안 b (Music \| Custom Build \| Try now) |
+| URL prefix | `/work`, `/music` |
+| redirect 매핑 | 10개 (next.config.ts) |
+| Custom Build 라인 수 | 4 (자동화는 외주 흡수) |
+| 사주 통합 | 단순 URL 마이그, 카탈로그 보류 |
+| 가격 표기 | 견적 문의 CTA만 (가격 결정 후 별도) |
+| 외주 진행 5건 | 비공개 (납품 5건만) |
+| /about 신설 | 미실시 (P3) |
+| Brand Hero 영상 | hero-bg.mp4 blur+opacity 35% |
+| Music 카드 가격 | ₩39,000~ 노출 |
+| Custom Build 카드 가격 | 노출 X (견적 문의로 분기) |
+| 마이그레이션 phase | A(인프라+신규) → B(원본 삭제+안 2) → C(검증) |