@tailwind base; @tailwind components; @tailwind utilities; /* JetBrains Mono 字体 - 用于代码编辑器 */ @font-face { font-family: 'JetBrains Mono'; src: url('/fonts/JetBrainsMono-Medium.ttf') format('truetype'); font-weight: 500; font-style: normal; font-display: swap; } @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: 221.2 83.2% 53.3%; --primary-foreground: 210 40% 98%; --primary-gradient: none; /* 默认无渐变 */ --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: 221.2 83.2% 53.3%; --radius: 0.5rem; --chart-1: 221.2 83.2% 53.3%; --chart-2: 160 60% 45%; --chart-3: 30 80% 55%; --chart-4: 280 65% 60%; --chart-5: 340 75% 55%; } .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: 217.2 91.2% 59.8%; --primary-foreground: 210 40% 98%; --primary-gradient: none; /* 默认无渐变 */ --secondary: 217.2 32.6% 17.5%; --secondary-foreground: 210 40% 98%; --muted: 217.2 32.6% 17.5%; --muted-foreground: 215 20.2% 65.1%; --accent: 217.2 32.6% 17.5%; --accent-foreground: 210 40% 98%; --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: 224.3 76.3% 48%; --chart-1: 217.2 91.2% 59.8%; --chart-2: 160 60% 50%; --chart-3: 30 80% 60%; --chart-4: 280 65% 65%; --chart-5: 340 75% 60%; } } @layer base { * { @apply border-border; } body { @apply bg-background text-foreground; } /* 隐藏数字输入框的默认上下箭头 */ input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button { -webkit-appearance: none; margin: 0; } input[type="number"] { -moz-appearance: textfield; appearance: textfield; } } @layer utilities { /* 渐变色背景工具类 */ .bg-primary-gradient { background: var(--primary-gradient, hsl(var(--primary))); } /* 渐变色文字工具类 - 默认使用普通文字颜色 */ .text-primary-gradient { color: hsl(var(--primary)); } /* 当应用了 has-gradient 类时,使用渐变文字效果 */ .has-gradient .text-primary-gradient { background: var(--primary-gradient); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; } /* 渐变色边框工具类 */ .border-primary-gradient { border-image: var(--primary-gradient, linear-gradient(to right, hsl(var(--primary)), hsl(var(--primary)))) 1; } } /* 禁用动效时的样式 */ .no-animations *, .no-animations *::before, .no-animations *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; } /* 保留基本的 hover 反馈 */ .no-animations *:hover { transition-duration: 0.01ms !important; } /* View Transition API 动画 */ ::view-transition-old(root), ::view-transition-new(root) { animation: none; mix-blend-mode: normal; } /* 默认情况下(亮色→暗色),新内容在上层 */ ::view-transition-old(root) { z-index: 1; } ::view-transition-new(root) { z-index: 999; } /* React Joyride Tour 样式 - 确保在 Dialog 之上 */ .__floater { z-index: 99999 !important; pointer-events: auto !important; } .react-joyride__overlay { z-index: 99998 !important; } .react-joyride__spotlight { z-index: 99998 !important; } /* Tour tooltip 内的按钮需要可点击 */ .react-joyride__tooltip { pointer-events: auto !important; } #tour-portal-container * { pointer-events: auto; } /* 自定义滚动条样式 */ .custom-scrollbar { scrollbar-width: thin; scrollbar-color: hsl(var(--border)) transparent; } .custom-scrollbar::-webkit-scrollbar { width: 8px; height: 8px; } .custom-scrollbar::-webkit-scrollbar-track { background: transparent; border-radius: 4px; } .custom-scrollbar::-webkit-scrollbar-thumb { background: hsl(var(--border)); border-radius: 4px; border: 2px solid transparent; background-clip: content-box; } .custom-scrollbar::-webkit-scrollbar-thumb:hover { background: hsl(var(--muted-foreground) / 0.5); background-clip: content-box; } .custom-scrollbar::-webkit-scrollbar-corner { background: transparent; }