@tailwind base; @tailwind components; @tailwind utilities; /* LIGHT MODE */ :root { --button-outline: rgba(0,0,0, .10); --badge-outline: rgba(0,0,0, .05); --opaque-button-border-intensity: -8; --elevate-1: rgba(0,0,0, .03); --elevate-2: rgba(0,0,0, .08); --background: 0 0% 100%; --foreground: 0 0% 9%; --border: 0 0% 89%; --card: 0 0% 98%; --card-foreground: 0 0% 9%; --card-border: 0 0% 94%; --sidebar: 0 0% 96%; --sidebar-foreground: 0 0% 9%; --sidebar-border: 0 0% 92%; --sidebar-primary: 221 83% 53%; --sidebar-primary-foreground: 0 0% 98%; --sidebar-accent: 0 0% 92%; --sidebar-accent-foreground: 0 0% 9%; --sidebar-ring: 221 83% 53%; --popover: 0 0% 94%; --popover-foreground: 0 0% 9%; --popover-border: 0 0% 90%; --primary: 221 83% 53%; --primary-foreground: 0 0% 98%; --secondary: 0 0% 90%; --secondary-foreground: 0 0% 9%; --muted: 0 0% 92%; --muted-foreground: 0 0% 35%; --accent: 220 14% 91%; --accent-foreground: 0 0% 9%; --destructive: 0 84% 45%; --destructive-foreground: 0 0% 98%; --input: 0 0% 72%; --ring: 221 83% 53%; --chart-1: 221 83% 43%; --chart-2: 195 77% 38%; --chart-3: 271 81% 43%; --chart-4: 32 95% 44%; --chart-5: 142 76% 36%; --font-sans: Open Sans, sans-serif; --font-serif: Georgia, serif; --font-mono: Menlo, monospace; --radius: .5rem; --shadow-2xs: 0px 2px 0px 0px hsl(0 0% 0% / 0.00); --shadow-xs: 0px 2px 0px 0px hsl(0 0% 0% / 0.00); --shadow-sm: 0px 2px 0px 0px hsl(0 0% 0% / 0.00), 0px 1px 2px -1px hsl(0 0% 0% / 0.00); --shadow: 0px 2px 0px 0px hsl(0 0% 0% / 0.00), 0px 1px 2px -1px hsl(0 0% 0% / 0.00); --shadow-md: 0px 2px 0px 0px hsl(0 0% 0% / 0.00), 0px 2px 4px -1px hsl(0 0% 0% / 0.00); --shadow-lg: 0px 2px 0px 0px hsl(0 0% 0% / 0.00), 0px 4px 6px -1px hsl(0 0% 0% / 0.00); --shadow-xl: 0px 2px 0px 0px hsl(0 0% 0% / 0.00), 0px 8px 10px -1px hsl(0 0% 0% / 0.00); --shadow-2xl: 0px 2px 0px 0px hsl(0 0% 0% / 0.00); --tracking-normal: 0em; --spacing: 0.25rem; /* Fallback for older browsers */ --sidebar-primary-border: hsl(var(--sidebar-primary)); --sidebar-primary-border: hsl(from hsl(var(--sidebar-primary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --sidebar-accent-border: hsl(var(--sidebar-accent)); --sidebar-accent-border: hsl(from hsl(var(--sidebar-accent)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --primary-border: hsl(var(--primary)); --primary-border: hsl(from hsl(var(--primary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --secondary-border: hsl(var(--secondary)); --secondary-border: hsl(from hsl(var(--secondary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --muted-border: hsl(var(--muted)); --muted-border: hsl(from hsl(var(--muted)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --accent-border: hsl(var(--accent)); --accent-border: hsl(from hsl(var(--accent)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --destructive-border: hsl(var(--destructive)); --destructive-border: hsl(from hsl(var(--destructive)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); } .dark { --button-outline: rgba(255,255,255, .10); --badge-outline: rgba(255,255,255, .05); --opaque-button-border-intensity: 9; --elevate-1: rgba(255,255,255, .04); --elevate-2: rgba(255,255,255, .09); --background: 0 0% 7%; --foreground: 0 0% 95%; --border: 0 0% 18%; --card: 0 0% 9%; --card-foreground: 0 0% 95%; --card-border: 0 0% 13%; --sidebar: 0 0% 11%; --sidebar-foreground: 0 0% 95%; --sidebar-border: 0 0% 15%; --sidebar-primary: 221 83% 53%; --sidebar-primary-foreground: 0 0% 98%; --sidebar-accent: 0 0% 15%; --sidebar-accent-foreground: 0 0% 95%; --sidebar-ring: 221 83% 53%; --popover: 0 0% 13%; --popover-foreground: 0 0% 95%; --popover-border: 0 0% 17%; --primary: 221 83% 53%; --primary-foreground: 0 0% 98%; --secondary: 0 0% 17%; --secondary-foreground: 0 0% 95%; --muted: 0 0% 16%; --muted-foreground: 0 0% 65%; --accent: 220 14% 18%; --accent-foreground: 0 0% 95%; --destructive: 0 84% 45%; --destructive-foreground: 0 0% 98%; --input: 0 0% 35%; --ring: 221 83% 53%; --chart-1: 221 83% 63%; --chart-2: 195 77% 58%; --chart-3: 271 81% 63%; --chart-4: 32 95% 64%; --chart-5: 142 76% 56%; --shadow-2xs: 0px 2px 0px 0px hsl(0 0% 0% / 0.00); --shadow-xs: 0px 2px 0px 0px hsl(0 0% 0% / 0.00); --shadow-sm: 0px 2px 0px 0px hsl(0 0% 0% / 0.00), 0px 1px 2px -1px hsl(0 0% 0% / 0.00); --shadow: 0px 2px 0px 0px hsl(0 0% 0% / 0.00), 0px 1px 2px -1px hsl(0 0% 0% / 0.00); --shadow-md: 0px 2px 0px 0px hsl(0 0% 0% / 0.00), 0px 2px 4px -1px hsl(0 0% 0% / 0.00); --shadow-lg: 0px 2px 0px 0px hsl(0 0% 0% / 0.00), 0px 4px 6px -1px hsl(0 0% 0% / 0.00); --shadow-xl: 0px 2px 0px 0px hsl(0 0% 0% / 0.00), 0px 8px 10px -1px hsl(0 0% 0% / 0.00); --shadow-2xl: 0px 2px 0px 0px hsl(0 0% 0% / 0.00); /* Fallback for older browsers */ --sidebar-primary-border: hsl(var(--sidebar-primary)); --sidebar-primary-border: hsl(from hsl(var(--sidebar-primary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --sidebar-accent-border: hsl(var(--sidebar-accent)); --sidebar-accent-border: hsl(from hsl(var(--sidebar-accent)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --primary-border: hsl(var(--primary)); --primary-border: hsl(from hsl(var(--primary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --secondary-border: hsl(var(--secondary)); --secondary-border: hsl(from hsl(var(--secondary)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --muted-border: hsl(var(--muted)); --muted-border: hsl(from hsl(var(--muted)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --accent-border: hsl(var(--accent)); --accent-border: hsl(from hsl(var(--accent)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); /* Fallback for older browsers */ --destructive-border: hsl(var(--destructive)); --destructive-border: hsl(from hsl(var(--destructive)) h s calc(l + var(--opaque-button-border-intensity)) / alpha); } @layer base { * { @apply border-border; } body { @apply font-sans antialiased bg-background text-foreground; } } /** * Using the elevate system. * Automatic contrast adjustment. * * * * * // Using the tailwind utility when a data attribute is "on" * * // Or manually controlling the toggle state * * * Elevation systems have to handle many states. * - not-hovered, vs. hovered vs. active (three mutually exclusive states) * - toggled or not * - focused or not (this is not handled with these utilities) * * Even without handling focused or not, this is six possible combinations that * need to be distinguished from eachother visually. */ @layer utilities { /* Hide ugly search cancel button in Chrome until we can style it properly */ input[type="search"]::-webkit-search-cancel-button { @apply hidden; } /* Placeholder styling for contentEditable div */ [contenteditable][data-placeholder]:empty::before { content: attr(data-placeholder); color: hsl(var(--muted-foreground)); pointer-events: none; } /* .no-default-hover-elevate/no-default-active-elevate is an escape hatch so consumers of * buttons/badges can remove the automatic brightness adjustment on interactions * and program their own. */ .no-default-hover-elevate {} .no-default-active-elevate {} /** * Toggleable backgrounds go behind the content. Hoverable/active goes on top. * This way they can stack/compound. Both will overlap the parent's borders! * So borders will be automatically adjusted both on toggle, and hover/active, * and they will be compounded. */ .toggle-elevate::before, .toggle-elevate-2::before { content: ""; pointer-events: none; position: absolute; inset: 0px; /*border-radius: inherit; match rounded corners */ border-radius: inherit; z-index: -1; /* sits behind content but above backdrop */ } .toggle-elevate.toggle-elevated::before { background-color: var(--elevate-2); } /* If there's a 1px border, adjust the inset so that it covers that parent's border */ .border.toggle-elevate::before { inset: -1px; } /* Does not work on elements with overflow:hidden! */ .hover-elevate:not(.no-default-hover-elevate), .active-elevate:not(.no-default-active-elevate), .hover-elevate-2:not(.no-default-hover-elevate), .active-elevate-2:not(.no-default-active-elevate) { position: relative; z-index: 0; } .hover-elevate:not(.no-default-hover-elevate)::after, .active-elevate:not(.no-default-active-elevate)::after, .hover-elevate-2:not(.no-default-hover-elevate)::after, .active-elevate-2:not(.no-default-active-elevate)::after { content: ""; pointer-events: none; position: absolute; inset: 0px; /*border-radius: inherit; match rounded corners */ border-radius: inherit; z-index: 999; /* sits in front of content */ } .hover-elevate:hover:not(.no-default-hover-elevate)::after, .active-elevate:active:not(.no-default-active-elevate)::after { background-color: var(--elevate-1); } .hover-elevate-2:hover:not(.no-default-hover-elevate)::after, .active-elevate-2:active:not(.no-default-active-elevate)::after { background-color: var(--elevate-2); } /* If there's a 1px border, adjust the inset so that it covers that parent's border */ .border.hover-elevate:not(.no-hover-interaction-elevate)::after, .border.active-elevate:not(.no-active-interaction-elevate)::after, .border.hover-elevate-2:not(.no-hover-interaction-elevate)::after, .border.active-elevate-2:not(.no-active-interaction-elevate)::after, .border.hover-elevate:not(.no-hover-interaction-elevate)::after { inset: -1px; } }