Install
openclaw skills install distinctive-design-systemsPatterns for creating design systems with personality and distinctive aesthetics. Covers aesthetic documentation, color token architecture, typography systems, layered surfaces, and motion. Use when building design systems that go beyond generic templates. Triggers on design system, design tokens, aesthetic, color palette, typography, CSS variables, tailwind config.
openclaw skills install distinctive-design-systemsCreate design systems with personality that users remember. Move beyond generic templates to build cohesive, emotionally resonant visual languages.
A distinctive design system starts with aesthetic documentation, not color pickers.
1. Define the vibe → What does this look and feel like?
2. Gather references → Mood boards, inspiration, examples
3. Document emotions → What should users feel?
4. Extract tokens → Colors, typography, spacing, motion
5. Build components → Implement the documented vision
Document the vibe before writing CSS:
The Vibe: Crystalline, luminescent, slightly melancholic—hopeful hues tempered by muted gradients, sharp typography, and CRT textures. Everything references a primary "Crystal" cyan tone.
Inspirations:
| Emotion | How It's Achieved |
|---|---|
| Precision | Sharp typography, tabular numerics, grid patterns |
| Nostalgia | CRT scanlines, pixel grain, retro-era color palette |
| Hope | Floating cyan orbs, gentle animations, luminous accents |
| Melancholy | Dark gradients, muted backgrounds, soft focus layers |
The Vibe: Warm neutral cyberpunk with a terminal feel. Unlike harsh green-on-black hacker aesthetics, uses warm tan/beige as the foundation, creating approachable yet technical atmosphere.
Key Differentiation: Most dark UIs go cold with neon accents. This approach uses warmth as its secret weapon—the neutral tan base creates visual comfort while emerald accents maintain the futuristic aesthetic.
| Emotion | How It's Achieved |
|---|---|
| Technical credibility | Terminal typography, mono fonts, glow effects |
| Approachability | Warm neutral base instead of cold black |
| Premium quality | Glass panels, backdrop blur, layered shadows |
| Futuristic trust | Circuit patterns, hex grids, scanlines |
CSS Variables (source of truth)
↓
Tailwind Config (utility classes)
↓
TypeScript Tokens (runtime access)
:root {
/* Base tones (use in rgba()) */
--tone-void: 2, 7, 18;
--tone-midnight: 6, 12, 32;
--tone-cyan: 76, 204, 255;
/* Semantic colors (HSL) */
--primary: 216 90% 68%;
--success: 154 80% 60%;
--destructive: 346 80% 62%;
/* Effect variables */
--glow-primary: 216 90% 68%;
--glass-bg: 33 18% 71% / 0.8;
}
// tailwind.config.ts
export default {
theme: {
extend: {
colors: {
background: 'hsl(var(--background))',
foreground: 'hsl(var(--foreground))',
primary: {
DEFAULT: 'hsl(var(--primary))',
foreground: 'hsl(var(--primary-foreground))',
},
// Tone palette for rgba usage
tone: {
void: 'rgb(var(--tone-void))',
cyan: 'rgb(var(--tone-cyan))',
},
},
},
},
};
// styles/design-tokens.ts
export const colors = {
primary: 'hsl(var(--primary))',
success: 'hsl(var(--success))',
// For rgba usage
toneCyan: 'rgb(var(--tone-cyan))',
};
export const withOpacity = (token: string, opacity: number) =>
token.replace('rgb(', 'rgba(').replace(')', `, ${opacity})`);
fonts: {
display: ['Orbitron', 'system-ui'], // Headings, labels
mono: ['Share Tech Mono', 'monospace'], // Metrics, code
sans: ['Inter', 'system-ui'], // Body fallback
}
:root {
--typo-scale: 0.88; /* Responsive multiplier */
--typo-page-title: calc(1.75rem * var(--typo-scale));
--typo-section-title: calc(1rem * var(--typo-scale));
--typo-metric-lg: calc(1.75rem * var(--typo-scale));
--typo-metric-md: calc(0.96rem * var(--typo-scale));
--typo-body: calc(0.9rem * var(--typo-scale));
}
@media (min-width: 640px) {
:root { --typo-scale: 1; }
}
Magazine-Style Numbers:
.metric {
font-weight: 800;
letter-spacing: -0.02em;
font-variant-numeric: tabular-nums;
}
Labels:
.label {
text-transform: uppercase;
letter-spacing: 0.1em;
font-weight: 700;
font-size: 0.72rem;
}
| Layer | Name | Purpose |
|---|---|---|
| 0 | Ambient | Full-viewport gradients, slow motion |
| 1 | Glow Field | Floating orbs, atmospheric effects |
| 2 | Texture | CRT scanlines, grain, filters |
| 3 | Panels | Elevated cards, section headers |
| 4 | Content | Metrics, charts, tables |
| 5 | Details | Nested sub-panels, rows |
interface SurfaceProps {
layer?: 'panel' | 'tile' | 'chip' | 'deep' | 'metric';
children: React.ReactNode;
}
export function Surface({ layer = 'tile', children }: SurfaceProps) {
return (
<div className={cn(
'rounded-lg backdrop-blur-sm',
layerStyles[layer]
)}>
{children}
</div>
);
}
const layerStyles = {
panel: 'bg-tone-cadet/40 border border-tone-jordy/10',
tile: 'bg-tone-midnight/60 border border-tone-jordy/5',
chip: 'bg-tone-cyan/10 border border-tone-cyan/20',
deep: 'bg-tone-void/80',
metric: 'bg-tone-cadet/20',
};
:root {
--transition-fast: 0.15s;
--transition-default: 0.2s;
--transition-medium: 0.25s;
--transition-slow: 0.3s;
}
// tailwind.config.ts
keyframes: {
'shimmer': {
'0%': { backgroundPosition: '200% 0' },
'100%': { backgroundPosition: '-200% 0' },
},
'pulse-glow': {
'0%, 100%': { opacity: '1', transform: 'scale(1)' },
'50%': { opacity: '0.5', transform: 'scale(1.05)' },
},
'slide-in': {
'0%': { opacity: '0', transform: 'translateY(10px)' },
'100%': { opacity: '1', transform: 'translateY(0)' },
},
'value-flash': {
'0%': { textShadow: '0 0 8px currentColor' },
'100%': { textShadow: 'none' },
},
},
animation: {
'shimmer': 'shimmer 1.5s ease-in-out infinite',
'pulse-glow': 'pulse-glow 1.8s ease-in-out infinite',
'slide-in': 'slide-in 0.2s ease-out',
'value-flash': 'value-flash 0.6s ease-out',
}
.glass-panel {
background: linear-gradient(180deg,
hsl(var(--glass-bg) / 0.95) 0%,
hsl(var(--glass-bg) / 0.85) 100%
);
backdrop-filter: blur(16px);
border: 1px solid hsl(var(--glass-border));
box-shadow:
0 4px 16px hsl(var(--glass-shadow)),
0 0 0 1px hsl(var(--glass-border) / 0.6) inset,
0 0 20px hsl(var(--glow-primary) / 0.1);
}
.neon-border {
border: 1px solid hsl(var(--brand-600) / 0.4);
box-shadow:
0 0 10px hsl(var(--glow-primary) / 0.3),
0 0 20px hsl(var(--glow-primary) / 0.2),
inset 0 0 10px hsl(var(--glow-primary) / 0.1);
}
| Aesthetic | Inspirations | Emotions |
|---|---|---|
| Retro-futuristic glassmorphism | Retro console UIs, JRPG HUDs, sci-fi terminals | Precision, nostalgia, hope |
| Warm neutral cyberpunk | Terminal UIs, sci-fi film interfaces | Credibility, approachability |
| Magazine-style financial | Trading platforms, data dashboards | Trust, clarity, sophistication |
styles/
├── globals.css # CSS variables, base styles
├── design-tokens.ts # TypeScript token exports
├── theme.css # Component patterns
└── patterns/
├── glass.css
├── neon.css
└── backgrounds.css
tailwind.config.ts # Token integration
/* 1. Define CSS variables */
:root {
--tone-primary: 76, 204, 255;
--primary: 200 90% 65%;
}
/* 2. Configure Tailwind */
colors: {
primary: 'hsl(var(--primary))',
tone: { primary: 'rgb(var(--tone-primary))' },
}
/* 3. Use in components */
<div className="bg-primary text-tone-primary/80">