style.css 9.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483
  1. :root {
  2. font-family: system-ui, Avenir, Helvetica, Arial, sans-serif;
  3. line-height: 1.5;
  4. font-weight: 400;
  5. color-scheme: light dark;
  6. font-synthesis: none;
  7. text-rendering: optimizeLegibility;
  8. -webkit-font-smoothing: antialiased;
  9. -moz-osx-font-smoothing: grayscale;
  10. --el-color-primary: #ff6b6b;
  11. }
  12. /* 浅色主题(默认) */
  13. :root {
  14. --bg-page: #ffffff;
  15. --bg-base: #ffffff;
  16. --bg-container: #f5f7fa;
  17. --bg-overlay: #ffffff;
  18. --text-primary: #303133;
  19. --text-secondary: #606266;
  20. --text-tertiary: #909399;
  21. --text-placeholder: #adb3b8;
  22. --text-disabled: #c0c4c8;
  23. --text-strong: #000000;
  24. --card-bg-selected: linear-gradient(135deg, #ffe6e6 0%, #ffd6d6 100%);
  25. --card-bg-unselected: linear-gradient(135deg, #f5f7fa 0%, #ffffff 100%);
  26. --border-light: #ebeef5;
  27. --border-base: #dcdfe6;
  28. --border-dark: #ccc;
  29. /* Element Plus 全局背景和文字 */
  30. --el-bg-color: #ffffff;
  31. --el-text-color-primary: #303133;
  32. --el-text-color-regular: #606266;
  33. --el-text-color-secondary: #909399;
  34. --el-text-color-placeholder: #adb3b8;
  35. --el-text-color-disabled: #c0c4c8;
  36. --el-border-color: #dcdfe6;
  37. --el-border-color-light: #ebeef5;
  38. --el-border-color-lighter: #f5f7fa;
  39. --el-border-color-extra-light: #fafafa;
  40. --el-fill-color-blank: #ffffff;
  41. --el-fill-color-white: #ffffff;
  42. --el-fill-color: #f0f2f5;
  43. --el-fill-color-light: #f5f7fa;
  44. --el-fill-color-lighter: #fafafa;
  45. --el-fill-color-extra-light: #fafbfc;
  46. }
  47. /* 暗黑主题 */
  48. :root.dark {
  49. --bg-page: #0a0a0a;
  50. --bg-base: #141414;
  51. --bg-container: #1f1f1f;
  52. --bg-overlay: #262626;
  53. --text-primary: #efefef;
  54. --text-secondary: #b3b3b3;
  55. --text-tertiary: #909399;
  56. --text-placeholder: #757575;
  57. --text-disabled: #6c6c6c;
  58. --text-strong: #ffffff;
  59. --card-bg-selected: linear-gradient(135deg, #4a2a2a 0%, #3a1f1f 100%);
  60. --card-bg-unselected: linear-gradient(135deg, #2a2a2a 0%, #141414 100%);
  61. --border-light: #414141;
  62. --border-base: #434343;
  63. --border-dark: #595959;
  64. /* Element Plus 暗黑背景和文字 */
  65. --el-bg-color: #141414;
  66. --el-text-color-primary: #efefef;
  67. --el-text-color-regular: #b3b3b3;
  68. --el-text-color-secondary: #909399;
  69. --el-text-color-placeholder: #757575;
  70. --el-text-color-disabled: #6c6c6c;
  71. --el-border-color: #434343;
  72. --el-border-color-light: #414141;
  73. --el-border-color-lighter: #373737;
  74. --el-border-color-extra-light: #262626;
  75. --el-fill-color-blank: #1f1f1f;
  76. --el-fill-color-white: #1f1f1f;
  77. --el-fill-color: #262626;
  78. --el-fill-color-light: #2a2a2a;
  79. --el-fill-color-lighter: #2e2e2e;
  80. --el-fill-color-extra-light: #323232;
  81. }
  82. a {
  83. font-weight: 500;
  84. color: var(--el-color-primary);
  85. text-decoration: inherit;
  86. }
  87. a:hover {
  88. color: var(--el-color-primary);
  89. }
  90. body {
  91. margin: 0;
  92. padding: 0;
  93. min-width: 320px;
  94. height: 100%;
  95. background-color: var(--bg-page);
  96. color: var(--text-primary);
  97. transition:
  98. background-color 0.3s,
  99. color 0.3s;
  100. }
  101. h1 {
  102. font-size: 3.2em;
  103. line-height: 1.1;
  104. }
  105. button {
  106. border-radius: 8px;
  107. border: 1px solid transparent;
  108. padding: 0.6em 1.2em;
  109. font-size: 1em;
  110. font-weight: 500;
  111. font-family: inherit;
  112. background-color: var(--bg-container);
  113. color: var(--text-primary);
  114. cursor: pointer;
  115. transition: all 0.25s;
  116. }
  117. button:hover {
  118. border-color: var(--el-color-primary);
  119. background-color: var(--bg-base);
  120. }
  121. button:focus,
  122. button:focus-visible {
  123. outline: 4px auto -webkit-focus-ring-color;
  124. }
  125. .card {
  126. padding: 2em;
  127. }
  128. #app {
  129. height: 100%;
  130. width: 100%;
  131. margin: 0;
  132. padding: 0;
  133. }
  134. @media (prefers-color-scheme: light) {
  135. :root {
  136. color: #213547;
  137. background-color: #ffffff;
  138. }
  139. a:hover {
  140. color: var(--el-color-primary);
  141. }
  142. button {
  143. background-color: #f9f9f9;
  144. }
  145. }
  146. /* Dialog 全局样式 */
  147. .el-dialog {
  148. overflow: hidden;
  149. border-top-left-radius: 4px !important;
  150. border-top-right-radius: 4px !important;
  151. padding: 0 !important;
  152. }
  153. .el-dialog__body {
  154. padding: calc(var(--el-dialog-padding-primary)) var(--el-dialog-padding-primary);
  155. background-color: var(--bg-base);
  156. color: var(--text-primary);
  157. }
  158. .el-dialog__header {
  159. border-bottom: 1px solid var(--border-base) !important;
  160. margin-right: 0 !important;
  161. border-top-left-radius: 4px;
  162. border-top-right-radius: 4px;
  163. padding: 0px 13px !important;
  164. line-height: 53px;
  165. height: 50px;
  166. color: var(--text-primary) !important;
  167. font-weight: bold;
  168. font-size: 14px;
  169. background-color: var(--bg-base) !important;
  170. }
  171. .el-dialog__headerbtn {
  172. height: 50px !important;
  173. width: 50px !important;
  174. top: 0 !important;
  175. }
  176. .el-dialog__footer {
  177. padding: var(--el-dialog-padding-primary) !important;
  178. /* padding-top: 0 !important; */
  179. text-align: right;
  180. box-sizing: border-box;
  181. background-color: var(--bg-base);
  182. border-top: 1px solid var(--border-light);
  183. }
  184. .el-dialog__headerbtn .el-dialog__close {
  185. color: var(--text-primary) !important;
  186. }
  187. .el-dialog__title {
  188. color: var(--text-primary);
  189. }
  190. /* Element Plus 所有组件的全局样式覆盖 */
  191. .el-input,
  192. .el-input__wrapper,
  193. .el-input__inner {
  194. background-color: var(--bg-base);
  195. border-color: var(--border-base);
  196. color: var(--text-primary);
  197. }
  198. .el-input__inner::placeholder {
  199. color: var(--text-placeholder);
  200. }
  201. .el-textarea__inner {
  202. background-color: var(--bg-base);
  203. border-color: var(--border-base);
  204. color: var(--text-primary);
  205. }
  206. .el-select-dropdown {
  207. background-color: var(--bg-container);
  208. border-color: var(--border-base);
  209. }
  210. .el-option {
  211. color: var(--text-primary);
  212. }
  213. .el-option:hover {
  214. background-color: var(--bg-base);
  215. }
  216. .el-option.selected {
  217. background-color: var(--bg-base);
  218. color: var(--el-color-primary);
  219. }
  220. .el-popper {
  221. background-color: var(--bg-container);
  222. border-color: var(--border-base);
  223. color: var(--text-primary);
  224. }
  225. .el-table {
  226. background-color: var(--bg-base);
  227. color: var(--text-primary);
  228. }
  229. .el-table__header th {
  230. background-color: var(--bg-container);
  231. border-color: var(--border-base);
  232. color: var(--text-primary);
  233. }
  234. .el-table__body tr {
  235. background-color: var(--bg-base);
  236. border-color: var(--border-base);
  237. }
  238. .el-table__body tr:hover > td {
  239. background-color: var(--bg-overlay);
  240. }
  241. .el-card {
  242. background-color: var(--bg-base);
  243. border-color: var(--border-light);
  244. color: var(--text-primary);
  245. }
  246. .el-card__header {
  247. background-color: var(--bg-base);
  248. border-color: var(--border-light);
  249. color: var(--text-primary);
  250. }
  251. .el-container {
  252. background-color: var(--bg-page);
  253. }
  254. .el-main {
  255. background-color: var(--bg-page);
  256. color: var(--text-primary);
  257. }
  258. .el-aside {
  259. background-color: var(--bg-base);
  260. }
  261. .el-header {
  262. background-color: var(--bg-base);
  263. border-color: var(--border-light);
  264. color: var(--text-primary);
  265. }
  266. .el-footer {
  267. background-color: var(--bg-base);
  268. border-color: var(--border-light);
  269. color: var(--text-primary);
  270. }
  271. .el-menu {
  272. background-color: var(--bg-base);
  273. border-color: var(--border-light);
  274. color: var(--text-primary);
  275. }
  276. .el-menu-item,
  277. .el-sub-menu__title {
  278. color: var(--text-secondary);
  279. }
  280. .el-menu-item:hover,
  281. .el-sub-menu__title:hover {
  282. color: var(--text-primary);
  283. background-color: var(--bg-container) !important;
  284. }
  285. .el-menu-item.is-active {
  286. background-color: var(--bg-container) !important;
  287. color: var(--el-color-primary) !important;
  288. border-right-color: var(--el-color-primary);
  289. }
  290. .el-button {
  291. border-color: var(--border-base);
  292. color: var(--text-primary);
  293. }
  294. .el-button:hover {
  295. background-color: var(--bg-container);
  296. border-color: var(--border-base);
  297. color: var(--text-primary);
  298. }
  299. .el-tag {
  300. background-color: var(--bg-container);
  301. border-color: var(--border-light);
  302. color: var(--text-primary);
  303. }
  304. .el-pagination .btn {
  305. background-color: var(--bg-base);
  306. color: var(--text-primary);
  307. border-color: var(--border-light);
  308. }
  309. .el-pagination .btn:hover {
  310. color: var(--el-color-primary);
  311. }
  312. .el-tooltip__popper {
  313. background-color: var(--bg-container);
  314. border-color: var(--border-base);
  315. color: var(--text-primary);
  316. }
  317. .el-drawer {
  318. background-color: var(--bg-base);
  319. color: var(--text-primary);
  320. }
  321. /* 全局通用样式类 - 供所有组件使用 */
  322. /* 白色/基础背景的元素 */
  323. [style*='background: #fff'],
  324. [style*='background:#fff'],
  325. [style*='background-color: #fff'],
  326. [style*='background-color:#fff'],
  327. [style*='background: white'],
  328. .panel,
  329. .card-container,
  330. .content-wrapper {
  331. background-color: var(--bg-base) !important;
  332. }
  333. /* 浅灰背景的元素 */
  334. [style*='background: #f'],
  335. [style*='background:#f'],
  336. .container-light,
  337. .section-light {
  338. background-color: var(--bg-container) !important;
  339. }
  340. /* 深色文字 */
  341. [style*='color: #333'],
  342. [style*='color:#333'],
  343. [style*='color: #222'],
  344. [style*='color: #1f2937'],
  345. [style*='color: #111827'],
  346. h1,
  347. h2,
  348. h3,
  349. h4,
  350. h5,
  351. h6,
  352. .title,
  353. .heading,
  354. .text-primary {
  355. color: var(--text-primary) !important;
  356. }
  357. /* 次要文字 */
  358. [style*='color: #666'],
  359. [style*='color:#666'],
  360. [style*='color: #6b7280'],
  361. .description,
  362. .subtitle,
  363. .text-secondary {
  364. color: var(--text-secondary) !important;
  365. }
  366. /* 三级文字 */
  367. [style*='color: #999'],
  368. [style*='color:#999'],
  369. [style*='color: #888'],
  370. .text-muted,
  371. .text-tertiary {
  372. color: var(--text-tertiary) !important;
  373. }
  374. /* 边框 */
  375. [style*='border: 1px solid #f0'],
  376. [style*='border-bottom: 1px solid #f'],
  377. [style*='border-top: 1px solid #f'] {
  378. border-color: var(--border-light) !important;
  379. }
  380. /* 卡片和面板通用样式 */
  381. .stat-card,
  382. .action-card,
  383. .content-panel,
  384. .workflow-card,
  385. .panel-header,
  386. .welcome-banner {
  387. background-color: var(--bg-base) !important;
  388. border-color: var(--border-light) !important;
  389. color: var(--text-primary) !important;
  390. }
  391. .stat-card:hover,
  392. .action-card:hover,
  393. .workflow-card:hover {
  394. background-color: var(--bg-container) !important;
  395. }
  396. /* 阴影效果 - 根据主题调整透明度 */
  397. :root {
  398. --shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.12);
  399. --shadow-md: 0 4px 16px rgba(0, 0, 0, 0.15);
  400. --shadow-lg: 2px 4px 12px rgba(0, 0, 0, 0.18);
  401. }
  402. :root.dark {
  403. --shadow-sm: 0 2px 8px rgba(255, 255, 255, 0.25);
  404. --shadow-md: 0 4px 16px rgba(255, 255, 255, 0.35);
  405. --shadow-lg: 2px 4px 12px rgba(255, 255, 255, 0.4);
  406. }
  407. /* NProgress 主题色 */
  408. #nprogress .bar {
  409. background: var(--el-color-primary) !important;
  410. }
  411. #nprogress .peg {
  412. box-shadow:
  413. 0 0 10px var(--el-color-primary),
  414. 0 0 5px var(--el-color-primary) !important;
  415. }
  416. #nprogress .spinner-icon {
  417. border-top-color: var(--el-color-primary) !important;
  418. border-left-color: var(--el-color-primary) !important;
  419. }