Descript's UI design system. Use when building interfaces inspired by Descript's aesthetic - dark mode, Inter font, 4px grid.
70
62%
Does it follow best practices?
Impact
Pending
No eval scenarios have been run
Passed
No known issues
Optimize this skill with Tessl
npx tessl skill review --optimize ./skills/descript/SKILL.mdOpinionated constraints for building Descript-style interfaces with AI agents.
Reference these guidelines when:
#2C0814 as page background (surface-base)| Token | HEX | RGB | Usage |
|---|---|---|---|
surface-base | #2C0814 | rgb(44,8,20) | Page background |
surface-raised | #F9F6F3 | rgb(249,246,243) | Cards, modals, raised surfaces |
surface-overlay | #F2212E | rgb(242,33,46) | Overlays, tooltips, dropdowns |
text-primary | #484543 | rgb(72,69,67) | Headings, body text |
text-secondary | #747474 | rgb(116,116,116) | Secondary, muted text |
text-tertiary | #F4A9AF | rgb(244,169,175) | Additional text |
border-default | #ECE3E4 | rgb(236,227,228) | Subtle borders, dividers |
destructive | #F2212E | rgb(242,33,46) | Error states, delete actions |
warning | #F9F6F3 | rgb(249,246,243) | Warning states, cautions |
Inter as primary font family79px / 700 for primary headings18px / 400 for body texttext-balance for headings and text-pretty for body texttabular-nums for numeric data| Style | Font | Size | Weight | Color | Count |
|---|---|---|---|---|---|
heading-1 | Inter | 79px | 700 | #F1E6E3 | 1 |
body | Inter | 18px | 400 | #BEBEBE | 1 |
body-secondary | Inter | 17px | 500 | #3E3337 | 1 |
body-secondary | Inter | 16px | 400 | #C6ACB4 | 1 |
body-secondary | Inter | 16px | 400 | #3E3236 | 1 |
caption | Inter | 15px | 500 | #484543 | 1 |
label | Inter | 15px | 400 | #A52335 | 1 |
label | Inter | 15px | 400 | #413438 | 1 |
label | Inter | 14px | 400 | #747474 | 1 |
label | Inter | 14px | 400 | #F4A9AF | 1 |
Font Families:
Inter (used 15x)Font Sizes: 13px, 14px, 15px, 16px, 17px, 18px, 79px
Scale: 3px, 6px, 7px, 9px, 13px
h-screen, use h-dvh for full viewport heightsafe-area-inset for fixed elementssize-* for square elements instead of w-* + h-*| Variant | Background | Text | Border | Height | Radius |
|---|---|---|---|---|---|
| Ghost | transparent | #F4A9AF | none | - | - |
2px outline with accent color (#5E6AD2)2px outline-offset#F9F6F3 background#F9F6F3 backgroundopacity: 0.5cursor: not-allowedAlertDialog for destructive or irreversible actionsinput or textarea elementsaria-label to icon-only buttonstransform, opacity)width, height, top, left, margin, padding)ease-out on entrance animations200ms for interaction feedbackprefers-reduced-motionblur() or backdrop-filter surfaceswill-change outside an active animationuseEffect for anything that can be expressed as render logic126714e
If you maintain this skill, you can claim it as your own. Once claimed, you can manage eval scenarios, bundle related skills, attach documentation or rules, and ensure cross-agent compatibility.