feat: redesign UI with Twilight design system
Outfit + JetBrains Mono typography, soft dark palette with blue undertones, electric teal primary, purple-branded AI features, noise texture, glow effects, glassmorphism, and refined grid/tree.
This commit is contained in:
@@ -4,6 +4,11 @@
|
||||
|
||||
@custom-variant dark (&:is(.dark *));
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
TUSK — "Twilight" Design System
|
||||
Soft dark with blue undertones and teal accents
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
@theme inline {
|
||||
--radius-sm: calc(var(--radius) - 4px);
|
||||
--radius-md: calc(var(--radius) - 2px);
|
||||
@@ -43,50 +48,399 @@
|
||||
--color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
|
||||
--color-sidebar-border: var(--sidebar-border);
|
||||
--color-sidebar-ring: var(--sidebar-ring);
|
||||
|
||||
/* Custom semantic tokens */
|
||||
--color-tusk-teal: var(--tusk-teal);
|
||||
--color-tusk-purple: var(--tusk-purple);
|
||||
--color-tusk-amber: var(--tusk-amber);
|
||||
--color-tusk-rose: var(--tusk-rose);
|
||||
--color-tusk-surface: var(--tusk-surface);
|
||||
|
||||
/* Font families */
|
||||
--font-sans: "Outfit", system-ui, -apple-system, sans-serif;
|
||||
--font-mono: "JetBrains Mono", "Fira Code", "Cascadia Code", ui-monospace, monospace;
|
||||
}
|
||||
|
||||
:root {
|
||||
--radius: 0.625rem;
|
||||
--background: oklch(0.145 0 0);
|
||||
--foreground: oklch(0.985 0 0);
|
||||
--card: oklch(0.205 0 0);
|
||||
--card-foreground: oklch(0.985 0 0);
|
||||
--popover: oklch(0.205 0 0);
|
||||
--popover-foreground: oklch(0.985 0 0);
|
||||
--primary: oklch(0.922 0 0);
|
||||
--primary-foreground: oklch(0.205 0 0);
|
||||
--secondary: oklch(0.269 0 0);
|
||||
--secondary-foreground: oklch(0.985 0 0);
|
||||
--muted: oklch(0.269 0 0);
|
||||
--muted-foreground: oklch(0.708 0 0);
|
||||
--accent: oklch(0.269 0 0);
|
||||
--accent-foreground: oklch(0.985 0 0);
|
||||
--destructive: oklch(0.704 0.191 22.216);
|
||||
--border: oklch(1 0 0 / 10%);
|
||||
--input: oklch(1 0 0 / 15%);
|
||||
--ring: oklch(0.556 0 0);
|
||||
--chart-1: oklch(0.488 0.243 264.376);
|
||||
--chart-2: oklch(0.696 0.17 162.48);
|
||||
--chart-3: oklch(0.769 0.188 70.08);
|
||||
--chart-4: oklch(0.627 0.265 303.9);
|
||||
--chart-5: oklch(0.645 0.246 16.439);
|
||||
--sidebar: oklch(0.205 0 0);
|
||||
--sidebar-foreground: oklch(0.985 0 0);
|
||||
--sidebar-primary: oklch(0.488 0.243 264.376);
|
||||
--sidebar-primary-foreground: oklch(0.985 0 0);
|
||||
--sidebar-accent: oklch(0.269 0 0);
|
||||
--sidebar-accent-foreground: oklch(0.985 0 0);
|
||||
--sidebar-border: oklch(1 0 0 / 10%);
|
||||
--sidebar-ring: oklch(0.556 0 0);
|
||||
--radius: 0.5rem;
|
||||
|
||||
/* Soft twilight palette — comfortable, not eye-straining */
|
||||
--background: oklch(0.2 0.012 250);
|
||||
--foreground: oklch(0.9 0.005 250);
|
||||
--card: oklch(0.23 0.012 250);
|
||||
--card-foreground: oklch(0.9 0.005 250);
|
||||
--popover: oklch(0.25 0.014 250);
|
||||
--popover-foreground: oklch(0.9 0.005 250);
|
||||
|
||||
/* Teal primary — slightly softer for the lighter background */
|
||||
--primary: oklch(0.72 0.14 170);
|
||||
--primary-foreground: oklch(0.18 0.015 250);
|
||||
|
||||
/* Surfaces — gentle stepping */
|
||||
--secondary: oklch(0.27 0.012 250);
|
||||
--secondary-foreground: oklch(0.85 0.008 250);
|
||||
--muted: oklch(0.27 0.012 250);
|
||||
--muted-foreground: oklch(0.62 0.015 250);
|
||||
--accent: oklch(0.28 0.014 250);
|
||||
--accent-foreground: oklch(0.9 0.005 250);
|
||||
|
||||
/* Status */
|
||||
--destructive: oklch(0.65 0.2 15);
|
||||
|
||||
/* Borders & inputs — more visible, less transparent */
|
||||
--border: oklch(0.34 0.015 250 / 70%);
|
||||
--input: oklch(0.36 0.015 250 / 60%);
|
||||
--ring: oklch(0.72 0.14 170 / 40%);
|
||||
|
||||
/* Chart palette */
|
||||
--chart-1: oklch(0.72 0.14 170);
|
||||
--chart-2: oklch(0.68 0.14 200);
|
||||
--chart-3: oklch(0.78 0.14 85);
|
||||
--chart-4: oklch(0.62 0.18 290);
|
||||
--chart-5: oklch(0.68 0.16 30);
|
||||
|
||||
/* Sidebar <20><> same family, slightly offset */
|
||||
--sidebar: oklch(0.215 0.012 250);
|
||||
--sidebar-foreground: oklch(0.9 0.005 250);
|
||||
--sidebar-primary: oklch(0.72 0.14 170);
|
||||
--sidebar-primary-foreground: oklch(0.9 0.005 250);
|
||||
--sidebar-accent: oklch(0.28 0.014 250);
|
||||
--sidebar-accent-foreground: oklch(0.9 0.005 250);
|
||||
--sidebar-border: oklch(0.34 0.015 250 / 70%);
|
||||
--sidebar-ring: oklch(0.72 0.14 170 / 40%);
|
||||
|
||||
/* Tusk semantic tokens */
|
||||
--tusk-teal: oklch(0.72 0.14 170);
|
||||
--tusk-purple: oklch(0.62 0.2 290);
|
||||
--tusk-amber: oklch(0.78 0.14 85);
|
||||
--tusk-rose: oklch(0.65 0.2 15);
|
||||
--tusk-surface: oklch(0.26 0.012 250);
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Base layer
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
@layer base {
|
||||
* {
|
||||
@apply border-border outline-ring/50;
|
||||
}
|
||||
|
||||
body {
|
||||
@apply bg-background text-foreground;
|
||||
font-family: var(--font-sans);
|
||||
overflow: hidden;
|
||||
user-select: none;
|
||||
-webkit-font-smoothing: antialiased;
|
||||
-moz-osx-font-smoothing: grayscale;
|
||||
text-rendering: optimizeLegibility;
|
||||
}
|
||||
|
||||
/* Monospace for code and data */
|
||||
code, pre, .font-mono,
|
||||
[data-slot="sql-editor"],
|
||||
.cm-editor {
|
||||
font-family: var(--font-mono);
|
||||
}
|
||||
|
||||
/* Smoother scrollbars */
|
||||
::-webkit-scrollbar {
|
||||
width: 6px;
|
||||
height: 6px;
|
||||
}
|
||||
|
||||
::-webkit-scrollbar-track {
|
||||
background: transparent;
|
||||
}
|
||||
|
||||
::-webkit-scrollbar-thumb {
|
||||
background: oklch(0.42 0.015 250 / 45%);
|
||||
border-radius: 3px;
|
||||
}
|
||||
|
||||
::-webkit-scrollbar-thumb:hover {
|
||||
background: oklch(0.5 0.015 250 / 60%);
|
||||
}
|
||||
|
||||
::-webkit-scrollbar-corner {
|
||||
background: transparent;
|
||||
}
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Noise texture overlay — very subtle depth
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
.tusk-noise::before {
|
||||
content: "";
|
||||
position: fixed;
|
||||
inset: 0;
|
||||
z-index: 9999;
|
||||
pointer-events: none;
|
||||
opacity: 0.018;
|
||||
background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
|
||||
background-repeat: repeat;
|
||||
background-size: 256px 256px;
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Glow effects — softer for lighter background
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
.tusk-glow-teal {
|
||||
box-shadow: 0 0 10px oklch(0.72 0.14 170 / 12%),
|
||||
0 0 3px oklch(0.72 0.14 170 / 8%);
|
||||
}
|
||||
|
||||
.tusk-glow-purple {
|
||||
box-shadow: 0 0 10px oklch(0.62 0.2 290 / 15%),
|
||||
0 0 3px oklch(0.62 0.2 290 / 10%);
|
||||
}
|
||||
|
||||
.tusk-glow-teal-subtle {
|
||||
box-shadow: 0 0 6px oklch(0.72 0.14 170 / 6%);
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════<E29590><E29590>═══════
|
||||
Active tab indicator — top glow bar
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
.tusk-tab-active {
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.tusk-tab-active::after {
|
||||
content: "";
|
||||
position: absolute;
|
||||
top: 0;
|
||||
left: 0;
|
||||
right: 0;
|
||||
height: 2px;
|
||||
background: linear-gradient(90deg, oklch(0.72 0.14 170), oklch(0.68 0.14 200));
|
||||
border-radius: 0 0 2px 2px;
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
AI feature branding — purple glow language
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
.tusk-ai-bar {
|
||||
background: linear-gradient(
|
||||
135deg,
|
||||
oklch(0.62 0.2 290 / 5%) 0%,
|
||||
oklch(0.62 0.2 290 / 2%) 50%,
|
||||
oklch(0.72 0.14 170 / 3%) 100%
|
||||
);
|
||||
border-bottom: 1px solid oklch(0.62 0.2 290 / 12%);
|
||||
}
|
||||
|
||||
.tusk-ai-icon {
|
||||
color: oklch(0.68 0.18 290);
|
||||
filter: drop-shadow(0 0 3px oklch(0.62 0.2 290 / 30%));
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Transitions — smooth everything
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
button, a, [role="tab"], [role="menuitem"], [data-slot="button"] {
|
||||
transition: all 150ms cubic-bezier(0.4, 0, 0.2, 1);
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Glassmorphism for floating elements
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
[data-radix-popper-content-wrapper] [role="dialog"],
|
||||
[data-radix-popper-content-wrapper] [role="listbox"],
|
||||
[data-radix-popper-content-wrapper] [role="menu"],
|
||||
[data-state="open"][data-side] {
|
||||
backdrop-filter: blur(16px) saturate(1.2);
|
||||
-webkit-backdrop-filter: blur(16px) saturate(1.2);
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Sidebar tab active indicator
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
.tusk-sidebar-tab-active {
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.tusk-sidebar-tab-active::after {
|
||||
content: "";
|
||||
position: absolute;
|
||||
bottom: 0;
|
||||
left: 25%;
|
||||
right: 25%;
|
||||
height: 2px;
|
||||
background: oklch(0.72 0.14 170);
|
||||
border-radius: 2px 2px 0 0;
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Data grid refinements
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
.tusk-grid-header {
|
||||
background: oklch(0.23 0.012 250);
|
||||
border-bottom: 1px solid oklch(0.34 0.015 250 / 80%);
|
||||
}
|
||||
|
||||
.tusk-grid-row:hover {
|
||||
background: oklch(0.72 0.14 170 / 5%);
|
||||
}
|
||||
|
||||
.tusk-grid-cell-null {
|
||||
color: oklch(0.5 0.015 250);
|
||||
font-style: italic;
|
||||
}
|
||||
|
||||
.tusk-grid-cell-highlight {
|
||||
background: oklch(0.78 0.14 85 / 10%);
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Status bar
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
.tusk-status-bar {
|
||||
background: oklch(0.215 0.012 250);
|
||||
border-top: 1px solid oklch(0.34 0.015 250 / 50%);
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Connection color accent strip
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
.tusk-conn-strip {
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.tusk-conn-strip::before {
|
||||
content: "";
|
||||
position: absolute;
|
||||
left: 0;
|
||||
top: 0;
|
||||
bottom: 0;
|
||||
width: var(--strip-width, 3px);
|
||||
background: var(--strip-color, transparent);
|
||||
border-radius: 0 2px 2px 0;
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Toolbar
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
.tusk-toolbar {
|
||||
background: oklch(0.23 0.012 250);
|
||||
border-bottom: 1px solid oklch(0.34 0.015 250 / 60%);
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Resizable handle
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
[data-panel-group-direction="horizontal"] > [data-resize-handle] {
|
||||
width: 1px !important;
|
||||
background: oklch(0.34 0.015 250 / 50%);
|
||||
transition: background 200ms, width 200ms;
|
||||
}
|
||||
|
||||
[data-panel-group-direction="horizontal"] > [data-resize-handle]:hover,
|
||||
[data-panel-group-direction="horizontal"] > [data-resize-handle][data-resize-handle-active] {
|
||||
width: 3px !important;
|
||||
background: oklch(0.72 0.14 170 / 60%);
|
||||
}
|
||||
|
||||
[data-panel-group-direction="vertical"] > [data-resize-handle] {
|
||||
height: 1px !important;
|
||||
background: oklch(0.34 0.015 250 / 50%);
|
||||
transition: background 200ms, height 200ms;
|
||||
}
|
||||
|
||||
[data-panel-group-direction="vertical"] > [data-resize-handle]:hover,
|
||||
[data-panel-group-direction="vertical"] > [data-resize-handle][data-resize-handle-active] {
|
||||
height: 3px !important;
|
||||
background: oklch(0.72 0.14 170 / 60%);
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
CodeMirror theme overrides
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
.cm-editor {
|
||||
font-size: 13px;
|
||||
line-height: 1.6;
|
||||
}
|
||||
|
||||
.cm-editor .cm-gutters {
|
||||
background: oklch(0.215 0.012 250);
|
||||
border-right: 1px solid oklch(0.34 0.015 250 / 50%);
|
||||
color: oklch(0.48 0.012 250);
|
||||
}
|
||||
|
||||
.cm-editor .cm-activeLineGutter {
|
||||
background: oklch(0.72 0.14 170 / 8%);
|
||||
color: oklch(0.65 0.015 250);
|
||||
}
|
||||
|
||||
.cm-editor .cm-activeLine {
|
||||
background: oklch(0.72 0.14 170 / 4%);
|
||||
}
|
||||
|
||||
.cm-editor .cm-cursor {
|
||||
border-left-color: oklch(0.72 0.14 170);
|
||||
}
|
||||
|
||||
.cm-editor .cm-selectionBackground {
|
||||
background: oklch(0.72 0.14 170 / 15%) !important;
|
||||
}
|
||||
|
||||
.cm-editor .cm-tooltip-autocomplete {
|
||||
backdrop-filter: blur(16px);
|
||||
background: oklch(0.25 0.014 250 / 95%);
|
||||
border: 1px solid oklch(0.34 0.015 250 / 70%);
|
||||
border-radius: 6px;
|
||||
box-shadow: 0 8px 32px oklch(0 0 0 / 30%);
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Sonner toast styling
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
[data-sonner-toaster] [data-sonner-toast] {
|
||||
font-family: var(--font-sans);
|
||||
backdrop-filter: blur(12px);
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Utility animations
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
@keyframes tusk-fade-in {
|
||||
from { opacity: 0; transform: translateY(4px); }
|
||||
to { opacity: 1; transform: translateY(0); }
|
||||
}
|
||||
|
||||
@keyframes tusk-pulse-glow {
|
||||
0%, 100% { opacity: 0.6; }
|
||||
50% { opacity: 1; }
|
||||
}
|
||||
|
||||
.tusk-fade-in {
|
||||
animation: tusk-fade-in 200ms cubic-bezier(0.4, 0, 0.2, 1);
|
||||
}
|
||||
|
||||
.tusk-pulse-glow {
|
||||
animation: tusk-pulse-glow 2s ease-in-out infinite;
|
||||
}
|
||||
|
||||
/* ═══════════════════════════════════════════════════════
|
||||
Selection styling
|
||||
═══════════════════════════════════════════════════════ */
|
||||
|
||||
::selection {
|
||||
background: oklch(0.72 0.14 170 / 25%);
|
||||
color: oklch(0.95 0.005 250);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user