Duolingo design system.

Duolingo design system — Language-learning platform. Bright owl green, chunky shadows, gamified joy.

See it in context

The same design tokens applied across artifact kinds — a website, an app, a slide, a poster. Original mocks re-skinned with this system, not screenshots.

Website
Slides
App
Poster

Design tokens

56 tokens conforming to the Open Design token contract — the same structured palette, type, spacing, and motion values your agent reads to theme any artifact.

Surface

  • --bg #ffffff
  • --surface #f7f7f7
  • --surface-warm var(--surface)

Text

  • --fg #3c3c3c
  • --fg-2 var(--fg)
  • --muted #777777
  • --meta #afafaf

Border

  • --border #e5e5e5
  • --border-soft var(--border)

Accent

  • --accent #58cc02
  • --accent-on #ffffff
  • --accent-hover #89e219
  • --accent-active #58a700

Semantic

  • --success #58cc02
  • --warn #ffc800
  • --danger #ff4b4b

Typography

  • --font-display "Feather Bold", "DIN Round Pro", "Helvetica Neue", sans-serif
  • --font-body "Mona Sans", "Helvetica Neue", system-ui, sans-serif
  • --font-mono "JetBrains Mono", ui-monospace, Menlo, Monaco, Consolas, monospace

Type scale

  • --text-xs 12px
  • --text-sm 13px
  • --text-base 15px
  • --text-lg 18px
  • --text-xl 24px
  • --text-2xl 32px
  • --text-3xl 40px
  • --text-4xl 56px
  • --leading-body 1.5
  • --leading-tight 1.15
  • --tracking-display -0.01em

Spacing

  • --space-1 4px
  • --space-2 8px
  • --space-3 12px
  • --space-4 16px
  • --space-5 20px
  • --space-6 24px
  • --space-8 32px
  • --space-12 48px
  • --section-y-desktop 80px
  • --section-y-tablet 56px
  • --section-y-phone 40px

Radius

  • --radius-sm 12px
  • --radius-md 16px
  • --radius-lg 20px
  • --radius-pill 9999px

Elevation

  • --elev-flat none
  • --elev-ring 0 0 0 2px var(--border)
  • --elev-raised 0 4px 0 #d7d7d7

Focus

  • --focus-ring 0 0 0 3px rgba(28, 176, 246, 0.2)

Motion

  • --motion-fast 180ms
  • --motion-base 320ms
  • --ease-standard cubic-bezier(0.34, 1.56, 0.64, 1)

Layout

  • --container-max 1080px
  • --container-gutter-desktop 24px
  • --container-gutter-tablet 20px
  • --container-gutter-phone 16px

Design System Inspired by Duolingo

Category: Productivity & SaaS Language-learning platform. Bright owl green, chunky shadows, gamified joy.

1. Visual Theme & Atmosphere

Duolingo is gamification rendered as visual language. The interface is unapologetically bright, with owl green (#58cc02) as the brand primary and a chunky 4px bottom-shadow on every interactive element that reads like a 3D button waiting to be pressed. The page is white (#ffffff) with thick 2–3px borders in a deep gray (#e5e5e5) and the entire system reads like an iOS app from 2015 reborn with better hierarchy.

Typography uses Feather Bold (a custom rounded sans) for chrome and Mona Sans (or Inter) for body. Display sizes are big and confident — Duolingo never whispers. Headings often carry the green underline-stroke or sit on a green pill, and the mascot Duo (a green owl) appears as an active illustration character, not a static logo.

Shape language is friendly: 16–20px radii on cards, 12px on buttons, 9999px on chips and progress bars. Iconography is filled, rounded, and color-coded by skill — every lesson surface has an instantly identifiable color pairing.

Key Characteristics:

  • Owl green (#58cc02) as the dominant brand color, used in 30%+ of the surface
  • Chunky 4px bottom-shadow on every button (the “tactile press” affordance)
  • 2–3px solid borders, never hairlines
  • Feather Bold (rounded display) + Mona Sans (body)
  • Big confident type — display sizes start at 48px and climb
  • Mascot-as-character: Duo the owl appears in onboarding, errors, streaks
  • Streak orange (#ff9600) and gem pink (#ce82ff) as secondary brand colors

2. Color Palette & Roles

Primary

  • Owl Green (#58cc02): Brand primary, primary CTA, correct answer.
  • Owl Green Deep (#58a700): Pressed/shadow color for green buttons.
  • Owl Green Light (#89e219): Hover, soft fills.
  • Owl Green Pale (#dbf8c5): Soft surface, success banner.

Secondary Accents

  • Streak Orange (#ff9600): Streak counter, fire icon, premium energy.
  • Streak Orange Deep (#cc7a00): Pressed orange.
  • Gem Pink (#ce82ff): Gem currency, Super Duolingo.
  • Eel Blue (#1cb0f6): Hint button, info link.
  • Cardinal Red (#ff4b4b): Wrong answer, life lost.
  • Bee Yellow (#ffc800): Pro badge, achievement.

Surface

  • Snow (#ffffff): Primary background.
  • Eel (#f7f7f7): Section break, secondary surface.
  • Swan (#e5e5e5): Disabled background, inset block.
  • Wolf (#777777): Dark divider, secondary text.

Ink & Text

  • Eel Black (#3c3c3c): Primary text.
  • Wolf (#777777): Secondary text, captions.
  • Hare (#afafaf): Disabled, placeholder.

Border

  • Swan (#e5e5e5): Standard 2px border.
  • Hare (#afafaf): Emphasized border on hover.

3. Typography Rules

Font Family

  • Display / UI / Headings: Feather Bold, with fallback: 'DIN Round Pro', 'Helvetica Neue', sans-serif
  • Body / Long-form: Mona Sans, with fallback: 'Helvetica Neue', system-ui, sans-serif
  • Code (rare, schools/admin): JetBrains Mono, with fallback: ui-monospace, Menlo, monospace

Hierarchy

RoleFontSizeWeightLine HeightLetter SpacingNotes
DisplayFeather Bold56px (3.5rem)8001.05-0.01emOnboarding hero
H1Feather Bold32px (2rem)8001.15-0.005emPage title
H2Feather Bold24px (1.5rem)8001.2normalSection heading
H3Feather Bold18px (1.125rem)7001.25normalCard title, lesson row
Body LargeMona Sans17px (1.0625rem)5001.5normalLesson prompt, instruction
BodyMona Sans15px (0.9375rem)4001.5normalStandard prose
CaptionMona Sans13px (0.8125rem)6001.40.01emXP counter, metadata
ButtonFeather Bold16px (1rem)8001.20.02emStandard button label
StreakFeather Bold14px (0.875rem)8001.2normalStreak number, on flame

Principles

  • 800 is default: Feather Bold runs at 800 across headings and buttons. 700 feels weak in this system.
  • Big type: heading sizes are 25–40% larger than typical product brands — confidence as identity.
  • Rounded letterforms: every glyph has soft terminals; sharp serifs would break the friendliness contract.

4. Component Stylings

Buttons

Primary (Owl Green)

  • Background: #58cc02
  • Text: #ffffff
  • Padding: 14px 24px
  • Radius: 16px
  • Border-bottom: 4px solid #58a700 (the chunky shadow)
  • Hover: background #89e219
  • Active: translate-y 4px, border-bottom 0 (button “presses”)
  • Use: “Continue”, “Check”, main CTA.

Secondary (White with Bottom-Shadow)

  • Background: #ffffff
  • Text: #777777
  • Border: 2px solid #e5e5e5
  • Border-bottom: 4px solid #e5e5e5
  • Radius: 16px
  • Padding: 14px 24px
  • Hover: text #3c3c3c, border #afafaf

Streak Orange

  • Background: #ff9600
  • Text: #ffffff
  • Border-bottom: 4px solid #cc7a00
  • Use: streak goal, “Start streak”

Error (Cardinal Red)

  • Background: #ff4b4b
  • Text: #ffffff
  • Border-bottom: 4px solid #cc3b3b
  • Use: wrong answer feedback.

Cards / Lesson Tiles

  • Background: #ffffff
  • Border: 2px solid #e5e5e5
  • Border-bottom: 4px solid #e5e5e5
  • Radius: 16px
  • Padding: 16px
  • Hover: lift 2px, shadow 0 4px 0 #d7d7d7

Skill Tree Node (Lesson Bubble)

  • Size: 80×72px
  • Background: skill-color tinted (green for active, gray for locked)
  • Border-bottom: 6px solid darker variant
  • Radius: 50% (circular)
  • Active: pulses 1.0 → 1.05 every 1.6s

Inputs

  • Background: #ffffff
  • Border: 2px solid #e5e5e5
  • Radius: 12px
  • Padding: 12px 16px
  • Focus: border #1cb0f6 (eel blue), ring 0 0 0 3px rgba(28, 176, 246, 0.2)

Progress Bar

  • Track: #e5e5e5
  • Fill: #58cc02 (or #ff9600 for streak)
  • Radius: 9999px
  • Height: 16px
  • Animated fill: 320ms ease-out on increment.

5. Spacing & Layout

  • Base unit: 4px. Scale: 4, 8, 12, 16, 24, 32, 48, 64.
  • Container: max 1080px, 24px gutter.
  • Lesson tree column: 320px wide; centered on desktop.

6. Motion

  • Duration: 180ms for button press; 320ms for skill-node unlock; 1.6s for active-node pulse.
  • Easing: cubic-bezier(0.34, 1.56, 0.64, 1) (back-out, slight overshoot) for unlocks.
  • Mascot: Duo blinks every 4–6s, jumps on streak milestones (480ms ease-out spring).

7. Usage Guardrails

  • Keep the high-saturation owl green, chunky bottom shadows, and rounded lesson geometry together; flat green buttons alone do not read as Duolingo.
  • Reserve oversized bold type for lesson, streak, and progress moments where the product needs encouragement or feedback.
  • Use playful motion sparingly around progress state changes, avoiding generic bouncy animation on every control.
Mode
design-system
Scenario
design
Surface
web
Manifest id
design-system-duolingo

Tags

  • design-system
  • first-party
  • design
  • productivity-saas