/* Prism syntax highlighting theme */ @import './styles/prism-theme.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; } }