oh-my-design-cli 0.1.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.
- package/LICENSE +21 -0
- package/README.ja.md +145 -0
- package/README.ko.md +245 -0
- package/README.md +245 -0
- package/README.zh-TW.md +145 -0
- package/data/reference-tags.md +104 -0
- package/data/synonyms.json +79 -0
- package/data/vocabulary.json +516 -0
- package/dist/bin/oh-my-design.js +858 -0
- package/dist/bin/oh-my-design.js.map +1 -0
- package/dist/chunk-6YNSV3VY.js +35 -0
- package/dist/chunk-6YNSV3VY.js.map +1 -0
- package/dist/chunk-MHFYGZSO.js +337 -0
- package/dist/chunk-MHFYGZSO.js.map +1 -0
- package/dist/chunk-N2JG6N4Q.js +264 -0
- package/dist/chunk-N2JG6N4Q.js.map +1 -0
- package/dist/chunk-OOQQEUGX.js +46 -0
- package/dist/chunk-OOQQEUGX.js.map +1 -0
- package/dist/chunk-OR5DHENY.js +250 -0
- package/dist/chunk-OR5DHENY.js.map +1 -0
- package/dist/customizer-CM76752R.js +8 -0
- package/dist/customizer-CM76752R.js.map +1 -0
- package/dist/index.d.ts +559 -0
- package/dist/index.js +3113 -0
- package/dist/index.js.map +1 -0
- package/dist/init-STACB7E5.js +635 -0
- package/dist/init-STACB7E5.js.map +1 -0
- package/dist/install-skills-CM6VXFZJ.js +152 -0
- package/dist/install-skills-CM6VXFZJ.js.map +1 -0
- package/dist/learn-33LHKEJA.js +140 -0
- package/dist/learn-33LHKEJA.js.map +1 -0
- package/dist/reference-YMNAOXJQ.js +47 -0
- package/dist/reference-YMNAOXJQ.js.map +1 -0
- package/dist/reference-parser-TM3CJPNE.js +10 -0
- package/dist/reference-parser-TM3CJPNE.js.map +1 -0
- package/dist/remember-UAFA5B2O.js +78 -0
- package/dist/remember-UAFA5B2O.js.map +1 -0
- package/dist/sync-P7X4S2DK.js +404 -0
- package/dist/sync-P7X4S2DK.js.map +1 -0
- package/dist/templates/templates/design-md.hbs +44 -0
- package/dist/templates/templates/partials/agent-prompt-guide.hbs +28 -0
- package/dist/templates/templates/partials/color-palette.hbs +49 -0
- package/dist/templates/templates/partials/component-stylings.hbs +28 -0
- package/dist/templates/templates/partials/depth-elevation.hbs +31 -0
- package/dist/templates/templates/partials/dos-donts.hbs +13 -0
- package/dist/templates/templates/partials/layout.hbs +30 -0
- package/dist/templates/templates/partials/responsive.hbs +25 -0
- package/dist/templates/templates/partials/shadcn-tokens.hbs +64 -0
- package/dist/templates/templates/partials/typography.hbs +43 -0
- package/dist/templates/templates/partials/visual-theme.hbs +26 -0
- package/package.json +68 -0
- package/references/Claude-Design-Sys-Prompt.txt +421 -0
- package/references/airbnb/DESIGN.md +427 -0
- package/references/airbnb/README.md +23 -0
- package/references/airbnb/preview-dark.html +234 -0
- package/references/airbnb/preview.html +233 -0
- package/references/airtable/DESIGN.md +107 -0
- package/references/airtable/README.md +23 -0
- package/references/airtable/preview-dark.html +165 -0
- package/references/airtable/preview.html +164 -0
- package/references/apple/DESIGN.md +496 -0
- package/references/apple/README.md +24 -0
- package/references/apple/preview-dark.html +420 -0
- package/references/apple/preview.html +414 -0
- package/references/baemin/DESIGN.md +260 -0
- package/references/baemin/README.md +19 -0
- package/references/bmw/DESIGN.md +180 -0
- package/references/bmw/README.md +23 -0
- package/references/bmw/preview-dark.html +211 -0
- package/references/bmw/preview.html +210 -0
- package/references/cal/DESIGN.md +259 -0
- package/references/cal/README.md +23 -0
- package/references/cal/preview-dark.html +449 -0
- package/references/cal/preview.html +575 -0
- package/references/claude/DESIGN.md +455 -0
- package/references/claude/README.md +24 -0
- package/references/claude/preview-dark.html +803 -0
- package/references/claude/preview.html +826 -0
- package/references/clay/DESIGN.md +304 -0
- package/references/clay/README.md +23 -0
- package/references/clay/preview-dark.html +316 -0
- package/references/clay/preview.html +315 -0
- package/references/clickhouse/DESIGN.md +281 -0
- package/references/clickhouse/README.md +24 -0
- package/references/clickhouse/preview-dark.html +834 -0
- package/references/clickhouse/preview.html +786 -0
- package/references/cohere/DESIGN.md +266 -0
- package/references/cohere/README.md +24 -0
- package/references/cohere/preview-dark.html +803 -0
- package/references/cohere/preview.html +807 -0
- package/references/coinbase/DESIGN.md +129 -0
- package/references/coinbase/README.md +23 -0
- package/references/coinbase/preview-dark.html +164 -0
- package/references/coinbase/preview.html +163 -0
- package/references/composio/DESIGN.md +307 -0
- package/references/composio/README.md +24 -0
- package/references/composio/preview-dark.html +958 -0
- package/references/composio/preview.html +933 -0
- package/references/cursor/DESIGN.md +322 -0
- package/references/cursor/README.md +24 -0
- package/references/cursor/preview-dark.html +393 -0
- package/references/cursor/preview.html +383 -0
- package/references/dcard/DESIGN.md +302 -0
- package/references/dcard/README.md +12 -0
- package/references/dcard/_research/forum-1440px.png +0 -0
- package/references/dcard/_research.md +77 -0
- package/references/elevenlabs/DESIGN.md +265 -0
- package/references/elevenlabs/README.md +23 -0
- package/references/elevenlabs/preview-dark.html +252 -0
- package/references/elevenlabs/preview.html +251 -0
- package/references/expo/DESIGN.md +281 -0
- package/references/expo/README.md +24 -0
- package/references/expo/preview-dark.html +533 -0
- package/references/expo/preview.html +533 -0
- package/references/ferrari/DESIGN.md +314 -0
- package/references/ferrari/README.md +23 -0
- package/references/ferrari/preview-dark.html +1162 -0
- package/references/ferrari/preview.html +1122 -0
- package/references/figma/DESIGN.md +399 -0
- package/references/figma/README.md +24 -0
- package/references/figma/preview-dark.html +822 -0
- package/references/figma/preview.html +832 -0
- package/references/framer/DESIGN.md +246 -0
- package/references/framer/README.md +23 -0
- package/references/framer/preview-dark.html +902 -0
- package/references/framer/preview.html +883 -0
- package/references/freee/DESIGN.md +308 -0
- package/references/freee/README.md +12 -0
- package/references/freee/_research/vibes-storybook-1440px.png +0 -0
- package/references/freee/_research.md +77 -0
- package/references/hashicorp/DESIGN.md +278 -0
- package/references/hashicorp/README.md +24 -0
- package/references/hashicorp/preview-dark.html +1202 -0
- package/references/hashicorp/preview.html +1193 -0
- package/references/ibm/DESIGN.md +332 -0
- package/references/ibm/README.md +24 -0
- package/references/ibm/preview-dark.html +443 -0
- package/references/ibm/preview.html +428 -0
- package/references/intercom/DESIGN.md +146 -0
- package/references/intercom/README.md +23 -0
- package/references/intercom/preview-dark.html +185 -0
- package/references/intercom/preview.html +184 -0
- package/references/kakao/DESIGN.md +261 -0
- package/references/kakao/README.md +18 -0
- package/references/karrot/DESIGN.md +252 -0
- package/references/karrot/README.md +18 -0
- package/references/kraken/DESIGN.md +146 -0
- package/references/kraken/README.md +23 -0
- package/references/kraken/preview-dark.html +169 -0
- package/references/kraken/preview.html +168 -0
- package/references/lamborghini/DESIGN.md +288 -0
- package/references/lamborghini/README.md +23 -0
- package/references/lamborghini/preview-dark.html +303 -0
- package/references/lamborghini/preview.html +381 -0
- package/references/line/DESIGN.md +375 -0
- package/references/line/README.md +12 -0
- package/references/line/_research/home-1440px.png +0 -0
- package/references/line/_research.md +65 -0
- package/references/linear.app/DESIGN.md +526 -0
- package/references/linear.app/README.md +24 -0
- package/references/linear.app/preview-dark.html +383 -0
- package/references/linear.app/preview.html +373 -0
- package/references/lovable/DESIGN.md +298 -0
- package/references/lovable/README.md +24 -0
- package/references/lovable/preview-dark.html +349 -0
- package/references/lovable/preview.html +348 -0
- package/references/mercari/DESIGN.md +294 -0
- package/references/mercari/README.md +12 -0
- package/references/mercari/_research/home-1440px.png +0 -0
- package/references/mercari/_research.md +77 -0
- package/references/minimax/DESIGN.md +257 -0
- package/references/minimax/README.md +24 -0
- package/references/minimax/preview-dark.html +1262 -0
- package/references/minimax/preview.html +1248 -0
- package/references/mintlify/DESIGN.md +341 -0
- package/references/mintlify/README.md +24 -0
- package/references/mintlify/preview-dark.html +409 -0
- package/references/mintlify/preview.html +398 -0
- package/references/miro/DESIGN.md +108 -0
- package/references/miro/README.md +23 -0
- package/references/miro/preview-dark.html +174 -0
- package/references/miro/preview.html +173 -0
- package/references/mistral.ai/DESIGN.md +261 -0
- package/references/mistral.ai/README.md +24 -0
- package/references/mistral.ai/preview-dark.html +806 -0
- package/references/mistral.ai/preview.html +805 -0
- package/references/mongodb/DESIGN.md +266 -0
- package/references/mongodb/README.md +23 -0
- package/references/mongodb/preview-dark.html +260 -0
- package/references/mongodb/preview.html +259 -0
- package/references/notion/DESIGN.md +492 -0
- package/references/notion/README.md +24 -0
- package/references/notion/preview-dark.html +372 -0
- package/references/notion/preview.html +364 -0
- package/references/nvidia/DESIGN.md +308 -0
- package/references/nvidia/README.md +24 -0
- package/references/nvidia/preview-dark.html +374 -0
- package/references/nvidia/preview.html +366 -0
- package/references/ollama/DESIGN.md +267 -0
- package/references/ollama/README.md +24 -0
- package/references/ollama/preview-dark.html +678 -0
- package/references/ollama/preview.html +678 -0
- package/references/opencode.ai/DESIGN.md +295 -0
- package/references/opencode.ai/README.md +24 -0
- package/references/opencode.ai/preview-dark.html +366 -0
- package/references/opencode.ai/preview.html +357 -0
- package/references/pinkoi/DESIGN.md +309 -0
- package/references/pinkoi/README.md +12 -0
- package/references/pinkoi/_research/browse-1440px.png +0 -0
- package/references/pinkoi/_research.md +115 -0
- package/references/pinterest/DESIGN.md +230 -0
- package/references/pinterest/README.md +23 -0
- package/references/pinterest/preview-dark.html +233 -0
- package/references/pinterest/preview.html +232 -0
- package/references/posthog/DESIGN.md +256 -0
- package/references/posthog/README.md +23 -0
- package/references/posthog/preview-dark.html +699 -0
- package/references/posthog/preview.html +749 -0
- package/references/raycast/DESIGN.md +268 -0
- package/references/raycast/README.md +23 -0
- package/references/raycast/preview-dark.html +606 -0
- package/references/raycast/preview.html +688 -0
- package/references/renault/DESIGN.md +311 -0
- package/references/renault/README.md +23 -0
- package/references/renault/preview-dark.html +406 -0
- package/references/renault/preview.html +606 -0
- package/references/replicate/DESIGN.md +261 -0
- package/references/replicate/README.md +24 -0
- package/references/replicate/preview-dark.html +828 -0
- package/references/replicate/preview.html +831 -0
- package/references/resend/DESIGN.md +303 -0
- package/references/resend/README.md +23 -0
- package/references/resend/preview-dark.html +355 -0
- package/references/resend/preview.html +354 -0
- package/references/revolut/DESIGN.md +185 -0
- package/references/revolut/README.md +23 -0
- package/references/revolut/preview-dark.html +234 -0
- package/references/revolut/preview.html +233 -0
- package/references/runwayml/DESIGN.md +244 -0
- package/references/runwayml/README.md +24 -0
- package/references/runwayml/preview-dark.html +664 -0
- package/references/runwayml/preview.html +665 -0
- package/references/sanity/DESIGN.md +357 -0
- package/references/sanity/README.md +24 -0
- package/references/sanity/preview-dark.html +990 -0
- package/references/sanity/preview.html +1135 -0
- package/references/sentry/DESIGN.md +262 -0
- package/references/sentry/README.md +24 -0
- package/references/sentry/preview-dark.html +626 -0
- package/references/sentry/preview.html +951 -0
- package/references/spacex/DESIGN.md +205 -0
- package/references/spacex/README.md +23 -0
- package/references/spacex/preview-dark.html +221 -0
- package/references/spacex/preview.html +220 -0
- package/references/spotify/DESIGN.md +246 -0
- package/references/spotify/README.md +23 -0
- package/references/spotify/preview-dark.html +231 -0
- package/references/spotify/preview.html +230 -0
- package/references/stripe/DESIGN.md +473 -0
- package/references/stripe/README.md +24 -0
- package/references/stripe/preview-dark.html +428 -0
- package/references/stripe/preview.html +419 -0
- package/references/supabase/DESIGN.md +255 -0
- package/references/supabase/README.md +24 -0
- package/references/supabase/preview-dark.html +977 -0
- package/references/supabase/preview.html +955 -0
- package/references/superhuman/DESIGN.md +252 -0
- package/references/superhuman/README.md +23 -0
- package/references/superhuman/preview-dark.html +973 -0
- package/references/superhuman/preview.html +951 -0
- package/references/tesla/DESIGN.md +286 -0
- package/references/tesla/README.md +23 -0
- package/references/tesla/preview-dark.html +947 -0
- package/references/tesla/preview.html +925 -0
- package/references/together.ai/DESIGN.md +263 -0
- package/references/together.ai/README.md +24 -0
- package/references/together.ai/preview-dark.html +892 -0
- package/references/together.ai/preview.html +897 -0
- package/references/toss/DESIGN.md +387 -0
- package/references/toss/README.md +19 -0
- package/references/uber/DESIGN.md +295 -0
- package/references/uber/README.md +24 -0
- package/references/uber/preview-dark.html +1120 -0
- package/references/uber/preview.html +1119 -0
- package/references/vercel/DESIGN.md +456 -0
- package/references/vercel/README.md +24 -0
- package/references/vercel/preview-dark.html +368 -0
- package/references/vercel/preview.html +367 -0
- package/references/voltagent/DESIGN.md +323 -0
- package/references/voltagent/README.md +24 -0
- package/references/voltagent/preview-dark.html +487 -0
- package/references/voltagent/preview.html +766 -0
- package/references/warp/DESIGN.md +253 -0
- package/references/warp/README.md +23 -0
- package/references/warp/preview-dark.html +500 -0
- package/references/warp/preview.html +533 -0
- package/references/webflow/DESIGN.md +109 -0
- package/references/webflow/README.md +23 -0
- package/references/webflow/preview-dark.html +147 -0
- package/references/webflow/preview.html +146 -0
- package/references/wise/DESIGN.md +173 -0
- package/references/wise/README.md +23 -0
- package/references/wise/preview-dark.html +230 -0
- package/references/wise/preview.html +229 -0
- package/references/x.ai/DESIGN.md +267 -0
- package/references/x.ai/README.md +24 -0
- package/references/x.ai/preview-dark.html +356 -0
- package/references/x.ai/preview.html +407 -0
- package/references/zapier/DESIGN.md +328 -0
- package/references/zapier/README.md +24 -0
- package/references/zapier/preview-dark.html +380 -0
- package/references/zapier/preview.html +372 -0
- package/skills/omd-apply/SKILL.md +85 -0
- package/skills/omd-init/SKILL.md +167 -0
- package/skills/omd-learn/SKILL.md +81 -0
- package/skills/omd-remember/SKILL.md +44 -0
- package/skills/omd-sync/SKILL.md +38 -0
|
@@ -0,0 +1,387 @@
|
|
|
1
|
+
---
|
|
2
|
+
omd: 0.1
|
|
3
|
+
brand: Toss
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# Design System Inspiration of Toss (토스)
|
|
7
|
+
|
|
8
|
+
## 1. Visual Theme & Atmosphere
|
|
9
|
+
|
|
10
|
+
Toss is Korea's fintech super-app that redefined what a financial interface could feel like -- calm, confident, and deceptively simple. The page opens on a clean white canvas (`#ffffff`) with deep charcoal headings (`#191f28`) and a signature blue (`#3182f6`) that functions as the universal interactive accent. This isn't the cold, institutional blue of legacy banking; it's a bright, optimistic cerulean that says "your money is in good hands, and we'll make it easy."
|
|
11
|
+
|
|
12
|
+
The custom **Toss Product Sans** typeface is the quiet hero. Developed with Korean type foundries Sandoll and Leedotype, it was purpose-built for financial contexts: numerals and Latin characters are optically weighted to match Korean hangul proportions, and financial symbols (%, commas, ±) are given enhanced legibility. The font ships in 8 weights (300-950) but the UI exercises restraint, primarily using 400, 600, and 700. The system supports both variable-width numerals for display and fixed-width (tabular) numerals for data tables -- context determines mode.
|
|
13
|
+
|
|
14
|
+
What defines Toss visually is its OKLCH-based color system, rebuilt from scratch for perceptual uniformity. Colors at the same scale level appear equally bright regardless of hue, enabling consistent semantic coloring where blue-500, red-500, and green-500 carry identical visual weight without manual tuning.
|
|
15
|
+
|
|
16
|
+
**Key Characteristics:**
|
|
17
|
+
- Toss Blue (`#3182f6`) as the primary interactive color -- bright, optimistic, trustworthy
|
|
18
|
+
- Toss Product Sans with Korean-Latin optical balancing and tabular numeral support
|
|
19
|
+
- OKLCH color space for perceptual uniformity across all hue scales
|
|
20
|
+
- 10-step grey scale (grey50-grey900) with warm undertones
|
|
21
|
+
- Three-tier token architecture: primitive → semantic → component
|
|
22
|
+
- Minimal shadow system -- trust comes from clarity, not depth
|
|
23
|
+
- Mobile-first at 375px design baseline with accessibility scaling up to 310%
|
|
24
|
+
|
|
25
|
+
## 2. Color Palette & Roles
|
|
26
|
+
|
|
27
|
+
### Primary
|
|
28
|
+
- **Toss Blue** (`#3182f6`): `blue500`. Primary interactive color -- CTAs, links, active states, selection highlights. The workhorse of every tappable element.
|
|
29
|
+
- **Blue Hover** (`#2272eb`): `blue600`. Hover/pressed state for blue500 elements.
|
|
30
|
+
- **Blue Light** (`#e8f3ff`): `blue50`. Informational backgrounds, subtle blue-tinted surfaces.
|
|
31
|
+
- **Pure White** (`#ffffff`): `background`, `layeredBackground`. Page background, card surfaces.
|
|
32
|
+
- **Dark Charcoal** (`#191f28`): `grey900`. Primary heading color, strongest text. Warm near-black with subtle blue undertone.
|
|
33
|
+
|
|
34
|
+
### Brand (Logo/Marketing Only)
|
|
35
|
+
- **Brand Blue** (`#0064FF`): Official Toss brand color (Pantone 2175 C). Logo and marketing materials only -- distinct from UI blue500.
|
|
36
|
+
- **Brand Gray** (`#202632`): Official secondary brand color (Pantone 433 C). Corporate contexts.
|
|
37
|
+
|
|
38
|
+
### Semantic
|
|
39
|
+
- **Error Red** (`#f04452`): `red500`. Error states, destructive actions, negative financial indicators.
|
|
40
|
+
- **Success Green** (`#03b26c`): `green500`. Positive financial indicators, confirmations.
|
|
41
|
+
- **Warning Orange** (`#fe9800`): `orange500`. Pending states, attention-needed indicators.
|
|
42
|
+
- **Caution Yellow** (`#ffc342`): `yellow500`. Soft warnings, highlight moments.
|
|
43
|
+
- **Info Teal** (`#18a5a5`): `teal500`. Informational accent, alternative categorization.
|
|
44
|
+
- **Premium Purple** (`#a234c7`): `purple500`. Premium features, special offers.
|
|
45
|
+
|
|
46
|
+
### Neutral Scale
|
|
47
|
+
- **Grey 50** (`#f9fafb`): Lightest gray, `greyBackground` surface.
|
|
48
|
+
- **Grey 100** (`#f2f4f6`): Secondary background, card fills, disabled surfaces.
|
|
49
|
+
- **Grey 200** (`#e5e8eb`): Default border color, dividers, input backgrounds.
|
|
50
|
+
- **Grey 400** (`#b0b8c1`): Placeholder text, disabled icon fills.
|
|
51
|
+
- **Grey 500** (`#8b95a1`): Caption text, secondary labels.
|
|
52
|
+
- **Grey 600** (`#6b7684`): Body text, descriptions, metadata.
|
|
53
|
+
- **Grey 700** (`#4e5968`): Emphasized body text, sub-headings.
|
|
54
|
+
- **Grey 800** (`#333d4b`): Strong labels, navigation text.
|
|
55
|
+
|
|
56
|
+
### Surface & Borders
|
|
57
|
+
- **Border Default**: `#e5e8eb` (grey200). Standard card borders, input borders, dividers.
|
|
58
|
+
- **Border Strong**: `#d1d6db` (grey300). Emphasized borders, active input outlines.
|
|
59
|
+
- **Background Float**: `#ffffff`. `floatBackground`. Floating elements -- tooltips, dropdowns.
|
|
60
|
+
- **Overlay Scrim**: `rgba(2,9,19,0.5)` to `rgba(2,9,19,0.91)`. `greyOpacity` scale. Blue-tinted dark overlays.
|
|
61
|
+
|
|
62
|
+
## 3. Typography Rules
|
|
63
|
+
|
|
64
|
+
### Font Family
|
|
65
|
+
- **Primary**: `"Toss Product Sans", "Tossface", "SF Pro KR", "SF Pro Display", -apple-system, BlinkMacSystemFont, "Basier Square", "Apple SD Gothic Neo", Roboto, "Noto Sans KR", sans-serif`
|
|
66
|
+
- **Monospace**: `"SF Mono", SFMono-Regular, Menlo, Consolas, monospace`
|
|
67
|
+
- **Emoji**: `Tossface` -- Toss's custom emoji font (3500+ emojis, open-source on GitHub)
|
|
68
|
+
|
|
69
|
+
### Hierarchy
|
|
70
|
+
|
|
71
|
+
| Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
|
|
72
|
+
|------|------|------|--------|-------------|----------------|-------|
|
|
73
|
+
| Display Hero | Toss Product Sans | 30px | 700 | 40px (1.33) | normal | Splash screens, hero moments |
|
|
74
|
+
| Display Large | Toss Product Sans | 26px | 700 | 36px (1.38) | normal | Section headers, key metrics |
|
|
75
|
+
| Heading Large | Toss Product Sans | 22px | 700 | 30px (1.36) | normal | Feature titles, modal headers |
|
|
76
|
+
| Heading | Toss Product Sans | 20px | 600 | 28px (1.40) | normal | Card headings, sub-sections |
|
|
77
|
+
| Subtitle | Toss Product Sans | 16px | 600 | 24px (1.50) | normal | Navigation titles, list headers |
|
|
78
|
+
| Body Large | Toss Product Sans | 16px | 400 | 24px (1.50) | normal | Descriptions, explanations |
|
|
79
|
+
| Body | Toss Product Sans | 14px | 400 | 22px (1.57) | normal | Standard reading text |
|
|
80
|
+
| Body Small | Toss Product Sans | 13px | 400 | 20px (1.54) | normal | Secondary information |
|
|
81
|
+
| Caption | Toss Product Sans | 12px | 400 | 18px (1.50) | normal | Timestamps, fine print |
|
|
82
|
+
| Number Display | Toss Product Sans | 30px+ | 700 | tight | normal | Financial amounts -- tabular nums |
|
|
83
|
+
|
|
84
|
+
### Principles
|
|
85
|
+
- **Eight weights, three used**: Ships 300-950, but UI uses 400 (body), 600 (emphasis), 700 (headings). Restraint over variety.
|
|
86
|
+
- **Dual numeral modes**: Variable-width for display, fixed-width (tabular) for financial tables and stock tickers. Context determines mode.
|
|
87
|
+
- **Korean-Latin optical balance**: Korean characters and Latin/numerals are independently weighted so mixed text looks harmonious without manual kerning.
|
|
88
|
+
- **Financial symbol optimization**: %, comma separators, ±, currency symbols, and directional arrows given enhanced legibility at small sizes.
|
|
89
|
+
|
|
90
|
+
## 4. Component Stylings
|
|
91
|
+
|
|
92
|
+
### Buttons
|
|
93
|
+
|
|
94
|
+
**Primary (Fill)**
|
|
95
|
+
- Background: `#3182f6` (blue500)
|
|
96
|
+
- Text: `#ffffff`
|
|
97
|
+
- Radius: `var(--button-border-radius)` (typically 8px-12px)
|
|
98
|
+
- Font: 16px weight 600
|
|
99
|
+
- Pressed: dimmed overlay (opacity reduction)
|
|
100
|
+
- Loading: 3-dot animation replacing text
|
|
101
|
+
- Disabled: reduced opacity via `--button-disabled-opacity-color`
|
|
102
|
+
- Display modes: `inline` (auto-width), `block` (full-width with line break), `full` (fills parent)
|
|
103
|
+
- Sizes: `tiny`, `medium`, `large`, `big` (default)
|
|
104
|
+
- Colors: `primary`, `dark`, `danger`, `light`
|
|
105
|
+
- Use: Primary CTAs ("송금하기", "확인")
|
|
106
|
+
|
|
107
|
+
**Secondary (Weak)**
|
|
108
|
+
- Background: `#e8f3ff` (blue50) or `#f2f4f6` (grey100)
|
|
109
|
+
- Text: `#3182f6` (blue500) or `#191f28` (grey900)
|
|
110
|
+
- Use: Less prominent CTAs, secondary actions
|
|
111
|
+
|
|
112
|
+
**Dark**
|
|
113
|
+
- Background: `#191f28` (grey900)
|
|
114
|
+
- Text: `#ffffff`
|
|
115
|
+
- Use: Actions on light backgrounds where blue would be too playful
|
|
116
|
+
|
|
117
|
+
**Danger**
|
|
118
|
+
- Background: `#f04452` (red500)
|
|
119
|
+
- Text: `#ffffff`
|
|
120
|
+
- Use: Destructive actions, alert confirmations
|
|
121
|
+
|
|
122
|
+
### Cards & Containers
|
|
123
|
+
- Background: `#ffffff` (layeredBackground)
|
|
124
|
+
- Border: 1px solid `#e5e8eb` (grey200) or no border
|
|
125
|
+
- Radius: 12px (standard), 16px (featured), 8px (compact)
|
|
126
|
+
- Shadow: `0px 2px 8px rgba(0,0,0,0.08)` -- single-layer, minimal
|
|
127
|
+
- Financial cards: prominent number display with amount in 700 weight, currency label in 400
|
|
128
|
+
|
|
129
|
+
### Inputs & Forms
|
|
130
|
+
- Background: `#f2f4f6` (grey100) for contained variant
|
|
131
|
+
- Border: 1px solid `#e5e8eb`, focus: 2px solid `#3182f6`
|
|
132
|
+
- Radius: 8px
|
|
133
|
+
- Text: `#191f28`, Placeholder: `#b0b8c1` (grey400)
|
|
134
|
+
- Error border: `#f04452` (red500)
|
|
135
|
+
- Special: SplitTextField for OTP, SecureKeypad for financial input
|
|
136
|
+
|
|
137
|
+
### Navigation
|
|
138
|
+
- Bottom tab bar: white background, top border `#e5e8eb`
|
|
139
|
+
- Active: `#3182f6` icon + `#191f28` text, Inactive: `#b0b8c1` icon + `#8b95a1` text
|
|
140
|
+
- Top app bar: white, sticky, optional backdrop blur
|
|
141
|
+
- Segmented control for section switching
|
|
142
|
+
|
|
143
|
+
### Overlays
|
|
144
|
+
- Bottom Sheet: `#ffffff`, 16px top radius, managed via `overlay-kit`
|
|
145
|
+
- Dialog: centered modal, AlertDialog and ConfirmDialog variants
|
|
146
|
+
- Toast: floating notification, subtle shadow, auto-dismiss
|
|
147
|
+
- Tooltip: `#191f28` background, white text, arrow pointer
|
|
148
|
+
|
|
149
|
+
## 5. Layout Principles
|
|
150
|
+
|
|
151
|
+
### Spacing System
|
|
152
|
+
- Base unit: 8px
|
|
153
|
+
- Common values: 4px, 8px, 12px, 16px, 20px, 24px, 32px, 40px, 48px
|
|
154
|
+
- Horizontal padding: 20px (slightly wider than typical 16px)
|
|
155
|
+
- Financial data grids: tighter 4px internal spacing
|
|
156
|
+
|
|
157
|
+
### Grid & Container
|
|
158
|
+
- Design baseline: 375px mobile width
|
|
159
|
+
- Content: full-width with 20px horizontal padding
|
|
160
|
+
- No explicit multi-column grid -- single-column, mobile-first
|
|
161
|
+
- Transaction lists: full-width rows with consistent left-align for amounts
|
|
162
|
+
|
|
163
|
+
### Whitespace Philosophy
|
|
164
|
+
- **Breathing room for money**: Financial numbers get extra surrounding space. A balance at 30px with 32px margins communicates security through spaciousness.
|
|
165
|
+
- **Progressive density**: Summary screens are spacious; detail/transaction screens are denser. The deeper you go, the more information-dense.
|
|
166
|
+
- **Grouped by function**: Send/receive/invest actions separated by 24px+ gaps; related data within a group uses 8-12px gaps.
|
|
167
|
+
|
|
168
|
+
### Border Radius Scale
|
|
169
|
+
- Compact (4px): Small badges, inline elements
|
|
170
|
+
- Standard (8px): Inputs, small buttons, compact cards
|
|
171
|
+
- Comfortable (12px): Standard cards, dialog corners
|
|
172
|
+
- Large (16px): Featured cards, bottom sheet top corners
|
|
173
|
+
- Pill (9999px): Toggle switches, floating chips
|
|
174
|
+
|
|
175
|
+
## 6. Depth & Elevation
|
|
176
|
+
|
|
177
|
+
| Level | Treatment | Use |
|
|
178
|
+
|-------|-----------|-----|
|
|
179
|
+
| Flat (Level 0) | No shadow | Page background, inline elements |
|
|
180
|
+
| Subtle (Level 1) | `0px 1px 3px rgba(0,0,0,0.06)` | Slight lift, list item separation |
|
|
181
|
+
| Standard (Level 2) | `0px 2px 8px rgba(0,0,0,0.08)` | Cards, content panels |
|
|
182
|
+
| Elevated (Level 3) | `0px 4px 12px rgba(0,0,0,0.12)` | Dropdowns, popovers, floating buttons |
|
|
183
|
+
| Modal (Level 4) | `0px 8px 24px rgba(0,0,0,0.16)` | Bottom sheets, dialogs, modals |
|
|
184
|
+
|
|
185
|
+
**Shadow Philosophy**: Toss keeps shadows minimal and neutral. In a financial app, visual noise undermines trust -- elevation is communicated through subtle opacity differences rather than dramatic depth. Pure black with low opacity creates clinical precision matching the fintech context. Where Stripe uses brand-colored shadows, Toss uses restraint as its brand statement.
|
|
186
|
+
|
|
187
|
+
### Blur Effects
|
|
188
|
+
- Menu components use backdrop blur for lightweight floating panels
|
|
189
|
+
- Navigation bar applies subtle blur on scroll for the sticky header
|
|
190
|
+
|
|
191
|
+
## 7. Do's and Don'ts
|
|
192
|
+
|
|
193
|
+
### Do
|
|
194
|
+
- Use Toss Blue (`#3182f6`) for all interactive elements -- links, buttons, toggles, selections
|
|
195
|
+
- Apply the full font stack with Korean fallbacks including Tossface emoji
|
|
196
|
+
- Use tabular (fixed-width) numerals for financial data and transaction amounts
|
|
197
|
+
- Use 700 weight for financial amounts and headings, 400 for body, 600 for emphasis
|
|
198
|
+
- Keep border-radius between 8px-16px for most elements
|
|
199
|
+
- Show positive changes in green (`#03b26c`), negative in red (`#f04452`)
|
|
200
|
+
- Use blue50 (`#e8f3ff`) for subtle informational backgrounds
|
|
201
|
+
|
|
202
|
+
### Don't
|
|
203
|
+
- Don't confuse Brand Blue (`#0064FF`) with UI Blue (`#3182f6`) -- brand is for marketing/logo only
|
|
204
|
+
- Don't use heavy shadows -- rely on background color layering, not depth
|
|
205
|
+
- Don't use bold (700) for body text -- reserved for headings and financial amounts
|
|
206
|
+
- Don't mix variable-width and tabular numerals in the same data context
|
|
207
|
+
- Don't use warm accent colors (orange, pink) for primary actions -- blue is the sole interactive hue
|
|
208
|
+
- Don't use border-radius > 16px except for pills/toggles
|
|
209
|
+
- Don't add decorative elements to financial data displays -- clarity is the aesthetic
|
|
210
|
+
|
|
211
|
+
## 8. Responsive Behavior
|
|
212
|
+
|
|
213
|
+
### Breakpoints
|
|
214
|
+
| Name | Width | Key Changes |
|
|
215
|
+
|------|-------|-------------|
|
|
216
|
+
| Mobile (Primary) | <480px | Full design fidelity, 375px baseline |
|
|
217
|
+
| Tablet | 480-768px | Expanded cards, optional side margins |
|
|
218
|
+
| Desktop (Web) | >768px | Centered column, max-width ~480px for mobile-web parity |
|
|
219
|
+
|
|
220
|
+
### Touch Targets
|
|
221
|
+
- Buttons: xlarge (~56px), large (~48px), medium (~40px), small (~36px)
|
|
222
|
+
- List items: minimum 52px row height for financial actions
|
|
223
|
+
- Keypad buttons: large targets (56-64px) for secure input
|
|
224
|
+
|
|
225
|
+
### Collapsing Strategy
|
|
226
|
+
- Desktop web mirrors mobile layout in a centered column
|
|
227
|
+
- Bottom sheet → modal dialog on larger screens
|
|
228
|
+
- Sticky bottom CTA bar with safe area insets on all devices
|
|
229
|
+
- Horizontal scrolling card carousels for product discovery
|
|
230
|
+
|
|
231
|
+
### Image Behavior
|
|
232
|
+
- Bank/service logos: 24-40px with consistent sizing within context
|
|
233
|
+
- Tossface emojis: inline at text size, display size for decorative use
|
|
234
|
+
- Charts/graphs: full-width, responsive, maintain aspect ratio
|
|
235
|
+
|
|
236
|
+
## 9. Agent Prompt Guide
|
|
237
|
+
|
|
238
|
+
### Quick Color Reference
|
|
239
|
+
- Primary CTA: Toss Blue (`#3182f6`)
|
|
240
|
+
- CTA Hover: Blue 600 (`#2272eb`)
|
|
241
|
+
- Background: Pure White (`#ffffff`)
|
|
242
|
+
- Background Surface: Light Gray (`#f2f4f6`)
|
|
243
|
+
- Heading text: Dark Charcoal (`#191f28`)
|
|
244
|
+
- Body text: Medium Gray (`#6b7684`)
|
|
245
|
+
- Caption text: Gray (`#8b95a1`)
|
|
246
|
+
- Placeholder: Soft Gray (`#b0b8c1`)
|
|
247
|
+
- Border: Gray 200 (`#e5e8eb`)
|
|
248
|
+
- Success/Positive: Green (`#03b26c`)
|
|
249
|
+
- Error/Negative: Red (`#f04452`)
|
|
250
|
+
- Warning: Orange (`#fe9800`)
|
|
251
|
+
|
|
252
|
+
### Example Component Prompts
|
|
253
|
+
- "Create a balance card: white bg, 12px radius, 20px padding. Balance label 14px weight 400, #8b95a1. Amount 30px weight 700, #191f28, tabular numerals. Currency '원' 20px weight 400. Shadow 0px 2px 8px rgba(0,0,0,0.08)."
|
|
254
|
+
- "Build a send-money button: #3182f6 bg, white text, 16px weight 600, min-height 56px, 12px radius, full-width. Pressed: overlay dim. Loading: 3-dot white animation."
|
|
255
|
+
- "Design a transaction row: full-width, 16px h-padding, 52px min-height. Left: 32px circle icon + name (14px weight 600, #191f28) + category (13px weight 400, #8b95a1). Right: amount (14px weight 600, #f04452 expense / #03b26c income)."
|
|
256
|
+
- "Create an OTP input: 6 boxes, each 48px wide, 56px tall, 8px radius, 1px border #e5e8eb. Active: 2px border #3182f6. Digit: 24px weight 700, centered, #191f28."
|
|
257
|
+
- "Design a bottom tab bar: white bg, top border 1px #e5e8eb. 4 tabs evenly spaced. Active: #3182f6 icon + #191f28 label 11px weight 500. Inactive: #b0b8c1 icon + #8b95a1 label. Tab height 56px with safe area."
|
|
258
|
+
|
|
259
|
+
### Iteration Guide
|
|
260
|
+
1. Always use the full Toss Product Sans font stack with Korean fallbacks
|
|
261
|
+
2. Primary interactive color is `#3182f6` (blue500) -- never `#0064FF` (brand blue)
|
|
262
|
+
3. Financial numbers: 700 weight, tabular numerals, right-aligned in lists
|
|
263
|
+
4. Grey scale has warm undertones: grey900 `#191f28`, grey50 `#f9fafb`
|
|
264
|
+
5. Border-radius: 8px inputs, 12px cards, 16px sheets, pill for toggles
|
|
265
|
+
6. Shadows are single-layer, pure black opacity, no colored tints
|
|
266
|
+
7. Mobile-first: design at 375px, 20px horizontal padding
|
|
267
|
+
|
|
268
|
+
---
|
|
269
|
+
|
|
270
|
+
## 10. Voice & Tone
|
|
271
|
+
|
|
272
|
+
Toss speaks like a friend who happens to be a fiduciary: calm, unhurried, zero jargon, positive statements without hedging. Balance is stated, not "approximately" anything. Korean is the primary voice — English UI strings are secondary translations, not parity. Sentences end in periods; buttons do not. No emoji in financial contexts. Tossface exists as brand decoration but is disallowed on money-handling screens.
|
|
273
|
+
|
|
274
|
+
| Context | Tone |
|
|
275
|
+
|---|---|
|
|
276
|
+
| CTAs | Imperative, short Korean verb form (`송금하기`, `확인`, `가입하기`) |
|
|
277
|
+
| Success toasts | Past-tense single sentence (`송금이 완료되었어요`). No emoji. |
|
|
278
|
+
| Error messages | Specific + blameless + actionable. Never `문제가 발생했습니다`. |
|
|
279
|
+
| Onboarding screens | Second-person, one idea per screen, no bullet lists. |
|
|
280
|
+
| Financial amounts | Bare numerals with comma separators, then currency unit. `1,240,000원`, never `₩1.24M`. |
|
|
281
|
+
| Empty states | Explain the *why* in one line, offer one action. Never `데이터가 없습니다`. |
|
|
282
|
+
| Legal / disclosure | Korean financial-regulation tone — formal `합니다` endings. Single exception to the casual voice. |
|
|
283
|
+
|
|
284
|
+
**Forbidden phrases.** `불편을 드려 죄송합니다`, `Oops`, `죄송하지만`, `약 ~원` (approximation on money), any sentence starting with `I'm sorry` in English strings. Rounded currency amounts (`약 120만원`) are forbidden on primary surfaces; exact numerals only.
|
|
285
|
+
|
|
286
|
+
## 11. Brand Narrative
|
|
287
|
+
|
|
288
|
+
Toss launched in 2015 as a single-feature money-transfer app in a Korean banking market dominated by legacy institutions — KB, Shinhan, Woori, Hana — each with institutional-indigo websites, 12-digit account numbers, Active-X plug-ins, and the presumption that handling money had to feel like filing taxes. The founding rejection was of that entire aesthetic vocabulary. The specific cerulean `#3182f6` was chosen because it was **not** the indigo of any incumbent bank. The optimism of the color was the whole thesis: money could feel light.
|
|
289
|
+
|
|
290
|
+
Toss is not a neo-bank. It's a super-app: one interface holds transfers, investments, credit scoring, insurance, brokerage, and lending. The design's job is to flatten that complexity into **one gesture per screen**. That requires extreme restraint — shadows are single-layer black, palette is blue-and-neutral, type is one family in three weights. Every ornamental move costs clarity, and clarity is the entire brand promise.
|
|
291
|
+
|
|
292
|
+
What Toss refuses: the institutional seriousness of legacy finance, the playfulness of consumer apps (no bright pink, no illustrations of cartoon piggy banks), the data-viz density of Bloomberg-style terminals. Toss occupies a narrow middle — calm but optimistic, dense with functionality but spacious in presentation.
|
|
293
|
+
|
|
294
|
+
## 12. Principles
|
|
295
|
+
|
|
296
|
+
1. **Breathing room for money.** Financial amounts get ≥1.5× the surrounding spacing of normal text. A balance at 30px with 32px margins is correct; the same balance at 16px margins looks cheap and therefore untrustworthy.
|
|
297
|
+
2. **Progressive density.** Summary screens are spacious; detail and transaction screens are dense. The deeper the user navigates, the more information per pixel — they've committed to the context and want facts.
|
|
298
|
+
3. **One action per screen.** If a screen has two primary buttons, it is two screens. Secondary actions are acceptable; two primaries are never acceptable.
|
|
299
|
+
4. **Blue is interaction, not decoration.** `#3182f6` appears only where the user can tap. It never decorates. Illustrations, ornaments, borders, and headers never use blue500 unless they are interactive surfaces.
|
|
300
|
+
5. **Restraint communicates trust.** Shadows are single-layer, pure black, low opacity. No colored shadows, no multi-layer elevation stacks. In finance, visual noise is credibility tax.
|
|
301
|
+
6. **Korean and Latin are co-equal.** Never assume one is primary. Typography stacks, optical weights, and tabular numerals all assume both scripts render simultaneously in the same line.
|
|
302
|
+
7. **Numbers are typography.** Financial amounts use 700 weight and tabular numerals with the same care as display headings. Amounts never inherit body-text weight.
|
|
303
|
+
8. **Negative space is a brand asset.** If reducing padding would fit more on screen, the answer is another screen, not tighter packing.
|
|
304
|
+
|
|
305
|
+
## 13. Personas
|
|
306
|
+
|
|
307
|
+
*Personas below are fictional archetypes informed by publicly described Korean fintech user segments, not individual people.*
|
|
308
|
+
|
|
309
|
+
**정민 (Jeongmin), 28, Seoul.** Software engineer at a mid-size startup. Opens Toss 2–3 times a day — morning subway, post-lunch balance check, evening transfer to a flatmate. Expects the app to open directly to the account screen and paint in under 1s. If she has to tap twice to see her money, she's already irritated. Uses both Korean and English on-device; reads financial English natively but prefers Korean UI for speed.
|
|
310
|
+
|
|
311
|
+
**이선생님 (Mr. Lee), 54, Busan.** Runs a three-person machining shop. His daughter set up Toss for him two years ago. Primary use: transferring to suppliers and receiving invoice payments. Needs one-tap repeat transfer — he has about 12 regular counterparties. Distrusts anything that looks like an advertisement. Would uninstall the app before tapping a promoted banner. Reads Korean only; English strings on product surfaces are invisible to him. Values receipts and transaction history — never deletes them.
|
|
312
|
+
|
|
313
|
+
**예은 (Yeeun), 21, Daegu.** University student, third year, Economics. Toss is her primary banking app — she opened her first account through it, and has never touched a legacy bank's web interface except under duress. Expects Toss Blue to be "banking blue." If another financial app uses cerulean, she assumes it's imitating Toss. Sends ₩5,000–₩30,000 amounts constantly (splitting bills, paying back friends). Treats the app like a messaging app with money attached.
|
|
314
|
+
|
|
315
|
+
## 14. States
|
|
316
|
+
|
|
317
|
+
| State | Treatment |
|
|
318
|
+
|---|---|
|
|
319
|
+
| **Empty (first use)** | Single paragraph of `grey700` body text explaining *why* the screen is empty (`아직 거래내역이 없어요`), plus one suggested action as a secondary button (blue50 bg, blue500 text). Never an illustration. Never `데이터가 없습니다`. |
|
|
320
|
+
| **Empty (filter cleared)** | Single line of `grey500` caption (`조건에 맞는 결과가 없어요`). No button — user resets the filter themselves. |
|
|
321
|
+
| **Loading (first paint)** | Skeleton blocks matching the final layout's structure at `#f2f4f6` (grey100). Financial amounts render as `--` until resolved; they never appear as skeleton blocks (would look like they have a placeholder value). |
|
|
322
|
+
| **Loading (refresh)** | Top bar pull-down spinner in blue500. No overlay, no blocking. Content stays visible with its previous values. |
|
|
323
|
+
| **Error (inline field)** | `#f04452` (red500) 2px border on the input, error text below in red500 13px. One actionable sentence (`계좌번호를 다시 확인해주세요`). |
|
|
324
|
+
| **Error (toast)** | `#191f28` background, white 14px 400 text, 3s auto-dismiss. One sentence. No icons. Bottom of screen with 20px inset. |
|
|
325
|
+
| **Error (screen-blocking)** | Reserved for server outage. White screen, centered single-line message in `grey900` 16px weight 600, retry button in blue500 below. No illustration. |
|
|
326
|
+
| **Success (inline flash)** | Brief flash of `#e8f3ff` (blue50) background behind the updated element, 300ms fade to default. For routine actions like toggling a setting. |
|
|
327
|
+
| **Success (money moved)** | Dedicated confirmation screen — not a toast. `#03b26c` (green500) checkmark top-center, exact amount in 30px weight 700 below, recipient name, timestamp. Single button: `확인`. This weight is intentional; money moving is never a toast. |
|
|
328
|
+
| **Skeleton** | `#f2f4f6` blocks at exact final dimensions. 1.2s shimmer as `linear-gradient` with 8% white highlight. Rounded at component radius (8px/12px/16px per component). Never used on financial amounts — those show `--`. |
|
|
329
|
+
| **Disabled** | Button opacity drops per `--button-disabled-opacity-color`. No grey-out of input borders — disabled inputs keep `grey200` border, so the geometry is stable if re-enabled. |
|
|
330
|
+
| **Loading inside pressed button** | Text is replaced by the 3-dot white animation. Width of the button does not change. Press is visually committed; user cannot double-submit. |
|
|
331
|
+
|
|
332
|
+
## 15. Motion & Easing
|
|
333
|
+
|
|
334
|
+
**Durations** (named, not raw milliseconds):
|
|
335
|
+
|
|
336
|
+
| Token | Value | Use |
|
|
337
|
+
|---|---|---|
|
|
338
|
+
| `motion-instant` | 0ms | Toggle flips, checkbox state changes |
|
|
339
|
+
| `motion-fast` | 150ms | Hover, focus, small reveals, button press overlay |
|
|
340
|
+
| `motion-standard` | 250ms | The default — sheet opens, card expands, tab switches |
|
|
341
|
+
| `motion-slow` | 400ms | Emphasized transitions — success checkmarks, onboarding step advances |
|
|
342
|
+
| `motion-page` | 350ms | Full-screen transitions between top-level routes |
|
|
343
|
+
|
|
344
|
+
**Easings:**
|
|
345
|
+
|
|
346
|
+
| Token | Curve | Use |
|
|
347
|
+
|---|---|---|
|
|
348
|
+
| `ease-enter` | `cubic-bezier(0.0, 0.0, 0.2, 1)` | Things appearing — sheets, toasts, screen pushes |
|
|
349
|
+
| `ease-exit` | `cubic-bezier(0.4, 0.0, 1, 1)` | Things leaving — dismissals, pops |
|
|
350
|
+
| `ease-standard` | `cubic-bezier(0.4, 0.0, 0.2, 1)` | Two-way transitions — collapsible cards, tab content |
|
|
351
|
+
| `ease-spring` | `cubic-bezier(0.34, 1.56, 0.64, 1)` | Reserved. Only for money-moved success checkmark. Nowhere else — overshoot on routine UI would feel unserious. |
|
|
352
|
+
|
|
353
|
+
**Signature motions.**
|
|
354
|
+
|
|
355
|
+
1. **Money-moves.** When a balance updates, the old number slides up 20px and fades out (`motion-fast / ease-exit`), the new number slides in from below 20px (`motion-standard / ease-enter`). Never cross-fade money — a financial amount flickering between values looks like a bug.
|
|
356
|
+
2. **Bottom-sheet presentation.** Sheets rise from `y+40px` with `motion-standard / ease-enter` and a synchronized backdrop fade from `rgba(2,9,19,0)` to `rgba(2,9,19,0.5)`. Dismissal uses `motion-fast / ease-exit` — leaving feels lighter than entering.
|
|
357
|
+
3. **Success checkmark.** On money-moved confirmation, the checkmark draws over `motion-slow` with `ease-spring`. This is the one place spring easing is licensed. Everywhere else, standard easing.
|
|
358
|
+
4. **Reduce motion.** If `prefers-reduced-motion: reduce`, all `motion-*` tokens collapse to `motion-instant`. No exceptions. Crossfades replace slides. The app stays usable; just less kinetic.
|
|
359
|
+
|
|
360
|
+
<!--
|
|
361
|
+
OmD v0.1 Sources — Philosophy Layer (sections 10–15)
|
|
362
|
+
|
|
363
|
+
Direct verification via WebFetch (2026-04-19):
|
|
364
|
+
- https://toss.im/ — confirms Viva Republica (비바리퍼블리카) as operating company,
|
|
365
|
+
unified-finance super-app positioning ("내 모든 금융 내역을 한눈에 조회하고 한 곳에서 관리하세요"),
|
|
366
|
+
and mission framing "모두의 금융에 자유를" (financial freedom for everyone).
|
|
367
|
+
- https://slash.page/ — confirms Toss maintains a public open-source engineering
|
|
368
|
+
presence ("Copyright © 2024 Viva Republica - Toss Frontend Chapter"), with
|
|
369
|
+
packages including overlay-kit, suspensive, use-funnel — demonstrating the
|
|
370
|
+
design/engineering self-documentation culture referenced in §12 Principles.
|
|
371
|
+
|
|
372
|
+
Base DESIGN.md (sections 1–9) is the source for token-level claims including
|
|
373
|
+
Toss Blue #3182f6, Toss Product Sans, the OKLCH-based palette, and shadow tokens.
|
|
374
|
+
|
|
375
|
+
Not independently verified via WebFetch — widely documented public facts used:
|
|
376
|
+
- Toss (Viva Republica) was founded in 2013; the money-transfer app launched in 2015.
|
|
377
|
+
- Korean legacy-bank institutional palette context (KB, Shinhan, Woori, Hana) is
|
|
378
|
+
general industry knowledge, not a sourced Toss statement.
|
|
379
|
+
|
|
380
|
+
Personas (§13) are fictional archetypes informed by publicly described Korean
|
|
381
|
+
fintech user segments. Any resemblance to specific individuals is unintended.
|
|
382
|
+
|
|
383
|
+
Interpretive claims (e.g., "the specific cerulean was chosen because it was
|
|
384
|
+
not the indigo of any incumbent bank") are editorial readings of the design,
|
|
385
|
+
not documented Toss statements.
|
|
386
|
+
-->
|
|
387
|
+
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
# Toss (토스) Inspired Design System
|
|
2
|
+
|
|
3
|
+
DESIGN.md crafted from Toss's publicly documented [TDS (Toss Design System)](https://tossmini-docs.toss.im/tds-mobile/) and [brand guidelines](https://brand.toss.im/). This references the TDS color tokens, typography system, and component specifications from official documentation and tech blog posts. Colors, fonts, and spacing are based on publicly available specifications.
|
|
4
|
+
|
|
5
|
+
## Files
|
|
6
|
+
|
|
7
|
+
| File | Description |
|
|
8
|
+
|------|-------------|
|
|
9
|
+
| `DESIGN.md` | Complete design system documentation (9 sections) |
|
|
10
|
+
|
|
11
|
+
Use DESIGN.md as a reference for AI agents (Claude, Cursor, Stitch) to generate UI that looks like the Toss design language.
|
|
12
|
+
|
|
13
|
+
## Sources
|
|
14
|
+
|
|
15
|
+
- [TDS Mobile Docs](https://tossmini-docs.toss.im/tds-mobile/) — Component and token documentation
|
|
16
|
+
- [Toss Brand Resource Center](https://brand.toss.im/) — Brand colors and identity
|
|
17
|
+
- [Toss Tech Blog (Design)](https://toss.tech/design) — Design system philosophy and updates
|
|
18
|
+
- [Tossface](https://github.com/toss/tossface) — Open-source emoji font
|
|
19
|
+
- [Toss GitHub](https://github.com/toss) — Open-source libraries
|