make-interfaces-feel-better

작성자: jakubkrehel

Design engineering principles for making interfaces feel polished. Use when building UI components, reviewing frontend code, implementing animations, hover states, shadows, borders, typography, micro-interactions, enter/exit animations, or any visual detail work. Triggers on UI polish, design details, "make it feel better", "feels off", stagger animations, border radius, optical alignment, font smoothing, tabular numbers, image outlines, box shadows.

npx skills add https://github.com/jakubkrehel/make-interfaces-feel-better --skill make-interfaces-feel-better

Details that make interfaces feel better

Great interfaces rarely come from a single thing. It's usually a collection of small details that compound into a great experience. Apply these principles when building or reviewing UI code.

Quick Reference

CategoryWhen to Use
TypographyText wrapping, font smoothing, tabular numbers
SurfacesBorder radius, optical alignment, shadows, image outlines, hit areas
AnimationsInterruptible animations, enter/exit transitions, icon animations, scale on press
PerformanceTransition specificity, will-change usage

Core Principles

1. Concentric Border Radius

Outer radius = inner radius + padding. Mismatched radii on nested elements is the most common thing that makes interfaces feel off.

2. Optical Over Geometric Alignment

When geometric centering looks off, align optically. Buttons with icons, play triangles, and asymmetric icons all need manual adjustment.

3. Shadows Over Borders

Layer multiple transparent box-shadow values for natural depth. Shadows adapt to any background; solid borders don't.

4. Interruptible Animations

Use CSS transitions for interactive state changes — they can be interrupted mid-animation. Reserve keyframes for staged sequences that run once.

5. Split and Stagger Enter Animations

Don't animate a single container. Break content into semantic chunks and stagger each with ~100ms delay.

6. Subtle Exit Animations

Use a small fixed translateY instead of full height. Exits should be softer than enters.

7. Contextual Icon Animations

Animate icons with opacity, scale, and blur instead of toggling visibility. Use exactly these values: scale from 0.25 to 1, opacity from 0 to 1, blur from 4px to 0px. If the project has motion or framer-motion in package.json, use transition: { type: "spring", duration: 0.3, bounce: 0 } — bounce must always be 0. If no motion library is installed, keep both icons in the DOM (one absolute-positioned) and cross-fade with CSS transitions using cubic-bezier(0.2, 0, 0, 1) — this gives both enter and exit animations without any dependency.

8. Font Smoothing

Apply -webkit-font-smoothing: antialiased to the root layout on macOS for crisper text.

9. Tabular Numbers

Use font-variant-numeric: tabular-nums for any dynamically updating numbers to prevent layout shift.

10. Text Wrapping

Use text-wrap: balance on headings. Use text-wrap: pretty for body text to avoid orphans.

11. Image Outlines

Add a subtle 1px outline with low opacity to images for consistent depth. The color must be pure black in light mode (rgba(0, 0, 0, 0.1)) and pure white in dark mode (rgba(255, 255, 255, 0.1)) — never a near-black like slate, zinc, or any tinted neutral. A tinted outline picks up the surface color underneath it and reads as dirt on the image edge.

12. Scale on Press

A subtle scale(0.96) on click gives buttons tactile feedback. Always use 0.96. Never use a value smaller than 0.95 — anything below feels exaggerated. Add a static prop to disable it when motion would be distracting.

13. Skip Animation on Page Load

Use initial={false} on AnimatePresence to prevent enter animations on first render. Verify it doesn't break intentional entrance animations.

14. Never Use transition: all

Always specify exact properties: transition-property: scale, opacity. Tailwind's transition-transform covers transform, translate, scale, rotate.

15. Use will-change Sparingly

Only for transform, opacity, filter — properties the GPU can composite. Never use will-change: all. Only add when you notice first-frame stutter.

16. Minimum Hit Area

Interactive elements need at least 40×40px hit area. Extend with a pseudo-element if the visible element is smaller. Never let hit areas of two elements overlap.

Common Mistakes

MistakeFix
Same border radius on parent and childCalculate outerRadius = innerRadius + padding
Icons look off-centerAdjust optically with padding or fix SVG directly
Hard borders between sectionsUse layered box-shadow with transparency
Jarring enter/exit animationsSplit, stagger, and keep exits subtle
Numbers cause layout shiftApply tabular-nums
Heavy text on macOSApply antialiased to root
Animation plays on page loadAdd initial={false} to AnimatePresence
transition: all on elementsSpecify exact properties
First-frame animation stutterAdd will-change: transform (sparingly)
Tiny hit areas on small controlsExtend with pseudo-element to 40×40px

Review Output Format

Always present changes as a markdown table with Before and After columns. Include every change you made — not just a subset. Never list findings as separate "Before:" / "After:" lines outside of a table. Group changes by principle using a heading above each table, and keep each row focused on a single diff so the reader can scan the whole list quickly.

Example

Concentric border radius

BeforeAfter
rounded-xl on card + rounded-xl on inner button (p-2)rounded-2xl on card (12 + 8), rounded-lg on inner button
border-radius: 16px on both nested surfacesOuter 24px, inner 16px with 8px padding

Tabular numbers

BeforeAfter
<span>{count}</span> on animated counter<span className="tabular-nums">{count}</span>
Default numerals on timerAdded font-variant-numeric: tabular-nums to root

Scale on press

BeforeAfter
<button className="...">Added active:scale-[0.96] transition-transform
scale(0.9) on pressRaised to scale(0.96) — anything below 0.95 feels exaggerated

Rows should cite the specific file and the specific property that changed when it isn't obvious from the snippet. If a principle was reviewed but nothing needed to change, omit that table entirely — empty tables add noise.

Review Checklist

  • Nested rounded elements use concentric border radius
  • Icons are optically centered, not just geometrically
  • Shadows used instead of borders where appropriate
  • Enter animations are split and staggered
  • Exit animations are subtle
  • Dynamic numbers use tabular-nums
  • Font smoothing is applied
  • Headings use text-wrap: balance
  • Images have subtle outlines
  • Buttons use scale on press where appropriate
  • AnimatePresence uses initial={false} for default-state elements
  • No transition: all — only specific properties
  • will-change only on transform/opacity/filter, never all
  • Interactive elements have at least 40×40px hit area

Reference Files

  • typography.md — Text wrapping, font smoothing, tabular numbers
  • surfaces.md — Border radius, optical alignment, shadows, image outlines
  • animations.md — Interruptible animations, enter/exit transitions, icon animations, scale on press
  • performance.md — Transition specificity, will-change usage

관련 스킬

sentry-code-review
sentry
GitHub Pull Request에서 Sentry 댓글을 분석하고 해결합니다. PR 댓글에서 Sentry가 식별한 문제를 검토하거나 수정하라는 요청을 받았을 때 사용합니다. 검토할 수 있는 항목…
official
dd-audit-ai-activity
datadog-labs
Bits AI 어시스턴트(MCP 서버)가 Datadog 조직에서 수행한 작업을 감사합니다 — 사용자별 도구 호출, 액세스한 리소스, AI 거버넌스를 위한 이상 플래그.
official
creating-mermaid-dbt-dag
dbt-labs
MCP 도구, manifest.json 또는 직접 코드 파싱을 대체 수단으로 사용하여 dbt 모델 계보의 Mermaid 플로우차트 다이어그램을 생성합니다. dbt 모델 시각화 시 사용합니다.
official
web-animation-design
vercel
web-animation-design — AI 에이전트용 설치 가능한 스킬로, vercel-labs/open-agents에서 게시되었습니다.
official
documentation-writer
github
Diátaxis 프레임워크 기반 문서 작성을 위한 전문 테크니컬 라이터로, 튜토리얼, 하우투 가이드, 레퍼런스, 설명 형식을 다룹니다. 학습을 위한 튜토리얼, 문제 해결을 위한 하우투 가이드, 기술 사양을 위한 레퍼런스, 개념 이해를 위한 설명의 네 가지 유형으로 문서를 구조화합니다. 문서 유형과 대상을 명확히 하고, 승인을 위해 상세한 개요를 제안한 후, 전체 마크다운 콘텐츠를 생성하는 3단계 워크플로를 따릅니다. 유지합니다...
official
dex
sentry
dex CLI를 통해 작업을 관리합니다. 복잡한 작업을 분해하거나, 구현 항목을 추적하거나, 세션 간 컨텍스트를 유지할 때 사용합니다.
official
temporal-developer
temporalio
Python, TypeScript, Go, Java 및 .NET에서 Temporal 애플리케이션을 개발, 디버그 및 관리합니다. 사용자가 워크플로, 액티비티 또는 워커를 구축할 때 사용하세요.
official
deep-agents-memory
langchain-ai
Deep Agent가 메모리, 지속성 또는 파일 시스템 접근이 필요할 때 이 스킬을 호출하세요. StateBackend(임시), StoreBackend(지속적) 등을 포함합니다.
official