+
🛍️
{t('project.type.product')}
diff --git a/src/styles/global.css b/src/styles/global.css
index 723c79d..936ca3b 100644
--- a/src/styles/global.css
+++ b/src/styles/global.css
@@ -1,5 +1,6 @@
@import "tailwindcss";
@import "tw-animate-css";
+@import url('https://fonts.googleapis.com/css2?family=Archivo:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500&family=Space+Grotesk:wght@300;400;500;600;700&display=swap');
@plugin "@tailwindcss/typography";
/* Blog List Component Styles */
@@ -43,24 +44,24 @@
:root {
--radius: 0.75rem;
- --background: oklch(1 0 0);
- --foreground: oklch(0.145 0 0);
- --card: oklch(1 0 0);
- --card-foreground: oklch(0.145 0 0);
- --popover: oklch(1 0 0);
- --popover-foreground: oklch(0.145 0 0);
- --primary: oklch(0.205 0 0);
- --primary-foreground: oklch(0.985 0 0);
- --secondary: oklch(0.97 0 0);
- --secondary-foreground: oklch(0.205 0 0);
- --muted: oklch(0.97 0 0);
- --muted-foreground: oklch(0.556 0 0);
- --accent: oklch(0.97 0 0);
- --accent-foreground: oklch(0.205 0 0);
- --destructive: oklch(0.577 0.245 27.325);
- --border: oklch(0.922 0 0);
- --input: oklch(0.922 0 0);
- --ring: oklch(0.708 0 0);
+ --background: #F8FAFC;
+ --foreground: #1E293B;
+ --card: #FFFFFF;
+ --card-foreground: #1E293B;
+ --popover: #FFFFFF;
+ --popover-foreground: #1E293B;
+ --primary: #2563EB;
+ --primary-foreground: #FFFFFF;
+ --secondary: #E4E4E7;
+ --secondary-foreground: #1E293B;
+ --muted: #F4F4F5;
+ --muted-foreground: #71717A;
+ --accent: #F97316;
+ --accent-foreground: #FFFFFF;
+ --destructive: #EF4444;
+ --border: #E4E4E7;
+ --input: #E4E4E7;
+ --ring: #2563EB;
--chart-1: oklch(0.646 0.222 41.116);
--chart-2: oklch(0.6 0.118 184.704);
--chart-3: oklch(0.398 0.07 227.392);
@@ -76,36 +77,39 @@
--sidebar-ring: oklch(0.708 0 0);
--transition-standard: 0.3s cubic-bezier(0.4, 0, 0.2, 1);
--svg-filter-color: invert(0%) sepia(0%) saturate(0%) hue-rotate(324deg) brightness(96%) contrast(104%);
-
+
/* Modern Design Variables */
- --gradient-primary: linear-gradient(135deg, #8B5CF6, #EC4899);
+ --gradient-primary: linear-gradient(135deg, #2563EB, #F97316);
--gradient-secondary: linear-gradient(135deg, #3B82F6, #10B981);
+ --gradient-accent: linear-gradient(135deg, #F97316, #FB923C);
--shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.05);
--shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
--shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.12);
+ --shadow-xl: 0 12px 40px rgba(37, 99, 235, 0.15);
--animation-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);
--animation-smooth: cubic-bezier(0.65, 0, 0.35, 1);
+ --animation-spring: cubic-bezier(0.22, 1, 0.36, 1);
}
.dark {
- --background: oklch(0.145 0 0);
- --foreground: oklch(0.985 0 0);
- --card: oklch(0.205 0 0);
- --card-foreground: oklch(0.985 0 0);
- --popover: oklch(0.205 0 0);
- --popover-foreground: oklch(0.985 0 0);
- --primary: oklch(0.922 0 0);
- --primary-foreground: oklch(0.205 0 0);
- --secondary: oklch(0.269 0 0);
- --secondary-foreground: oklch(0.985 0 0);
- --muted: oklch(0.269 0 0);
- --muted-foreground: oklch(0.708 0 0);
- --accent: oklch(0.269 0 0);
- --accent-foreground: oklch(0.985 0 0);
- --destructive: oklch(0.704 0.191 22.216);
- --border: oklch(1 0 0 / 10%);
- --input: oklch(1 0 0 / 15%);
- --ring: oklch(0.556 0 0);
+ --background: #09090B;
+ --foreground: #F8FAFC;
+ --card: #18181B;
+ --card-foreground: #F8FAFC;
+ --popover: #18181B;
+ --popover-foreground: #F8FAFC;
+ --primary: #3B82F6;
+ --primary-foreground: #FFFFFF;
+ --secondary: #27272A;
+ --secondary-foreground: #F8FAFC;
+ --muted: #27272A;
+ --muted-foreground: #A1A1AA;
+ --accent: #FB923C;
+ --accent-foreground: #09090B;
+ --destructive: #EF4444;
+ --border: #27272A;
+ --input: #27272A;
+ --ring: #3B82F6;
--chart-1: oklch(0.488 0.243 264.376);
--chart-2: oklch(0.696 0.17 162.48);
--chart-3: oklch(0.769 0.188 70.08);
@@ -120,11 +124,12 @@
--sidebar-border: oklch(1 0 0 / 10%);
--sidebar-ring: oklch(0.556 0 0);
--svg-filter-color: invert(100%) sepia(0%) saturate(0%) hue-rotate(324deg) brightness(102%) contrast(101%);
-
+
/* Dark Mode Modern Design Variables */
- --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.2);
- --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.25);
- --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.3);
+ --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.3);
+ --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
+ --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.5);
+ --shadow-xl: 0 12px 40px rgba(59, 130, 246, 0.2);
}
@theme inline {
@@ -172,11 +177,12 @@
}
body {
@apply bg-background text-foreground;
- font-family: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans SC", "Inter", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
+ font-family: "Space Grotesk", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans SC", "Inter", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
font-feature-settings: "ss01", "ss02", "cv01", "cv02";
}
h1, h2, h3, h4, h5, h6 {
@apply font-bold tracking-tight;
+ font-family: "Archivo", "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "Noto Sans SC", "Inter", "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
line-height: 1.2;
}
a {
@@ -186,3 +192,148 @@
@apply rounded-md;
}
}
+
+/* Animation utilities */
+@layer utilities {
+ .animate-fade-in {
+ animation: fadeIn 0.6s ease-out forwards;
+ }
+
+ .animate-fade-in-up {
+ animation: fadeInUp 0.6s ease-out forwards;
+ }
+
+ .animate-slide-in-left {
+ animation: slideInLeft 0.5s ease-out forwards;
+ }
+
+ .animate-slide-in-right {
+ animation: slideInRight 0.5s ease-out forwards;
+ }
+
+ .animate-scale-in {
+ animation: scaleIn 0.4s ease-out forwards;
+ }
+
+ .animate-bounce-in {
+ animation: bounceIn 0.6s cubic-bezier(0.22, 1, 0.36, 1) forwards;
+ }
+
+ .hover-lift {
+ transition: transform 0.3s ease, box-shadow 0.3s ease;
+ }
+
+ .hover-lift:hover {
+ transform: translateY(-5px);
+ box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1);
+ }
+
+ .dark .hover-lift:hover {
+ box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.3);
+ }
+
+ .gradient-text-primary {
+ background: linear-gradient(135deg, #2563EB, #F97316);
+ -webkit-background-clip: text;
+ -webkit-text-fill-color: transparent;
+ background-clip: text;
+ }
+
+ .gradient-text-accent {
+ background: linear-gradient(135deg, #F97316, #FB923C);
+ -webkit-background-clip: text;
+ -webkit-text-fill-color: transparent;
+ background-clip: text;
+ }
+
+ /* Scroll reveal animations */
+ .reveal {
+ opacity: 0;
+ transform: translateY(20px);
+ transition: opacity 0.6s ease-out, transform 0.6s ease-out;
+ }
+
+ .reveal.active {
+ opacity: 1;
+ transform: translateY(0);
+ }
+
+ /* Reduced motion support */
+ @media (prefers-reduced-motion: reduce) {
+ .animate-fade-in,
+ .animate-fade-in-up,
+ .animate-slide-in-left,
+ .animate-slide-in-right,
+ .animate-scale-in,
+ .animate-bounce-in,
+ .reveal {
+ animation: none;
+ opacity: 1;
+ transform: none;
+ }
+ }
+}
+
+@keyframes fadeIn {
+ from {
+ opacity: 0;
+ }
+ to {
+ opacity: 1;
+ }
+}
+
+@keyframes fadeInUp {
+ from {
+ opacity: 0;
+ transform: translateY(20px);
+ }
+ to {
+ opacity: 1;
+ transform: translateY(0);
+ }
+}
+
+@keyframes slideInLeft {
+ from {
+ opacity: 0;
+ transform: translateX(-20px);
+ }
+ to {
+ opacity: 1;
+ transform: translateX(0);
+ }
+}
+
+@keyframes slideInRight {
+ from {
+ opacity: 0;
+ transform: translateX(20px);
+ }
+ to {
+ opacity: 1;
+ transform: translateX(0);
+ }
+}
+
+@keyframes scaleIn {
+ from {
+ opacity: 0;
+ transform: scale(0.95);
+ }
+ to {
+ opacity: 1;
+ transform: scale(1);
+ }
+}
+
+@keyframes bounceIn {
+ from {
+ opacity: 0;
+ transform: scale(0.9);
+ }
+ to {
+ opacity: 1;
+ transform: scale(1);
+ }
+}