summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjspark2023-08-29 05:50:32 +0900
committerGitHub2023-08-28 22:50:32 +0200
commite659097ac3c0901fda4dfe51f53469c009443f2d (patch)
tree7d99816c6d324a537bc1a08cd2dfa655eaacdc73
parent5eb3448241875a232b4a1be006c5d2e427fdd03c (diff)
downloadIT.starlight-e659097ac3c0901fda4dfe51f53469c009443f2d.tar.gz
IT.starlight-e659097ac3c0901fda4dfe51f53469c009443f2d.tar.bz2
IT.starlight-e659097ac3c0901fda4dfe51f53469c009443f2d.zip
i18n(ko-KR): translate `i18n.mdx` (#584)
Co-authored-by: Chris Swithinbank <swithinbank@gmail.com>
-rw-r--r--docs/src/content/docs/ko/guides/customization.mdx400
-rw-r--r--docs/src/content/docs/ko/guides/i18n.mdx218
2 files changed, 618 insertions, 0 deletions
diff --git a/docs/src/content/docs/ko/guides/customization.mdx b/docs/src/content/docs/ko/guides/customization.mdx
new file mode 100644
index 00000000..d2ba89e4
--- /dev/null
+++ b/docs/src/content/docs/ko/guides/customization.mdx
@@ -0,0 +1,400 @@
+---
+title: Starlight ์‚ฌ์šฉ์ž ์ •์˜
+description: ๋กœ๊ณ , ์‚ฌ์šฉ์ž ์ •์˜ ๊ธ€๊ผด, ๋žœ๋”ฉ ํŽ˜์ด์ง€ ๋””์ž์ธ ๋“ฑ์„ ์‚ฌ์šฉํ•˜์—ฌ ๋‚˜๋งŒ์˜ Starlight ์‚ฌ์ดํŠธ๋ฅผ ๋งŒ๋“œ๋Š” ๋ฐฉ๋ฒ•์„ ์•Œ์•„๋ณด์„ธ์š”.
+---
+
+import { Tabs, TabItem } from '@astrojs/starlight/components';
+import FileTree from '../../../../components/file-tree.astro';
+
+Starlight๋Š” ํ•ฉ๋ฆฌ์ ์ธ ๊ธฐ๋ณธ ์Šคํƒ€์ผ๊ณผ ๊ธฐ๋Šฅ์„ ์ œ๊ณตํ•˜๋ฏ€๋กœ ๊ตฌ์„ฑ ์—†์ด ๋น ๋ฅด๊ฒŒ ์‹œ์ž‘ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. Starlight ์‚ฌ์ดํŠธ์˜ ๋ชจ์–‘๊ณผ ๋А๋‚Œ์„ ๋ณ€๊ฒฝํ•˜๋ ค๋Š” ๊ฒฝ์šฐ ์ด ๊ฐ€์ด๋“œ๋ฅผ ์ฐธ์กฐํ•˜์„ธ์š”.
+
+## ๋กœ๊ณ  ์ถ”๊ฐ€
+
+์‚ฌ์ดํŠธ ํ—ค๋”์— ๋กœ๊ณ ๋ฅผ ์ถ”๊ฐ€ํ•˜๋Š” ๊ฒƒ์€ Starlight ์‚ฌ์ดํŠธ์— ๋ธŒ๋žœ๋“œ๋ฅผ ์ถ”๊ฐ€ํ•˜๋Š” ๋น ๋ฅธ ๋ฐฉ๋ฒ•์ž…๋‹ˆ๋‹ค.
+
+1. `src/assets/` ๋””๋ ‰ํ† ๋ฆฌ์— ๋กœ๊ณ  ์ด๋ฏธ์ง€ ํŒŒ์ผ์„ ์ถ”๊ฐ€ํ•ฉ๋‹ˆ๋‹ค.
+
+ <FileTree>
+
+ - src/
+ - assets/
+ - **my-logo.svg**
+ - content/
+ - astro.config.mjs
+
+ </FileTree>
+
+2. `astro.config.mjs` ํŒŒ์ผ์— ์žˆ๋Š” [logo.src](/ko/reference/configuration/#logo) ์˜ต์…˜์˜ ๊ฐ’์œผ๋กœ ๋กœ๊ณ  ํŒŒ์ผ์˜ ๊ฒฝ๋กœ๋ฅผ ์ถ”๊ฐ€ํ•˜์„ธ์š”.
+
+ ```js
+ // astro.config.mjs
+ import { defineConfig } from 'astro/config';
+ import starlight from '@astrojs/starlight';
+
+ export default defineConfig({
+ integrations: [
+ starlight({
+ title: '๋กœ๊ณ ๋ฅผ ์‚ฌ์šฉํ•˜๋Š” ๋ฌธ์„œ',
+ logo: {
+ src: './src/assets/my-logo.svg',
+ },
+ }),
+ ],
+ });
+ ```
+
+๊ธฐ๋ณธ์ ์œผ๋กœ ๋กœ๊ณ ๋Š” ์‚ฌ์ดํŠธ์˜ `title`๊ณผ ํ•จ๊ป˜ ํ‘œ์‹œ๋ฉ๋‹ˆ๋‹ค. ๋กœ๊ณ  ์ด๋ฏธ์ง€์— ์‚ฌ์ดํŠธ ์ œ๋ชฉ์ด ์ด๋ฏธ ํฌํ•จ๋˜์–ด ์žˆ๋Š” ๊ฒฝ์šฐ, `replacementTitle` ์˜ต์…˜์„ ์„ค์ •ํ•˜์—ฌ ์ œ๋ชฉ ํ…์ŠคํŠธ๋ฅผ ์‹œ๊ฐ์ ์œผ๋กœ ์ˆจ๊ธธ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. `title` ํ…์ŠคํŠธ๋Š” ์Šคํฌ๋ฆฐ ๋ฆฌ๋”๋ฅผ ์œ„ํ•ด ๋‚จ์•„ ์žˆ๊ธฐ ๋•Œ๋ฌธ์— ํ—ค๋”๋Š” ์ ‘๊ทผ์„ฑ์ด ์œ ์ง€๋ฉ๋‹ˆ๋‹ค.
+
+```js
+starlight({
+ title: '๋กœ๊ณ ๋ฅผ ์‚ฌ์šฉํ•˜๋Š” ๋ฌธ์„œ',
+ logo: {
+ src: './src/assets/my-logo.svg',
+ replacesTitle: true,
+ },
+}),
+```
+
+### ๋ผ์ดํŠธ ๋ชจ๋“œ์™€ ๋‹คํฌ ๋ชจ๋“œ์—์„œ์˜ ๋กœ๊ณ  ๋ณ€ํ˜•
+
+๋ผ์ดํŠธ ๋ชจ๋“œ์™€ ๋‹คํฌ ๋ชจ๋“œ์—์„œ ๋‹ค๋ฅธ ๋ฒ„์ „์˜ ๋กœ๊ณ ๋ฅผ ํ‘œ์‹œํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+1. `src/assets/`์— ๊ฐ ๋ณ€ํ˜•์— ๋Œ€ํ•œ ์ด๋ฏธ์ง€ ํŒŒ์ผ์„ ์ถ”๊ฐ€ํ•ฉ๋‹ˆ๋‹ค.
+
+ <FileTree>
+
+ - src/
+ - assets/
+ - **light-logo.svg**
+ - **dark-logo.svg**
+ - content/
+ - astro.config.mjs
+
+ </FileTree>
+
+2. `astro.config.mjs` ํŒŒ์ผ์—์„œ `src` ๋Œ€์‹  `light` ๋ฐ `dark` ์˜ต์…˜์„ ์ „๋‹ฌํ•˜์—ฌ ๋กœ๊ณ  ๋ณ€ํ˜•์— ๋Œ€ํ•œ ๊ฒฝ๋กœ๋ฅผ ์ถ”๊ฐ€ํ•˜์„ธ์š”.
+
+ ```js
+ starlight({
+ title: '๋กœ๊ณ ๋ฅผ ์‚ฌ์šฉํ•˜๋Š” ๋ฌธ์„œ',
+ logo: {
+ light: './src/assets/light-logo.svg',
+ dark: './src/assets/dark-logo.svg',
+ },
+ }),
+ ```
+
+## ํŽ˜์ด์ง€ ๋ ˆ์ด์•„์›ƒ
+
+๊ธฐ๋ณธ์ ์œผ๋กœ Starlight ํŽ˜์ด์ง€๋Š” ์ „์—ญ ํƒ์ƒ‰ ์‚ฌ์ด๋“œ๋ฐ”์™€ ํ˜„์žฌ ํŽ˜์ด์ง€ ์ œ๋ชฉ์˜ ๋ชฉ์ฐจ๊ฐ€ ์žˆ๋Š” ๋ ˆ์ด์•„์›ƒ์„ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค.
+
+ํŽ˜์ด์ง€ frontmatter์— [`template: splash`](/ko/reference/frontmatter/#template)๋ฅผ ์„ค์ •ํ•˜์—ฌ ์‚ฌ์ด๋“œ๋ฐ” ์—†์ด ๋” ๋„“์€ ํŽ˜์ด์ง€ ๋ ˆ์ด์•„์›ƒ์„ ์ ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ์ด๋Š” ํŠนํžˆ ๋žœ๋”ฉ ํŽ˜์ด์ง€์— ํšจ๊ณผ์ ์ด๋ฉฐ [์ด ์‚ฌ์ดํŠธ์˜ ํ™ˆํŽ˜์ด์ง€](/ko)์—์„œ ์‹ค์ œ๋กœ ์ž‘๋™ํ•˜๋Š” ๊ฒƒ์„ ํ™•์ธํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+```md
+---
+# src/content/docs/index.md
+
+title: ๋žœ๋”ฉ ํŽ˜์ด์ง€
+template: splash
+---
+```
+
+## ๋ชฉ์ฐจ
+
+Starlight๋Š” ๋…์ž๊ฐ€ ์›ํ•˜๋Š” ์ œ๋ชฉ์œผ๋กœ ์‰ฝ๊ฒŒ ์ด๋™ํ•  ์ˆ˜ ์žˆ๋„๋ก ๊ฐ ํŽ˜์ด์ง€์— ๋ชฉ์ฐจ๋ฅผ ํ‘œ์‹œํ•ฉ๋‹ˆ๋‹ค. Starlight ํ†ตํ•ฉ์„ ํ†ตํ•ด ๋ชจ๋“  ํŽ˜์ด์ง€์˜ ๋ชฉ์ฐจ๋ฅผ ๋ณ€๊ฒฝํ•˜๊ฑฐ๋‚˜ ๋น„ํ™œ์„ฑํ™”ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ๋˜ํ•œ, frontmatter๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ ๊ฐ ํŽ˜์ด์ง€๋ณ„๋กœ ๋ชฉ์ฐจ๋ฅผ ๋ณ€๊ฒฝํ•  ์ˆ˜๋„ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+๊ธฐ๋ณธ์ ์œผ๋กœ `<h2>` ๋ฐ `<h3>` ์ œ๋ชฉ์ด ๋ชฉ์ฐจ์— ํฌํ•จ๋ฉ๋‹ˆ๋‹ค. ๋ชจ๋“  ํŽ˜์ด์ง€์˜ ๋ชฉ์ฐจ๋ฅผ ๋ณ€๊ฒฝํ•˜๋ ค๋ฉด [`tableOfContents`](/ko/reference/configuration/#tableofcontents) ์˜ `minHeadingLevel` ๋ฐ `maxHeadingLevel` ์˜ต์…˜์„ ์‚ฌ์šฉํ•˜์„ธ์š”. ๊ฐœ๋ณ„ ํŽ˜์ด์ง€์˜ ๊ธฐ๋ณธ ๋ชฉ์ฐจ๋ฅผ ๋ณ€๊ฒฝํ•˜๊ธฐ ์œ„ํ•ด์„œ๋Š” [frontmatter์— `tableOfContents`](/ko/reference/frontmatter/#tableofcontents) ์†์„ฑ์„ ์ถ”๊ฐ€ํ•˜์„ธ์š”.
+
+<Tabs>
+ <TabItem label="๊ฐœ๋ณ„ ํŽ˜์ด์ง€ ์„ค์ •">
+
+```md
+---
+# src/content/docs/example.md
+title: ๋ชฉ์ฐจ์— H2๋งŒ ์žˆ๋Š” ํŽ˜์ด์ง€
+tableOfContents:
+ minHeadingLevel: 2
+ maxHeadingLevel: 2
+---
+```
+
+ </TabItem>
+ <TabItem label="์ „์—ญ ์„ค์ •">
+
+```js
+// astro.config.mjs
+
+defineConfig({
+ integrations: [
+ starlight({
+ title: '',
+ tableOfContents: { minHeadingLevel: 2, maxHeadingLevel: 2 },
+ }),
+ ],
+});
+```
+
+ </TabItem>
+</Tabs>
+
+`tableOfContents` ์˜ต์…˜์˜ ๊ฐ’์„ `false`๋กœ ์„ค์ •ํ•˜์—ฌ ๋ชจ๋“  ํŽ˜์ด์ง€์˜ ๋ชฉ์ฐจ๋ฅผ ๋น„ํ™œ์„ฑํ™” ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+<Tabs>
+ <TabItem label="๊ฐœ๋ณ„ ํŽ˜์ด์ง€ ์„ค์ •">
+
+```md
+---
+# src/content/docs/example.md
+title: ๋ชฉ์ฐจ๊ฐ€ ์—†๋Š” ํŽ˜์ด์ง€
+tableOfContents: false
+---
+```
+
+ </TabItem>
+ <TabItem label="์ „์—ญ ์„ค์ •">
+
+```js
+// astro.config.mjs
+
+defineConfig({
+ integrations: [
+ starlight({
+ title: '๋ชจ๋“  ๋ชฉ์ฐจ๊ฐ€ ๋น„ํ™œ์„ฑํ™”๋œ ๋ฌธ์„œ',
+ tableOfContents: false,
+ }),
+ ],
+});
+```
+
+ </TabItem>
+</Tabs>
+
+## ์†Œ์…œ ๋งํฌ
+
+Starlight์—๋Š” Starlight ํ†ตํ•ฉ์˜ [`social`](/ko/reference/configuration/#social) ์˜ต์…˜์„ ํ†ตํ•ด ์‚ฌ์ดํŠธ ํ—ค๋”์— ์†Œ์…œ ๋ฏธ๋””์–ด ๊ณ„์ •์„ ๋งํฌํ•˜๋Š” ๊ธฐ๋Šฅ์ด ๋‚ด์žฅ๋˜์–ด ์žˆ์Šต๋‹ˆ๋‹ค.
+
+ํ˜„์žฌ Bitbucket, Codeberg, CodePen, Discord, GitHub, GitLab, Gitter, Instagram, LinkedIn, Mastodon, Microsoft Teams, Threads, Twitch, Twitter ๋ฐ Youtube์— ๋Œ€ํ•œ ๋งํฌ๊ฐ€ ์ง€์›๋ฉ๋‹ˆ๋‹ค. ๋‹ค๋ฅธ ์„œ๋น„์Šค์— ๋Œ€ํ•œ ์ง€์›์ด ํ•„์š”ํ•˜๋ฉด GitHub๋‚˜ Discord๋ฅผ ํ†ตํ•ด ์•Œ๋ ค์ฃผ์„ธ์š”!
+
+```js
+// astro.config.mjs
+import { defineConfig } from 'astro/config';
+import starlight from '@astrojs/starlight';
+
+export default defineConfig({
+ integrations: [
+ starlight({
+ title: '์†Œ์…œ ๋งํฌ๋ฅผ ์‚ฌ์šฉํ•˜๋Š” ๋ฌธ์„œ',
+ social: {
+ discord: 'https://astro.build/chat',
+ github: 'https://github.com/withastro/starlight',
+ },
+ }),
+ ],
+});
+```
+
+## ๋งํฌ ํŽธ์ง‘
+
+Starlight๋Š” ๊ฐ ํŽ˜์ด์ง€์˜ ์•„๋ž˜์— "ํŽ˜์ด์ง€ ํŽธ์ง‘" ๋งํฌ๋ฅผ ํ‘œ์‹œํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ์ด๋ ‡๊ฒŒ ํ•˜๋ฉด ๋…์ž๊ฐ€ ๋ฌธ์„œ ๊ฐœ์„ ์„ ์œ„ํ•ด ํŽธ์ง‘ํ•  ํŒŒ์ผ์„ ์‰ฝ๊ฒŒ ์ฐพ์„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ํŠนํžˆ ์˜คํ”ˆ ์†Œ์Šค ํ”„๋กœ์ ํŠธ์˜ ๊ฒฝ์šฐ ์ด๋Š” ์ปค๋ฎค๋‹ˆํ‹ฐ์˜ ๊ธฐ์—ฌ๋ฅผ ์žฅ๋ คํ•˜๋Š” ๋ฐ ๋„์›€์ด ๋  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+ํŽธ์ง‘ ๋งํฌ๋ฅผ ํ™œ์„ฑํ™”ํ•˜๋ ค๋ฉด [`editLink.baseUrl`](/ko/reference/configuration/#editlink)๋ฅผ Starlight ํ†ตํ•ฉ ๊ตฌ์„ฑ์—์„œ ์ €์žฅ์†Œ๋ฅผ ํŽธ์ง‘ํ•˜๋Š” ๋ฐ ์‚ฌ์šฉ๋˜๋Š” URL๋กœ ์„ค์ •ํ•˜์„ธ์š”. `editLink.baseUrl` ๊ฐ’์€ ์ „์ฒด ํŽธ์ง‘ ๋งํฌ๋ฅผ ํ˜•์„ฑํ•˜๊ธฐ ์œ„ํ•ด ํ˜„์žฌ ํŽ˜์ด์ง€์˜ ๊ฒฝ๋กœ ์•ž์— ์ถ”๊ฐ€๋ฉ๋‹ˆ๋‹ค.
+
+์ผ๋ฐ˜์ ์ธ ํŒจํ„ด์€ ๋‹ค์Œ๊ณผ ๊ฐ™์Šต๋‹ˆ๋‹ค.
+
+- GitHub: `https://github.com/USER_NAME/REPO_NAME/edit/BRANCH_NAME/`
+- GitLab: `https://gitlab.com/USER_NAME/REPO_NAME/-/edit/BRANCH_NAME/`
+
+Starlight ํ”„๋กœ์ ํŠธ๊ฐ€ ์ €์žฅ์†Œ์˜ ๋ฃจํŠธ์— ์—†๋Š” ๊ฒฝ์šฐ ๊ธฐ๋ณธ URL ๋์— ํ”„๋กœ์ ํŠธ ๊ฒฝ๋กœ๋ฅผ ํฌํ•จํ•ฉ๋‹ˆ๋‹ค.
+
+์ด ์˜ˆ์—์„œ๋Š” GitHub์˜ `withastro/starlight` ์ €์žฅ์†Œ์˜ `main` ๋ธŒ๋žœ์น˜์— ์žˆ๋Š” `docs/` ํ•˜์œ„ ๋””๋ ‰ํ† ๋ฆฌ์— ์žˆ๋Š” Starlight ๋ฌธ์„œ์— ๋Œ€ํ•ด ๊ตฌ์„ฑ๋œ ํŽธ์ง‘ ๋งํฌ๋ฅผ ๋ณด์—ฌ์ค๋‹ˆ๋‹ค.
+
+```js
+// astro.config.mjs
+import { defineConfig } from 'astro/config';
+import starlight from '@astrojs/starlight';
+
+export default defineConfig({
+ integrations: [
+ starlight({
+ title: 'ํŽธ์ง‘ ๋งํฌ๊ฐ€ ์žˆ๋Š” ๋ฌธ์„œ',
+ editLink: {
+ baseUrl: 'https://github.com/withastro/starlight/edit/main/docs/',
+ },
+ }),
+ ],
+});
+```
+
+## ์‚ฌ์šฉ์ž ์ •์˜ 404 ํŽ˜์ด์ง€
+
+Starlight ์‚ฌ์ดํŠธ๋Š” ๊ธฐ๋ณธ์ ์œผ๋กœ ๊ฐ„๋‹จํ•œ 404 ํŽ˜์ด์ง€๋ฅผ ํ‘œ์‹œํ•ฉ๋‹ˆ๋‹ค. `src/content/docs/` ๋””๋ ‰ํ† ๋ฆฌ์— `404.md`(๋˜๋Š” `404.mdx`) ํŒŒ์ผ์„ ์ถ”๊ฐ€ํ•˜์—ฌ ์ด๋ฅผ ๋ณ€๊ฒฝํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค:
+
+<FileTree>
+
+- src/
+ - content/
+ - docs/
+ - **404.md**
+ - index.md
+- astro.config.mjs
+
+</FileTree>
+
+404 ํŽ˜์ด์ง€์—์„œ Starlight์˜ ๋ชจ๋“  ํŽ˜์ด์ง€ ๋ ˆ์ด์•„์›ƒ๊ณผ ์‚ฌ์šฉ์ž ์ •์˜ ๊ธฐ์ˆ ์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด ๊ธฐ๋ณธ 404 ํŽ˜์ด์ง€๋Š” frontmatter์—์„œ [`splash` ํ…œํ”Œ๋ฆฟ](#ํŽ˜์ด์ง€-๋ ˆ์ด์•„์›ƒ)๊ณผ [`hero`](/ko/reference/frontmatter/#hero) ์ปดํฌ๋„ŒํŠธ๋ฅผ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค.
+
+````md
+```md
+---
+title: '404'
+template: splash
+editUrl: false
+hero:
+ title: '404'
+ tagline: ํŽ˜์ด์ง€๋ฅผ ์ฐพ์„ ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค. URL์„ ํ™•์ธํ•˜๊ฑฐ๋‚˜ ๊ฒ€์ƒ‰์ฐฝ์„ ์‚ฌ์šฉํ•ด ๋ณด์„ธ์š”.
+---
+```
+````
+
+## ์‚ฌ์šฉ์ž ์ •์˜ ๊ธ€๊ผด
+
+๊ธฐ๋ณธ์ ์œผ๋กœ Starlight๋Š” ๋ชจ๋“  ํ…์ŠคํŠธ์— ๋Œ€ํ•ด ์‚ฌ์šฉ์ž์˜ ๋กœ์ปฌ ์žฅ์น˜์—์„œ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ๋Š” sans-serif ๊ธ€๊ผด์„ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค. ์ด๋ฅผ ํ†ตํ•ด ๋Œ€์šฉ๋Ÿ‰ ๊ธ€๊ผด ํŒŒ์ผ์„ ๋‹ค์šด๋กœ๋“œํ•˜๊ธฐ ์œ„ํ•œ ์ถ”๊ฐ€ ๋Œ€์—ญํญ ์—†์ด ๊ฐ ์‚ฌ์šฉ์ž์—๊ฒŒ ์นœ์ˆ™ํ•œ ๊ธ€๊ผด๋กœ ๋ฌธ์„œ๋ฅผ ๋น ๋ฅด๊ฒŒ ๋กœ๋“œํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+Starlight ์‚ฌ์ดํŠธ์— ์‚ฌ์šฉ์ž ์ •์˜ ๊ธ€๊ผด์„ ์ถ”๊ฐ€ํ•ด์•ผ ํ•˜๋Š” ๊ฒฝ์šฐ, ์‚ฌ์šฉ์ž ์ •์˜ CSS ํŒŒ์ผ์ด๋‚˜ ๋‹ค๋ฅธ [Astro ์Šคํƒ€์ผ๋ง ๊ธฐ์ˆ ](https://docs.astro.build/ko/guides/styling/)์„ ์ด์šฉํ•ด ๊ธ€๊ผด์„ ์„ค์ •ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+### ๊ธ€๊ผด ์„ค์ •
+
+์ด๋ฏธ ๊ธ€๊ผด ํŒŒ์ผ์ด ์žˆ๋Š” ๊ฒฝ์šฐ [๋กœ์ปฌ ์„ค์ • ๊ฐ€์ด๋“œ](#๋กœ์ปฌ-๊ธ€๊ผด-ํŒŒ์ผ-์„ค์ •)๋ฅผ ๋”ฐ๋ฅด์„ธ์š”. Google Fonts๋ฅผ ์‚ฌ์šฉํ•˜๋ ค๋ฉด [Fontsource ์„ค์ • ๊ฐ€์ด๋“œ](#fontsource-๊ธ€๊ผด-์„ค์ •)๋ฅผ ๋”ฐ๋ฅด์„ธ์š”.
+
+#### ๋กœ์ปฌ ๊ธ€๊ผด ํŒŒ์ผ ์„ค์ •
+
+1. `src/fonts/` ๋””๋ ‰ํ† ๋ฆฌ์— ๊ธ€๊ผด ํŒŒ์ผ์„ ์ถ”๊ฐ€ํ•˜๊ณ  ๋นˆ `font-face.css` ํŒŒ์ผ์„ ๋งŒ๋“œ์„ธ์š”.
+
+ <FileTree>
+
+ - src/
+ - content/
+ - fonts/
+ - **CustomFont.woff2**
+ - **font-face.css**
+ - astro.config.mjs
+
+ </FileTree>
+
+2. `src/fonts/font-face.css`์— ๊ฐ ๊ธ€๊ผด์— ๋Œ€ํ•œ [`@font-face` ์„ ์–ธ](https://developer.mozilla.org/ko/docs/Web/CSS/@font-face)์„ ์ถ”๊ฐ€ํ•˜์„ธ์š”. `url()` ํ•จ์ˆ˜์—์„œ ๊ธ€๊ผด ํŒŒ์ผ์˜ ์ƒ๋Œ€ ๊ฒฝ๋กœ๋ฅผ ์‚ฌ์šฉํ•˜์„ธ์š”.
+
+ ```css
+ /* src/fonts/font-face.css */
+
+ @font-face {
+ font-family: 'Custom Font';
+ /* `url()`์—์„œ ๋กœ์ปฌ ๊ธ€๊ผด ํŒŒ์ผ์˜ ์ƒ๋Œ€ ๊ฒฝ๋กœ๋ฅผ ์‚ฌ์šฉํ•˜์„ธ์š”. */
+ src: url('./CustomFont.woff2') format('woff2');
+ font-weight: normal;
+ font-style: normal;
+ font-display: swap;
+ }
+ ```
+
+3. `astro.config.mjs`์— ์žˆ๋Š” Starlight์˜ `customCss` ๋ฐฐ์—ด์— `font-face.css` ํŒŒ์ผ์˜ ๊ฒฝ๋กœ๋ฅผ ์ถ”๊ฐ€ํ•˜์„ธ์š”.
+
+ ```js
+ // astro.config.mjs
+ import { defineConfig } from 'astro/config';
+ import starlight from '@astrojs/starlight';
+
+ export default defineConfig({
+ integrations: [
+ starlight({
+ title: '์‚ฌ์šฉ์ž ์ •์˜ ๊ธ€๊ผด์„ ์‚ฌ์šฉํ•˜๋Š” ๋ฌธ์„œ',
+ customCss: [
+ // @font-face CSS ํŒŒ์ผ์˜ ์ƒ๋Œ€ ๊ฒฝ๋กœ์ž…๋‹ˆ๋‹ค.
+ './src/fonts/font-face.css',
+ ],
+ }),
+ ],
+ });
+ ```
+
+#### Fontsource ๊ธ€๊ผด ์„ค์ •
+
+[Fontsource](https://fontsource.org/) ํ”„๋กœ์ ํŠธ๋Š” Google Fonts ๋ฐ ๊ธฐํƒ€ ์˜คํ”ˆ ์†Œ์Šค ๊ธ€๊ผด ์‚ฌ์šฉ์„ ๋‹จ์ˆœํ™”ํ•ฉ๋‹ˆ๋‹ค. ์‚ฌ์šฉํ•˜๋ ค๋Š” ๊ธ€๊ผด์„ ์„ค์น˜ํ•  ์ˆ˜ ์žˆ๋Š” npm ๋ชจ๋“ˆ๊ณผ ํ”„๋กœ์ ํŠธ์— ์ถ”๊ฐ€ํ•  CSS ํŒŒ์ผ์„ ์ œ๊ณตํ•ฉ๋‹ˆ๋‹ค.
+
+1. [Fontsource ์นดํƒˆ๋กœ๊ทธ](https://fontsource.org/)์—์„œ ์‚ฌ์šฉํ•˜๋ ค๋Š” ๊ธ€๊ผด์„ ์ฐพ์œผ์„ธ์š”. ์ด ์˜ˆ์—์„œ๋Š” [IBM Plex Serif](https://fontsource.org/fonts/ibm-plex-serif)๋ฅผ ์‚ฌ์šฉํ•ฉ๋‹ˆ๋‹ค.
+
+2. ์„ ํƒํ•œ ๊ธ€๊ผด์— ๋Œ€ํ•œ ํŒจํ‚ค์ง€๋ฅผ ์„ค์น˜ํ•ฉ๋‹ˆ๋‹ค. Fontsource ๊ธ€๊ผด ํŽ˜์ด์ง€์—์„œ โ€œInstallโ€์„ ํด๋ฆญํ•˜๋ฉด ํŒจํ‚ค์ง€ ์ด๋ฆ„์„ ์ฐพ์„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+ <Tabs>
+
+ <TabItem label="npm">
+
+ ```sh
+ npm install @fontsource/ibm-plex-serif
+ ```
+
+ </TabItem>
+
+ <TabItem label="pnpm">
+
+ ```sh
+ pnpm install @fontsource/ibm-plex-serif
+ ```
+
+ </TabItem>
+
+ <TabItem label="Yarn">
+
+ ```sh
+ yarn add @fontsource/ibm-plex-serif
+ ```
+
+ </TabItem>
+
+ </Tabs>
+
+3. `astro.config.mjs`์— ์žˆ๋Š” Starlight์˜ `customCss` ๋ฐฐ์—ด์— Fontsource CSS ํŒŒ์ผ์„ ์ถ”๊ฐ€ํ•ฉ๋‹ˆ๋‹ค.
+
+ ```js
+ // astro.config.mjs
+ import { defineConfig } from 'astro/config';
+ import starlight from '@astrojs/starlight';
+
+ export default defineConfig({
+ integrations: [
+ starlight({
+ title: '์‚ฌ์šฉ์ž ์ •์˜ ๊ธ€๊ผด์„ ์‚ฌ์šฉํ•˜๋Š” ๋ฌธ์„œ',
+ customCss: [
+ // ๋ณดํ†ต ๋ฐ ์•ฝ๊ฐ„ ๊ตต์€ ๊ธ€๊ผด ๋‘๊ป˜์— ๋Œ€ํ•œ Fontsource ํŒŒ์ผ์ž…๋‹ˆ๋‹ค.
+ '@fontsource/ibm-plex-serif/400.css',
+ '@fontsource/ibm-plex-serif/600.css',
+ ],
+ }),
+ ],
+ });
+ ```
+
+ Fontsource๋Š” ๊ฐ ๊ธ€๊ผด์— ๋Œ€ํ•ด ์—ฌ๋Ÿฌ CSS ํŒŒ์ผ์„ ์ œ๊ณตํ•ฉ๋‹ˆ๋‹ค. ๋‹ค๋ฅธ ๊ตต๊ธฐ ๋ฐ ์Šคํƒ€์ผ์„ ํฌํ•จํ•˜๋Š” ๋ฐฉ๋ฒ•์ด ๊ถ๊ธˆํ•˜๋‹ค๋ฉด [Fontsource ๋ฌธ์„œ](https://fontsource.org/docs/getting-started/install#4-weights-and-styles)๋ฅผ ์ฐธ์กฐํ•˜์„ธ์š”.
+
+### ๊ธ€๊ผด ์‚ฌ์šฉ
+
+์„ค์ •ํ•œ ๊ธ€๊ผด์„ ์‚ฌ์ดํŠธ์— ์ ์šฉํ•˜๋ ค๋ฉด [์‚ฌ์šฉ์ž ์ •์˜ CSS ํŒŒ์ผ](/ko/guides/css-and-tailwind/#custom-css-styles)์—์„œ ์„ ํƒํ•œ ๊ธ€๊ผด ์ด๋ฆ„์„ ์‚ฌ์šฉํ•˜์„ธ์š”. ์˜ˆ๋ฅผ ๋“ค์–ด Starlight์˜ ๊ธฐ๋ณธ ๊ธ€๊ผด์„ ๋ณ€๊ฒฝํ•˜๋ ค๋ฉด ์‚ฌ์šฉ์ž ์ •์˜ ์†์„ฑ์ธ `--sl-font`๋ฅผ ์„ค์ •ํ•˜์„ธ์š”.
+
+```css
+/* src/styles/custom.css */
+
+:root {
+ --sl-font: 'IBM Plex Serif', serif;
+}
+```
+
+๊ธ€๊ผด์„ ๋” ์„ ํƒ์ ์œผ๋กœ ์ ์šฉํ•˜๋ ค๋ฉด ๋” ๋งŽ์€ ํƒ€๊ฒŸ CSS๋ฅผ ์ž‘์„ฑํ•  ์ˆ˜๋„ ์žˆ์Šต๋‹ˆ๋‹ค.
+์˜ˆ๋ฅผ ๋“ค์–ด ๋‹ค์Œ๊ณผ ๊ฐ™์€ ๋ฐฉ๋ฒ•์œผ๋กœ ๋ฉ”์ธ ์ฝ˜ํ…์ธ ์—๋งŒ ๊ธ€๊ผด์„ ์„ค์ •ํ•˜๊ณ  ์‚ฌ์ด๋“œ๋ฐ”์—๋Š” ๊ธ€๊ผด์„ ์„ค์ •ํ•˜์ง€ ์•Š์„ ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+```css
+/* src/styles/custom.css */
+
+main {
+ font-family: 'IBM Plex Serif', serif;
+}
+```
+
+[์‚ฌ์šฉ์ž ์ •์˜ CSS ์‚ฌ์šฉ๋ฒ•](/ko/guides/css-and-tailwind/#์‚ฌ์šฉ์ž-์ •์˜-css-์Šคํƒ€์ผ)์— ๋”ฐ๋ผ ์‚ฌ์ดํŠธ์— ์Šคํƒ€์ผ์„ ์ถ”๊ฐ€ํ•˜์„ธ์š”.
diff --git a/docs/src/content/docs/ko/guides/i18n.mdx b/docs/src/content/docs/ko/guides/i18n.mdx
new file mode 100644
index 00000000..4c7c4826
--- /dev/null
+++ b/docs/src/content/docs/ko/guides/i18n.mdx
@@ -0,0 +1,218 @@
+---
+title: ๊ตญ์ œํ™” (i18n)
+description: ์—ฌ๋Ÿฌ ์–ธ์–ด๋ฅผ ์ง€์›ํ•˜๋„๋ก Starlight ์‚ฌ์ดํŠธ๋ฅผ ๊ตฌ์„ฑํ•˜๋Š” ๋ฐฉ๋ฒ•์„ ์•Œ์•„๋ณด์„ธ์š”.
+---
+
+import FileTree from '../../../../components/file-tree.astro';
+
+Starlight๋Š” ๋ผ์šฐํŒ…, ๋Œ€์ฒด ์ฝ˜ํ…์ธ  ๋ฐ ์ „์ฒด RTL(์˜ค๋ฅธ์ชฝ์—์„œ ์™ผ์ชฝ์œผ๋กœ) ์–ธ์–ด ์ง€์›์„ ํฌํ•จํ•˜์—ฌ ๋‹ค๊ตญ์–ด ์‚ฌ์ดํŠธ์— ๋Œ€ํ•œ ๊ธฐ๋ณธ ์ง€์›์„ ์ œ๊ณตํ•ฉ๋‹ˆ๋‹ค.
+
+## i18n ๊ตฌ์„ฑ
+
+1. Starlight ํ†ตํ•ฉ์— [`locales`](/ko/reference/configuration/#locales) ๋ฐ [`defaultLocale`](/ko/reference/configuration/#defaultlocale)์„ ์ „๋‹ฌํ•˜์—ฌ ์‚ฌ์ดํŠธ๊ฐ€ ์ง€์›ํ•ด์•ผ ํ•  ์–ธ์–ด์— ๋Œ€ํ•ด ์•Œ๋ ค์ฃผ์„ธ์š”.
+
+ ```js
+ // astro.config.mjs
+ import { defineConfig } from 'astro/config';
+ import starlight from '@astrojs/starlight';
+
+ export default defineConfig({
+ integrations: [
+ starlight({
+ title: '๋‚˜์˜ ๋ฌธ์„œ',
+ // ์‚ฌ์ดํŠธ์˜ ๊ธฐ๋ณธ ์–ธ์–ด๋ฅผ ์˜์–ด๋กœ ์„ค์ •ํ•ฉ๋‹ˆ๋‹ค.
+ defaultLocale: 'en',
+ locales: {
+ // ์˜์–ด ๋ฌธ์„œ๋Š” `src/content/docs/en/`์— ์žˆ์Šต๋‹ˆ๋‹ค.
+ en: {
+ label: 'English',
+ },
+ // ์ค‘๊ตญ์–ด ๊ฐ„์ฒด ๋ฌธ์„œ๋Š” `src/content/docs/zh/`์— ์žˆ์Šต๋‹ˆ๋‹ค.
+ zh: {
+ label: '็ฎ€ไฝ“ไธญๆ–‡',
+ lang: 'zh-CN',
+ },
+ // ์•„๋ž์–ด ๋ฌธ์„œ๋Š” `src/content/docs/ar/`์— ์žˆ์Šต๋‹ˆ๋‹ค.
+ ar: {
+ label: 'ุงู„ุนุฑุจูŠุฉ',
+ dir: 'rtl',
+ },
+ },
+ }),
+ ],
+ });
+ ```
+
+ `defaultLocale`์€ ๋Œ€์ฒด ์ฝ˜ํ…์ธ  ๋ฐ UI ๋ผ๋ฒจ์— ์‚ฌ์šฉ๋˜๋ฏ€๋กœ ์ฝ˜ํ…์ธ  ์ž‘์„ฑ์„ ์‹œ์ž‘ํ•  ๊ฐ€๋Šฅ์„ฑ์ด ๊ฐ€์žฅ ๋†’๊ฑฐ๋‚˜ ์ด๋ฏธ ์ฝ˜ํ…์ธ ๊ฐ€ ์žˆ๋Š” ์–ธ์–ด๋กœ ์„ ํƒํ•˜์„ธ์š”.
+
+2. `src/content/docs/`์— ๊ฐ ์–ธ์–ด์— ๋Œ€ํ•œ ๋””๋ ‰ํ† ๋ฆฌ๋ฅผ ๋งŒ๋“ญ๋‹ˆ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด ์œ„์—์„œ ์‚ฌ์šฉํ•œ ๊ตฌ์„ฑ์˜ ๊ฒฝ์šฐ ๋‹ค์Œ๊ณผ ๊ฐ™์ด ๋””๋ ‰ํ† ๋ฆฌ๋ฅผ ์ƒ์„ฑํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+ <FileTree>
+
+ - src/
+ - content/
+ - docs/
+ - ar/
+ - en/
+ - zh/
+
+ </FileTree>
+
+3. ์ด์ œ ์–ธ์–ด ๋””๋ ‰ํ† ๋ฆฌ์— ์ฝ˜ํ…์ธ  ํŒŒ์ผ์„ ์ถ”๊ฐ€ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ์—ฌ๋Ÿฌ ์–ธ์–ด๋กœ ์ž‘์„ฑ๋œ ํŽ˜์ด์ง€๋ฅผ ์—ฐ๊ฒฐํ•˜๊ธฐ ์œ„ํ•ด ๊ฐ™์€ ์ด๋ฆ„์˜ ํŒŒ์ผ์„ ์‚ฌ์šฉํ•˜๋ฉด Starlight์˜ ๋ชจ๋“  i18n ๊ธฐ๋Šฅ(๋Œ€์ฒด ์ฝ˜ํ…์ธ , ๋ฒˆ์—ญ ์•Œ๋ฆผ ๋“ฑ)์„ ํ™œ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+ ์˜ˆ๋ฅผ ๋“ค์–ด, ์•„๋ž์–ด์™€ ์˜์–ด ํ™ˆํŽ˜์ด์ง€๋ฅผ ๊ฐ๊ฐ ๋‚˜ํƒ€๋‚ด๋ ค๋ฉด `ar/index.md` ๋ฐ `en/index.md`๋ฅผ ๋งŒ๋“ญ๋‹ˆ๋‹ค.
+
+### ๋ฃจํŠธ ๋กœ์ผ€์ผ ์‚ฌ์šฉ
+
+๊ฒฝ๋กœ์— i18n ์ ‘๋‘์‚ฌ๊ฐ€ ์—†๋Š” ์–ธ์–ด๋ฅผ ์ œ๊ณตํ•˜๋ ค๋ฉด "๋ฃจํŠธ" ๋กœ์ผ€์ผ์„ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด ์˜์–ด๊ฐ€ ๋ฃจํŠธ ๋กœ์ผ€์ผ์ธ ๊ฒฝ์šฐ ์˜์–ด ํŽ˜์ด์ง€ ๊ฒฝ๋กœ๋Š” `/en/about` ๋Œ€์‹  `/about`๊ฐ€ ๋ฉ๋‹ˆ๋‹ค.
+
+๋ฃจํŠธ ๋กœ์ผ€์ผ์„ ์„ค์ •ํ•˜๋ ค๋ฉด `locales` ๊ตฌ์„ฑ์—์„œ `root` ํ‚ค๋ฅผ ์‚ฌ์šฉํ•˜์„ธ์š”. ๋ฃจํŠธ ๋กœ์ผ€์ผ์ด ์ฝ˜ํ…์ธ ์˜ ๊ธฐ๋ณธ ๋กœ์ผ€์ผ์ด๊ธฐ๋„ ํ•œ ๊ฒฝ์šฐ `defaultLocale`์„ ์ œ๊ฑฐํ•˜๊ฑฐ๋‚˜ ๊ฐ’์„ `root`๋กœ ์„ค์ •ํ•˜์„ธ์š”.
+
+```js
+// astro.config.mjs
+import { defineConfig } from 'astro/config';
+import starlight from '@astrojs/starlight';
+
+export default defineConfig({
+ integrations: [
+ starlight({
+ title: '๋‚˜์˜ ๋ฌธ์„œ',
+ defaultLocale: 'root', // ์„ ํƒ์ 
+ locales: {
+ root: {
+ label: 'English',
+ lang: 'en', // ๋ฃจํŠธ ๋กœ์ผ€์ผ์€ lang์ด ๋ฐ˜๋“œ์‹œ ํ•„์š”ํ•ฉ๋‹ˆ๋‹ค.
+ },
+ zh: {
+ label: '็ฎ€ไฝ“ไธญๆ–‡',
+ lang: 'zh-CN',
+ },
+ },
+ }),
+ ],
+});
+```
+
+๋ฃจํŠธ ๋กœ์ผ€์ผ์„ ์‚ฌ์šฉํ•˜๋Š” ๊ฒฝ์šฐ ํ•ด๋‹น ์–ธ์–ด๋กœ ์ž‘์„ฑ๋œ ํŽ˜์ด์ง€๋ฅผ ์ „์šฉ ์–ธ์–ด ํด๋” ๋Œ€์‹  `src/content/docs/`์— ์ง์ ‘ ๋ณด๊ด€ํ•˜์„ธ์š”. ์˜ˆ๋ฅผ ๋“ค์–ด ์œ„ ๊ตฌ์„ฑ์„ ์‚ฌ์šฉํ•  ๋•Œ ์˜์–ด์™€ ์ค‘๊ตญ์–ด์— ๋Œ€ํ•œ ํ™ˆ ํŽ˜์ด์ง€ ํŒŒ์ผ์€ ๋‹ค์Œ๊ณผ ๊ฐ™์Šต๋‹ˆ๋‹ค.
+
+<FileTree>
+
+- src/
+ - content/
+ - docs/
+ - **index.md**
+ - zh/
+ - **index.md**
+
+</FileTree>
+
+#### ๋‹จ์ผ ์–ธ์–ด๋ฅผ ์‚ฌ์šฉํ•˜๋Š” ์‚ฌ์ดํŠธ
+
+๊ธฐ๋ณธ์ ์œผ๋กœ Starlight๋Š” ๋‹จ์ผ ์–ธ์–ด(์˜์–ด) ์‚ฌ์ดํŠธ์ž…๋‹ˆ๋‹ค.
+๋‹ค๋ฅธ ์–ธ์–ด๋กœ ๋‹จ์ผ ์–ธ์–ด ์‚ฌ์ดํŠธ๋ฅผ ๋งŒ๋“ค๋ ค๋ฉด `locales` ๊ตฌ์„ฑ์—์„œ `root`๋ฅผ ํ•ด๋‹น ์–ธ์–ด๋กœ ์„ค์ •ํ•˜์„ธ์š”.
+
+```js
+// astro.config.mjs
+import { defineConfig } from 'astro/config';
+import starlight from '@astrojs/starlight';
+
+export default defineConfig({
+ integrations: [
+ starlight({
+ title: '๋‚˜์˜ ๋ฌธ์„œ',
+ locales: {
+ root: {
+ label: 'ํ•œ๊ตญ์–ด',
+ lang: 'ko',
+ },
+ },
+ }),
+ ],
+});
+```
+
+์ด๋ฅผ ํ†ตํ•ด ์–ธ์–ด ์„ ํƒ๊ธฐ์™€ ๊ฐ™์€ ๋‹ค๊ตญ์–ด ์‚ฌ์ดํŠธ์— ๋Œ€ํ•œ ๋‹ค๋ฅธ ๊ตญ์ œํ™” ๊ธฐ๋Šฅ์„ ํ™œ์„ฑํ™”ํ•˜์ง€ ์•Š๊ณ ๋„ Starlight์˜ ๊ธฐ๋ณธ ์–ธ์–ด๋ฅผ ๋ณ€๊ฒฝํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+## ๋Œ€์ฒด ์ฝ˜ํ…์ธ 
+
+Starlight๋Š” ๊ท€ํ•˜๊ฐ€ ๋ชจ๋“  ์–ธ์–ด๋กœ ๊ฐ™์€ ํŽ˜์ด์ง€๋ฅผ ์ƒ์„ฑํ•  ๊ฒƒ์„ ๊ธฐ๋Œ€ํ•ฉ๋‹ˆ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด `en/about.md` ํŒŒ์ผ์ด ์žˆ๋Š” ๊ฒฝ์šฐ ์ง€์›ํ•˜๋Š” ๊ฐ ์–ธ์–ด์— ๋Œ€ํ•ด `about.md`๋ฅผ ๋งŒ๋“ญ๋‹ˆ๋‹ค. ์ด๋ฅผ ํ†ตํ•ด Starlight๋Š” ์•„์ง ๋ฒˆ์—ญ๋˜์ง€ ์•Š์€ ํŽ˜์ด์ง€์— ์ž๋™ ๋Œ€์ฒด ์ฝ˜ํ…์ธ ๋ฅผ ์ œ๊ณตํ•ฉ๋‹ˆ๋‹ค.
+
+ํŠน์ • ์–ธ์–ด์— ๋Œ€ํ•œ ๋ฒˆ์—ญ์ด ์•„์ง ์ œ๊ณต๋˜์ง€ ์•Š๋Š” ๊ฒฝ์šฐ Starlight๋Š” ๋…์ž์—๊ฒŒ ํ•ด๋‹น ํŽ˜์ด์ง€์˜ ์ฝ˜ํ…์ธ ๋ฅผ ๊ธฐ๋ณธ ์–ธ์–ด(`defaultLocale`์„ ํ†ตํ•ด ์„ค์ •๋œ ์–ธ์–ด)๋กœ ํ‘œ์‹œํ•ฉ๋‹ˆ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด, About ํŽ˜์ด์ง€์˜ ํ”„๋ž‘์Šค์–ด ๋ฒ„์ „์„ ์•„์ง ๋งŒ๋“ค์ง€ ์•Š์•˜๊ณ  ๊ธฐ๋ณธ ์–ธ์–ด๊ฐ€ ์˜์–ด์ธ ๊ฒฝ์šฐ `/fr/about`์— ๋ฐฉ๋ฌธํ•œ ๋…์ž๋Š” ์ด ํŽ˜์ด์ง€๊ฐ€ ์•„์ง ๋ฒˆ์—ญ๋˜์ง€ ์•Š์•˜๋‹ค๋Š” ์•Œ๋ฆผ๊ณผ ํ•จ๊ป˜ `/en/about`์— ์žˆ๋Š” ์˜์–ด ์ฝ˜ํ…์ธ ๋ฅผ ๋ณด๊ฒŒ ๋ฉ๋‹ˆ๋‹ค. ์ด๋ฅผ ํ†ตํ•ด ๊ธฐ๋ณธ ์–ธ์–ด๋กœ ์ฝ˜ํ…์ธ ๋ฅผ ์ถ”๊ฐ€ํ•œ ๋‹ค์Œ ์ ์ง„์ ์œผ๋กœ ๋ฒˆ์—ญํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+## Starlight UI ๋ฒˆ์—ญ
+
+๋ฒˆ์—ญ๋œ ์ฝ˜ํ…์ธ  ํŒŒ์ผ์„ ํ˜ธ์ŠคํŒ…ํ•˜๋Š” ๊ฒƒ ์™ธ์—๋„ Starlight๋ฅผ ์‚ฌ์šฉํ•˜๋ฉด ๋…์ž๊ฐ€ ์„ ํƒํ•œ ์–ธ์–ด๋กœ ์‚ฌ์ดํŠธ ์ „์ฒด๋ฅผ ๊ฒฝํ—˜ํ•  ์ˆ˜ ์žˆ๋„๋ก ๊ธฐ๋ณธ UI ๋ฌธ์ž์—ด(์˜ˆ๋ฅผ ๋“ค์–ด, ์˜ค๋ฅธ์ชฝ ๋ชฉ์ฐจ์˜ ์ œ๋ชฉ์ธ "๋ชฉ์ฐจ")๋ฅผ ๋ฒˆ์—ญํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+์˜์–ด, ์ฒด์ฝ”์–ด, ํ”„๋ž‘์Šค์–ด, ๋…์ผ์–ด, ์ดํƒˆ๋ฆฌ์•„์–ด, ์ผ๋ณธ์–ด, ํฌ๋ฅดํˆฌ๊ฐˆ์–ด, ๋„ค๋œ๋ž€๋“œ์–ด, ๋ด๋งˆํฌ์–ด, ์ŠคํŽ˜์ธ์–ด, ํ„ฐํ‚ค์–ด, ์•„๋ž์–ด, ๋…ธ๋ฅด์›จ์ด์–ด, ํŽ˜๋ฅด์‹œ์•„์–ด, ์ค‘๊ตญ์–ด ๊ฐ„์ฒด, ํ•œ๊ตญ์–ด ๋ฐ ์Šค์›จ๋ด์–ด๋กœ ๋ฒˆ์—ญ๋œ UI ๋ฌธ์ž์—ด์ด ๊ธฐ๋ณธ์ ์œผ๋กœ ์ œ๊ณต๋ฉ๋‹ˆ๋‹ค. ๊ทธ๋ฆฌ๊ณ  ์šฐ๋ฆฌ๋Š” [๋” ๋งŽ์€ ๊ธฐ๋ณธ ์–ธ์–ด๋ฅผ ์ถ”๊ฐ€ํ•˜๋Š” ๋ฐ ๊ธฐ์—ฌ](https://github.com/withastro/starlight/blob/main/CONTRIBUTING.md)ํ•˜๋Š”๊ฑธ ํ™˜์˜ํ•ฉ๋‹ˆ๋‹ค.
+
+`i18n` ๋ฐ์ดํ„ฐ ์ปฌ๋ ‰์…˜์„ ํ†ตํ•ด ์ง€์›ํ•˜๋Š” ์ถ”๊ฐ€ ์–ธ์–ด์— ๋Œ€ํ•œ ๋ฒˆ์—ญ์„ ์ œ๊ณตํ•˜๊ฑฐ๋‚˜ ๊ธฐ๋ณธ ๋ผ๋ฒจ์„ ๋ณ€๊ฒฝํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+1. ์•„์ง ๊ตฌ์„ฑ๋˜์ง€ ์•Š์€ ๊ฒฝ์šฐ `src/content/config.ts`์—์„œ `i18n` ๋ฐ์ดํ„ฐ ์ปฌ๋ ‰์…˜์„ ๊ตฌ์„ฑํ•ฉ๋‹ˆ๋‹ค.
+
+ ```js
+ // src/content/config.ts
+ import { defineCollection } from 'astro:content';
+ import { docsSchema, i18nSchema } from '@astrojs/starlight/schema';
+
+ export const collections = {
+ docs: defineCollection({ schema: docsSchema() }),
+ i18n: defineCollection({ type: 'data', schema: i18nSchema() }),
+ };
+ ```
+
+2. `src/content/i18n/`์— UI ๋ฒˆ์—ญ ๋ฌธ์ž์—ด์„ ์ œ๊ณตํ•˜๋ ค๋Š” ๊ฐ ์ถ”๊ฐ€ ์–ธ์–ด์— ๋Œ€ํ•œ JSON ํŒŒ์ผ์„ ๋งŒ๋“ญ๋‹ˆ๋‹ค. ์˜ˆ๋ฅผ ๋“ค์–ด ๋‹ค์Œ์€ ์•„๋ž์–ด ๋ฐ ์ค‘๊ตญ์–ด ๊ฐ„์ฒด์— ๋Œ€ํ•œ ๋ฒˆ์—ญ ํŒŒ์ผ์„ ์ถ”๊ฐ€ํ•ฉ๋‹ˆ๋‹ค.
+
+ <FileTree>
+
+ - src/
+ - content/
+ - i18n/
+ - ar.json
+ - zh-CN.json
+
+ </FileTree>
+
+3. JSON ํŒŒ์ผ์—์„œ ๋ฒˆ์—ญํ•  ํ‚ค์— ๋Œ€ํ•œ ๋ฒˆ์—ญ์„ ์ถ”๊ฐ€ํ•ฉ๋‹ˆ๋‹ค. ํ‚ค๋Š” ์˜์–ด๋กœ ๋‚จ๊ฒจ๋‘๊ณ  ๊ฐ’์„ ๋ฒˆ์—ญํ•ด์•ผํ•ฉ๋‹ˆ๋‹ค. (์˜ˆ: `"search.label": "Buscar"`)
+
+ Starlight์™€ ํ•จ๊ป˜ ์ œ๊ณต๋˜๋Š” ๊ธฐ์กด ๋ฌธ์ž์—ด์˜ ์˜์–ด ๊ธฐ๋ณธ๊ฐ’์€ ๋‹ค์Œ๊ณผ ๊ฐ™์Šต๋‹ˆ๋‹ค.
+
+ ```json
+ {
+ "skipLink.label": "Skip to content",
+ "search.label": "Search",
+ "search.shortcutLabel": "(Press / to Search)",
+ "search.cancelLabel": "Cancel",
+ "search.devWarning": "Search is only available in production builds. \nTry building and previewing the site to test it out locally.",
+ "themeSelect.accessibleLabel": "Select theme",
+ "themeSelect.dark": "Dark",
+ "themeSelect.light": "Light",
+ "themeSelect.auto": "Auto",
+ "languageSelect.accessibleLabel": "Select language",
+ "menuButton.accessibleLabel": "Menu",
+ "sidebarNav.accessibleLabel": "Main",
+ "tableOfContents.onThisPage": "On this page",
+ "tableOfContents.overview": "Overview",
+ "i18n.untranslatedContent": "This content is not available in your language yet.",
+ "page.editLink": "Edit page",
+ "page.lastUpdated": "Last updated:",
+ "page.previousLink": "Next",
+ "page.nextLink": "Previous"
+ }
+ ```
+
+ Starlight์˜ ๊ฒ€์ƒ‰ ๋ชจ๋‹ฌ์€ [Pagefind](https://pagefind.app/) ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ์— ์˜ํ•ด ๊ตฌ๋™๋ฉ๋‹ˆ๋‹ค. ๋™์ผํ•œ JSON ํŒŒ์ผ์—์„œ `pagefind` ํ‚ค๋ฅผ ์‚ฌ์šฉํ•˜์—ฌ Pagefind์˜ UI์— ๋Œ€ํ•œ ๋ฒˆ์—ญ์„ ์„ค์ •ํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
+
+ ```json
+ {
+ "pagefind.clear_search": "Clear",
+ "pagefind.load_more": "Load more results",
+ "pagefind.search_label": "Search this site",
+ "pagefind.filters_label": "Filters",
+ "pagefind.zero_results": "No results for [SEARCH_TERM]",
+ "pagefind.many_results": "[COUNT] results for [SEARCH_TERM]",
+ "pagefind.one_result": "[COUNT] result for [SEARCH_TERM]",
+ "pagefind.alt_search": "No results for [SEARCH_TERM]. Showing results for [DIFFERENT_TERM] instead",
+ "pagefind.search_suggestion": "No results for [SEARCH_TERM]. Try one of the following searches:",
+ "pagefind.searching": "Searching for [SEARCH_TERM]..."
+ }
+ ```