
Karrot's interface is the digital equivalent of a friendly neighborhood bulletin board -- warm, approachable, and built for trust between strangers. The page opens on a clean white canvas (#ffffff) with warm near-black headings (#1a1c20) and the unmistakable Karrot Orange (#ff6600) that serves as the singular brand accent. This isn't the corporate orange of enterprise dashboards; it's the vivid, saturated orange of a fresh carrot -- energetic, trustworthy, and unmistakably local.
The design system, called Seed Design, is one of the most mature open-source systems in Korean tech. It operates on a strict 4px grid with a three-tier token architecture (palette → semantic → component) that ensures every measurement is intentional. Typography relies entirely on the platform's native font stack rather than a custom typeface -- Pretendard on web, system fonts on native -- putting community content first. The overall aesthetic is warm neutral: soft grays, generous whitespace, and that singular orange accent. Where Stripe uses shadows as brand expression, Karrot uses shadows as pure function -- minimal, neutral, and warm.
Key Characteristics:
#ff6600) as the singular brand accent -- warm, energetic, unmistakableclamp()-based accessibility font scaling#ff6600): $color.palette.carrot-600. Primary CTA, active states, brand solid backgrounds. The iconic orange that defines every Karrot touchpoint.#e14d00): $color.palette.carrot-700. Pressed/hover state for brand elements, dark mode brand solid.#1a1c20): $color.palette.gray-1000, fg-neutral. Primary heading and text color. Warm near-black that avoids harshness.#ffffff): $color.palette.gray-00, bg-layer-default. Page background, card surfaces.#fff2ec): $color.palette.carrot-100. Brand weak background, subtle orange-tinted surfaces.#ffb999): $color.palette.carrot-400. Medium brand tint, progress indicators.#b93901): $color.palette.carrot-800. Deep orange for emphasis in dark contexts.#fa342c): fg-critical. Error foreground, destructive action labels.#217cf9): fg-informative. Links, informational highlights.#079171): fg-positive. Success states, confirmation indicators.#9b7821): fg-warning. Caution labels, attention-needed states.#5e98fe): stroke-focus-ring. Keyboard focus ring on interactive elements.#f7f8f9): bg-layer-fill. Subtle background fill.#f3f4f5): bg-layer-basement, bg-disabled. Secondary surfaces.#dcdee3): stroke-neutral-weak. Standard borders, dividers.#b0b3ba): fg-placeholder. Placeholder text, muted icons.#868b94): fg-neutral-subtle. Captions, tertiary text.#555d6d): fg-neutral-muted. Secondary body text.rgba(0,0,0,0.08)): stroke-neutral-subtle. Soft card borders, barely-there separation.rgba(0,0,0,0.12)): stroke-neutral-muted. Moderate borders for definition.rgba(0,0,0,0.7)): bg-overlay. Modal/sheet backdrop.rgba(0,0,0,0.5)): bg-overlay-muted. Bottom sheet scrims."Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", Roboto, "Noto Sans KR", sans-serif"SF Mono", SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace| Role | Font | Size | Weight | Line Height | Letter Spacing | Notes |
|---|---|---|---|---|---|---|
| Display XL | System | 26px (t10) | 700 | 35px | 0em | Hero headlines, splash screens |
| Display Large | System | 24px (t9) | 700 | 32px | 0em | Section headers |
| Heading Large | System | 20px (t7) | 700 | 27px | 0em | Card headings, sub-sections |
| Heading | System | 18px (t6) | 700 | 24px | 0em | List section headers |
| Title | System | 16px (t5) | 500 | 22px | 0em | Navigation, standard titles |
| Body | System | 14px (t4) | 400 | 19px | 0em | Standard reading text, listings |
| Body Small | System | 13px (t3) | 400 | 18px | 0em | Secondary text, metadata |
| Caption | System | 12px (t2) | 400 | 16px | 0em | Timestamps, small labels |
| Caption Small | System | 11px (t1) | 400 | 15px | 0em | Fine print, badges |
clamp() with --seed-font-size-multiplier, supporting 80% to 150% of base size.Brand Solid (Primary CTA)
#ff6600 (carrot-600)#ffffff#e14d00 (carrot-700)#f3f4f5 background, #d1d3d8 textNeutral Weak
#f3f4f5 (gray-200)#1a1c20 (gray-1000)#eeeff1 (gray-300)Neutral Outline
#1a1c20 (gray-1000)#dcdee3 (gray-400)#f7f8f9 backgroundCritical Solid
#fa342c (red-700)#ffffff#ffffff (bg-layer-default)rgba(0,0,0,0.08) (stroke-neutral-subtle) or no border with shadow0px 2px 10px rgba(0,0,0,0.1) (s2) for standard cards#f3f4f5 (gray-200), Selected: #1a1c20 (gray-1000) with white text#f7f8f9 (gray-100)#dcdee3 (gray-400)#5e98fe (blue-600) focus ring#1a1c20, Placeholder: #b0b3ba (gray-600)#fa342c (red-700)#868b94 (gray-700)| Level | Treatment | Use |
|---|---|---|
| Flat (Level 0) | No shadow | Page background, inline elements |
| Subtle (s1) | 0px 1px 4px rgba(0,0,0,0.08) | Slight lift, list item hover |
| Standard (s2) | 0px 2px 10px rgba(0,0,0,0.10) | Cards, dropdowns, popovers |
| Prominent (s3) | 0px 4px 16px rgba(0,0,0,0.12) | Floating action button, bottom sheets, modals |
Shadow Philosophy: Only three levels -- enough for clear layering without visual clutter. Shadows use pure black with varying opacity (no brand-tinted shadows), keeping the system neutral so the orange accent remains the sole source of warmth. In dark mode, opacities increase dramatically (s1: 0.50, s2: 0.68, s3: 0.80) to remain perceptible on dark surfaces.
#ff6600) as the singular brand accent -- it should feel special, not overwhelmingfg-neutral, bg-layer-default) over raw palette values in component code#000000) for text -- use gray-1000 (#1a1c20) for warmthclamp() wrapper on font sizes -- accessibility scaling is non-negotiable| Name | Width | Key Changes |
|---|---|---|
| Mobile | <480px | Full-width cards, single column, 16px gutter |
| Tablet | 480-768px | 2-column listing grid, expanded cards |
| Desktop (Web) | >768px | Max-width 640px content, centered layout |
#ff6600)#e14d00)#ffffff)#1a1c20)#555d6d)#868b94)#b0b3ba)#dcdee3)#f3f4f5)#fa342c)#079171)#217cf9)#5e98fe)#ff6600 only -- no secondary brand hue exists#1a1c20) for headings, gray-800 (#555d6d) for body, gray-700 (#868b94) for captionsKarrot speaks like a trustworthy neighbor who just moved in next door: warm, plain-spoken, low-friction, and allergic to anything that sounds like corporate marketing. The voice assumes two strangers are about to hand each other a used crib across a parking lot — it protects that trust with earnestness, removes barriers with 부담 없이 (without burden) framing, and stays in everyday Korean sentence endings (-어요, -예요) rather than the formal -ㅂ니다. English surfaces (Karrot in US/Canada/UK/JP) mirror this in plain, contraction-friendly English — "Buy and sell for free with locals", not "Discover premium local marketplace experiences".
| Context | Tone |
|---|---|
| CTAs | Short verb-first Korean (판매하기, 채팅하기, 거래 완료) / plain imperative English (Sell, Chat, Apply) |
| Empty states | One warm line explaining why it's empty + one low-pressure suggestion. Never 데이터가 없습니다. |
| Error messages | Specific, blameless, actionable. Prefer 다시 시도해 주세요 over 오류가 발생했습니다. |
| Success toasts | Past-tense single sentence (거래가 완료되었어요). Quiet, not celebratory. |
| Community guidelines | Second-person, direct, grounded in neighborhood norms. Reads like a house rule, not a ToS. |
| Trust & safety | Calm, factual, never fearmongering. The goal is to keep people transacting, not to scare them off. |
| Local / hyperlocal copy | Always name the neighborhood (강남구 역삼동, Manhattan). Proximity is the brand — surface it. |
| Onboarding | One screen, one idea, one action. No bullet lists. No feature tours. |
Forbidden phrases. 불편을 드려 죄송합니다, 죄송하지만, 데이터가 없습니다, 오류가 발생했습니다, 혁신적인, English boilerplate like Oops, something went wrong or We apologize for the inconvenience. Marketing-speak bans: amazing deals, best-in-class, revolutionary, world-class. Emoji are permitted sparingly in community chat and stickers, but never in error messages, never in trust/safety copy, and never in financial/payment confirmations.
Voice samples.
Buy and sell for free with locals — homepage hero, English. Welcome to your new neighborhood buy & sell — homepage sub-hero. It's easier in the apps / Download the Karrot app — app-install nudge. 동네를 여는 문, 당근 — brand narrative tagline (corporate site). 로컬의 모든 것을 연결해, 동네의 숨은 가치를 깨워요 — mission statement. <neighborhood>에서 <product>을(를) 찾고 있어요 — illustrative search/wanted-listing pattern (variable placeholders). 이 거래, 직접 만나서 할까요? — illustrative in-chat nudge for face-to-face meeting (hyperlocal behavior). Karrot (당근, daangn) launched in 2015 in Pangyo, South Korea, founded by Kim Yong-hyun and Kim Jae-hyun — both former Kakao engineers who had watched the open-marketplace model (Korean e-commerce giants, nationwide shipping, anonymous counterparties) fail the one job users actually cared about: trust. Their founding bet was that secondhand transactions are not a logistics problem; they are a neighborhood problem. The first version of the app hard-capped transactions to a 6 km radius (later relaxed to 10 km in KR/JP, up to 50 km in North America), on the theory that if you can walk to the meeting, you can look the other person in the eye (Crunchbase, KED Global).
The product is built around that proximity constraint. Every listing surfaces the neighborhood name. Every match is geo-scoped. Every CTA assumes the buyer and seller will eventually stand in the same parking lot. The design language follows suit: a warm orange (#ff6600) that reads as a fresh carrot — not the corporate orange of enterprise dashboards, not the alarm orange of warnings — and no custom typeface, because the brand doesn't want a distinctive voice around user content; it wants user content to feel like the voice of the neighborhood itself. By early 2025, the company reports 40M+ cumulative registered users and 20M+ monthly active users across 1,400+ regions worldwide, with 227B KRW in cumulative funding (about.daangn.com).
What Karrot refuses: the anonymity of nationwide marketplaces (eBay, Coupang), the impersonal aesthetics of enterprise commerce (data-heavy dashboards, filter-rich search UIs), and the gamified engagement loops of consumer social (streaks, badges, algorithmic feeds). The brand's mission, stated on its own corporate page, is "로컬의 모든 것을 연결해 동네의 숨은 가치를 기술로 깨우는" — connecting everything local, awakening hidden neighborhood value through technology (medium.com/daangn). Orange is the accent because the brand is supposed to feel like one warm thing in an otherwise neutral room.
#ff6600 appears only on the primary CTA, active states, and a small set of brand moments. It never decorates, never fills a hero background, never tints a shadow. UI implication: at most one orange element per viewport in the primary flow; if a design has two orange CTAs competing on one screen, one must demote to neutral-weak.동 / neighborhood) as visible metadata, not hidden in a detail screen.{4, 8, 12, 16, 20, 24, 32, 40, 48, 56, 64} must be justified in a comment or corrected.fg-critical, fg-informative, fg-positive) exist — but they are utility, not brand. UI implication: if a design introduces a second brand-scale color, it has drifted off-system; reject or re-scope to semantic.filter: invert() or runtime HSL math. Every component reads from semantic tokens that already account for theme.Personas are fictional archetypes informed by publicly described Karrot user segments, not individual people.
지우 (Jiwoo), 31, Seoul. New mother in 망원동. Uses Karrot 3–4 times a week — mostly to sell outgrown baby gear and pick up a stroller from someone two blocks away. Expects the app to open on the local listings feed in <1s and remember her neighborhood without re-asking. Will walk 10 minutes for a good deal; won't drive 20.
민호 (Minho), 26, Busan. Graduate student. Treats Karrot as a free Craigslist replacement for textbooks, a desk lamp, and the occasional IKEA handoff. Reads every listing's neighborhood tag before the title — if it's outside 동구, he scrolls past. Prefers chat over calls; never gives out his phone number.
Sarah, 34, Toronto. Just moved to Leslieville from Manhattan. Installed Karrot after a neighbor mentioned it because Facebook Marketplace "felt like strangers on the internet, and this feels like people on my street." Expects English-first UI, imperial units, and the ability to set the pickup spot to a coffee shop without drama.
이선생님 (Mr. Lee), 58, Daegu. Retired, primary Karrot user is his spouse who shares the account. Uses it for 동네생활 community posts ("who has a working lawnmower I can borrow") more than buying and selling. Trust in face-to-face transactions is his whole reason for tolerating an app at all.
| State | Treatment |
|---|---|
| Empty (no listings nearby) | Warm one-line explanation (아직 우리 동네에 올라온 물건이 없어요) + one secondary CTA in neutral-weak (내 동네 바꾸기 / change neighborhood). Never an illustration. Never 데이터가 없습니다. |
| Empty (filter cleared) | Single line of gray-700 caption (조건에 맞는 물건이 없어요). No button — user resets the filter themselves. |
| Empty (new user, first paint) | Single welcome sentence naming the user's detected neighborhood, plus a primary CTA 둘러보기 (browse) in Karrot Orange. No onboarding carousel. |
| Loading (first paint) | Skeleton blocks at gray-200 matching the final listing-card layout — 1:1 thumbnail box, two text lines, one metadata line. Shimmer at 1.2s with 8% white highlight. |
| Loading (infinite scroll) | Bottom-of-list spinner in Karrot Orange, 24px diameter. No overlay. Existing cards stay visible. |
| Loading (refresh / pull-to-refresh) | Pull-down reveals a carrot-glyph progress indicator in Karrot Orange; never a generic iOS spinner on branded surfaces. |
| Error (inline field) | Input border becomes #fa342c (red-700) 2px, helper text below in red-700 13px. One actionable sentence (동네를 다시 선택해 주세요). |
| Error (toast) | #1a1c20 (gray-1000) background, white 14px weight 400 text, 3s auto-dismiss. Bottom of screen with 16px inset above the tab bar. One sentence. No icon. |
| Error (network / server-blocking) | Full-screen centered message in gray-1000 16px weight 600, gray-800 14px weight 400 subline, retry button in Karrot Orange. No illustration. |
| Success (inline flash) | Brief 300ms flash of #fff2ec (carrot-100) behind the updated element, fading back to default. For routine confirmations (favorited, saved search). |
| Success (transaction complete) | Dedicated confirmation screen — not a toast. #079171 (positive green) check icon top-center, one-line past-tense sentence (거래가 완료되었어요), and a single primary button 매너 평가 남기기 (leave manner rating). |
| Skeleton | gray-200 blocks at exact final dimensions matching the listing-card layout (1:1 thumbnail, two text lines, one metadata line). Shimmer 1.2s with 8% white highlight. Never over the neighborhood-name metadata — that slot stays blank until resolved, so the UI never implies a location that hasn't been confirmed. |
| Disabled | Button background drops to gray-200, text to gray-500. No color inversion. Geometry stays identical so re-enable is frame-stable. |
Durations (named, not raw milliseconds):
| Token | Value | Use |
|---|---|---|
motion-instant | 0ms | Toggle flips, checkbox state changes |
motion-fast | 150ms | Hover, focus, button press overlays, inline flash success |
motion-standard | 250ms | The default — card taps, tab switches, bottom-sheet reveals |
motion-slow | 350ms | Emphasized transitions — full-sheet presentations, success screens |
motion-page | 300ms | Native-style push/pop between routes |
Easings:
| Token | Curve | Use |
|---|---|---|
ease-enter | cubic-bezier(0.0, 0.0, 0.2, 1) | Sheets, toasts, screen pushes appearing |
ease-exit | cubic-bezier(0.4, 0.0, 1, 1) | Dismissals, pops, toast auto-close |
ease-standard | cubic-bezier(0.4, 0.0, 0.2, 1) | Two-way transitions — expandable cards, tab content |
Spring stance. Spring and overshoot easings are forbidden across Karrot surfaces. The brand is a neighborhood marketplace between strangers; playful bounce undermines the calm trust the rest of the system works to establish. Money and goods change hands on this app — a button that wobbles on press reads as toy-like, and a success card that springs in reads as celebratory in a way Karrot deliberately isn't. The one licensed exception is the native-platform pull-to-refresh indicator, which inherits the OS's default spring because overriding it would feel more jarring than accepting it. Every other motion uses ease-enter, ease-exit, or ease-standard.
Signature motions.
motion-fast / ease-standard), releases on tap-up before navigation begins. Feedback is immediate; the route transition follows on motion-page / ease-enter.y+40px with motion-standard / ease-enter and a synchronized backdrop fade from rgba(0,0,0,0) to rgba(0,0,0,0.5) (bg-overlay-muted). Dismissal uses motion-fast / ease-exit — leaving is lighter than entering.motion-slow rather than sliding — sliding would imply geographic direction, which is misleading (Korean neighborhoods aren't ordered on an axis).prefers-reduced-motion: reduce, all motion-* tokens collapse to motion-instant. No exceptions. Cross-fades replace slides. Pull-to-refresh indicator simplifies to a static spinner. The app stays fully usable; just less kinetic.Not independently verified — widely documented public facts:
Personas (§13) are fictional archetypes informed by publicly described Karrot user segments (KR urban young adult, KR secondary-city student, NA expat, KR retiree 동네생활 user). Any resemblance to specific individuals is unintended.
Interpretive claims (editorial, not documented Karrot statements):
Karrot's interface is the digital equivalent of a friendly neighborhood bulletin board -- warm, approachable, and built for trust between strangers. The page opens on a clean white canvas (`#ffffff`) with warm near-black headings (`#1a1c20`) and the unmistakable Karrot Orange (`#ff6600`) that serves as the singular brand accent. This isn't the corporate oran
Top 18 hex values found in §2 of DESIGN.md, ranked by usage frequency.
A wider example card showing how content sits inside the radius and shadow combination defined by this brand. Card radius is capped at 16px even on pill systems (LINE/Wise/Spotify) so large surfaces stay readable.
Shadow recipes parsed from §6 of DESIGN.md, or default 5-tier scale if none found.