mirror of
https://github.com/purrgrammer/grimoire.git
synced 2026-04-09 15:07:10 +02:00
257 lines
6.3 KiB
CSS
257 lines
6.3 KiB
CSS
@tailwind base;
|
|
@tailwind components;
|
|
@tailwind utilities;
|
|
|
|
/* Custom scrollbar styling */
|
|
* {
|
|
scrollbar-width: thin;
|
|
scrollbar-color: rgba(255, 255, 255, 0.2) transparent;
|
|
}
|
|
|
|
*::-webkit-scrollbar {
|
|
width: 8px;
|
|
height: 8px;
|
|
}
|
|
|
|
*::-webkit-scrollbar-track {
|
|
background: transparent;
|
|
}
|
|
|
|
*::-webkit-scrollbar-thumb {
|
|
background-color: rgba(255, 255, 255, 0.2);
|
|
border-radius: 4px;
|
|
}
|
|
|
|
*::-webkit-scrollbar-thumb:hover {
|
|
background-color: rgba(255, 255, 255, 0.3);
|
|
}
|
|
|
|
@layer base {
|
|
:root {
|
|
--background: 0 0% 100%;
|
|
--foreground: 222.2 84% 4.9%;
|
|
--card: 0 0% 100%;
|
|
--card-foreground: 222.2 84% 4.9%;
|
|
--popover: 0 0% 100%;
|
|
--popover-foreground: 222.2 84% 4.9%;
|
|
--primary: 222.2 47.4% 11.2%;
|
|
--primary-foreground: 210 40% 98%;
|
|
--secondary: 210 40% 96.1%;
|
|
--secondary-foreground: 222.2 47.4% 11.2%;
|
|
--muted: 210 40% 96.1%;
|
|
--muted-foreground: 215.4 16.3% 46.9%;
|
|
--accent: 210 40% 96.1%;
|
|
--accent-foreground: 222.2 47.4% 11.2%;
|
|
--destructive: 0 84.2% 60.2%;
|
|
--destructive-foreground: 210 40% 98%;
|
|
--border: 214.3 31.8% 91.4%;
|
|
--input: 214.3 31.8% 91.4%;
|
|
--ring: 222.2 84% 4.9%;
|
|
--radius: 0.5rem;
|
|
--chart-1: 12 76% 61%;
|
|
--chart-2: 173 58% 39%;
|
|
--chart-3: 197 37% 24%;
|
|
--chart-4: 43 74% 66%;
|
|
--chart-5: 27 87% 67%;
|
|
}
|
|
.dark {
|
|
--background: 222.2 84% 4.9%;
|
|
--foreground: 210 40% 98%;
|
|
--card: 222.2 84% 4.9%;
|
|
--card-foreground: 210 40% 98%;
|
|
--popover: 222.2 84% 4.9%;
|
|
--popover-foreground: 210 40% 98%;
|
|
--primary: 210 40% 98%;
|
|
--primary-foreground: 222.2 47.4% 11.2%;
|
|
--secondary: 217.2 32.6% 17.5%;
|
|
--secondary-foreground: 210 40% 98%;
|
|
--muted: 217.2 32.6% 17.5%;
|
|
--muted-foreground: 215 20.2% 70%;
|
|
--accent: 270 100% 70%;
|
|
--accent-foreground: 222.2 84% 4.9%;
|
|
--destructive: 0 62.8% 30.6%;
|
|
--destructive-foreground: 210 40% 98%;
|
|
--border: 217.2 32.6% 17.5%;
|
|
--input: 217.2 32.6% 17.5%;
|
|
--ring: 212.7 26.8% 83.9%;
|
|
--chart-1: 220 70% 50%;
|
|
--chart-2: 160 60% 45%;
|
|
--chart-3: 30 80% 55%;
|
|
--chart-4: 280 65% 60%;
|
|
--chart-5: 340 75% 55%;
|
|
}
|
|
}
|
|
|
|
@layer base {
|
|
* {
|
|
@apply border-border;
|
|
}
|
|
body {
|
|
@apply bg-background text-foreground font-mono;
|
|
}
|
|
}
|
|
|
|
@layer utilities {
|
|
.text-grimoire-gradient {
|
|
background: linear-gradient(
|
|
to bottom,
|
|
rgb(250 204 21),
|
|
/* yellow-400 */ rgb(251 146 60),
|
|
/* orange-400 */ rgb(168 85 247),
|
|
/* purple-500 */ rgb(34 211 238) /* cyan-400 */
|
|
);
|
|
background-clip: text;
|
|
-webkit-background-clip: text;
|
|
-webkit-text-fill-color: transparent;
|
|
}
|
|
}
|
|
|
|
/* react-medium-image-zoom dark theme customization */
|
|
[data-rmiz-modal-overlay] {
|
|
background-color: rgba(12, 12, 18, 0.92) !important;
|
|
}
|
|
|
|
[data-rmiz-modal-content] {
|
|
box-shadow: 0 0 40px rgba(0, 0, 0, 0.5);
|
|
}
|
|
|
|
/* React Mosaic Dark Theme Customization */
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme {
|
|
background: hsl(var(--background));
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme
|
|
.mosaic-window
|
|
.mosaic-window-toolbar {
|
|
background: hsl(var(--background));
|
|
border: none;
|
|
border-bottom: 1px solid hsl(var(--border));
|
|
border-radius: 0;
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme
|
|
.mosaic-window
|
|
.mosaic-window-title {
|
|
color: hsl(var(--foreground));
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme .mosaic-window {
|
|
background: hsl(var(--background));
|
|
outline: none;
|
|
border-radius: 0 !important;
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme .mosaic-window * {
|
|
border-radius: 0 !important;
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme .mosaic-window::before,
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme .mosaic-window::after {
|
|
display: none;
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme.bp4-dark .mosaic-window,
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme.bp4-dark .mosaic-preview {
|
|
box-shadow: none;
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme
|
|
.mosaic-window
|
|
.mosaic-window-toolbar {
|
|
background: hsl(var(--muted));
|
|
border: none;
|
|
border-bottom: 1px solid hsl(var(--border));
|
|
color: hsl(var(--foreground));
|
|
height: 30px;
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme
|
|
.mosaic-window
|
|
.mosaic-window-title {
|
|
color: hsl(var(--foreground));
|
|
font-family: inherit;
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme
|
|
.mosaic-window
|
|
.mosaic-window-body {
|
|
background: hsl(var(--background));
|
|
color: hsl(var(--foreground));
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme .mosaic-window-controls {
|
|
color: hsl(var(--muted-foreground));
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme
|
|
.mosaic-window-controls:hover {
|
|
color: hsl(var(--foreground));
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme
|
|
.mosaic-window-toolbar
|
|
.separator {
|
|
border-left: 1px solid hsl(var(--border));
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme
|
|
.mosaic-window-body-overlay {
|
|
background: hsl(var(--background));
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme .mosaic-preview {
|
|
background: hsl(var(--accent) / 0.3);
|
|
border: 2px solid hsl(var(--primary));
|
|
outline: none;
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme .mosaic-drop-target {
|
|
border: 2px solid var(--border);
|
|
outline: none;
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme .mosaic-split:hover {
|
|
background: hsl(var(--primary));
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme .mosaic-split.-row {
|
|
width: 4px;
|
|
margin: 0 -2px;
|
|
}
|
|
|
|
.mosaic.mosaic-blueprint-theme.mosaic-blueprint-theme .mosaic-split.-column {
|
|
height: 4px;
|
|
margin: -2px 0;
|
|
}
|
|
|
|
/* Accessibility: Focus indicators for keyboard navigation */
|
|
@layer base {
|
|
/* Focus-visible for buttons and interactive elements */
|
|
button:focus-visible,
|
|
a:focus-visible,
|
|
[role="button"]:focus-visible {
|
|
outline: 2px solid hsl(var(--ring));
|
|
outline-offset: 2px;
|
|
}
|
|
|
|
/* Focus-visible for input elements */
|
|
input:focus-visible,
|
|
textarea:focus-visible,
|
|
select:focus-visible {
|
|
outline: 2px solid hsl(var(--ring));
|
|
outline-offset: 0;
|
|
}
|
|
|
|
/* Focus-visible for command launcher items */
|
|
[cmdk-item]:focus-visible {
|
|
outline: 2px solid hsl(var(--ring));
|
|
outline-offset: -2px;
|
|
}
|
|
|
|
/* Focus-visible for tab buttons */
|
|
.tabbar-button:focus-visible {
|
|
outline: 2px solid hsl(var(--ring));
|
|
outline-offset: 2px;
|
|
}
|
|
}
|