@tailwind base; @tailwind components; @tailwind utilities; /* Catppuccin Mocha Theme - Dark Only */ :root { --button-outline: rgba(255, 255, 255, 0.1); --badge-outline: rgba(255, 255, 255, 0.05); --opaque-button-border-intensity: 9; --elevate-1: rgba(255, 255, 255, 0.04); --elevate-2: rgba(255, 255, 255, 0.09); --background: 240 21% 15%; --foreground: 226 64% 88%; --border: 240 17% 20%; --card: 240 21% 17%; --card-foreground: 226 64% 88%; --card-border: 240 17% 22%; --sidebar: 240 21% 16%; --sidebar-foreground: 226 64% 88%; --sidebar-border: 240 17% 19%; --sidebar-primary: 115 54% 76%; --sidebar-primary-foreground: 240 21% 12%; --sidebar-accent: 240 17% 19%; --sidebar-accent-foreground: 226 64% 88%; --sidebar-ring: 115 54% 76%; --popover: 240 21% 18%; --popover-foreground: 226 64% 88%; --popover-border: 240 17% 21%; --primary: 115 54% 76%; --primary-foreground: 240 21% 12%; --secondary: 240 17% 22%; --secondary-foreground: 226 64% 88%; --muted: 240 17% 21%; --muted-foreground: 226 40% 65%; --accent: 170 57% 73%; --accent-foreground: 240 21% 12%; --destructive: 0 62% 32%; --destructive-foreground: 0 62% 96%; --input: 240 17% 35%; --ring: 115 54% 76%; --chart-1: 115 54% 76%; --chart-2: 170 57% 73%; --chart-3: 197 37% 62%; --chart-4: 43 74% 68%; --chart-5: 27 87% 70%; --font-sans: "JetBrains Mono", monospace; --font-serif: Georgia, serif; --font-mono: "JetBrains Mono", monospace; --radius: 0.5rem; --shadow-2xs: 0px 2px 0px 0px hsl(0 0% 0% / 0); --shadow-xs: 0px 2px 0px 0px hsl(0 0% 0% / 0); --shadow-sm: 0px 2px 0px 0px hsl(0 0% 0% / 0), 0px 1px 2px -1px hsl(0 0% 0% / 0); --shadow: 0px 2px 0px 0px hsl(0 0% 0% / 0), 0px 1px 2px -1px hsl(0 0% 0% / 0); --shadow-md: 0px 2px 0px 0px hsl(0 0% 0% / 0), 0px 2px 4px -1px hsl(0 0% 0% / 0); --shadow-lg: 0px 2px 0px 0px hsl(0 0% 0% / 0), 0px 4px 6px -1px hsl(0 0% 0% / 0); --shadow-xl: 0px 2px 0px 0px hsl(0 0% 0% / 0), 0px 8px 10px -1px hsl(0 0% 0% / 0); --shadow-2xl: 0px 2px 0px 0px hsl(0 0% 0% / 0); --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 ); } @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; } }