As Statement’s product expanded, grew the need for a structured design system. With more modules, pages, and features, maintaining consistency and efficiency became challenging. We set out to build a scalable, practical system that would streamline design and development while ensuring a cohesive user experience. The process involved thorough research, iteration, and careful structuring to create a system that was both flexible and reliable.
As Statement’s product expanded, grew the need for a structured design system. With more modules, pages, and features, maintaining consistency and efficiency became challenging. We set out to build a scalable, practical system that would streamline design and development while ensuring a cohesive user experience. The process involved thorough research, iteration, and careful structuring to create a system that was both flexible and reliable.
As we began building the design system, we outlined key goals to ensure it would be both practical and scalable:
We wanted ready-made, reusable assets to speed up our workflow and reduce repetitive work.
We wanted consistency—both across our designs and between the designs and the live product.
We wanted the system to be built in a smart, flexible way, making it easy to apply updates and changes across the product.
We wanted a well-defined framework and documentation so that both current and future team members could quickly get up to speed.
Our approach, aligned with the developers’ practices, was based on the atomic method, a common industry standard for building scalable design systems. When making decisions or resolving uncertainties, we looked to established systems like Carbon (IBM), Atlassian (Jira), and Material (Google) for guidance. However, we kept in mind that our design system needed to serve our product’s specific needs—not everything from large-scale systems would be relevant, and some solutions would be unnecessary or overly complex for us.
With our approach defined and aligned with development practices, we turned to the actual work of building the system. Let's go through some of the more interesting results of the process.
Color System: From Guidelines to Functional Tokens
Instead of treating colors as static swatches, we built a token-based system:
Primitive Tokens: Generic names reflecting hue and brightness (e.g., blue-100, grey-700).
Semantic Tokens: Mapped to functional context like: [color][background]negative-subtle,
[color][boarder]negative etc.
This approach decoupled visual decisions from specific color codes, making it easier to maintain consistency and adapt to future changes. For example, changing a button's color across the product became a matter of updating a single token, not hunting through dozens of components.
This approach decoupled visual decisions from specific color codes, making it easier to maintain consistency and adapt to future changes. For example, changing a button's color across the product became a matter of updating a single token, not hunting through dozens of components.
Structuring Typography with Tokens
Typography evolved from a fragmented set of styles into a more systematic structure.
We defined primitive tokens for sizes, weights, and line heights, which we used in turn to define Figma styles, replacing raw values for a more flexible and easily adjustable system, similar to our approach with colors.
With the semantic tokens (Figma styles) we initially took a component-oriented approach, creating styles such as page-header, selected-tab, and medium-input-emphasized. This decision stemmed from concerns that a system that was too generic would make it difficult to adjust specific parts of the design without requiring extensive manual work. However, as the list of component-specific styles grew, we started exploring a shift toward a more generic semantic system to improve scalability. While we were still in the early stages of this transition before my departure, it was clear that finding the right balance between flexibility and system simplicity would be key to long-term efficiency.
With our tokenized foundations in place, we moved to define and design the components our platform needed, grouping them into components and patterns. Components, like buttons, could stand alone but were often part of larger patterns—structures combining multiple components for common interactions.
Scalable, Token-Based Buttons
Buttons were a key component in our system, so we focused on making them both flexible and consistent. We built them as a single component with variations for size, type (primary, secondary, danger, link), and state (default, hover, focus, disabled). To keep things consistent and easy to update, we used tokens for everything—spacing, padding, colors, and text styles.
We also used Figma’s component properties, like booleans for toggling icons and variants for different states, so the same button could work across different use cases without extra effort.
The Popover Component: Designed to support diverse content types.
Through iterations with the dev team, we optimized its structure to allow flexible layouts without compromising consistency. We built the popover as an auto-layout, setting the header and footer sections so that removing them wouldn't affect the overall appearance—maintaining elements like rounded corners. At the component level, we used boolean properties and swap instances, enabling the same component to adapt to different scenarios and content options.
The Data Table Component
The data table was one of our most frequently used components, and we aimed to create a reusable, ready-to-use asset that could also be easily adapted to specific needs. We established typical headers and cells as foundational building blocks, with their content set as components to enable instance swapping later. Using these, we constructed the table as an auto-layout of columns, allowing for flexible modifications.
In addition to the structure, we addressed various functional requirements such as sorting, hovering, selecting, editing, and sticky columns. These functionalities were thoroughly documented to ensure maximum consistency between design and development.
For us, building a design system wasn’t just about organizing components in Figma and in the development environment—it was about shaping a way of working that’s efficient, coordinated and scalable. The need for this system was obvious, but the process of implementing it was anything but simple. It required ongoing adjustments, collaboration, and a mindset that valued long-term efficiency over quick fixes. The real test of its success would come over time, as the system proved itself in daily use. While there was still work ahead, we focused on laying down a solid foundation—one designed to evolve, support the team, and ultimately make the work faster, clearer, and more scalable.