diff --git a/src/app/globals.css b/src/app/globals.css
index 5acc100..d681b99 100644
--- a/src/app/globals.css
+++ b/src/app/globals.css
@@ -140,6 +140,99 @@
--ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
}
+[data-theme="dark"] {
+ --color-primary: #E5E5E5;
+ --color-primary-hover: #F5F5F5;
+ --color-primary-light: #A3A3A3;
+ --color-primary-lighter: #262626;
+ --color-primary-rgb: 229, 229, 229;
+
+ --color-brand-primary: #E04A68;
+ --color-brand-primary-hover: #F06880;
+ --color-brand-primary-light: #C41E3A;
+ --color-brand-primary-bg: rgba(196, 30, 58, 0.15);
+
+ --color-bg-primary: #0A0A0A;
+ --color-bg-secondary: #0F0F0F;
+ --color-bg-tertiary: #1A1A1A;
+ --color-bg-section: #141414;
+ --color-bg-hover: #262626;
+
+ --color-text-primary: #E5E5E5;
+ --color-text-secondary: #B0B0B0;
+ --color-text-tertiary: #A0A0A0;
+ --color-text-muted: #8C8C8C;
+ --color-text-subtle: #666666;
+ --color-text-placeholder: #737373;
+ --color-text-hint: #5C5C5C;
+
+ --color-border-primary: #2A2A2A;
+ --color-border-secondary: #333333;
+ --color-border-accent: #E5E5E5;
+ --color-border-light: #1F1F1F;
+ --color-border-dark: #CCCCCC;
+
+ --color-link: #E5E5E5;
+ --color-link-hover: #E04A68;
+
+ --color-success: #22C55E;
+ --color-success-hover: #16A34A;
+ --color-success-bg: rgba(22, 163, 74, 0.15);
+ --color-warning: #F59E0B;
+ --color-warning-hover: #D97706;
+ --color-warning-bg: rgba(217, 119, 6, 0.15);
+ --color-info: #8C8C8C;
+ --color-info-bg: #1A1A1A;
+ --color-error: #E04A68;
+ --color-error-bg: rgba(196, 30, 58, 0.15);
+
+ --color-accent-blue: #3B82F6;
+ --color-accent-purple: #8B5CF6;
+ --color-accent-cyan: #06B6D4;
+
+ --color-brand-primary-rgb: 224, 74, 104;
+ --color-warning-rgb: 245, 158, 11;
+ --color-success-rgb: 34, 197, 94;
+ --color-accent-blue-rgb: 59, 130, 246;
+ --color-accent-purple-rgb: 139, 92, 246;
+ --color-accent-cyan-rgb: 6, 182, 212;
+
+ --color-footer-bg: #000000;
+ --color-footer-text: #8C8C8C;
+ --color-footer-text-muted: #525252;
+ --color-footer-text-dim: #737373;
+ --color-footer-text-link: #B0B0B0;
+ --color-footer-border: #262626;
+
+ --color-challenge-isolation: rgba(196, 30, 58, 0.12);
+ --color-challenge-isolation-hover: rgba(196, 30, 58, 0.2);
+ --color-challenge-growth: rgba(217, 119, 6, 0.12);
+ --color-challenge-growth-hover: rgba(217, 119, 6, 0.2);
+ --color-challenge-compliance: rgba(22, 163, 74, 0.12);
+ --color-challenge-compliance-hover: rgba(22, 163, 74, 0.2);
+
+ --color-flip-card-bg: #1A1A1A;
+ --color-flip-card-border: #2A2A2A;
+ --color-flip-card-divider: #525252;
+ --color-flip-card-divider-subtle: #333333;
+
+ --color-toast-success-bg: rgba(22, 163, 74, 0.15);
+ --color-toast-success-border: rgba(34, 197, 94, 0.3);
+ --color-toast-error-bg: rgba(196, 30, 58, 0.15);
+ --color-toast-error-border: rgba(224, 74, 104, 0.3);
+ --color-toast-info-bg: rgba(59, 130, 246, 0.15);
+ --color-toast-info-border: rgba(59, 130, 246, 0.3);
+ --color-toast-close: #666666;
+ --color-toast-close-hover: #A3A3A3;
+
+ --color-skeleton-bg: #262626;
+
+ --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
+ --shadow-md: 0 4px 6px rgba(0, 0, 0, 0.3);
+ --shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.3);
+ --shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.3);
+}
+
@layer base {
* {
@apply antialiased;
diff --git a/src/app/layout.tsx b/src/app/layout.tsx
index 77df2e8..0b6e391 100644
--- a/src/app/layout.tsx
+++ b/src/app/layout.tsx
@@ -121,6 +121,11 @@ export default function RootLayout({
return (
+
diff --git a/src/components/layout/header.tsx b/src/components/layout/header.tsx
index 7e85d11..36dac06 100644
--- a/src/components/layout/header.tsx
+++ b/src/components/layout/header.tsx
@@ -7,6 +7,8 @@ import { usePathname } from 'next/navigation';
import { Menu, X } from 'lucide-react';
import { AnimatePresence, motion } from 'framer-motion';
import { Button } from '@/components/ui/button';
+import { ThemeToggle } from '@/components/ui/theme-toggle';
+import { useTheme } from '@/contexts/theme-context';
import { COMPANY_INFO, NAVIGATION_V2, MEGA_DROPDOWN_DATA, type NavigationItemV2 } from '@/lib/constants';
import { MegaDropdown } from '@/components/layout/mega-dropdown';
import { useFocusTrap } from '@/hooks/use-focus-trap';
@@ -17,6 +19,7 @@ function HeaderContent() {
const [openDropdown, setOpenDropdown] = useState(null);
const pathname = usePathname();
const focusTrapRef = useFocusTrap(isOpen);
+ const { resolvedTheme } = useTheme();
useEffect(() => {
const handleScroll = () => {
@@ -90,7 +93,7 @@ function HeaderContent() {
aria-label="返回首页"
>
+