oh-my-design-cli 1.3.8 → 1.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (138) hide show
  1. package/README.ja.md +8 -8
  2. package/README.ko.md +28 -7
  3. package/README.md +71 -16
  4. package/README.zh-TW.md +8 -8
  5. package/agents/omd-asset-curator.md +2 -7
  6. package/agents/omd-codex-image.md +49 -0
  7. package/agents/omd-designer-review.md +38 -0
  8. package/agents/omd-final-qa.md +40 -0
  9. package/agents/omd-kr-writer.md +35 -0
  10. package/agents/omd-locale-adapter.md +32 -0
  11. package/agents/omd-master.md +3 -13
  12. package/agents/omd-orchestrator.md +34 -0
  13. package/data/reference-audits/2026-05-14-kr10.md +72 -0
  14. package/data/reference-audits/2026-05-15-kr10.md +124 -0
  15. package/data/reference-fingerprints.json +253 -3
  16. package/data/research/2026-05-18-agent-landscape.md +69 -0
  17. package/data/research/2026-05-18-kr-style-presets.md +572 -0
  18. package/dist/bin/oh-my-design.js +6 -3
  19. package/dist/bin/oh-my-design.js.map +1 -1
  20. package/dist/{install-skills-MVXVXYAY.js → install-skills-IETT2TBJ.js} +91 -8
  21. package/dist/install-skills-IETT2TBJ.js.map +1 -0
  22. package/package.json +9 -3
  23. package/skills/omd-apply/SKILL.md +0 -1
  24. package/skills/omd-codex-image/SKILL.md +162 -0
  25. package/skills/omd-designer-review/SKILL.md +146 -0
  26. package/skills/omd-final-qa/SKILL.md +153 -0
  27. package/skills/omd-kr-writer/SKILL.md +229 -0
  28. package/skills/omd-locale-adapter/SKILL.md +124 -0
  29. package/skills/omd-orchestrator/SKILL.md +124 -0
  30. package/web/references/29cm/DESIGN.md +11 -2
  31. package/web/references/ably/DESIGN.md +12 -2
  32. package/web/references/airbnb/DESIGN.md +17 -2
  33. package/web/references/airtable/DESIGN.md +20 -0
  34. package/web/references/apple/DESIGN.md +17 -2
  35. package/web/references/baemin/DESIGN.md +11 -2
  36. package/web/references/banksalad/DESIGN.md +17 -2
  37. package/web/references/bmw/DESIGN.md +14 -0
  38. package/web/references/bunjang/DESIGN.md +308 -0
  39. package/web/references/cal/DESIGN.md +14 -0
  40. package/web/references/catchtable/DESIGN.md +262 -0
  41. package/web/references/channeltalk/DESIGN.md +374 -0
  42. package/web/references/classum/DESIGN.md +217 -0
  43. package/web/references/claude/DESIGN.md +11 -2
  44. package/web/references/clay/DESIGN.md +19 -0
  45. package/web/references/clickhouse/DESIGN.md +19 -0
  46. package/web/references/cohere/DESIGN.md +20 -0
  47. package/web/references/coinbase/DESIGN.md +14 -0
  48. package/web/references/composio/DESIGN.md +14 -0
  49. package/web/references/coupang/DESIGN.md +17 -2
  50. package/web/references/cursor/DESIGN.md +20 -0
  51. package/web/references/dabang/DESIGN.md +210 -0
  52. package/web/references/dcard/DESIGN.md +11 -2
  53. package/web/references/elevenlabs/DESIGN.md +20 -0
  54. package/web/references/expo/DESIGN.md +20 -0
  55. package/web/references/fastcampus/DESIGN.md +460 -0
  56. package/web/references/ferrari/DESIGN.md +14 -0
  57. package/web/references/figma/DESIGN.md +17 -2
  58. package/web/references/flex/DESIGN.md +309 -0
  59. package/web/references/framer/DESIGN.md +20 -0
  60. package/web/references/freee/DESIGN.md +16 -2
  61. package/web/references/gangnamunni/DESIGN.md +18 -2
  62. package/web/references/gmarket/DESIGN.md +464 -0
  63. package/web/references/hashicorp/DESIGN.md +19 -0
  64. package/web/references/ibm/DESIGN.md +20 -0
  65. package/web/references/inflearn/DESIGN.md +396 -0
  66. package/web/references/intercom/DESIGN.md +14 -0
  67. package/web/references/jumpit/DESIGN.md +366 -0
  68. package/web/references/kakao/DESIGN.md +14 -0
  69. package/web/references/kakaobank/DESIGN.md +17 -2
  70. package/web/references/kakaopay/DESIGN.md +17 -2
  71. package/web/references/karrot/DESIGN.md +16 -2
  72. package/web/references/kbank/DESIGN.md +195 -0
  73. package/web/references/kraken/DESIGN.md +14 -0
  74. package/web/references/krds/DESIGN.md +17 -2
  75. package/web/references/kream/DESIGN.md +382 -0
  76. package/web/references/kurly/DESIGN.md +11 -2
  77. package/web/references/lamborghini/DESIGN.md +14 -0
  78. package/web/references/line/DESIGN.md +17 -2
  79. package/web/references/linear.app/DESIGN.md +17 -2
  80. package/web/references/lovable/DESIGN.md +14 -0
  81. package/web/references/lunit/DESIGN.md +249 -0
  82. package/web/references/mercari/DESIGN.md +11 -2
  83. package/web/references/minimax/DESIGN.md +14 -0
  84. package/web/references/mintlify/DESIGN.md +14 -0
  85. package/web/references/miro/DESIGN.md +20 -0
  86. package/web/references/mistral.ai/DESIGN.md +20 -0
  87. package/web/references/mongodb/DESIGN.md +19 -0
  88. package/web/references/musinsa/DESIGN.md +11 -2
  89. package/web/references/naver/DESIGN.md +17 -2
  90. package/web/references/notion/DESIGN.md +11 -2
  91. package/web/references/nvidia/DESIGN.md +11 -2
  92. package/web/references/ohouse/DESIGN.md +11 -2
  93. package/web/references/oliveyoung/DESIGN.md +342 -0
  94. package/web/references/ollama/DESIGN.md +14 -0
  95. package/web/references/opencode.ai/DESIGN.md +20 -0
  96. package/web/references/pinkoi/DESIGN.md +11 -2
  97. package/web/references/pinterest/DESIGN.md +19 -0
  98. package/web/references/posthog/DESIGN.md +20 -0
  99. package/web/references/qanda/DESIGN.md +11 -2
  100. package/web/references/raycast/DESIGN.md +19 -0
  101. package/web/references/remember/DESIGN.md +17 -2
  102. package/web/references/renault/DESIGN.md +14 -0
  103. package/web/references/replicate/DESIGN.md +14 -0
  104. package/web/references/resend/DESIGN.md +20 -0
  105. package/web/references/revolut/DESIGN.md +14 -0
  106. package/web/references/ridi/DESIGN.md +11 -2
  107. package/web/references/runwayml/DESIGN.md +14 -0
  108. package/web/references/sanity/DESIGN.md +20 -0
  109. package/web/references/sentry/DESIGN.md +14 -0
  110. package/web/references/socar/DESIGN.md +17 -2
  111. package/web/references/spacex/DESIGN.md +11 -2
  112. package/web/references/spotify/DESIGN.md +14 -0
  113. package/web/references/stripe/DESIGN.md +11 -2
  114. package/web/references/supabase/DESIGN.md +20 -0
  115. package/web/references/superhuman/DESIGN.md +20 -0
  116. package/web/references/tesla/DESIGN.md +11 -2
  117. package/web/references/together.ai/DESIGN.md +20 -0
  118. package/web/references/toss/DESIGN.md +16 -2
  119. package/web/references/toss-securities/DESIGN.md +193 -0
  120. package/web/references/tving/DESIGN.md +259 -0
  121. package/web/references/uber/DESIGN.md +19 -0
  122. package/web/references/upbit/DESIGN.md +276 -0
  123. package/web/references/upstage/DESIGN.md +214 -0
  124. package/web/references/vercel/DESIGN.md +17 -2
  125. package/web/references/voltagent/DESIGN.md +14 -0
  126. package/web/references/wadiz/DESIGN.md +344 -0
  127. package/web/references/wanted/DESIGN.md +16 -2
  128. package/web/references/warp/DESIGN.md +14 -0
  129. package/web/references/webflow/DESIGN.md +14 -0
  130. package/web/references/wise/DESIGN.md +19 -0
  131. package/web/references/x.ai/DESIGN.md +14 -0
  132. package/web/references/yanolja/DESIGN.md +17 -2
  133. package/web/references/yeogiotte/DESIGN.md +18 -2
  134. package/web/references/zapier/DESIGN.md +20 -0
  135. package/web/references/zigbang/DESIGN.md +12 -2
  136. package/web/references/zigzag/DESIGN.md +17 -2
  137. package/agents/omd-3d-blender.md +0 -269
  138. package/dist/install-skills-MVXVXYAY.js.map +0 -1
@@ -1,3 +1,23 @@
1
+ ---
2
+ id: expo
3
+ name: Expo
4
+ country: US
5
+ category: developer-tools
6
+ homepage: "https://expo.dev"
7
+ primary_color: "#000020"
8
+ logo:
9
+ type: simpleicons
10
+ slug: expo
11
+ verified: "2026-05-15"
12
+ omd: "0.1"
13
+ ds:
14
+ name: Expo Brand
15
+ url: "https://expo.dev/brand"
16
+ type: brand
17
+ description: Expo logo/wordmark trademark and usage guidelines.
18
+ og_image: "https://og.expo.dev/?theme=universe&title=Brand%2C+Assets%2C+Styles&description=Get+Expo+brand+assets+and+styles+for+any+use."
19
+ ---
20
+
1
21
  # Design System Inspiration of Expo
2
22
 
3
23
  ## 1. Visual Theme & Atmosphere
@@ -0,0 +1,460 @@
1
+ ---
2
+ id: fastcampus
3
+ name: Fastcampus
4
+ country: KR
5
+ category: education
6
+ homepage: "https://fastcampus.co.kr"
7
+ primary_color: "#fc1c49"
8
+ logo:
9
+ type: favicon
10
+ slug: "https://www.google.com/s2/favicons?domain=fastcampus.co.kr&sz=256"
11
+ verified: "2026-05-15"
12
+ omd: "0.1"
13
+ ---
14
+
15
+ # Design System Inspiration of Fastcampus
16
+
17
+ ## 1. Visual Theme & Atmosphere
18
+
19
+ Fastcampus (패스트캠퍼스) is the design language of a **Korean adult-upskilling marketplace that competes on density, momentum, and rich-color play** — a deliberately louder register than Inflearn's calm-mint catalog or Classum's institutional blue chrome. Where Inflearn whispers "lifetime career, no pressure" with a single mint accent on a white page, Fastcampus shouts **"this cohort starts soon, the discount expires Friday"** through a full Material-style palette — yellow `#ffeb3b`, red `#fc1c49`, orange `#f8930f`, blue `#3b83ff`, green `#43a047`, pink `#e91e63` — each color used decisively per surface band so the catalog scrolls like a programmed market rather than a quiet library. The 103 `--fds-color-*` and `--c-primary-*` CSS variables on `:root` of `fastcampus.co.kr` reveal the underlying engine: a private internal "Fastcampus Design System" (the `fds-` prefix) with full **10-shade ramps per hue (50/100/200/300/400/500/600/700/800/900)** plus semantic role tokens (`--fds-semantic-primary-primary = #fc1c49`, `--fds-semantic-label-primary = #171b1f`).
20
+
21
+ The signature is **crimson-red `#fc1c49`** — `--c-primary` and `--fds-semantic-primary-primary` are pinned to the same value, with `--c-primary-darken = #c9032a` and `--c-primary-darken-renewal = #d60039` as the pressed-state ladder. This red is *commerce-red*, not warning-red: it lands on enrolment CTAs, sale-price strikethroughs, and limited-time banners, never on form errors (errors use the separate `--fds-color-red-*` ramp, distinct from primary brand red). The geometric vocabulary is **4px-everywhere with corner-clipped variations**: cards use `4px 4px 0 0` (top-rounded, bottom flat — thumbnail caps the visual seam), category pills `4px`, rank badges `4px 0` (NW-SE corner only) for the dark `#171b1f` "1위 / 2위 / 3위" overlays. There is no full-pill radius on category navigation — a notable departure from Inflearn (`32px` nav pills) and Toss (`12-16px` everywhere). Fastcampus chose **sharper, more conventional rectangles** to read as "structured course list," not "browsy social feed."
22
+
23
+ Typography is **Pretendard Variable** (the variable-weight version, not static Pretendard) loaded as `--font-base`, with Apple SD Gothic Neo carrying `html` and the full Korean fallback chain on body. Banner headlines run **40px / 700** with two-line breaks (`관심 가는 원데이 클래스 / 0원 사전 알림 신청하세요!`) — bigger and bolder than Inflearn's 34px hero — and category-pill labels at **14px / 600** sit at the *commerce density* register, not the calm-catalog one. Body text is `#171b1f` (`--fds-color-neutral-950`), muted is `#747678` (`--fds-color-neutral-500`), and the neutral surface fill is `#f5f5f6` (`--fds-color-neutral-30`) — a slightly cooler/grayer neutral than Inflearn's Mantine gray-0 `#f8f9fa`.
24
+
25
+ **Key Characteristics:**
26
+ - Pretendard Variable as primary; Apple SD Gothic Neo on `html`; full Korean fallback chain on body
27
+ - Signature crimson `#fc1c49` (`--c-primary`, `--fds-semantic-primary-primary`) for enrolment / sale / limited-time; darken `#c9032a` for pressed, renewal `#d60039` for refreshed campaign skin
28
+ - Rich Material-style 10-shade palette (`--fds-color-{yellow,orange,red,pink,green,blue,neutral}-{50..950}`) — yellow `#ffeb3b` / `#fdd835`, orange `#f8930f`, pink `#e91e63`, green `#43a047`, blue `#3b83ff` all live on the home rail simultaneously
29
+ - Two radius vocabularies: `4px` flat (default — category pills, banner-list buttons) and `4px 4px 0 0` (course cards, top-rounded with thumbnail seam)
30
+ - Banner headlines 40px / 700 (Pretendard Variable, two-line) — louder than Inflearn's 34px
31
+ - Rank badges are dark `#171b1f` corner-clipped (`4px 0`) overlays on tile NW corner — "1위 / 2위 / 3위 / 1,940+" enrolment-count flex
32
+ - Category-pill carousel: black-on-white selected (`#000` / `#fff` / radius 4px / 14px-600), gray-on-gray neutral (`#f5f5f6` bg / `#747678` text) for the 11+ category browser strip
33
+ - Zero box-shadow on the category-pill or rank-badge layer (depth is color contrast, not elevation)
34
+ - GNB nav links sit at 16px / 400 default + 12px / 600 (smaller-bolder) for `커뮤니티` / `기업교육` secondary links — an inverted-density signature versus Inflearn's flat 16px/600 nav
35
+
36
+ ## 2. Color Palette & Roles
37
+
38
+ ### Primary (commerce-red)
39
+
40
+ - **Primary Red** (`#fc1c49`) — `--c-primary` and `--fds-semantic-primary-primary`. Enrolment CTA, sale-price highlight, limited-time banners, time-left countdown text.
41
+ - **Primary Darken** (`#c9032a`) — `--c-primary-darken`. Pressed / active CTA, hover on red link.
42
+ - **Primary Darken Renewal** (`#d60039`) — `--c-primary-darken-renewal`. Campaign-refresh skin variant (used on seasonal home banners).
43
+ - **Primary RGB tuple** (`237, 35, 75`) — exposed as `--c-primary-rgb` for `rgba(var(--c-primary-rgb), 0.X)` alpha mixing on hover scrims.
44
+
45
+ ### Neutrals (full 10-shade `--fds-color-neutral-*` ladder)
46
+
47
+ | Token | Value | Use |
48
+ |---|---|---|
49
+ | `neutral-30` | `#f5f5f6` | Default neutral surface — category-pill rest bg, secondary chip fill |
50
+ | `neutral-50` | `#e7e7e8` | Soft divider, skeleton block bg |
51
+ | `neutral-100` | `#cfd0d1` | Neutral border light |
52
+ | `neutral-200` | `#b7b9ba` | Neutral border default |
53
+ | `neutral-300` | `#a0a2a3` | Disabled icon fill |
54
+ | `neutral-400` | `#8a8c8d` | Caption / metadata bottom tier |
55
+ | `neutral-500` | `#747678` | Muted text / unselected-pill label |
56
+ | `neutral-600` | `#5f6163` | Secondary body text |
57
+ | `neutral-700` | `#4b4d4f` | Strong body text |
58
+ | `neutral-800` | `#37393b` | Heading on light surface |
59
+ | `neutral-900` | `#252729` | Heading display |
60
+ | `neutral-950` | `#171b1f` | `--fds-semantic-label-primary` — body / banner overlay text / rank-badge fill |
61
+
62
+ ### Static neutrals
63
+ - **Static White** (`#fff`) — `--fds-color-static-white`. Theme-independent white (does not flip in dark theme).
64
+ - **Static Black** (`#000`) — `--fds-color-static-black`. Theme-independent black; observed as category-pill selected bg.
65
+
66
+ ### Semantic role tokens (FDS namespace)
67
+
68
+ - **Semantic Primary** (`#fc1c49`) — `--fds-semantic-primary-primary`. Same as `--c-primary`; the system pins them.
69
+ - **Semantic Primary Low** (`#ffdad8`) — `--fds-semantic-primary-primary-low`. Tinted red surface (sale-tag fill, primary CTA hover scrim).
70
+ - **Semantic Label Primary** (`#171b1f`) — default text role on light surfaces.
71
+
72
+ ### Extended hue ramps (the rich-color signature)
73
+
74
+ Each hue carries the full 10-shade Material-style ladder. The shipped color frequency on `/` reveals the **per-band convention**: each home-page section claims one accent hue for its category tag, badge, and gradient backdrop.
75
+
76
+ - **Yellow** (`#fffde7 / #fff9c4 / #fff59d / #fff176 / #ffee58 / #ffeb3b / #fdd835 / #fbc02d / #f9a825 / #f57f17`) — "0원 사전 알림" lemon banner, attention-grabbing free-class promotion.
77
+ - **Orange** (`#fef4e7 / #fddeb5 / #fccd91 / #fab75e / #fa a93f / #f8930f / #e2860e / #b0680b / #885108 / #683e06`) — early-bird discount band, "최대 25% 할인" rails.
78
+ - **Red** (`#ffeceb / #ffdad8 / #ffb4b2 / #ff8d8d / #ff616a / #fc1c49 / #c5213b / #91202d / #601c20 / #331414`) — primary + error scale; `red-500 = #fc1c49` is the canonical primary.
79
+ - **Pink** (`#fce4ec / #f8bbd0 / #f48fb1 / #f06292 / #ec407a / #e91e63 / #d81b60 / #c2185b / #ad1457 / #880e4f`) — creative/design category accent, "비주얼 브랜딩" rails.
80
+ - **Green** (`#e8f5e9 / #c8e6c9 / #a5d6a7 / #81c784 / #66bb6a / #4caf50 / #43a047 / #388e3c / #2e7d32 / #1b5e20`) — success state, "수강신청 완료" toast, course-progress complete bar.
81
+ - **Blue** (`#ebf3ff / #c2d9ff / #a5c6ff / #7cacff / #629cff / #3b83ff / #3677e8 / #2a5db5 / #20488c / #19376b`) — developer / data category accent, "Codex 기반 AI 인증시험" rails.
82
+ - **Neutral** — see full ladder above.
83
+
84
+ Designers picking from Fastcampus should treat the FDS hue scales as an officially shipped Material-style internal DS — even though no public DS site exists, the runtime tokens are the truth.
85
+
86
+ ### Implementation hints
87
+ - `--c-primary-rgb` exists alongside `--c-primary` specifically to enable `rgba(237, 35, 75, 0.X)` alpha blending — used for hover scrims and red gradient backdrops without requiring a second hex.
88
+ - Yellow and orange shades cohabit on the same fold (free-class lemon + early-bird amber) — readers should treat them as **two adjacent accent slots**, not as a primary/secondary brand-color duo.
89
+ - `--swiper-theme-color = #007aff` appears in the var dump — this is the Swiper.js library default, not a Fastcampus token. Do not adopt.
90
+
91
+ ## 3. Typography Rules
92
+
93
+ ### Font Family
94
+ - **Primary** (`--font-base`): `"Pretendard Variable", pretendard, -apple-system, BlinkMacSystemFont, system-ui, Roboto, "Helvetica Neue", "Segoe UI", "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", sans-serif`
95
+ - **HTML root**: `"Apple SD Gothic Neo"` (carries the document-level fallback before body inherits `--font-base`)
96
+ - **Mono** (inferred): system mono stack — surfaces inside coding-bootcamp course pages and inline code snippets in course descriptions.
97
+ - No custom display face. The variable-weight Pretendard (single variable file vs. Inflearn's static Pretendard) is the only typographic choice — weight ranges 100-900 are addressable.
98
+ - Korean glyphs render via Pretendard Variable's full Hangul block coverage; no separate Korean web-font is shipped.
99
+
100
+ ### Hierarchy
101
+
102
+ | Role | Size | Weight | Line Height | Notes |
103
+ |---|---|---|---|---|
104
+ | Banner H3 (home carousel) | 40px | 700 | ~1.2 (≈48px on captured 96px two-line block) | Two-line marketing headline (`관심 가는 원데이 클래스 / 0원 사전 알림 신청하세요!`) |
105
+ | Page H1 (inferred — category / course pages) | 32-36px | 700 | 1.3 | Course-list page titles |
106
+ | Section H2 (inferred) | 24-28px | 700 | 1.35 | Rail group labels ("AI TECH", "AI CREATIVE") |
107
+ | Body | 16px | 400 | 1.5 | Default nav link, paragraph copy |
108
+ | GNB primary nav | 16px | 400 | 1.5 | `기업교육`-class secondary GNB items |
109
+ | GNB compact (secondary) | 12px | 600 | 1.4 | `커뮤니티`-class smaller-bolder GNB items — inverted-density signature |
110
+ | Button label (filled / pill) | 14px | 600 | 1.0 | Category-pill carousel label, "전체 / AI TECH / 디자인" |
111
+ | Caption — rank badge | 12px | 500 | 1.4 | "1위 / 2위 / 3위" white-on-`#171b1f` corner overlay |
112
+ | Caption — enrolment count | 16px | 400 | 1.4 | "1,940+ / 1,020+" alpha-30 dark pill |
113
+
114
+ ### Rules
115
+ - **Pretendard Variable everywhere.** No serif, no rounded display face, no Korean display contrast face. Weight is dialed via variable-weight axis (100-900), not separate static cuts.
116
+ - **700 = banner, 600 = button + secondary-compact GNB, 400 = body + primary GNB.** The 500 weight appears only on rank-badge corner labels — a deliberate restraint on the otherwise-binary 400/700 cadence.
117
+ - **Inverted density on GNB**: compact secondary links (`커뮤니티`, `기업교육` smaller-bolder cluster) signal "utility shortcuts" versus the 16px-400 primary nav — a Fastcampus-specific signature versus Inflearn's flat 16px-600 nav.
118
+ - **Banner copy is two-line by default.** 40px / 700 with a deliberate mid-headline break (`\n`) is the brand cadence — designers reproducing the look should plan headlines around natural Korean two-clause splits, not one-line tagline drama.
119
+ - Korean punctuation: straight quotes in UI; honorific `~님` reserved for instructor-facing surfaces; casual-polite `~해요 / ~하기` dominates the home carousel copy ("신청하세요", "만나자", "쓸 수 있는").
120
+
121
+ ## 4. Component Stylings
122
+
123
+ ### Buttons
124
+
125
+ **Category Pill — Selected (Black)**
126
+ - Background: `#000` (`--fds-color-static-black`)
127
+ - Text: `#FFFFFF`
128
+ - Border: none
129
+ - Radius: 4px
130
+ - Padding: 12px 16px
131
+ - Height: 40px
132
+ - Font: 14px / 600 / Pretendard Variable
133
+ - Use: Active category in the home/courses category-pill carousel ("전체" when on category-aggregate view).
134
+
135
+ **Category Pill — Unselected (Neutral)**
136
+ - Background: `#f5f5f6` (`--fds-color-neutral-30`)
137
+ - Text: `#747678` (`--fds-color-neutral-500`)
138
+ - Border: none
139
+ - Radius: 4px
140
+ - Padding: 12px 16px
141
+ - Height: 40px
142
+ - Font: 14px / 600 / Pretendard Variable
143
+ - Use: All non-active category pills ("AI TECH", "AI CREATIVE", "디자인", "영상/3D", …).
144
+
145
+ **Primary CTA — Enrolment (Inferred from `--c-primary` semantic)**
146
+ - Background: `#fc1c49` (`--c-primary` / `--fds-semantic-primary-primary`)
147
+ - Text: `#FFFFFF`
148
+ - Border: none
149
+ - Radius: 4px
150
+ - Padding: 12px 24px (inferred from category-pill geometry; matches 40px target height)
151
+ - Height: 40-48px
152
+ - Font: 14-16px / 600 / Pretendard Variable
153
+ - Hover: background `#c9032a` (`--c-primary-darken`)
154
+ - Pressed: background `#c9032a`
155
+ - Use: "수강신청 하기", "결제하기", primary enrolment actions on course-detail and cart screens.
156
+
157
+ **Primary CTA — Renewal Skin (Campaign-refresh Inferred)**
158
+ - Background: `#d60039` (`--c-primary-darken-renewal`)
159
+ - Text: `#FFFFFF`
160
+ - Border: none
161
+ - Radius: 4px
162
+ - Use: Same primary role on seasonal-campaign home skins where the brand swaps to the renewal red.
163
+
164
+ **Primary CTA — Tinted Surface (Inferred from `--fds-semantic-primary-primary-low`)**
165
+ - Background: `#ffdad8` (`--fds-semantic-primary-primary-low`)
166
+ - Text: `#fc1c49`
167
+ - Border: none
168
+ - Radius: 4px
169
+ - Use: Sale-tag fills, primary CTA hover scrims, "할인 적용중" inline pill.
170
+
171
+ **Carousel Nav — Previous / Next Arrow**
172
+ - Background: `rgba(0, 0, 0, 0)` (transparent)
173
+ - Text / icon color: `#171b1f` (`--fds-semantic-label-primary`)
174
+ - Border: none
175
+ - Radius (prev): `16px 0 0 16px` (left half-pill)
176
+ - Radius (next): `0 16px 16px 0` (right half-pill)
177
+ - Padding (prev): `6px 2px 6px 8px`
178
+ - Padding (next): `6px 8px 6px 2px`
179
+ - Height: 32px
180
+ - Use: Banner carousel arrow controls. Half-pill radius pairs read as a single split surface across the carousel rail.
181
+
182
+ **Carousel Nav — Dots Cluster**
183
+ - Background: `rgba(0, 0, 0, 0.2)` (alpha-20 dark scrim)
184
+ - Text: `#171b1f`
185
+ - Border: none
186
+ - Radius: 19px
187
+ - Padding: 0
188
+ - Height: 32px
189
+ - Use: "배너 목록" — the dot-cluster overlay on the carousel.
190
+
191
+ ### Cards & Containers
192
+
193
+ **Course Card (Default — Top-Rounded)**
194
+ - Background: transparent (thumbnail provides the surface)
195
+ - Border: none
196
+ - Radius: `4px 4px 0 0` (top-rounded, bottom flat)
197
+ - Padding: 0 (metadata flows below thumbnail in unified card frame)
198
+ - Width × Height (rail): ~327px × variable (thumbnail caps the visual seam)
199
+ - Shadow: none
200
+ - Use: Course tile on home rails and `/courses` listings. Thumbnail image carries the top half, metadata block sits below.
201
+
202
+ **Course Card — Rank Badge Overlay (NW corner)**
203
+ - Background: `#171b1f` (`--fds-semantic-label-primary`)
204
+ - Text: `#FFFFFF`
205
+ - Border: none
206
+ - Radius: `4px 0` (NW corner only)
207
+ - Padding: 0 (text-only badge, height 20px)
208
+ - Height: 20px
209
+ - Font: 12px / 500 / Pretendard Variable
210
+ - Use: "1위 / 2위 / 3위" rank label on top-ranked course tiles.
211
+
212
+ **Course Card — Enrolment-Count Pill (Below Rank)**
213
+ - Background: `rgba(0, 0, 0, 0.3)`
214
+ - Text: `#171b1f` (sampled — appears against a light thumbnail backdrop)
215
+ - Border: none
216
+ - Radius: 19px
217
+ - Padding: 2px 6px
218
+ - Height: 24px
219
+ - Font: 16px / 400 / Pretendard Variable
220
+ - Use: "1,940+ / 1,020+" enrolment-count flex — sits below rank badge on top-tier tiles.
221
+
222
+ ### Navigation
223
+
224
+ **Global Nav (GNB) — Desktop**
225
+ - Background: transparent on scroll (sticky; `bg=rgba(0, 0, 0, 0)` captured)
226
+ - Text: `#171b1f` (`--fds-semantic-label-primary`)
227
+ - Border-bottom: none
228
+ - Shadow: none
229
+ - Position: sticky (CSS-module class `GNBDesktop-module-scss-module__*`)
230
+ - Layout: [logo] · [primary nav 16px/400] · [secondary compact nav 12px/600] · [search] · [auth]
231
+ - Use: Single GNB pattern persisting across `/` and category pages.
232
+
233
+ ### Inputs & Forms
234
+
235
+ **Text Input — Search (Inferred from category-page CSS-module pattern)**
236
+ - Background: `#FFFFFF` or `#f5f5f6`
237
+ - Text: `#171b1f`
238
+ - Placeholder: `#747678` (`--fds-color-neutral-500`)
239
+ - Border: 1px solid `#cfd0d1` (`--fds-color-neutral-100`) on rest, `1px solid #fc1c49` on focus
240
+ - Radius: 4px
241
+ - Padding: 0 12px
242
+ - Height: 40px
243
+ - Font: 14-16px / 400 / Pretendard Variable
244
+ - Use: Course search field in GNB and category-filter rail.
245
+
246
+ **Disabled (Inferred from neutral ladder)**
247
+ - Background: `#e7e7e8` (`--fds-color-neutral-50`)
248
+ - Text: `#a0a2a3` (`--fds-color-neutral-300`)
249
+ - Border: none
250
+ - Radius: 4px
251
+ - Use: Form-incomplete state on enrolment / payment flows.
252
+
253
+ ### Tags & Chips (Inferred from extended hue ramps)
254
+
255
+ **Free / Promo Tag — Yellow**
256
+ - Background: `#fff9c4` (`--fds-color-yellow-100`)
257
+ - Text: `#f57f17` (`--fds-color-yellow-900`)
258
+ - Radius: 4px
259
+ - Padding: 2px 8px
260
+ - Font: 12px / 600 / Pretendard Variable
261
+ - Use: "0원 / 무료 / 사전알림" promotional indicators.
262
+
263
+ **Discount Tag — Red**
264
+ - Background: `#ffdad8` (`--fds-semantic-primary-primary-low`)
265
+ - Text: `#fc1c49` (`--c-primary`)
266
+ - Radius: 4px
267
+ - Padding: 2px 8px
268
+ - Font: 12px / 600 / Pretendard Variable
269
+ - Use: "최대 25% 할인", "30% 깜짝 쿠폰" sale flags.
270
+
271
+ **Category Tag — Blue (Dev / Data)**
272
+ - Background: `#ebf3ff` (`--fds-color-blue-50`)
273
+ - Text: `#3b83ff` (`--fds-color-blue-500`)
274
+ - Radius: 4px
275
+ - Padding: 2px 8px
276
+ - Font: 12px / 600 / Pretendard Variable
277
+ - Use: Developer / data category tags on course tiles.
278
+
279
+ **Category Tag — Pink (Design / Creative)**
280
+ - Background: `#fce4ec` (`--fds-color-pink-50`)
281
+ - Text: `#e91e63` (`--fds-color-pink-500`)
282
+ - Radius: 4px
283
+ - Padding: 2px 8px
284
+ - Font: 12px / 600 / Pretendard Variable
285
+ - Use: Design / creative category tags.
286
+
287
+ ---
288
+
289
+ **Verified:** 2026-05-15
290
+ **Tier 1 sources:**
291
+ - `https://fastcampus.co.kr/` — live CDP inspect (browser-harness :9222) → `assets/_reference/.live-inspect-proof.json` (40 raw_samples + 103 `--fds-color-*` / `--c-primary-*` CSS vars + Pretendard Variable font stack + banner H3 40px/700 sample + category-pill carousel 11+ samples + rank-badge + enrolment-count pill)
292
+ - `https://fastcampus.co.kr/category_online_all` — second-surface live CDP inspect → 2 additional structure samples (category-page GNB confirmation)
293
+ - Internal "Fastcampus Design System" (`fds-` prefix) — directly evidenced by the `--fds-color-*` + `--fds-semantic-*` namespace on `:root` of the production site
294
+
295
+ **Tier 1 official DS:** ✗ negative — no public DS site (`design.fastcampus.co.kr` DNS no-resolve; `tech.day1company.io` ECONNREFUSED; `fastcampus.co.kr/design` and `/brand` 404; no Figma Community kit; no GitHub org-level design-system / Storybook / tokens repo published by Day1Company). The DS exists internally as a Material-style token set (`--fds-color-*` 10-shade ramps × 7 hues + semantic role tokens) but lives only as production runtime CSS — accessible exclusively via live inspect. Documented as authoritative negative result.
296
+
297
+ **Tier 2 sources:**
298
+ - `https://getdesign.md/fastcampus` — empty (verified 2026-05-15: "No designs found for 'fastcampus'")
299
+ - `https://styles.refero.design/?q=fastcampus` — empty (verified 2026-05-15: no result cards returned)
300
+
301
+ **Conflicts unresolved:** none
302
+
303
+ **Inferred-but-not-live-captured tokens** (flagged for follow-up UPDATE on a course-detail / cart / payment surface): primary CTA labelled fill (only category-pill geometry captured live; inferred from semantic-primary token + category-pill measurements), input focus state, disabled state, exact tag chip alpha values, GNB sticky bg on scroll-down vs scroll-up, footer spacing tokens, motion durations.
304
+
305
+ ## 5. Layout & Spacing
306
+
307
+ Fastcampus does not expose a `--fds-space-*` token namespace at `:root` — spacing lives inside CSS module classes (`GNBDesktop-module-scss-module__q8MgGW__*`, `MainBannerCarousel-module-scss-module__*`). Observed rhythm from raw geometry:
308
+
309
+ | Inferred token | Value | Typical use |
310
+ |---|---|---|
311
+ | space-2 | 4-6px | Tag chip padding-y, rank badge inset |
312
+ | space-3 | 8px | Inline icon gap |
313
+ | space-4 | 12px | Category-pill padding-y, button-inner gutter |
314
+ | space-5 | 16px | Category-pill padding-x, card metadata gap |
315
+ | space-6 | 24px | Rail-tile gap, section-internal block gap |
316
+ | space-8 | 32px | Section-block separator |
317
+ | space-10 | 48-64px | Major section divider, footer column gap |
318
+
319
+ Home page width is full-bleed banner + ~1280-1440px content container. Course rails use horizontal scroll-snap on viewports < 1280px and a fixed 4-5 column grid above. Density is **commerce-dense**: above-the-fold contains banner carousel (96px headline block) + category-pill carousel (40px row) + top-3 rank tiles (~327px tall) = the user sees 3 layered acquisition surfaces in the first scroll, where Inflearn shows 1 banner + 6 tiles flat. This is the *programmed-market* feel — Fastcampus assumes the user is here to enrol this week, not to browse for a quarter.
320
+
321
+ ## 6. Iconography & Imagery
322
+
323
+ - **Icon set**: 24×24 stroke icons (1.5-2px stroke) for GNB and inline actions; stroke color follows text-context (`#171b1f` default, `#fc1c49` when paired with a primary surface).
324
+ - **Course thumbnail style**: 16:9 photographic or illustrative (instructor portrait + course-title typography composite is the dominant convention — "강사 얼굴 + 굵은 타이포" layout). Aspect ratio is standardized but art direction is loud and varied (gradients, gradient meshes, vector illustration, photographic portraits).
325
+ - **Banner illustrations**: Full-bleed gradient backgrounds (multi-color gradient or solid hue band) with white or dark headline overlay. Frequent multi-hue gradient (yellow → orange → pink) on AI-creative rails.
326
+ - **Rank-badge overlays**: Strict text-only on dark-pill (`#171b1f` `4px 0` corner) — no medal icon, no star, no flame. The number itself does the work.
327
+
328
+ ## 7. Motion
329
+
330
+ Motion data was not exhaustively captured in this pass. Observable from raw class names and CSS-module patterns:
331
+ - Banner carousel uses **Swiper.js** (`--swiper-theme-color` exposed at `:root`) — default Swiper transitions (300ms ease) on slide change, manual + auto-advance.
332
+ - Category-pill carousel: horizontal scroll-snap, no animated transitions on tap (instant active-state swap).
333
+ - Hover on category pill: background fade `200ms ease` (inferred — Swiper / module default).
334
+ - Card hover: thumbnail micro-scale (1.0 → 1.02) `200ms ease-out` (inferred — common Korean-marketplace convention; not directly captured).
335
+ - Page transitions: SSR / Next.js — full-page navigation, no client-side route animation.
336
+
337
+ **Motion tokens not exposed at `:root`** — Fastcampus does not publish `--fds-motion-*` variables. Designers reproducing the look should adopt Swiper defaults (300ms slide, 200ms hover) and respect `prefers-reduced-motion: reduce`. Flagged for UPDATE pass.
338
+
339
+ ## 8. States
340
+
341
+ - **Hover (category pill)**: `#f5f5f6 → #e7e7e8` (inferred — neutral ladder one step down).
342
+ - **Hover (primary CTA)**: `#fc1c49 → #c9032a` (`--c-primary-darken`).
343
+ - **Active / Pressed (CTA)**: `#c9032a` solid; tinted ring `rgba(237, 35, 75, 0.12)` 4px offset.
344
+ - **Focus**: 2px outline `#fc1c49` at 2px offset on keyboard focus; input border swaps to `#fc1c49` (inferred from primary semantic token).
345
+ - **Disabled**: `#e7e7e8` background, `#a0a2a3` text, `cursor: not-allowed` (inferred from neutral ladder).
346
+ - **Loading**: Inline spinner replaces CTA label; primary red CTA remains red, label swaps to icon (Swiper / FDS module convention).
347
+ - **Empty**: Center-aligned illustration + headline (`아직 수강 중인 강의가 없어요`) + outlined primary CTA (`강의 둘러보기`).
348
+ - **Error — Validation**: 14px text below offending field in `#fc1c49` (primary red doubles as inline-error in adult-upskilling commerce context — distinct from system error red `#c5213b`); field border swaps to `#fc1c49`.
349
+ - **Error — Network**: Inline banner (`연결을 확인해 주세요. 다시 시도해주세요.`) + outlined `다시 시도` button.
350
+ - **Success — Enrolment**: One-line confirmation in `#43a047` (`--fds-color-green-600`), no toast theatre.
351
+ - **Skeleton — Card**: `#e7e7e8` blocks for thumbnail (16:9) + 2 text lines; shimmer 1.5s linear (inferred — Mantine / FDS default).
352
+
353
+ ## 9. Accessibility & Internationalization
354
+
355
+ - **Korean is the primary language.** Some technology course titles carry English terms ("React", "Next.js", "AI", "Codex"). No `/en/` mirror as of capture.
356
+ - **Pretendard Variable** supports the full Hangul block plus extended Latin; English text reads naturally without a separate Latin font.
357
+ - **Color contrast**:
358
+ - Heading `#171b1f` on `#FFFFFF` = 16.5:1 (AAA).
359
+ - Body `#747678` on `#FFFFFF` = 4.5:1 (AA for normal text).
360
+ - Muted caption `#a0a2a3` on `#FFFFFF` = 2.8:1 — **fails AA**; correctly reserved for non-essential caption (rank-3 sublabel, enrolment-count footnote).
361
+ - Primary `#fc1c49` on `#FFFFFF` = 4.0:1 — **borderline AA for normal text** (passes for ≥18pt large text). Fastcampus correctly uses white-on-red for CTAs (white on `#fc1c49` = 5.3:1, AA) and limits red-on-white to large-text headlines.
362
+ - Category-pill selected `#FFFFFF` on `#000` = 21:1 (AAA).
363
+ - **Keyboard nav**: Visible 2px primary-red outline on Tab navigation (inferred from `--c-primary` semantic).
364
+ - **Screen reader**: Carousel arrows carry `aria-label` (`이전 배너`, `다음 배너`, `배너 목록` observed in raw samples). Rank badge text is in-DOM (not background-image).
365
+ - **Density caveat**: The 12px / 500 rank-badge font sits at the lower bound of Korean readability — passes per Hangul x-height but reviewers should validate at 100% zoom on small viewports.
366
+
367
+ ## 10. Voice & Tone
368
+
369
+ Fastcampus speaks like **the senior friend who heard the workshop fills up by Friday and texts you "go now"** — energetic, time-aware, casual-polite. Where Inflearn says "부담없이 시작하기" (start without pressure), Fastcampus says "**0원 사전 알림 신청하세요!**" (sign up for the free-tier alert!) and "**최대 25% 할인!**" (up to 25% off!) — the verb is still on the learner's side, but the timing pressure is honestly named. The brand assumes the user is here because the cohort or the discount is closing soon, and the microcopy reflects that.
370
+
371
+ Korean is the dominant register; English appears in technology course titles where the technology has an English name ("AI", "Codex", "Claude", "LLM", "RAG", "AI Agent"). The voice mixes casual-polite `~해요 / ~하세요` with imperative-friendly `~하기 / ~만나자` — the latter (`만나자` = "let's meet") is the **brand-signature first-person-plural-implied invitation**, a softening device that distinguishes Fastcampus from straight-imperative Coursera ("Earn") and Udemy ("Save 90%").
372
+
373
+ | Context | Tone |
374
+ |---|---|
375
+ | CTAs (enrolment) | Imperative + concrete outcome. `수강신청 하기`, `결제하기`, `장바구니에 담기`. Exclamation reserved for time-sensitive: `지금 신청하세요!`. |
376
+ | Banner headlines | A two-clause invitation with a beat. `관심 가는 원데이 클래스 / 0원 사전 알림 신청하세요!` Section break is part of the cadence. |
377
+ | Discount banners | Fact + emphasis. `업무 자동화 베스트 라인업 / 최대 25% 할인!` — the discount is the fact, not the headline word. |
378
+ | Course tile metadata | Rank + count + title + instructor. Rank ("1위") is corner-badged, count ("1,940+") is the social-proof flex. |
379
+ | Free tag | Two characters: `무료` or `0원`. Yellow pill on white tile. |
380
+ | Empty states | Why empty + next step. `아직 수강 중인 강의가 없어요. 관심 분야의 강의를 둘러보세요.` |
381
+ | Error / validation | Specific cause + action. `이메일 형식이 올바르지 않아요. 다시 확인해 주세요.` |
382
+ | Success | One line. `수강신청이 완료되었어요. 내 강의실에서 확인할 수 있어요.` |
383
+ | Instructor surfaces | `~튜터 / ~강사` mix — Fastcampus uses both ("피그마튜터에게 배우는") more freely than Inflearn's strict `지식공유자님` honorific. |
384
+
385
+ **Forbidden phrases (illustrative — not from a published Fastcampus guide; derived from observable restraint on `/`)**: `놓치지 마세요`, `Oops!`, `오류가 발생했습니다`, `최저가 보장`, `평생 무료`, three-exclamation-mark CTA tails (`!!!`), emoji on price or enrolment surfaces, superlative-rank prose where the numeric rank badge already does the work (`최고의 강의 / 압도적 1위`). Where ranking matters, Fastcampus uses the corner badge + raw enrolment count (`1위 / 1,940+`) rather than editorialized rank labels.
386
+
387
+ **Voice samples (OmD-original — no verbatim Fastcampus copy reproduced; tone-shape only):**
388
+ - (Cohort enrolment) "이번 기수는 금요일에 마감해요. 들어가실 자리가 두 개 남았어요."
389
+ - (Sale): "여름 인텐시브, 21일까지 25% 할인. 결제 후 7일 이내 환불 가능해요."
390
+ - (Empty Wishlist): "찜한 강의가 아직 없어요. 분야부터 골라볼까요?"
391
+
392
+ ## 11. Brand Narrative
393
+
394
+ Fastcampus was founded in **2014** under the parent company **Day1Company** (data based on public Korean tech-press coverage of Day1Company / 데이원컴퍼니, the umbrella that operates Fastcampus, Colosso, RealClass, and adjacent brands). The founding observation was that **Korean adult upskilling had been a fragmented offline market — weekend classroom academies, public-institute lectures, and book-and-DVD self-study** — and that working professionals were willing to pay premium prices for short-format, instructor-led, project-based online courses if the production value matched the price.
395
+
396
+ Fastcampus's bet was that **the difference between a free YouTube tutorial and a paid course is project structure, instructor accountability, and cohort timing** — not just video quality. The platform brand name itself frames the proposition: *fast + campus*, a compressed academic experience for adults who cannot take a semester off. By 2026, Day1Company operates Fastcampus as the flagship **adult-upskilling marketplace covering IT, design, business, finance, language, and lifestyle**, with adjacent brands handling specialized tiers (Colosso for high-end masterclasses; RealClass for hobby/language).
397
+
398
+ The visual evolution from the early-2010s blue-and-white directory page to the current rich-color Material-style catalog is itself the signal: Fastcampus made the deliberate choice to **look like a programmed market** (multi-hue rails, rank badges, enrolment counts) rather than a calm catalog (Inflearn's choice) or an institutional LMS (Classum's choice). The two competitors share a country, an audience overlap, and Pretendard typography; Fastcampus distinguishes by *commerce energy*.
399
+
400
+ *(Founder, exact founding-month, and headcount details are not exhaustively verified from public English-language sources at OmD attribution fidelity; the narrative above is anchored to publicly observable brand artifacts — site copy, course catalog structure, and parent-company branding. UPDATE pass recommended on `tech.day1company.io` if/when that domain comes back online.)*
401
+
402
+ ## 12. Principles
403
+
404
+ 1. **Time is part of the offer.** Cohort start dates, discount end dates, and seat counts are first-class UI content — not legal fine print. *UI implication:* every primary CTA may carry a deadline or seat-count badge; design tokens must support a "time pressure" surface (countdown text in `--c-primary`, deadline pill in `--fds-color-orange-200`).
405
+
406
+ 2. **Rich color, per-band.** The home page assigns one accent hue per content rail — yellow for "0원 / 사전알림", orange for early-bird discount, blue for dev/data, pink for design/creative, red for primary brand commerce. *UI implication:* never mix two accent hues in one card; the rail-level hue is the spatial wayfinding.
407
+
408
+ 3. **Rank is a number, not a story.** "1위 / 1,940+" lives in a corner badge — no editorialized adjective. *UI implication:* if a tile says "최고의", the rank badge has failed. Use raw rank + raw count, let the number speak.
409
+
410
+ 4. **4px everywhere, top-rounded on cards.** A single radius vocabulary plus the `4px 4px 0 0` card-with-thumbnail convention. *UI implication:* introducing a full-pill radius on a CTA is a tonal mistake — Fastcampus reads as "structured market," not "social feed."
411
+
412
+ 5. **Casual-polite, not formal.** `~해요 / ~하기 / ~만나자` for product surfaces; `~합니다` reserved for legal / refund / receipt screens. *UI implication:* avoid `~하시기 바랍니다` and `~하실 수 있습니다` in CTA / banner copy.
413
+
414
+ ## 13. Personas
415
+
416
+ *(Personas inferred from observable surface targeting on `/` and `/category_online_all`; not from a published Fastcampus persona doc.)*
417
+
418
+ - **The 20s Self-Funded Upskiller.** 22–28, recent grad or early-career, paying out of pocket for a single-cohort bootcamp-style course (AI / data / design). Sensitive to deadline + discount; the orange-band "early-bird 25%" rail is the most-clicked acquisition surface for this persona. Buys 1-2 premium courses per year.
419
+
420
+ - **The B2B Sponsored Learner.** 28–38, mid-career, sent by the employer via the **기업교육 (corporate-training)** track. Comes via GNB compact secondary link; values certificate, syllabus, and live-session schedule; less price-sensitive, more time-sensitive (must complete by fiscal year-end).
421
+
422
+ - **The Career-Pivot IC.** 30–40, established IC considering a category jump (e.g., marketer → product, engineer → ML). Buys roadmap-style course bundles; reads instructor credentials and project deliverables carefully; rank badges and enrolment counts are decision shortcuts.
423
+
424
+ - **The Hobbyist / Adjacent-Function Curious.** 25–45, browsing outside core category (engineer learning design, designer learning a bit of code, marketer learning analytics). Drawn to the design/creative pink rail and drawing/illustration sub-category; price-elastic; uses the free-class yellow tag heavily.
425
+
426
+ ## 14. States Catalog
427
+
428
+ | Category | Treatment |
429
+ |---|---|
430
+ | **Empty — My Courses** | Center-aligned illustration + `아직 수강 중인 강의가 없어요`; outlined CTA `강의 둘러보기` linking to `/category_online_all`. |
431
+ | **Empty — Wishlist** | `찜한 강의가 아직 없어요. 마음에 드는 강의를 담아두세요.` + outlined CTA. |
432
+ | **Empty — Search results** | `'<query>'에 대한 결과가 없어요.` + 3 category-pill suggestions in unselected (`#f5f5f6`) state. |
433
+ | **Loading — page** | Skeleton blocks `#e7e7e8` for rail tiles (3-5 tiles per row, 16:9 thumbnail + 2 text lines), shimmer 1.5s linear. |
434
+ | **Loading — submit** | Inline 16px spinner replaces CTA label; CTA bg remains `#fc1c49`; pointer disabled. |
435
+ | **Error — Network** | Inline banner `연결을 확인해 주세요. 다시 시도해주세요.` + outlined `다시 시도` button. |
436
+ | **Error — Validation** | 14px `#fc1c49` text below field; field border `#fc1c49`. |
437
+ | **Error — Payment** | Modal with specific cause line + `다른 결제 수단으로 시도하기` primary red CTA. |
438
+ | **Success — Enrolment** | Inline `수강신청이 완료되었어요.` in `#43a047`; `내 강의실로 가기` primary CTA. |
439
+ | **Skeleton — Card** | `#e7e7e8` block for thumbnail (16:9, `4px 4px 0 0`) + 2 text lines; shimmer 1.5s linear. |
440
+ | **Disabled — Form** | `#e7e7e8` bg, `#a0a2a3` text, `cursor: not-allowed`; tooltip on hover explaining what's missing. |
441
+ | **Time-Pressure — Countdown** | Inline `#fc1c49` countdown text (`3일 21:14:02 남음`) paired with `--fds-color-orange-200` deadline pill on enrolment CTAs. |
442
+
443
+ ## 15. Motion & Easing
444
+
445
+ | Token | Value | Use |
446
+ |---|---|---|
447
+ | `motion-fast` | 150ms | Hover bg fade, focus ring appear |
448
+ | `motion-base` | 200ms | Card thumbnail scale, category-pill bg, button color |
449
+ | `motion-slow` | 300ms | Banner carousel slide (Swiper default), modal open |
450
+ | `easing-default` | `ease` | All hover / focus transitions |
451
+ | `easing-emphasized` | `cubic-bezier(0.4, 0, 0.2, 1)` | Modal / drawer enter |
452
+ | `easing-decelerate` | `cubic-bezier(0, 0, 0.2, 1)` | Skeleton shimmer, page-content fade-in |
453
+
454
+ **Motion rules**:
455
+ - Banner carousel auto-advances (Swiper default 5s) — Fastcampus accepts the convention; this is a deliberate departure from Inflearn ("no carousel auto-advance"). Time pressure is part of the brand.
456
+ - Card hover micro-scale (1.0 → 1.02) is the only ambient motion outside the carousel.
457
+ - No parallax. No scroll-triggered hero animation.
458
+ - Respect `prefers-reduced-motion: reduce` — fall back to instant transitions, keep color fades only, and stop carousel auto-advance.
459
+
460
+ **Motion tokens are inferred** — `--fds-motion-*` is not exposed at `:root`. UPDATE pass recommended on course-detail / cart pages where toast / modal / drawer interactions would expose canonical durations.
@@ -1,3 +1,17 @@
1
+ ---
2
+ id: ferrari
3
+ name: Ferrari
4
+ country: IT
5
+ category: automotive
6
+ homepage: "https://www.ferrari.com"
7
+ primary_color: "#ff2800"
8
+ logo:
9
+ type: simpleicons
10
+ slug: ferrari
11
+ verified: "2026-05-15"
12
+ omd: "0.1"
13
+ ---
14
+
1
15
  # Design System Inspiration of Ferrari
2
16
 
3
17
  ## 1. Visual Theme & Atmosphere
@@ -1,6 +1,21 @@
1
1
  ---
2
- omd: 0.1
3
- brand: Figma
2
+ id: figma
3
+ name: Figma
4
+ country: US
5
+ category: design-tools
6
+ homepage: "https://www.figma.com"
7
+ primary_color: "#a259ff"
8
+ logo:
9
+ type: simpleicons
10
+ slug: figma
11
+ verified: "2026-05-15"
12
+ omd: "0.1"
13
+ ds:
14
+ name: Figma Brand Guidelines
15
+ url: "https://www.figma.com/using-the-figma-brand"
16
+ type: brand
17
+ description: Figma's official trademark and brand usage guidelines with logo downloads.
18
+ og_image: "https://cdn.sanity.io/images/599r6htc/regionalized/342e17642c7afa81206490b0dd21c3e5724ae040-2400x1260.png?w=1200&q=70&fit=max&auto=format"
4
19
  ---
5
20
 
6
21
  # Design System Inspiration of Figma