243 lines
6.8 KiB
CSS
Raw Normal View History

/* Tailwind CSS v4: import the full framework */
@import "tailwindcss";
@import "../styles/tokens.css";
@import "../styles/utilities.css";
@import "../styles/responsive.css";
@import "tw-animate-css";
@custom-variant dark (&:is(.dark *));
:root {
--radius: 0.625rem;
/* Core neutrals (light) */
--background: oklch(0.98 0 0);
--foreground: oklch(0.16 0 0);
--card: var(--background);
--card-foreground: var(--foreground);
--popover: var(--background);
--popover-foreground: var(--foreground);
/* Primary brand (azure) */
--primary: oklch(0.62 0.17 255);
--primary-foreground: oklch(0.99 0 0);
/* Interaction shades */
--primary-hover: oklch(0.58 0.17 255);
--primary-active: oklch(0.54 0.17 255);
/* Subtle surfaces & text */
--secondary: oklch(0.93 0 0);
--secondary-foreground: oklch(0.29 0 0);
--muted: oklch(0.95 0 0);
--muted-foreground: oklch(0.55 0 0);
/* Light accent (tinted, not a second brand) */
--accent: oklch(0.94 0.03 245);
--accent-foreground: var(--foreground);
/* Feedback (now with full semantic set) */
--destructive: oklch(0.62 0.21 27);
--destructive-foreground: oklch(0.99 0 0);
--destructive-soft: oklch(0.96 0.05 27);
--success: oklch(0.67 0.14 150);
--success-foreground: oklch(0.99 0 0);
--success-soft: oklch(0.95 0.05 150);
--warning: oklch(0.78 0.16 90);
--warning-foreground: oklch(0.16 0 0);
--warning-soft: oklch(0.96 0.07 90);
--info: oklch(0.64 0.16 255);
--info-foreground: oklch(0.99 0 0);
--info-soft: oklch(0.95 0.05 255);
/* UI chrome */
--border: oklch(0.90 0 0);
--border-muted: oklch(0.88 0 0);
--input: var(--border);
--ring: oklch(0.68 0.16 255);
--ring-subtle: color-mix(in oklch, var(--ring) 45%, transparent);
/* Charts */
--chart-1: oklch(0.62 0.17 255);
--chart-2: oklch(0.66 0.15 202);
--chart-3: oklch(0.64 0.19 147);
--chart-4: oklch(0.70 0.16 82);
--chart-5: oklch(0.68 0.16 28);
/* Sidebar */
--sidebar: var(--background);
--sidebar-foreground: var(--foreground);
--sidebar-primary: var(--primary);
--sidebar-primary-foreground: var(--primary-foreground);
--sidebar-accent: var(--secondary);
--sidebar-accent-foreground: var(--secondary-foreground);
--sidebar-border: var(--border);
--sidebar-ring: var(--ring);
}
.dark {
/* Core neutrals (dark) */
--background: oklch(0.15 0 0);
--foreground: oklch(0.98 0 0);
--card: oklch(0.18 0 0);
--card-foreground: var(--foreground);
--popover: oklch(0.18 0 0);
--popover-foreground: var(--foreground);
/* Primary brand (slightly lighter for dark) */
--primary: oklch(0.74 0.16 255);
--primary-foreground: oklch(0.15 0 0);
--primary-hover: oklch(0.70 0.16 255);
--primary-active: oklch(0.66 0.16 255);
/* Subtle surfaces & text */
--secondary: oklch(0.22 0 0);
--secondary-foreground: oklch(0.90 0 0);
--muted: oklch(0.25 0 0);
--muted-foreground: oklch(0.74 0 0);
/* Accent (tinted) */
--accent: oklch(0.24 0.02 245);
--accent-foreground: oklch(0.92 0 0);
/* Feedback */
--destructive: oklch(0.70 0.21 27);
--destructive-foreground: oklch(0.15 0 0);
--destructive-soft: oklch(0.25 0.05 27);
--success: oklch(0.76 0.14 150);
--success-foreground: oklch(0.15 0 0);
--success-soft: oklch(0.24 0.05 150);
--warning: oklch(0.86 0.16 90);
--warning-foreground: oklch(0.15 0 0);
--warning-soft: oklch(0.26 0.07 90);
--info: oklch(0.78 0.15 255);
--info-foreground: oklch(0.15 0 0);
--info-soft: oklch(0.24 0.05 255);
/* UI chrome */
--border: oklch(0.32 0 0);
--border-muted: oklch(0.28 0 0);
--input: var(--border);
--ring: oklch(0.78 0.13 255);
--ring-subtle: color-mix(in oklch, var(--ring) 40%, transparent);
/* Charts */
--chart-1: oklch(0.74 0.16 255);
--chart-2: oklch(0.72 0.14 202);
--chart-3: oklch(0.70 0.18 147);
--chart-4: oklch(0.74 0.17 82);
--chart-5: oklch(0.72 0.17 28);
/* Sidebar */
--sidebar: var(--card);
--sidebar-foreground: var(--foreground);
--sidebar-primary: var(--primary);
--sidebar-primary-foreground: var(--primary-foreground);
--sidebar-accent: var(--secondary);
--sidebar-accent-foreground: var(--secondary-foreground);
--sidebar-border: var(--border);
--sidebar-ring: var(--ring);
}
/* Tailwind v4 token map (add the new ones) */
@theme {
--color-background: var(--background);
--color-foreground: var(--foreground);
--color-card: var(--card);
--color-card-foreground: var(--card-foreground);
--color-popover: var(--popover);
--color-popover-foreground: var(--popover-foreground);
--color-primary: var(--primary);
--color-primary-foreground: var(--primary-foreground);
--color-primary-hover: var(--primary-hover);
--color-primary-active: var(--primary-active);
--color-secondary: var(--secondary);
--color-secondary-foreground: var(--secondary-foreground);
--color-muted: var(--muted);
--color-muted-foreground: var(--muted-foreground);
--color-accent: var(--accent);
--color-accent-foreground: var(--accent-foreground);
--color-destructive: var(--destructive);
--color-destructive-foreground: var(--destructive-foreground);
--color-destructive-soft: var(--destructive-soft);
--color-success: var(--success);
--color-success-foreground: var(--success-foreground);
--color-success-soft: var(--success-soft);
--color-warning: var(--warning);
--color-warning-foreground: var(--warning-foreground);
--color-warning-soft: var(--warning-soft);
--color-info: var(--info);
--color-info-foreground: var(--info-foreground);
--color-info-soft: var(--info-soft);
--color-border: var(--border);
--color-border-muted: var(--border-muted);
--color-input: var(--input);
--color-ring: var(--ring);
--color-ring-subtle: var(--ring-subtle);
--color-chart-1: var(--chart-1);
--color-chart-2: var(--chart-2);
--color-chart-3: var(--chart-3);
--color-chart-4: var(--chart-4);
--color-chart-5: var(--chart-5);
--color-sidebar: var(--sidebar);
--color-sidebar-foreground: var(--sidebar-foreground);
--color-sidebar-primary: var(--sidebar-primary);
--color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
--color-sidebar-accent: var(--sidebar-accent);
--color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
--color-sidebar-border: var(--sidebar-border);
--color-sidebar-ring: var(--sidebar-ring);
}
@layer base {
* {
border-color: var(--border);
outline-color: var(--ring-subtle);
}
body {
background-color: var(--background);
color: var(--foreground);
font-family: var(--font-geist-sans), system-ui, sans-serif;
}
}
@theme inline {
--animate-aurora: aurora 60s linear infinite;
@keyframes aurora {
from {
backgroundPosition: 50% 50%, 50% 50%;
}
to {
backgroundPosition: 350% 50%, 350% 50%;
}
}
}
@layer base {
* {
@apply border-border outline-ring/50;
}
body {
@apply bg-background text-foreground;
}
}