devperf/frontend/src/styles/global.css
zyc 43f885e22a feat: MySQL 远程数据库 + CI/CD 流水线 + K8s 部署配置
数据库迁移:
- SQLite → MySQL (mysql-8351f937d637-public.rds.volces.com)
- Schema 从 drizzle-orm/sqlite-core 改为 drizzle-orm/mysql-core
- 全量数据迁移完成(13 张表 525 条记录)

CI/CD 流水线:
- .gitea/workflows/deploy.yaml(airlabs 分支触发)
- 前后端分别构建镜像推到火山引擎 CR internal 命名空间
- 自动部署到内部 K3s 集群

K8s 配置:
- backend-deployment.yaml(Bun 3200 端口 + MySQL 私网连接)
- web-deployment.yaml(Nginx 80 端口 + SPA fallback)
- backend-ingress.yaml(devperf-api.airlabs.art + TLS)
- web-ingress.yaml(devperf.airlabs.art + TLS)
- cert-manager-issuer.yaml(Let's Encrypt)

其他:
- 前端 Dockerfile 支持 VITE_API_BASE_URL 构建参数
- 后端 Dockerfile 改为直接运行源码(兼容 mysql2)
- 侧边栏/全局样式优化 + Git 图表修复

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-13 13:48:54 +08:00

145 lines
2.7 KiB
CSS

:root {
/* Primary - Trusted Indigo */
--color-primary: oklch(0.45 0.12 255);
--color-primary-hex: #3B5998;
--color-primary-hover: oklch(0.40 0.12 255);
--color-primary-light: oklch(0.92 0.03 255);
/* Accent - Amber */
--color-accent: oklch(0.75 0.15 75);
--color-accent-hex: #D4920A;
/* Semantic */
--color-success: #0D9668;
--color-warning: #D4920A;
--color-error: #DC2626;
--color-info: #2B8CA3;
/* Chart palette */
--chart-1: #3B5998;
--chart-2: #0D9668;
--chart-3: #D4920A;
--chart-4: #7C4DBA;
--chart-5: #2B8CA3;
/* Neutral */
--color-bg: #F8F9FB;
--color-bg-card: #FFFFFF;
--color-bg-sidebar: #1E2433;
--color-text-primary: #1A1F2E;
--color-text-secondary: #6B7280;
--color-text-muted: #9CA3AF;
--color-border: #E5E7EB;
/* Typography */
--font-heading: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
--font-body: 'Plus Jakarta Sans', -apple-system, BlinkMacSystemFont, sans-serif;
--font-code: 'JetBrains Mono', 'Fira Code', monospace;
/* Spacing */
--space-1: 4px;
--space-2: 8px;
--space-3: 12px;
--space-4: 16px;
--space-5: 20px;
--space-6: 24px;
--space-8: 32px;
--space-10: 40px;
--space-12: 48px;
--space-16: 64px;
/* Border radius */
--radius-btn: 8px;
--radius-card: 12px;
--radius-modal: 16px;
--radius-pill: 9999px;
/* Easing */
--ease-default: cubic-bezier(0.25, 1, 0.5, 1);
--ease-entrance: cubic-bezier(0.16, 1, 0.3, 1);
--duration-hover: 200ms;
--duration-entrance: 600ms;
--duration-collapse: 300ms;
/* Z-index */
--z-dropdown: 100;
--z-sticky: 200;
--z-modal: 300;
--z-toast: 9999;
/* Sidebar */
--sidebar-width: 240px;
--sidebar-collapsed-width: 64px;
}
*,
*::before,
*::after {
box-sizing: border-box;
margin: 0;
padding: 0;
}
html, body {
margin: 0;
padding: 0;
overflow-x: hidden;
}
html {
font-family: var(--font-body);
font-size: 14px;
line-height: 1.6;
color: var(--color-text-primary);
background-color: var(--color-bg);
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
body {
min-height: 100vh;
}
h1, h2, h3, h4, h5, h6 {
font-family: var(--font-heading);
font-weight: 700;
line-height: 1.3;
}
code, pre {
font-family: var(--font-code);
}
a {
color: var(--color-primary-hex);
text-decoration: none;
}
a:hover {
text-decoration: underline;
}
/* Scrollbar */
::-webkit-scrollbar {
width: 6px;
height: 6px;
}
::-webkit-scrollbar-track {
background: transparent;
}
::-webkit-scrollbar-thumb {
background: var(--color-border);
border-radius: 3px;
}
::-webkit-scrollbar-thumb:hover {
background: var(--color-text-muted);
}
/* Tabular figures for numbers */
.tabular-nums {
font-variant-numeric: tabular-nums;
}