Millie
Millie
millie
Design System
Millie logo

Millie

Millie's Library is Korea's largest reading-subscription service, and its interface behaves like a calm digital bookshelf -- a content storefront where book covers are the color and everything else stays quiet. The page opens on a clean white canvas (#ffffff) with a warm near-black body text (#242424) and a confident reading blue (#1b6dda) that functio

01

Color Palette

Brand

Accent

Neutrals

Semantic

02

Typography

Type Scale

Rendered in system-ui to clearly show scale & weight.

display48px · 700 · 1.25
Design at scale
32px32px · 700 · 1.25
Section heading
heading-lg24px · 700 · 1.4
Subheading
body16px · 400 · 1.5
Body text. The quick brown fox jumps over the lazy dog. Designed for readable line-height in long-form content.
small12px · 400 · 1.5
Supporting text
caption12px · 400 · 1.5
Caption · timestamp · 2026
label10px · 500 · 1.5
BADGE / LABEL

Fonts

Primary
Pretendard Variable
Open · OFL
Modern Korean variable font with full Latin coverage.
Install via GitHub · orioncactus/pretendard
Primary
Pretendard Fallback
Brand-only
Not in the OMD font registry. Likely a brand-proprietary typeface — check the brand's own design site for source/availability.
Not publicly distributed.
Primary
Pretendard Fallback Android
Brand-only
Not in the OMD font registry. Likely a brand-proprietary typeface — check the brand's own design site for source/availability.
Not publicly distributed.
03

Spacing & Shape

Spacing

PurposeValuePreview
Densitycompact
Base unit4px
Section gap32px
Card padding16px
Element gap12px

Border Radius

ElementValuePreview
buttonsSubtle4px
smallSubtle4px
bookStandard6px
primaryComfortable8px
inputsComfortable8px
neutralComfortable8px
categorySoft10px
feedLarge12px
audiobookLarge12px
floatingPill9999px
carouselPill9999px

Elevation

Shadow 1
Shadow 2
Shadow 3
04

Guidelines

Do and Don't guidelines parsed from DESIGN.md.

Do

  • Use Reading Blue (#1b6dda) for the subscription CTA, active tabs, and links
  • Use warm near-black #242424 for headings and body — not pure #000
  • Give book covers the signature 0px 2px 8px rgba(0,0,0,0.08) lift
  • Apply secondary accents (purple/coral/yellow) for content organization, scarcely
  • Use 10px radius on category tabs, 8px on buttons, 100px on scrim pills
  • Build a cover-forward feed of horizontal shelves — streaming-service posture
  • Keep type comfortable (14-16px) with generous leading for evening browsing

Don't

  • n't use the brand blue as decoration — reserve it for interactive elements
  • n't use pure #000 for body text — warm #242424 is the brand's softness
  • n't let chrome compete with cover art for color attention
  • n't apply purple/coral/yellow as primary CTA fills — those organize content
  • n't make the layout dense — Millie is leisure reading, not a data dashboard
  • n't drop the cover shadow — flat covers lose the physical-book warmth
  • n't mix sharp 0px corners into chrome — the system is consistently rounded
05

Components

Buttons

Primary (Reading Blue)
Background`#1b6dda`
Text`#ffffff`
Bordernone
Radius8px
Padding14px 20px
Font16px / 700 / Pretendard
Hover`#1860c2`
Active`#1554ad`
Disabled`#c1c1c1` background, `#ffffff` text
Use: Primary subscription CTA -- `무료체험 시작하기`, `구독하기`, `읽기`
Dark (Neutral Solid)
Background`#333333`
Text`#ffffff`
Bordernone
Radius4px
Padding0px 12px
Font12px / 400 / Pretendard
Height32px
Use: Compact chrome actions -- `로그인`, header utility buttons
Outline (Blue Border)
Background`#ffffff`
Text`#1b6dda`
Border1px solid `#1b6dda`
Radius8px
Padding14px 20px
Font16px / 600 / Pretendard
Hover`#f2f6fd` background
Use: Secondary CTA -- `책장에 담기`, `샘플 읽기`
Neutral (Gray Fill)
Background`#f2f2f2`
Text`#333333`
Bordernone
Radius8px
Padding12px 16px
Font14px / 500 / Pretendard
Hover`#ececec` background
Use: Tertiary actions -- share, filter open, more options

Inputs

Default
Background`#ffffff`
Text`#242424`
Border1px solid `#ececec`
Radius8px
Padding12px 14px
Font14px / 400 / Pretendard
Focus1px solid `#1b6dda`
Placeholder`#c1c1c1`
Use: Default text input -- login, search-detail forms
Search
Background`#f2f2f2`
Text`#242424`
Bordernone
Radius8px
Padding12px 16px 12px 40px (left-pad for inline magnifier)
Font14px / 400 / Pretendard
Focus`#ffffff` background, 1px solid `#1b6dda` border
Placeholder`#8b8b8b` ("제목, 저자, 출판사 검색")
Use: Header / discovery search bar
Error
Background`#ffffff`
Text`#242424`
Border1px solid `#ff5b4f`
Radius8px
Padding12px 14px
Font14px / 400 / Pretendard
Use: Form validation failure -- helper text 13px/400 `#ff5b4f` below

Cards

Book Cover Tile
Book Cover Tile
Background`#f2f2f2` (placeholder behind cover art)
Bordernone
Radius6px
Padding0px on cover; 8px gap to title/author metadata
Imageportrait cover (~2:3), 6px radius, soft `0px 2px 8px rgba(0,0,0,0.08)` shadow
Use: Default book unit in the feed grid -- the primary content surface
Feed Card (Editorial)
Feed Card (Editorial)
Background`#ffffff` (or full-bleed cover-derived gradient)
Bordernone
Radius12px
Padding0px (image) / 16px (text block)
Shadownone
Use: Curated "투데이" feed promotions, original-content banners
Audiobook Card
Audiobook Card
Background`#ffffff`
Border1px solid `#ececec`
Radius12px
Padding16px
Use: Audiobook entry with play affordance -- purple `#a451f7` play-button accent

Badges & Tags

Category
Category Tab (Active)
Background`#333333`
Text`#ffffff`
Bordernone
Radius10px
Padding0px 10px
Font14px / 600 / Pretendard
Height32px
Use: Active genre/category filter ("종합", "소설", "경제경영")
Category
Category Tab (Inactive)
Background`#f2f2f2`
Text`#6f6f6f`
Bordernone
Radius10px
Padding0px 10px
Font14px / 400 / Pretendard
Height32px
Use: Inactive genre/category filter
Original
Original Tag (Purple)
Background`#a451f7`
Text`#ffffff`
Bordernone
Radius4px
Padding3px 6px
Font11px / 700 / Pretendard
Use: "밀리 오리지널" original-content flag
Promotion
Promotion Tag (Coral)
Background`#ff5b4f`
Text`#ffffff`
Bordernone
Radius4px
Padding3px 6px
Font11px / 700 / Pretendard
Use: "오늘만", time-limited promotion flag. Used scarcely.
Rating
Rating (Yellow)
Backgroundtransparent
Text`#ffc004` (star fill) + `#6f6f6f` (count)
Bordernone
Radius0px
Padding0px
Font13px / 400 / Pretendard
Use: Star rating + review count on book detail

Pill Control

Floating
Floating Pill (Scrim)
Background`rgba(0,0,0,0.3)`
Text`#ffffff`
Bordernone
Radius100px
Padding4px 10px
Font16px / 400 / Pretendard
Use: "자동 재생 중지", carousel position indicator over imagery