@taskon/widget-react 0.0.1-beta.4 → 0.0.1-beta.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/README.md +13 -4
  2. package/dist/CommunityTaskList.css +119 -111
  3. package/dist/EligibilityInfo.css +114 -110
  4. package/dist/LeaderboardWidget.css +73 -71
  5. package/dist/PageBuilder.css +5 -0
  6. package/dist/Quest.css +259 -255
  7. package/dist/TaskOnProvider.css +2 -0
  8. package/dist/UserCenterWidget.css +6 -6
  9. package/dist/UserCenterWidget2.css +1626 -1601
  10. package/dist/{dynamic-import-helper.css → WidgetShell.css} +2 -2
  11. package/dist/chunks/{CommunityTaskList-C9Gv8KOF.js → CommunityTaskList-Hde2OKHH.js} +1070 -580
  12. package/dist/chunks/{EligibilityInfo-D-Fuy9GE.js → EligibilityInfo-BV0Z2TgY.js} +1972 -1028
  13. package/dist/chunks/{LeaderboardWidget-BV2D2q1N.js → LeaderboardWidget-BNGRD5Bu.js} +270 -249
  14. package/dist/chunks/{PageBuilder-DQoU4Mwf.js → PageBuilder-C5DSHiW9.js} +5 -5
  15. package/dist/chunks/{Quest-B5NyVr3o.js → Quest-DG9zfXJo.js} +723 -513
  16. package/dist/chunks/{TaskOnProvider-93UxARFo.js → TaskOnProvider-BhamHIyY.js} +98 -68
  17. package/dist/chunks/{ThemeProvider-CPI_roeh.js → ThemeProvider-mXLdLSkq.js} +107 -20
  18. package/dist/chunks/{UserCenterWidget-cADBSVg7.js → UserCenterWidget-D5ttw4hO.js} +1328 -1337
  19. package/dist/chunks/{UserCenterWidget-BRtigY_S.js → UserCenterWidget-jDO5zTN1.js} +358 -254
  20. package/dist/chunks/{dynamic-import-helper-DwXlQC0S.js → WidgetShell-D7yC894Y.js} +447 -457
  21. package/dist/chunks/communitytask-es-CBNnS4o2.js +521 -0
  22. package/dist/chunks/communitytask-ja-GRf9cbdx.js +521 -0
  23. package/dist/chunks/communitytask-ko-Bf24PQKI.js +521 -0
  24. package/dist/chunks/communitytask-ru-CZm2CPoV.js +521 -0
  25. package/dist/chunks/leaderboardwidget-es-vKjrjQaz.js +146 -0
  26. package/dist/chunks/leaderboardwidget-ja-Q6u0HxKG.js +146 -0
  27. package/dist/chunks/leaderboardwidget-ko-CG6SWgxf.js +146 -0
  28. package/dist/chunks/leaderboardwidget-ru-DCcHcJGz.js +146 -0
  29. package/dist/chunks/quest-es-Dyyy0zaw.js +863 -0
  30. package/dist/chunks/quest-ja-Depog33y.js +863 -0
  31. package/dist/chunks/quest-ko-BMu3uRQJ.js +863 -0
  32. package/dist/chunks/quest-ru-xne814Rw.js +863 -0
  33. package/dist/chunks/taskwidget-es-Do9b3Mqw.js +245 -0
  34. package/dist/chunks/taskwidget-ja-CqSu-yWA.js +245 -0
  35. package/dist/chunks/taskwidget-ko-EHgXFV4B.js +245 -0
  36. package/dist/chunks/taskwidget-ru-CMbLQDK4.js +245 -0
  37. package/dist/chunks/usercenter-es-Dz3Wp2vV.js +512 -0
  38. package/dist/chunks/usercenter-ja-CKE4DJC6.js +512 -0
  39. package/dist/chunks/usercenter-ko-Dtpkn2qb.js +512 -0
  40. package/dist/chunks/usercenter-ru-DnBGee45.js +512 -0
  41. package/dist/community-task.d.ts +0 -390
  42. package/dist/community-task.js +2 -7
  43. package/dist/core.d.ts +46 -10
  44. package/dist/core.js +11 -11
  45. package/dist/index.d.ts +46 -667
  46. package/dist/index.js +19 -28
  47. package/dist/leaderboard.d.ts +0 -498
  48. package/dist/leaderboard.js +2 -16
  49. package/dist/page-builder.js +1 -1
  50. package/dist/quest.d.ts +0 -289
  51. package/dist/quest.js +2 -5
  52. package/dist/user-center.d.ts +0 -1608
  53. package/dist/user-center.js +2 -494
  54. package/package.json +5 -2
  55. package/dist/chunks/leaderboardwidget-ja-Bj6gz6y1.js +0 -119
  56. package/dist/chunks/leaderboardwidget-ko-f1cLO9ic.js +0 -119
  57. package/dist/chunks/usercenter-ja-B2465c1O.js +0 -326
  58. package/dist/chunks/usercenter-ko-xAEYxqLg.js +0 -326
package/dist/Quest.css CHANGED
@@ -137,7 +137,7 @@
137
137
 
138
138
  .taskon-eligs-dialog-desc {
139
139
  margin: 0;
140
- font-size: 14px;
140
+ font-size: var(--taskon-font-size);
141
141
  line-height: 1.5;
142
142
  color: var(--taskon-color-text-secondary);
143
143
  text-align: center;
@@ -172,7 +172,7 @@
172
172
  border: none;
173
173
  cursor: pointer;
174
174
  color: var(--taskon-color-text);
175
- font-size: 14px;
175
+ font-size: var(--taskon-font-size);
176
176
  text-align: left;
177
177
  transition: background 0.2s;
178
178
  }
@@ -216,7 +216,7 @@
216
216
  border-radius: var(--taskon-border-radius);
217
217
  background: var(--taskon-color-primary);
218
218
  color: var(--taskon-color-text-on-primary);
219
- font-size: 16px;
219
+ font-size: var(--taskon-font-size-lg);
220
220
  font-weight: 500;
221
221
  cursor: pointer;
222
222
  transition: opacity 0.2s, background 0.2s;
@@ -275,7 +275,7 @@
275
275
 
276
276
  .taskon-eligs-bind-section-title {
277
277
  margin: 0 0 12px;
278
- font-size: 16px;
278
+ font-size: var(--taskon-font-size-lg);
279
279
  font-weight: 600;
280
280
  color: var(--taskon-color-text);
281
281
  }
@@ -284,7 +284,7 @@
284
284
 
285
285
  .taskon-eligs-bind-tip {
286
286
  margin: 0 0 20px;
287
- font-size: 14px;
287
+ font-size: var(--taskon-font-size);
288
288
  line-height: 1.5;
289
289
  color: var(--taskon-color-text-tertiary);
290
290
  }
@@ -297,7 +297,7 @@
297
297
 
298
298
  .taskon-eligs-bind-section-subtitle {
299
299
  margin: 0 0 12px;
300
- font-size: 14px;
300
+ font-size: var(--taskon-font-size);
301
301
  font-weight: 500;
302
302
  color: var(--taskon-color-text-secondary);
303
303
  }
@@ -328,7 +328,7 @@
328
328
  }
329
329
 
330
330
  .taskon-eligs-bind-item-label {
331
- font-size: 14px;
331
+ font-size: var(--taskon-font-size);
332
332
  font-weight: 500;
333
333
  color: var(--taskon-color-text);
334
334
  }
@@ -340,7 +340,7 @@
340
340
  align-items: center;
341
341
  gap: 6px;
342
342
  padding: 6px 16px;
343
- font-size: 13px;
343
+ font-size: var(--taskon-font-size-sm);
344
344
  font-weight: 500;
345
345
  color: var(--taskon-color-text-on-primary);
346
346
  background: linear-gradient(
@@ -386,7 +386,7 @@
386
386
  display: inline-flex;
387
387
  align-items: center;
388
388
  gap: 4px;
389
- font-size: 13px;
389
+ font-size: var(--taskon-font-size-sm);
390
390
  font-weight: 500;
391
391
  color: var(--taskon-color-success);
392
392
  }
@@ -441,7 +441,7 @@
441
441
  align-items: center;
442
442
  width: 100%;
443
443
  padding: 12px;
444
- font-size: 14px;
444
+ font-size: var(--taskon-font-size);
445
445
  font-weight: 500;
446
446
  color: var(--taskon-color-text);
447
447
  background: transparent;
@@ -508,16 +508,12 @@
508
508
  width: 100%;
509
509
  }
510
510
 
511
- /* 海报顶部 - 绿色渐变区域 */
511
+ /* 海报顶部 - 纯色背景 */
512
512
 
513
513
  .taskon-quest-qr-poster-header {
514
- background: linear-gradient(
515
- 89.87deg,
516
- var(--taskon-color-primary-bg) 0.13%,
517
- var(--taskon-color-primary) 99.92%
518
- );
514
+ background: var(--taskon-color-bg-surface);
519
515
  padding: 30px;
520
- color: var(--taskon-color-text-on-primary);
516
+ color: var(--taskon-color-text);
521
517
  }
522
518
 
523
519
  /* 社区信息 */
@@ -532,12 +528,12 @@
532
528
  height: 30px;
533
529
  border-radius: 50%;
534
530
  margin-right: 6px;
535
- border: 2px solid var(--taskon-color-text-on-primary);
531
+ border: 2px solid var(--taskon-color-border);
536
532
  object-fit: cover;
537
533
  }
538
534
 
539
535
  .taskon-quest-qr-owner-name {
540
- font-size: 24px;
536
+ font-size: var(--taskon-font-size-xxxl);
541
537
  font-weight: 600;
542
538
  white-space: nowrap;
543
539
  overflow: hidden;
@@ -549,8 +545,8 @@
549
545
  .taskon-quest-qr-campaign-name {
550
546
  margin-top: 14px;
551
547
  margin-bottom: 8px;
552
- font-size: 16px;
553
- line-height: 24px;
548
+ font-size: var(--taskon-font-size-lg);
549
+ line-height: 1.5;
554
550
  font-weight: 600;
555
551
  display: -webkit-box;
556
552
  -webkit-line-clamp: 2;
@@ -604,7 +600,7 @@
604
600
  align-items: center;
605
601
  margin-top: 15px;
606
602
  margin-bottom: 6px;
607
- font-size: 14px;
603
+ font-size: var(--taskon-font-size);
608
604
  font-weight: 500;
609
605
  color: var(--taskon-color-text);
610
606
  }
@@ -658,7 +654,7 @@
658
654
  align-items: center;
659
655
  white-space: nowrap;
660
656
  color: var(--taskon-color-text);
661
- font-size: 16px;
657
+ font-size: var(--taskon-font-size-lg);
662
658
  font-weight: 400;
663
659
  }
664
660
 
@@ -738,9 +734,9 @@
738
734
 
739
735
  .taskon-quest-participants-info-title {
740
736
  margin: 0;
741
- font-size: 24px;
737
+ font-size: var(--taskon-font-size-xxxl);
742
738
  font-weight: 600;
743
- line-height: 32px;
739
+ line-height: 1.33;
744
740
  color: var(--taskon-color-text);
745
741
  }
746
742
 
@@ -763,9 +759,9 @@
763
759
  display: flex;
764
760
  justify-content: space-between;
765
761
  align-items: center;
766
- font-size: 16px;
762
+ font-size: var(--taskon-font-size-lg);
767
763
  font-weight: 500;
768
- line-height: 24px;
764
+ line-height: 1.5;
769
765
  width: 100%;
770
766
  }
771
767
 
@@ -829,9 +825,9 @@
829
825
 
830
826
  .taskon-quest-participants-dialog-title {
831
827
  margin: 0 0 var(--taskon-spacing-lg) 0;
832
- font-size: 22px;
828
+ font-size: var(--taskon-font-size-xxl);
833
829
  font-weight: 600;
834
- line-height: 28px;
830
+ line-height: 1.27;
835
831
  color: var(--taskon-color-text);
836
832
  }
837
833
 
@@ -840,17 +836,17 @@
840
836
  }
841
837
 
842
838
  .taskon-quest-participants-dialog-subtitle {
843
- font-size: 16px;
839
+ font-size: var(--taskon-font-size-lg);
844
840
  font-weight: 600;
845
- line-height: 24px;
841
+ line-height: 1.5;
846
842
  color: var(--taskon-color-text);
847
843
  }
848
844
 
849
845
  .taskon-quest-participants-dialog-desc {
850
846
  margin-top: var(--taskon-spacing-xs);
851
- font-size: 14px;
847
+ font-size: var(--taskon-font-size);
852
848
  font-weight: 500;
853
- line-height: 20px;
849
+ line-height: 1.43;
854
850
  color: var(--taskon-color-text-tertiary);
855
851
  }
856
852
 
@@ -904,16 +900,16 @@
904
900
  }
905
901
 
906
902
  .taskon-quest-participants-dialog-card-title {
907
- font-size: 14px;
903
+ font-size: var(--taskon-font-size);
908
904
  font-weight: 600;
909
- line-height: 20px;
905
+ line-height: 1.43;
910
906
  color: var(--taskon-color-text);
911
907
  }
912
908
 
913
909
  .taskon-quest-participants-dialog-card-desc {
914
- font-size: 12px;
910
+ font-size: var(--taskon-font-size-sm);
915
911
  font-weight: 500;
916
- line-height: 16px;
912
+ line-height: 1.33;
917
913
  color: var(--taskon-color-text-tertiary);
918
914
  }
919
915
 
@@ -951,9 +947,9 @@
951
947
 
952
948
  .taskon-quest-winner-title {
953
949
  margin: 0;
954
- font-size: 22px;
950
+ font-size: var(--taskon-font-size-xxl);
955
951
  font-weight: 600;
956
- line-height: 28px;
952
+ line-height: 1.27;
957
953
  color: var(--taskon-color-text);
958
954
  }
959
955
 
@@ -982,6 +978,8 @@
982
978
  .taskon-quest-winner-error p {
983
979
  margin: 0;
984
980
  color: var(--taskon-color-text-secondary);
981
+ overflow-wrap: anywhere;
982
+ word-break: break-word;
985
983
  }
986
984
 
987
985
  /* ============================================================================
@@ -1015,9 +1013,9 @@
1015
1013
  .taskon-quest-winner-table th {
1016
1014
  padding: 12px 16px;
1017
1015
  text-align: left;
1018
- font-size: 14px;
1016
+ font-size: var(--taskon-font-size);
1019
1017
  font-weight: 500;
1020
- line-height: 20px;
1018
+ line-height: 1.43;
1021
1019
  color: var(--taskon-color-text-secondary);
1022
1020
  border-bottom: 1px solid var(--taskon-color-border);
1023
1021
  }
@@ -1028,9 +1026,9 @@
1028
1026
 
1029
1027
  .taskon-quest-winner-table td {
1030
1028
  padding: 12px 16px;
1031
- font-size: 14px;
1029
+ font-size: var(--taskon-font-size);
1032
1030
  font-weight: 500;
1033
- line-height: 20px;
1031
+ line-height: 1.43;
1034
1032
  color: var(--taskon-color-text);
1035
1033
  border-bottom: 1px solid var(--taskon-color-border-secondary);
1036
1034
  vertical-align: middle;
@@ -1132,9 +1130,9 @@
1132
1130
  padding: var(--taskon-spacing-xs) var(--taskon-spacing-sm);
1133
1131
  background: var(--taskon-color-bg-surface-strong);
1134
1132
  border-radius: var(--taskon-border-radius-sm);
1135
- font-size: 12px;
1133
+ font-size: var(--taskon-font-size-sm);
1136
1134
  font-weight: 500;
1137
- line-height: 16px;
1135
+ line-height: 1.33;
1138
1136
  white-space: nowrap;
1139
1137
  }
1140
1138
 
@@ -1210,9 +1208,9 @@
1210
1208
  white-space: nowrap;
1211
1209
  text-overflow: ellipsis;
1212
1210
  color: var(--taskon-color-text);
1213
- font-size: 22px;
1211
+ font-size: var(--taskon-font-size-xxl);
1214
1212
  font-weight: 500;
1215
- line-height: 28px;
1213
+ line-height: 1.27;
1216
1214
  }
1217
1215
 
1218
1216
  /* ============================================================================
@@ -1239,9 +1237,9 @@
1239
1237
  display: flex;
1240
1238
  align-items: center;
1241
1239
  color: var(--taskon-color-text-tertiary);
1242
- font-size: 16px;
1240
+ font-size: var(--taskon-font-size-lg);
1243
1241
  font-weight: 500;
1244
- line-height: 20px;
1242
+ line-height: 1.25;
1245
1243
  }
1246
1244
 
1247
1245
  /* Tip icon margin (controlled externally as TipPopover has no internal margin) */
@@ -1257,9 +1255,9 @@
1257
1255
 
1258
1256
  .taskon-quest-rewards-ranking-point-number {
1259
1257
  color: var(--taskon-color-primary);
1260
- font-size: 22px;
1258
+ font-size: var(--taskon-font-size-xxl);
1261
1259
  font-weight: 700;
1262
- line-height: 28px;
1260
+ line-height: 1.27;
1263
1261
  }
1264
1262
 
1265
1263
  .taskon-quest-rewards-ranking-point-tier {
@@ -1267,26 +1265,26 @@
1267
1265
  top: 100%;
1268
1266
  right: 0;
1269
1267
  color: var(--taskon-color-text-tertiary);
1270
- font-size: 13px;
1268
+ font-size: var(--taskon-font-size-sm);
1271
1269
  font-weight: 500;
1272
- line-height: 16px;
1270
+ line-height: 1.33;
1273
1271
  white-space: nowrap;
1274
1272
  }
1275
1273
 
1276
1274
  .taskon-quest-rewards-ranking-point-amount {
1277
1275
  margin-left: auto;
1278
1276
  color: var(--taskon-color-secondary);
1279
- font-size: 22px;
1277
+ font-size: var(--taskon-font-size-xxl);
1280
1278
  font-weight: 700;
1281
- line-height: 28px;
1279
+ line-height: 1.27;
1282
1280
  }
1283
1281
 
1284
1282
  .taskon-quest-rewards-ranking-point-tip {
1285
1283
  text-align: right;
1286
1284
  margin-left: auto;
1287
1285
  width: 50%;
1288
- font-size: 12px;
1289
- line-height: 16px;
1286
+ font-size: var(--taskon-font-size-sm);
1287
+ line-height: 1.33;
1290
1288
  color: var(--taskon-color-text-tertiary);
1291
1289
  }
1292
1290
 
@@ -1312,8 +1310,8 @@
1312
1310
 
1313
1311
  .taskon-quest-rewards-group-title {
1314
1312
  margin: 0;
1315
- font-size: 16px;
1316
- line-height: 20px;
1313
+ font-size: var(--taskon-font-size-lg);
1314
+ line-height: 1.25;
1317
1315
  font-weight: 500;
1318
1316
  color: var(--taskon-color-text);
1319
1317
  }
@@ -1351,8 +1349,8 @@
1351
1349
  gap: 8px;
1352
1350
  padding: 8px 16px;
1353
1351
  background: var(--taskon-color-bg-inset);
1354
- font-size: 16px;
1355
- line-height: 20px;
1352
+ font-size: var(--taskon-font-size-lg);
1353
+ line-height: 1.25;
1356
1354
  }
1357
1355
 
1358
1356
  .taskon-quest-rewards-card-tier--active {
@@ -1418,8 +1416,8 @@
1418
1416
 
1419
1417
  .taskon-quest-rewards-whitelist-desc-content {
1420
1418
  margin-top: 8px;
1421
- font-size: 14px;
1422
- line-height: 20px;
1419
+ font-size: var(--taskon-font-size);
1420
+ line-height: 1.43;
1423
1421
  color: var(--taskon-color-text-secondary);
1424
1422
  }
1425
1423
 
@@ -1435,8 +1433,8 @@
1435
1433
  }
1436
1434
 
1437
1435
  .taskon-quest-rewards-row-label {
1438
- font-size: 18px;
1439
- line-height: 24px;
1436
+ font-size: var(--taskon-font-size-xl);
1437
+ line-height: 1.33;
1440
1438
  font-weight: 500;
1441
1439
  color: var(--taskon-color-text);
1442
1440
  flex-shrink: 0;
@@ -1446,8 +1444,8 @@
1446
1444
  display: flex;
1447
1445
  align-items: center;
1448
1446
  gap: 8px;
1449
- font-size: 14px;
1450
- line-height: 16px;
1447
+ font-size: var(--taskon-font-size);
1448
+ line-height: 1.14;
1451
1449
  color: var(--taskon-color-text);
1452
1450
  }
1453
1451
 
@@ -1468,8 +1466,8 @@
1468
1466
  border: 1px solid var(--taskon-color-border);
1469
1467
  border-radius: var(--taskon-border-radius-sm);
1470
1468
  box-shadow: 0 4px 12px var(--taskon-color-bg-mask);
1471
- font-size: 12px;
1472
- line-height: 16px;
1469
+ font-size: var(--taskon-font-size-sm);
1470
+ line-height: 1.33;
1473
1471
  color: var(--taskon-color-text);
1474
1472
  z-index: 1000;
1475
1473
  white-space: nowrap;
@@ -1493,8 +1491,8 @@
1493
1491
  display: flex;
1494
1492
  align-items: center;
1495
1493
  gap: 8px;
1496
- font-size: 16px;
1497
- line-height: 20px;
1494
+ font-size: var(--taskon-font-size-lg);
1495
+ line-height: 1.25;
1498
1496
  font-weight: 600;
1499
1497
  margin-bottom: 20px;
1500
1498
  opacity: 0.9;
@@ -1519,20 +1517,20 @@
1519
1517
  }
1520
1518
 
1521
1519
  .taskon-quest-rewards-token-amount {
1522
- font-size: 22px;
1523
- line-height: 28px;
1520
+ font-size: var(--taskon-font-size-xxl);
1521
+ line-height: 1.27;
1524
1522
  color: var(--taskon-color-primary);
1525
1523
  }
1526
1524
 
1527
1525
  .taskon-quest-rewards-token-name {
1528
- font-size: 22px;
1529
- line-height: 28px;
1526
+ font-size: var(--taskon-font-size-xxl);
1527
+ line-height: 1.27;
1530
1528
  color: var(--taskon-color-primary);
1531
1529
  }
1532
1530
 
1533
1531
  .taskon-quest-rewards-token-usdt-tag {
1534
- font-size: 12px;
1535
- line-height: 14px;
1532
+ font-size: var(--taskon-font-size-sm);
1533
+ line-height: 1.17;
1536
1534
  padding: 2px 6px;
1537
1535
  background: var(--taskon-color-secondary-bg);
1538
1536
  border-radius: var(--taskon-border-radius-sm);
@@ -1547,15 +1545,15 @@
1547
1545
  }
1548
1546
 
1549
1547
  .taskon-quest-rewards-token-per-label {
1550
- font-size: 14px;
1551
- line-height: 16px;
1548
+ font-size: var(--taskon-font-size);
1549
+ line-height: 1.14;
1552
1550
  color: var(--taskon-color-text-tertiary);
1553
1551
  }
1554
1552
 
1555
1553
  .taskon-quest-rewards-token-per-value {
1556
1554
  margin-left: auto;
1557
- font-size: 14px;
1558
- line-height: 16px;
1555
+ font-size: var(--taskon-font-size);
1556
+ line-height: 1.14;
1559
1557
  color: var(--taskon-color-text-secondary);
1560
1558
  }
1561
1559
 
@@ -1563,8 +1561,8 @@
1563
1561
 
1564
1562
  .taskon-quest-rewards-token-brc20 {
1565
1563
  padding: 2px 6px;
1566
- font-size: 12px;
1567
- line-height: 14px;
1564
+ font-size: var(--taskon-font-size-sm);
1565
+ line-height: 1.17;
1568
1566
  font-weight: 500;
1569
1567
  color: var(--taskon-color-warning);
1570
1568
  background: var(--taskon-color-warning-bg);
@@ -1589,8 +1587,8 @@
1589
1587
  .taskon-quest-rewards-minted-nft-name,
1590
1588
  .taskon-quest-rewards-cap-name,
1591
1589
  .taskon-quest-rewards-whitelist-name {
1592
- font-size: 22px;
1593
- line-height: 28px;
1590
+ font-size: var(--taskon-font-size-xxl);
1591
+ line-height: 1.27;
1594
1592
  font-weight: 600;
1595
1593
  color: var(--taskon-color-text);
1596
1594
  overflow: hidden;
@@ -1600,8 +1598,8 @@
1600
1598
  }
1601
1599
 
1602
1600
  .taskon-quest-rewards-minted-nft-quantity {
1603
- font-size: 14px;
1604
- line-height: 16px;
1601
+ font-size: var(--taskon-font-size);
1602
+ line-height: 1.14;
1605
1603
  color: var(--taskon-color-text-secondary);
1606
1604
  }
1607
1605
 
@@ -1620,8 +1618,8 @@
1620
1618
  }
1621
1619
 
1622
1620
  .taskon-quest-rewards-popover-name {
1623
- font-size: 14px;
1624
- line-height: 18px;
1621
+ font-size: var(--taskon-font-size);
1622
+ line-height: 1.29;
1625
1623
  color: var(--taskon-color-text);
1626
1624
  word-break: break-all;
1627
1625
  }
@@ -1631,8 +1629,8 @@
1631
1629
  }
1632
1630
 
1633
1631
  .taskon-quest-rewards-popover-address-title {
1634
- font-size: 14px;
1635
- line-height: 18px;
1632
+ font-size: var(--taskon-font-size);
1633
+ line-height: 1.29;
1636
1634
  font-weight: 500;
1637
1635
  color: var(--taskon-color-text);
1638
1636
  }
@@ -1653,8 +1651,8 @@
1653
1651
 
1654
1652
  .taskon-quest-rewards-popover-address-text {
1655
1653
  flex: 1;
1656
- font-size: 12px;
1657
- line-height: 16px;
1654
+ font-size: var(--taskon-font-size-sm);
1655
+ line-height: 1.33;
1658
1656
  color: var(--taskon-color-text-tertiary);
1659
1657
  word-break: break-all;
1660
1658
  }
@@ -1694,16 +1692,16 @@
1694
1692
 
1695
1693
  .taskon-quest-rewards-points-amount,
1696
1694
  .taskon-quest-rewards-exp-amount {
1697
- font-size: 22px;
1698
- line-height: 28px;
1695
+ font-size: var(--taskon-font-size-xxl);
1696
+ line-height: 1.27;
1699
1697
  font-weight: 600;
1700
1698
  color: var(--taskon-color-primary);
1701
1699
  }
1702
1700
 
1703
1701
  .taskon-quest-rewards-points-name,
1704
1702
  .taskon-quest-rewards-exp-label {
1705
- font-size: 22px;
1706
- line-height: 28px;
1703
+ font-size: var(--taskon-font-size-xxl);
1704
+ line-height: 1.27;
1707
1705
  color: var(--taskon-color-text);
1708
1706
  }
1709
1707
 
@@ -1718,8 +1716,8 @@
1718
1716
  }
1719
1717
 
1720
1718
  .taskon-quest-rewards-discord-role-name {
1721
- font-size: 22px;
1722
- line-height: 28px;
1719
+ font-size: var(--taskon-font-size-xxl);
1720
+ line-height: 1.27;
1723
1721
  color: var(--taskon-color-link);
1724
1722
  cursor: pointer;
1725
1723
  }
@@ -1729,8 +1727,8 @@
1729
1727
  }
1730
1728
 
1731
1729
  .taskon-quest-rewards-discord-role-warning {
1732
- font-size: 12px;
1733
- line-height: 14px;
1730
+ font-size: var(--taskon-font-size-sm);
1731
+ line-height: 1.17;
1734
1732
  color: var(--taskon-color-warning);
1735
1733
  }
1736
1734
 
@@ -1739,8 +1737,8 @@
1739
1737
  ============================================================================ */
1740
1738
 
1741
1739
  .taskon-quest-rewards-winner-open {
1742
- font-size: 22px;
1743
- line-height: 28px;
1740
+ font-size: var(--taskon-font-size-xxl);
1741
+ line-height: 1.27;
1744
1742
  color: var(--taskon-color-secondary);
1745
1743
  }
1746
1744
 
@@ -1754,8 +1752,8 @@
1754
1752
  .taskon-quest-rewards-winner-fcfs-row {
1755
1753
  display: flex;
1756
1754
  align-items: baseline;
1757
- font-size: 18px;
1758
- line-height: 24px;
1755
+ font-size: var(--taskon-font-size-xl);
1756
+ line-height: 1.33;
1759
1757
  }
1760
1758
 
1761
1759
  .taskon-quest-rewards-winner-available {
@@ -1771,20 +1769,20 @@
1771
1769
  }
1772
1770
 
1773
1771
  .taskon-quest-rewards-winner-label {
1774
- font-size: 14px;
1775
- line-height: 16px;
1772
+ font-size: var(--taskon-font-size);
1773
+ line-height: 1.14;
1776
1774
  color: var(--taskon-color-text-secondary);
1777
1775
  }
1778
1776
 
1779
1777
  .taskon-quest-rewards-winner-count {
1780
- font-size: 22px;
1781
- line-height: 28px;
1778
+ font-size: var(--taskon-font-size-xxl);
1779
+ line-height: 1.27;
1782
1780
  color: var(--taskon-color-secondary);
1783
1781
  }
1784
1782
 
1785
1783
  .taskon-quest-rewards-winner-ranking {
1786
- font-size: 22px;
1787
- line-height: 28px;
1784
+ font-size: var(--taskon-font-size-xxl);
1785
+ line-height: 1.27;
1788
1786
  color: var(--taskon-color-secondary);
1789
1787
  }
1790
1788
 
@@ -1801,8 +1799,8 @@
1801
1799
  }
1802
1800
 
1803
1801
  .taskon-quest-rewards-gas-label {
1804
- font-size: 14px;
1805
- line-height: 16px;
1802
+ font-size: var(--taskon-font-size);
1803
+ line-height: 1.14;
1806
1804
  color: var(--taskon-color-text-tertiary);
1807
1805
  white-space: nowrap;
1808
1806
  }
@@ -1914,8 +1912,8 @@
1914
1912
  }
1915
1913
 
1916
1914
  .taskon-quest-rewards-estimated-title {
1917
- font-size: 14px;
1918
- line-height: 16px;
1915
+ font-size: var(--taskon-font-size);
1916
+ line-height: 1.14;
1919
1917
  font-weight: 500;
1920
1918
  color: var(--taskon-color-text-secondary);
1921
1919
  }
@@ -1924,8 +1922,8 @@
1924
1922
  display: flex;
1925
1923
  align-items: baseline;
1926
1924
  gap: 4px;
1927
- font-size: 18px;
1928
- line-height: 24px;
1925
+ font-size: var(--taskon-font-size-xl);
1926
+ line-height: 1.33;
1929
1927
  font-weight: 600;
1930
1928
  text-align: right;
1931
1929
  }
@@ -1939,22 +1937,22 @@
1939
1937
  }
1940
1938
 
1941
1939
  .taskon-quest-rewards-estimated-formula {
1942
- font-size: 12px;
1943
- line-height: 14px;
1940
+ font-size: var(--taskon-font-size-sm);
1941
+ line-height: 1.17;
1944
1942
  color: var(--taskon-color-text-tertiary);
1945
1943
  margin-top: 4px;
1946
1944
  }
1947
1945
 
1948
1946
  .taskon-quest-rewards-estimated-label {
1949
- font-size: 14px;
1950
- line-height: 16px;
1947
+ font-size: var(--taskon-font-size);
1948
+ line-height: 1.14;
1951
1949
  font-weight: 500;
1952
1950
  color: var(--taskon-color-text-secondary);
1953
1951
  }
1954
1952
 
1955
1953
  .taskon-quest-rewards-estimated-points {
1956
- font-size: 18px;
1957
- line-height: 24px;
1954
+ font-size: var(--taskon-font-size-xl);
1955
+ line-height: 1.33;
1958
1956
  font-weight: 700;
1959
1957
  color: var(--taskon-color-text);
1960
1958
  }
@@ -1964,8 +1962,8 @@
1964
1962
  align-items: center;
1965
1963
  justify-content: space-between;
1966
1964
  gap: 8px;
1967
- font-size: 14px;
1968
- line-height: 16px;
1965
+ font-size: var(--taskon-font-size);
1966
+ line-height: 1.14;
1969
1967
  color: var(--taskon-color-text-secondary);
1970
1968
  }
1971
1969
 
@@ -1991,8 +1989,8 @@
1991
1989
 
1992
1990
  .taskon-quest-rewards-estimated-mask-title {
1993
1991
  margin-top: 8px;
1994
- font-size: 14px;
1995
- line-height: 16px;
1992
+ font-size: var(--taskon-font-size);
1993
+ line-height: 1.14;
1996
1994
  font-weight: 500;
1997
1995
  color: var(--taskon-color-secondary);
1998
1996
  text-align: center;
@@ -2000,8 +1998,8 @@
2000
1998
 
2001
1999
  .taskon-quest-rewards-estimated-mask-subtitle {
2002
2000
  margin-top: 4px;
2003
- font-size: 12px;
2004
- line-height: 14px;
2001
+ font-size: var(--taskon-font-size-sm);
2002
+ line-height: 1.17;
2005
2003
  color: var(--taskon-color-text);
2006
2004
  text-align: center;
2007
2005
  }
@@ -2015,8 +2013,8 @@
2015
2013
  }
2016
2014
 
2017
2015
  .taskon-quest-rewards-bonus-title {
2018
- font-size: 16px;
2019
- line-height: 20px;
2016
+ font-size: var(--taskon-font-size-lg);
2017
+ line-height: 1.25;
2020
2018
  font-weight: 500;
2021
2019
  color: var(--taskon-color-text);
2022
2020
  }
@@ -2035,14 +2033,14 @@
2035
2033
 
2036
2034
  .taskon-quest-rewards-bonus-card .taskon-quest-rewards-row-label {
2037
2035
  color: var(--taskon-color-text-secondary);
2038
- font-size: 16px;
2039
- line-height: 20px;
2036
+ font-size: var(--taskon-font-size-lg);
2037
+ line-height: 1.25;
2040
2038
  }
2041
2039
 
2042
2040
  .taskon-quest-rewards-bonus-desc {
2043
2041
  color: var(--taskon-color-text-tertiary);
2044
- font-size: 14px;
2045
- line-height: 18px;
2042
+ font-size: var(--taskon-font-size);
2043
+ line-height: 1.29;
2046
2044
  text-align: right;
2047
2045
  }
2048
2046
 
@@ -2051,7 +2049,7 @@
2051
2049
  align-items: flex-end;
2052
2050
  color: var(--taskon-color-text);
2053
2051
  text-align: right;
2054
- font-size: 16px;
2052
+ font-size: var(--taskon-font-size-lg);
2055
2053
  font-weight: 600;
2056
2054
  line-height: normal;
2057
2055
  }
@@ -2061,7 +2059,7 @@
2061
2059
  }
2062
2060
 
2063
2061
  .taskon-quest-rewards-bonus-unit {
2064
- font-size: 14px;
2062
+ font-size: var(--taskon-font-size);
2065
2063
  font-weight: 400;
2066
2064
  }
2067
2065
 
@@ -2078,8 +2076,8 @@
2078
2076
  border: none;
2079
2077
  cursor: pointer;
2080
2078
  color: var(--taskon-color-link);
2081
- font-size: 14px;
2082
- line-height: 18px;
2079
+ font-size: var(--taskon-font-size);
2080
+ line-height: 1.29;
2083
2081
  transition: opacity 0.2s ease;
2084
2082
  }
2085
2083
 
@@ -2092,12 +2090,12 @@
2092
2090
  }
2093
2091
 
2094
2092
  .taskon-quest-rewards-view-leaderboard-text {
2095
- font-size: 14px;
2093
+ font-size: var(--taskon-font-size);
2096
2094
  font-weight: 400;
2097
2095
  }
2098
2096
 
2099
2097
  .taskon-quest-rewards-view-leaderboard-arrow {
2100
- font-size: 12px;
2098
+ font-size: var(--taskon-font-size-sm);
2101
2099
  margin-left: 4px;
2102
2100
  }
2103
2101
 
@@ -2109,14 +2107,14 @@
2109
2107
 
2110
2108
  .taskon-quest-leaderboard-title {
2111
2109
  margin: 0;
2112
- font-size: 24px;
2110
+ font-size: var(--taskon-font-size-xxxl);
2113
2111
  font-weight: 600;
2114
2112
  color: var(--taskon-color-text);
2115
2113
  }
2116
2114
 
2117
2115
  .taskon-quest-leaderboard-subtitle {
2118
2116
  margin: 0;
2119
- font-size: 14px;
2117
+ font-size: var(--taskon-font-size);
2120
2118
  color: var(--taskon-color-text-secondary);
2121
2119
  }
2122
2120
 
@@ -2130,6 +2128,12 @@
2130
2128
  color: var(--taskon-color-text-secondary);
2131
2129
  }
2132
2130
 
2131
+ .taskon-quest-leaderboard-error p {
2132
+ margin: 0;
2133
+ overflow-wrap: anywhere;
2134
+ word-break: break-word;
2135
+ }
2136
+
2133
2137
  .taskon-quest-leaderboard-table {
2134
2138
  margin-top: 8px;
2135
2139
  }
@@ -2216,7 +2220,7 @@
2216
2220
  .taskon-quest-leaderboard-rank {
2217
2221
  display: inline-flex;
2218
2222
  align-items: center;
2219
- font-size: 14px;
2223
+ font-size: var(--taskon-font-size);
2220
2224
  font-weight: 500;
2221
2225
  color: var(--taskon-color-text);
2222
2226
  }
@@ -2224,7 +2228,7 @@
2224
2228
  /* Unranked / N/A 状态 */
2225
2229
 
2226
2230
  .taskon-quest-leaderboard-rank--unranked {
2227
- font-size: 14px;
2231
+ font-size: var(--taskon-font-size);
2228
2232
  font-weight: 500;
2229
2233
  color: var(--taskon-color-text-tertiary);
2230
2234
  }
@@ -2240,7 +2244,7 @@
2240
2244
  /* 层级列 */
2241
2245
 
2242
2246
  .taskon-quest-leaderboard-tier {
2243
- font-size: 14px;
2247
+ font-size: var(--taskon-font-size);
2244
2248
  font-weight: 500;
2245
2249
  color: var(--taskon-color-text);
2246
2250
  }
@@ -2258,7 +2262,7 @@
2258
2262
 
2259
2263
  .taskon-quest-leaderboard-user-badge {
2260
2264
  padding: 2px 8px;
2261
- font-size: 12px;
2265
+ font-size: var(--taskon-font-size-sm);
2262
2266
  font-weight: 600;
2263
2267
  color: var(--taskon-color-text-on-primary);
2264
2268
  background: var(--taskon-color-secondary);
@@ -2266,7 +2270,7 @@
2266
2270
  }
2267
2271
 
2268
2272
  .taskon-quest-leaderboard-user-name {
2269
- font-size: 14px;
2273
+ font-size: var(--taskon-font-size);
2270
2274
  color: var(--taskon-color-text);
2271
2275
  overflow: hidden;
2272
2276
  text-overflow: ellipsis;
@@ -2276,7 +2280,7 @@
2276
2280
  /* 积分 */
2277
2281
 
2278
2282
  .taskon-quest-leaderboard-points {
2279
- font-size: 14px;
2283
+ font-size: var(--taskon-font-size);
2280
2284
  font-weight: 500;
2281
2285
  color: var(--taskon-color-text);
2282
2286
  }
@@ -2291,25 +2295,25 @@
2291
2295
  }
2292
2296
 
2293
2297
  .taskon-quest-leaderboard-reward-type {
2294
- font-size: 14px;
2298
+ font-size: var(--taskon-font-size);
2295
2299
  font-weight: 600;
2296
2300
  color: var(--taskon-color-text);
2297
2301
  }
2298
2302
 
2299
2303
  .taskon-quest-leaderboard-reward {
2300
- font-size: 14px;
2304
+ font-size: var(--taskon-font-size);
2301
2305
  font-weight: 600;
2302
2306
  color: var(--taskon-color-primary);
2303
2307
  }
2304
2308
 
2305
2309
  .taskon-quest-leaderboard-not-qualified {
2306
- font-size: 14px;
2310
+ font-size: var(--taskon-font-size);
2307
2311
  font-weight: 600;
2308
2312
  color: var(--taskon-color-text-tertiary);
2309
2313
  }
2310
2314
 
2311
2315
  .taskon-quest-leaderboard-no-reward {
2312
- font-size: 14px;
2316
+ font-size: var(--taskon-font-size);
2313
2317
  color: var(--taskon-color-text-tertiary);
2314
2318
  }
2315
2319
  /**
@@ -2385,9 +2389,9 @@
2385
2389
  height: 20px;
2386
2390
  padding: 0 8px;
2387
2391
  border-radius: var(--taskon-border-radius-lg);
2388
- font-size: 12px;
2392
+ font-size: var(--taskon-font-size-sm);
2389
2393
  font-weight: 600;
2390
- line-height: 16px;
2394
+ line-height: 1.33;
2391
2395
  text-transform: uppercase;
2392
2396
  }
2393
2397
 
@@ -2417,9 +2421,9 @@
2417
2421
  /* Card message text (for simple messages) */
2418
2422
 
2419
2423
  .taskon-quest-footer-card-message {
2420
- font-size: 16px;
2424
+ font-size: var(--taskon-font-size-lg);
2421
2425
  font-weight: 600;
2422
- line-height: 24px;
2426
+ line-height: 1.5;
2423
2427
  color: var(--taskon-color-text);
2424
2428
  }
2425
2429
 
@@ -2442,15 +2446,15 @@
2442
2446
  .taskon-quest-footer-title {
2443
2447
  font-size: 20px;
2444
2448
  font-weight: 600;
2445
- line-height: 28px;
2449
+ line-height: 1.4;
2446
2450
  color: var(--taskon-color-text);
2447
2451
  }
2448
2452
 
2449
2453
  .taskon-quest-footer-desc {
2450
2454
  margin-top: 2px;
2451
- font-size: 14px;
2455
+ font-size: var(--taskon-font-size);
2452
2456
  font-weight: 500;
2453
- line-height: 18px;
2457
+ line-height: 1.29;
2454
2458
  color: var(--taskon-color-text-tertiary);
2455
2459
  }
2456
2460
 
@@ -2466,7 +2470,7 @@
2466
2470
  .taskon-quest-footer-connect-btn {
2467
2471
  width: 100%;
2468
2472
  padding: 12px 24px;
2469
- font-size: 16px;
2473
+ font-size: var(--taskon-font-size-lg);
2470
2474
  font-weight: 600;
2471
2475
  color: var(--taskon-color-text-on-primary);
2472
2476
  background-color: var(--taskon-color-primary);
@@ -2487,7 +2491,7 @@
2487
2491
  .taskon-quest-footer-complete-btn {
2488
2492
  width: 100%;
2489
2493
  padding: 12px 24px;
2490
- font-size: 16px;
2494
+ font-size: var(--taskon-font-size-lg);
2491
2495
  font-weight: 600;
2492
2496
  color: var(--taskon-color-text-on-primary);
2493
2497
  background-color: var(--taskon-color-primary);
@@ -2547,7 +2551,7 @@
2547
2551
  }
2548
2552
 
2549
2553
  .taskon-quest-footer-earned-hint {
2550
- font-size: 14px;
2554
+ font-size: var(--taskon-font-size);
2551
2555
  font-weight: 500;
2552
2556
  color: var(--taskon-color-text-tertiary);
2553
2557
  }
@@ -2602,14 +2606,14 @@
2602
2606
  }
2603
2607
 
2604
2608
  .taskon-quest-footer-earned-single-type {
2605
- font-size: 18px;
2609
+ font-size: var(--taskon-font-size-xl);
2606
2610
  font-weight: 600;
2607
- line-height: 24px;
2611
+ line-height: 1.33;
2608
2612
  color: var(--taskon-color-text);
2609
2613
  }
2610
2614
 
2611
2615
  .taskon-quest-footer-earned-single-name {
2612
- font-size: 12px;
2616
+ font-size: var(--taskon-font-size-sm);
2613
2617
  font-weight: 500;
2614
2618
  line-height: normal;
2615
2619
  color: var(--taskon-color-text-disabled);
@@ -2625,9 +2629,9 @@
2625
2629
  }
2626
2630
 
2627
2631
  .taskon-quest-footer-earned-multi-text {
2628
- font-size: 16px;
2632
+ font-size: var(--taskon-font-size-lg);
2629
2633
  font-weight: 600;
2630
- line-height: 24px;
2634
+ line-height: 1.5;
2631
2635
  color: var(--taskon-color-text);
2632
2636
  }
2633
2637
 
@@ -2640,9 +2644,9 @@
2640
2644
  }
2641
2645
 
2642
2646
  .taskon-quest-footer-earned-redirect-text {
2643
- font-size: 16px;
2647
+ font-size: var(--taskon-font-size-lg);
2644
2648
  font-weight: 600;
2645
- line-height: 24px;
2649
+ line-height: 1.5;
2646
2650
  color: var(--taskon-color-text);
2647
2651
  flex: 1;
2648
2652
  }
@@ -2688,7 +2692,7 @@
2688
2692
  display: flex;
2689
2693
  align-items: center;
2690
2694
  gap: 4px;
2691
- font-size: 18px;
2695
+ font-size: var(--taskon-font-size-xl);
2692
2696
  }
2693
2697
 
2694
2698
  .taskon-quest-footer-reward-info img {
@@ -2718,7 +2722,7 @@
2718
2722
  display: flex;
2719
2723
  align-items: center;
2720
2724
  gap: 4px;
2721
- font-size: 14px;
2725
+ font-size: var(--taskon-font-size);
2722
2726
  color: var(--taskon-color-text-tertiary);
2723
2727
  cursor: pointer;
2724
2728
  transition: color 0.2s ease;
@@ -2738,7 +2742,7 @@
2738
2742
 
2739
2743
  .taskon-quest-footer-claim-btn {
2740
2744
  padding: 4px 12px;
2741
- font-size: 14px;
2745
+ font-size: var(--taskon-font-size);
2742
2746
  font-weight: 600;
2743
2747
  color: var(--taskon-color-text-on-primary);
2744
2748
  background-color: var(--taskon-color-primary);
@@ -2775,7 +2779,7 @@
2775
2779
  ============================================================================ */
2776
2780
 
2777
2781
  .taskon-quest-footer-earned-more-text {
2778
- font-size: 14px;
2782
+ font-size: var(--taskon-font-size);
2779
2783
  font-weight: 600;
2780
2784
  color: var(--taskon-color-text);
2781
2785
  }
@@ -2805,7 +2809,7 @@
2805
2809
  display: inline-flex;
2806
2810
  align-items: center;
2807
2811
  padding: 2px 6px;
2808
- font-size: 12px;
2812
+ font-size: var(--taskon-font-size-sm);
2809
2813
  font-weight: 500;
2810
2814
  color: var(--taskon-color-text-on-primary);
2811
2815
  background-color: var(--taskon-color-primary);
@@ -2835,7 +2839,7 @@
2835
2839
  display: flex;
2836
2840
  align-items: center;
2837
2841
  gap: 4px;
2838
- font-size: 14px;
2842
+ font-size: var(--taskon-font-size);
2839
2843
  }
2840
2844
 
2841
2845
  .taskon-quest-footer-reward-tx-label {
@@ -2857,7 +2861,7 @@
2857
2861
 
2858
2862
  .taskon-quest-footer-reward-dropping {
2859
2863
  margin-top: 4px;
2860
- font-size: 14px;
2864
+ font-size: var(--taskon-font-size);
2861
2865
  color: var(--taskon-color-text-tertiary);
2862
2866
  }
2863
2867
 
@@ -2885,7 +2889,7 @@
2885
2889
  }
2886
2890
 
2887
2891
  .taskon-quest-footer-detail-title {
2888
- font-size: 22px;
2892
+ font-size: var(--taskon-font-size-xxl);
2889
2893
  font-weight: 600;
2890
2894
  color: var(--taskon-color-text);
2891
2895
  margin: 0 0 20px 0;
@@ -2910,7 +2914,7 @@
2910
2914
  }
2911
2915
 
2912
2916
  .taskon-quest-footer-selection-label {
2913
- font-size: 16px;
2917
+ font-size: var(--taskon-font-size-lg);
2914
2918
  font-weight: 500;
2915
2919
  color: var(--taskon-color-text-secondary);
2916
2920
  }
@@ -2934,8 +2938,8 @@
2934
2938
  display: flex;
2935
2939
  align-items: center;
2936
2940
  gap: 6px;
2937
- font-size: 14px;
2938
- line-height: 18px;
2941
+ font-size: var(--taskon-font-size);
2942
+ line-height: 1.29;
2939
2943
  color: var(--taskon-color-text-tertiary);
2940
2944
  }
2941
2945
 
@@ -2950,9 +2954,9 @@
2950
2954
  display: flex;
2951
2955
  align-items: center;
2952
2956
  gap: 8px;
2953
- font-size: 14px;
2957
+ font-size: var(--taskon-font-size);
2954
2958
  font-weight: 500;
2955
- line-height: 16px;
2959
+ line-height: 1.14;
2956
2960
  color: var(--taskon-color-text);
2957
2961
  }
2958
2962
 
@@ -3029,7 +3033,7 @@
3029
3033
  }
3030
3034
 
3031
3035
  .taskon-quest-footer-detail-bonus-label {
3032
- font-size: 16px;
3036
+ font-size: var(--taskon-font-size-lg);
3033
3037
  font-weight: 500;
3034
3038
  color: var(--taskon-color-text-secondary);
3035
3039
  }
@@ -3040,7 +3044,7 @@
3040
3044
  }
3041
3045
 
3042
3046
  .taskon-quest-footer-detail-bonus-item {
3043
- font-size: 14px;
3047
+ font-size: var(--taskon-font-size);
3044
3048
  font-weight: 600;
3045
3049
  text-align: right;
3046
3050
  color: var(--taskon-color-text);
@@ -3090,15 +3094,17 @@ a.taskon-quest-footer-action-btn {
3090
3094
  .taskon-task-validation-dialog-message {
3091
3095
  margin: 0;
3092
3096
  margin-bottom: 16px;
3093
- font-size: 16px;
3097
+ font-size: var(--taskon-font-size-lg);
3094
3098
  line-height: 1.5;
3095
3099
  color: var(--taskon-color-text);
3100
+ overflow-wrap: anywhere;
3101
+ word-break: break-word;
3096
3102
  }
3097
3103
 
3098
3104
  .taskon-task-validation-dialog-progress {
3099
3105
  margin: 0;
3100
3106
  margin-bottom: 16px;
3101
- font-size: 14px;
3107
+ font-size: var(--taskon-font-size);
3102
3108
  line-height: 1.5;
3103
3109
  color: var(--taskon-color-text-tertiary);
3104
3110
  }
@@ -3111,7 +3117,7 @@ a.taskon-quest-footer-action-btn {
3111
3117
  border-radius: var(--taskon-border-radius);
3112
3118
  background: var(--taskon-color-primary);
3113
3119
  color: var(--taskon-color-text-on-primary);
3114
- font-size: 16px;
3120
+ font-size: var(--taskon-font-size-lg);
3115
3121
  font-weight: 600;
3116
3122
  cursor: pointer;
3117
3123
  transition: opacity 0.2s ease;
@@ -3136,7 +3142,7 @@ a.taskon-quest-footer-action-btn {
3136
3142
  .taskon-reward-bind-tip {
3137
3143
  margin: 0;
3138
3144
  margin-bottom: 20px;
3139
- font-size: 14px;
3145
+ font-size: var(--taskon-font-size);
3140
3146
  line-height: 1.6;
3141
3147
  color: var(--taskon-color-text-tertiary);
3142
3148
  }
@@ -3163,7 +3169,7 @@ a.taskon-quest-footer-action-btn {
3163
3169
  }
3164
3170
 
3165
3171
  .taskon-reward-bind-item-label {
3166
- font-size: 14px;
3172
+ font-size: var(--taskon-font-size);
3167
3173
  font-weight: 500;
3168
3174
  color: var(--taskon-color-text);
3169
3175
  }
@@ -3172,7 +3178,7 @@ a.taskon-quest-footer-action-btn {
3172
3178
  display: flex;
3173
3179
  align-items: center;
3174
3180
  gap: 6px;
3175
- font-size: 13px;
3181
+ font-size: var(--taskon-font-size-sm);
3176
3182
  color: var(--taskon-color-secondary);
3177
3183
  }
3178
3184
 
@@ -3185,7 +3191,7 @@ a.taskon-quest-footer-action-btn {
3185
3191
  border-radius: var(--taskon-border-radius-sm);
3186
3192
  background: var(--taskon-color-primary);
3187
3193
  color: var(--taskon-color-text-on-primary);
3188
- font-size: 13px;
3194
+ font-size: var(--taskon-font-size-sm);
3189
3195
  font-weight: 600;
3190
3196
  cursor: pointer;
3191
3197
  transition: opacity 0.2s ease;
@@ -3223,7 +3229,7 @@ a.taskon-quest-footer-action-btn {
3223
3229
  border-radius: var(--taskon-border-radius);
3224
3230
  background: transparent;
3225
3231
  color: var(--taskon-color-text);
3226
- font-size: 14px;
3232
+ font-size: var(--taskon-font-size);
3227
3233
  font-weight: 500;
3228
3234
  cursor: pointer;
3229
3235
  transition: all 0.2s ease;
@@ -3258,7 +3264,7 @@ a.taskon-quest-footer-action-btn {
3258
3264
  .taskon-discord-bind-dialog-desc {
3259
3265
  margin: 0;
3260
3266
  margin-bottom: 24px;
3261
- font-size: 14px;
3267
+ font-size: var(--taskon-font-size);
3262
3268
  line-height: 1.6;
3263
3269
  color: var(--taskon-color-text-tertiary);
3264
3270
  }
@@ -3274,7 +3280,7 @@ a.taskon-quest-footer-action-btn {
3274
3280
  width: 100%;
3275
3281
  padding: 14px 24px;
3276
3282
  border-radius: var(--taskon-border-radius);
3277
- font-size: 14px;
3283
+ font-size: var(--taskon-font-size);
3278
3284
  font-weight: 600;
3279
3285
  cursor: pointer;
3280
3286
  transition: all 0.2s ease;
@@ -3326,9 +3332,9 @@ a.taskon-quest-footer-action-btn {
3326
3332
  /* Winners 标签 */
3327
3333
 
3328
3334
  .taskon-quest-winners-row-label {
3329
- font-size: 18px;
3335
+ font-size: var(--taskon-font-size-xl);
3330
3336
  font-weight: 500;
3331
- line-height: 23px;
3337
+ line-height: 1.28;
3332
3338
  color: var(--taskon-color-text);
3333
3339
  }
3334
3340
 
@@ -3337,9 +3343,9 @@ a.taskon-quest-footer-action-btn {
3337
3343
  .taskon-quest-winners-row-count {
3338
3344
  flex: 1;
3339
3345
  margin-left: 8px;
3340
- font-size: 18px;
3346
+ font-size: var(--taskon-font-size-xl);
3341
3347
  font-weight: 600;
3342
- line-height: 23px;
3348
+ line-height: 1.28;
3343
3349
  text-align: left;
3344
3350
  color: var(--taskon-color-secondary);
3345
3351
  }
@@ -3383,7 +3389,7 @@ a.taskon-quest-footer-action-btn {
3383
3389
  gap: 8px;
3384
3390
  padding: 16px;
3385
3391
  background: var(--taskon-color-bg-surface-strong);
3386
- font-size: 16px;
3392
+ font-size: var(--taskon-font-size-lg);
3387
3393
  font-weight: 500;
3388
3394
  color: var(--taskon-color-text-secondary);
3389
3395
  text-decoration: none;
@@ -3424,7 +3430,7 @@ a.taskon-quest-footer-action-btn {
3424
3430
  }
3425
3431
 
3426
3432
  .taskon-winners-pow-info {
3427
- font-size: 12px;
3433
+ font-size: var(--taskon-font-size-sm);
3428
3434
  line-height: 1.5;
3429
3435
  color: var(--taskon-color-warning);
3430
3436
  margin-bottom: 16px;
@@ -3457,7 +3463,7 @@ a.taskon-quest-footer-action-btn {
3457
3463
  display: flex;
3458
3464
  align-items: center;
3459
3465
  justify-content: space-between;
3460
- font-size: 16px;
3466
+ font-size: var(--taskon-font-size-lg);
3461
3467
  }
3462
3468
 
3463
3469
  .taskon-winners-card-label {
@@ -3510,7 +3516,7 @@ a.taskon-quest-footer-action-btn {
3510
3516
 
3511
3517
  .taskon-quest {
3512
3518
  container-type: inline-size;
3513
- font-size: 16px;
3519
+ font-size: var(--taskon-font-size-lg);
3514
3520
  line-height: 1.5;
3515
3521
  color: var(--taskon-color-text);
3516
3522
  }
@@ -3677,13 +3683,15 @@ a.taskon-quest-footer-action-btn {
3677
3683
 
3678
3684
  .taskon-quest-error-message {
3679
3685
  color: var(--taskon-color-error);
3680
- font-size: 14px;
3686
+ font-size: var(--taskon-font-size);
3687
+ overflow-wrap: anywhere;
3688
+ word-break: break-word;
3681
3689
  }
3682
3690
 
3683
3691
  .taskon-quest-error-retry {
3684
3692
  margin-top: 8px;
3685
3693
  padding: 8px 16px;
3686
- font-size: 14px;
3694
+ font-size: var(--taskon-font-size);
3687
3695
  color: var(--taskon-color-text);
3688
3696
  background-color: var(--taskon-color-primary);
3689
3697
  border: none;
@@ -3706,7 +3714,7 @@ a.taskon-quest-footer-action-btn {
3706
3714
  justify-content: center;
3707
3715
  padding: 48px 24px;
3708
3716
  color: var(--taskon-color-text-tertiary);
3709
- font-size: 14px;
3717
+ font-size: var(--taskon-font-size);
3710
3718
  }
3711
3719
 
3712
3720
  /* ============================================================================
@@ -3773,7 +3781,7 @@ a.taskon-quest-footer-action-btn {
3773
3781
  margin: 0;
3774
3782
  font-size: 28px;
3775
3783
  font-weight: 600;
3776
- line-height: 38px;
3784
+ line-height: 1.36;
3777
3785
  color: var(--taskon-color-text);
3778
3786
  }
3779
3787
 
@@ -3808,9 +3816,9 @@ a.taskon-quest-footer-action-btn {
3808
3816
  }
3809
3817
 
3810
3818
  .taskon-quest-countdown-label {
3811
- font-size: 14px;
3819
+ font-size: var(--taskon-font-size);
3812
3820
  font-weight: 400;
3813
- line-height: 20px;
3821
+ line-height: 1.43;
3814
3822
  color: var(--taskon-color-text-secondary);
3815
3823
  }
3816
3824
 
@@ -3822,9 +3830,9 @@ a.taskon-quest-footer-action-btn {
3822
3830
  }
3823
3831
 
3824
3832
  .taskon-quest-countdown-value {
3825
- font-size: 14px;
3833
+ font-size: var(--taskon-font-size);
3826
3834
  font-weight: 600;
3827
- line-height: 20px;
3835
+ line-height: 1.43;
3828
3836
  color: var(--taskon-color-primary);
3829
3837
  }
3830
3838
 
@@ -3839,16 +3847,16 @@ a.taskon-quest-footer-action-btn {
3839
3847
  flex-direction: column;
3840
3848
  gap: 2px;
3841
3849
  min-width: 0;
3842
- font-size: 14px;
3850
+ font-size: var(--taskon-font-size);
3843
3851
  font-weight: 500;
3844
- line-height: 20px;
3852
+ line-height: 1.43;
3845
3853
  color: var(--taskon-color-text-secondary);
3846
3854
  }
3847
3855
 
3848
3856
  .taskon-quest-time-range-timezone {
3849
- font-size: 12px;
3857
+ font-size: var(--taskon-font-size-sm);
3850
3858
  font-weight: 500;
3851
- line-height: 16px;
3859
+ line-height: 1.33;
3852
3860
  color: var(--taskon-color-text-tertiary);
3853
3861
  }
3854
3862
 
@@ -3899,9 +3907,9 @@ a.taskon-quest-footer-action-btn {
3899
3907
 
3900
3908
  .taskon-quest-desc-text {
3901
3909
  margin: 0;
3902
- font-size: 16px;
3910
+ font-size: var(--taskon-font-size-lg);
3903
3911
  font-weight: 400;
3904
- line-height: 24px;
3912
+ line-height: 1.5;
3905
3913
  color: var(--taskon-color-text-secondary);
3906
3914
  max-height: 120px;
3907
3915
  overflow: hidden;
@@ -3972,9 +3980,9 @@ a.taskon-quest-footer-action-btn {
3972
3980
  }
3973
3981
 
3974
3982
  .taskon-quest-desc-more {
3975
- font-size: 16px;
3983
+ font-size: var(--taskon-font-size-lg);
3976
3984
  font-weight: 600;
3977
- line-height: 24px;
3985
+ line-height: 1.5;
3978
3986
  color: var(--taskon-color-text);
3979
3987
  text-decoration: underline;
3980
3988
  text-decoration-skip-ink: none;
@@ -4017,9 +4025,9 @@ a.taskon-quest-footer-action-btn {
4017
4025
 
4018
4026
  .taskon-quest-tasks-title {
4019
4027
  margin: 0;
4020
- font-size: 24px;
4028
+ font-size: var(--taskon-font-size-xxxl);
4021
4029
  font-weight: 600;
4022
- line-height: 32px;
4030
+ line-height: 1.33;
4023
4031
  color: var(--taskon-color-text);
4024
4032
  }
4025
4033
 
@@ -4040,14 +4048,14 @@ a.taskon-quest-footer-action-btn {
4040
4048
  background: var(--taskon-color-bg-surface-strong);
4041
4049
  border: 1px solid var(--taskon-color-border-secondary);
4042
4050
  border-radius: var(--taskon-border-radius);
4043
- font-size: 18px;
4051
+ font-size: var(--taskon-font-size-xl);
4044
4052
  font-weight: 600;
4045
4053
  color: var(--taskon-color-text);
4046
4054
  }
4047
4055
 
4048
4056
  .taskon-quest-task-template {
4049
4057
  color: var(--taskon-color-text-disabled);
4050
- font-size: 14px;
4058
+ font-size: var(--taskon-font-size);
4051
4059
  font-weight: 500;
4052
4060
  }
4053
4061
 
@@ -4057,9 +4065,9 @@ a.taskon-quest-footer-action-btn {
4057
4065
  width: 100%;
4058
4066
  margin-top: var(--taskon-spacing-lg);
4059
4067
  padding: var(--taskon-spacing-md) var(--taskon-spacing-xl);
4060
- font-size: 18px;
4068
+ font-size: var(--taskon-font-size-xl);
4061
4069
  font-weight: 600;
4062
- line-height: 24px;
4070
+ line-height: 1.33;
4063
4071
  color: var(--taskon-color-text-on-primary);
4064
4072
  background-color: var(--taskon-color-primary);
4065
4073
  border: none;
@@ -4094,9 +4102,9 @@ a.taskon-quest-footer-action-btn {
4094
4102
 
4095
4103
  .taskon-quest-winners-section-title {
4096
4104
  margin: 0;
4097
- font-size: 24px;
4105
+ font-size: var(--taskon-font-size-xxxl);
4098
4106
  font-weight: 600;
4099
- line-height: 32px;
4107
+ line-height: 1.33;
4100
4108
  color: var(--taskon-color-text);
4101
4109
  }
4102
4110
 
@@ -4112,9 +4120,9 @@ a.taskon-quest-footer-action-btn {
4112
4120
 
4113
4121
  .taskon-quest-rewards-section-title {
4114
4122
  margin: 0;
4115
- font-size: 24px;
4123
+ font-size: var(--taskon-font-size-xxxl);
4116
4124
  font-weight: 600;
4117
- line-height: 32px;
4125
+ line-height: 1.33;
4118
4126
  color: var(--taskon-color-text);
4119
4127
  }
4120
4128
 
@@ -4130,9 +4138,9 @@ a.taskon-quest-footer-action-btn {
4130
4138
 
4131
4139
  .taskon-quest-rewards-title {
4132
4140
  margin: 0;
4133
- font-size: 24px;
4141
+ font-size: var(--taskon-font-size-xxxl);
4134
4142
  font-weight: 600;
4135
- line-height: 32px;
4143
+ line-height: 1.33;
4136
4144
  color: var(--taskon-color-text);
4137
4145
  }
4138
4146
 
@@ -4149,7 +4157,7 @@ a.taskon-quest-footer-action-btn {
4149
4157
  padding: var(--taskon-spacing-md);
4150
4158
  background-color: var(--taskon-color-border-secondary);
4151
4159
  border-radius: var(--taskon-border-radius-lg);
4152
- font-size: 16px;
4160
+ font-size: var(--taskon-font-size-lg);
4153
4161
  color: var(--taskon-color-text);
4154
4162
  }
4155
4163
 
@@ -4172,7 +4180,7 @@ a.taskon-quest-footer-action-btn {
4172
4180
  margin: 0;
4173
4181
  font-size: 20px;
4174
4182
  font-weight: 600;
4175
- line-height: 28px;
4183
+ line-height: 1.4;
4176
4184
  color: var(--taskon-color-text);
4177
4185
  }
4178
4186
 
@@ -4188,9 +4196,9 @@ a.taskon-quest-footer-action-btn {
4188
4196
 
4189
4197
  .taskon-quest-participants-title {
4190
4198
  margin: 0;
4191
- font-size: 24px;
4199
+ font-size: var(--taskon-font-size-xxxl);
4192
4200
  font-weight: 600;
4193
- line-height: 32px;
4201
+ line-height: 1.33;
4194
4202
  color: var(--taskon-color-text);
4195
4203
  }
4196
4204
 
@@ -4198,9 +4206,9 @@ a.taskon-quest-footer-action-btn {
4198
4206
  display: flex;
4199
4207
  justify-content: space-between;
4200
4208
  align-items: center;
4201
- font-size: 16px;
4209
+ font-size: var(--taskon-font-size-lg);
4202
4210
  font-weight: 500;
4203
- line-height: 24px;
4211
+ line-height: 1.5;
4204
4212
  }
4205
4213
 
4206
4214
  .taskon-quest-participants-label {
@@ -4248,8 +4256,8 @@ a.taskon-quest-footer-action-btn {
4248
4256
 
4249
4257
  .taskon-quest-countdown-label,
4250
4258
  .taskon-quest-countdown-value {
4251
- font-size: 16px;
4252
- line-height: 24px;
4259
+ font-size: var(--taskon-font-size-lg);
4260
+ line-height: 1.5;
4253
4261
  }
4254
4262
 
4255
4263
  .taskon-quest-countdown-divider {
@@ -4264,15 +4272,15 @@ a.taskon-quest-footer-action-btn {
4264
4272
  flex: 0 1 auto;
4265
4273
  flex-direction: row;
4266
4274
  gap: 8px;
4267
- font-size: 16px;
4275
+ font-size: var(--taskon-font-size-lg);
4268
4276
  font-weight: 400;
4269
- line-height: 24px;
4277
+ line-height: 1.5;
4270
4278
  }
4271
4279
 
4272
4280
  .taskon-quest-time-range-timezone {
4273
- font-size: 16px;
4281
+ font-size: var(--taskon-font-size-lg);
4274
4282
  font-weight: 400;
4275
- line-height: 24px;
4283
+ line-height: 1.5;
4276
4284
  color: var(--taskon-color-text-secondary);
4277
4285
  }
4278
4286
 
@@ -4351,8 +4359,8 @@ a.taskon-quest-footer-action-btn {
4351
4359
 
4352
4360
  .taskon-quest-countdown-label,
4353
4361
  .taskon-quest-countdown-value {
4354
- font-size: 16px;
4355
- line-height: 24px;
4362
+ font-size: var(--taskon-font-size-lg);
4363
+ line-height: 1.5;
4356
4364
  }
4357
4365
 
4358
4366
  .taskon-quest-countdown-divider {
@@ -4367,15 +4375,15 @@ a.taskon-quest-footer-action-btn {
4367
4375
  flex: 0 1 auto;
4368
4376
  flex-direction: row;
4369
4377
  gap: 8px;
4370
- font-size: 16px;
4378
+ font-size: var(--taskon-font-size-lg);
4371
4379
  font-weight: 400;
4372
- line-height: 24px;
4380
+ line-height: 1.5;
4373
4381
  }
4374
4382
 
4375
4383
  .taskon-quest-time-range-timezone {
4376
- font-size: 16px;
4384
+ font-size: var(--taskon-font-size-lg);
4377
4385
  font-weight: 400;
4378
- line-height: 24px;
4386
+ line-height: 1.5;
4379
4387
  color: var(--taskon-color-text-secondary);
4380
4388
  }
4381
4389
 
@@ -4428,7 +4436,6 @@ a.taskon-quest-footer-action-btn {
4428
4436
  ============================================================================ */
4429
4437
 
4430
4438
  .taskon-quest-blindbox-dialog-wrapper {
4431
- background: var(--taskon-color-bg-surface);
4432
4439
  padding: 0;
4433
4440
  width: auto;
4434
4441
  max-width: 560px;
@@ -4438,13 +4445,10 @@ a.taskon-quest-footer-action-btn {
4438
4445
  padding: 0;
4439
4446
  }
4440
4447
 
4441
- .taskon-quest-blindbox-reward-wrapper {
4442
- background: var(--taskon-color-bg-surface);
4443
- padding: 0;
4444
- width: auto;
4448
+ .taskon-quest-blindbox-dialog-wrapper--result {
4445
4449
  max-width: 560px;
4446
4450
  }
4447
4451
 
4448
- .taskon-quest-blindbox-reward-wrapper .taskon-dialog-body {
4452
+ .taskon-quest-blindbox-dialog-wrapper--result .taskon-dialog-body {
4449
4453
  padding: 0;
4450
4454
  }