@domternal/theme 0.6.2 → 0.7.1

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.
@@ -12,8 +12,37 @@
12
12
  --dm-accent-surface: rgba(37, 99, 235, 0.1);
13
13
  --dm-focus-color: rgba(66, 133, 244, 0.3);
14
14
  --dm-selection: rgba(66, 133, 244, 0.2);
15
+ --dm-scrollbar-thumb: rgba(0, 0, 0, 0.18);
16
+ --dm-scrollbar-thumb-hover: rgba(0, 0, 0, 0.28);
17
+ --dm-z-handle: 25;
18
+ --dm-z-popover: 50;
19
+ --dm-block-handle-gutter: 3rem;
20
+ --dm-block-handle-left: -0.5rem;
21
+ --dm-block-inline-padding: 0.375rem;
22
+ --dm-block-children-indent: 1.5rem;
23
+ --dm-popover-shadow: 0 10px 25px rgba(0, 0, 0, 0.08), 0 4px 10px rgba(0, 0, 0, 0.04);
15
24
  --dm-code-surface: #f0f0f0;
16
25
  --dm-code-color: inherit;
26
+ --dm-block-bg-gray: #f1f1ef;
27
+ --dm-block-bg-brown: #f3eeee;
28
+ --dm-block-bg-orange: #f8ecdf;
29
+ --dm-block-bg-yellow: #faf3dd;
30
+ --dm-block-bg-green: #eef3ed;
31
+ --dm-block-bg-blue: #e9f3f7;
32
+ --dm-block-bg-purple: #f6f3f8;
33
+ --dm-block-bg-pink: #f9f2f5;
34
+ --dm-block-bg-red: #faecec;
35
+ --dm-block-text-gray: #787774;
36
+ --dm-block-text-brown: #976d57;
37
+ --dm-block-text-orange: #cc782f;
38
+ --dm-block-text-yellow: #c29343;
39
+ --dm-block-text-green: #548164;
40
+ --dm-block-text-blue: #487ca5;
41
+ --dm-block-text-purple: #8a67ab;
42
+ --dm-block-text-pink: #b35488;
43
+ --dm-block-text-red: #c4554d;
44
+ --dm-block-selected-halo: rgba(112, 207, 248, 0.25);
45
+ --dm-block-context-active-bg: rgba(55, 53, 47, 0.06);
17
46
  --dm-editor-bg: var(--dm-bg);
18
47
  --dm-editor-text: var(--dm-text);
19
48
  --dm-editor-font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
@@ -58,6 +87,8 @@
58
87
  --dm-details-border: 1px solid var(--dm-border-color);
59
88
  --dm-details-bg: var(--dm-surface);
60
89
  --dm-details-summary-font-weight: 600;
90
+ --dm-task-checkbox-left: -1.15em;
91
+ --dm-task-checkbox-top: 0.45em;
61
92
  }
62
93
 
63
94
  .dm-toolbar {
@@ -77,6 +108,66 @@
77
108
  --dm-separator-margin: 0.375rem;
78
109
  }
79
110
 
111
+ :root {
112
+ --dm-toc-tick-h1-width: 18px;
113
+ --dm-toc-tick-h2-width: 12px;
114
+ --dm-toc-tick-h3-width: 8px;
115
+ --dm-toc-tick-h4-width: 6px;
116
+ --dm-toc-tick-h5-width: 5px;
117
+ --dm-toc-tick-h6-width: 4px;
118
+ --dm-toc-tick-height: 2px;
119
+ --dm-toc-tick-radius: 1px;
120
+ --dm-toc-tick-gap: 10px;
121
+ --dm-toc-tick-color: rgba(55, 53, 47, 0.4);
122
+ --dm-toc-tick-hover-color: rgba(55, 53, 47, 0.7);
123
+ --dm-toc-tick-active-color: rgba(55, 53, 47, 0.95);
124
+ --dm-toc-padding-block: 12px;
125
+ --dm-toc-padding-inline: 8px;
126
+ --dm-toc-right-offset: 24px;
127
+ --dm-toc-z-index: 10;
128
+ --dm-toc-editor-top: 1rem;
129
+ --dm-toc-page-offset: 8px;
130
+ --dm-toc-card-viewport-margin: 16px;
131
+ --dm-toc-card-bg: rgba(255, 255, 255, 0.98);
132
+ --dm-toc-card-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
133
+ --dm-toc-card-radius: 6px;
134
+ --dm-toc-card-border: 1px solid rgba(0, 0, 0, 0.06);
135
+ --dm-toc-card-min-width: 180px;
136
+ --dm-toc-card-max-width: 260px;
137
+ --dm-toc-card-padding-block: 6px;
138
+ --dm-toc-card-offset: 8px;
139
+ --dm-toc-card-transition: 180ms;
140
+ --dm-toc-row-padding-block: 4px;
141
+ --dm-toc-row-padding-inline-start: 12px;
142
+ --dm-toc-row-padding-inline-end: 16px;
143
+ --dm-toc-row-indent: 14px;
144
+ --dm-toc-row-color: rgba(55, 53, 47, 0.7);
145
+ --dm-toc-row-hover-bg: rgba(0, 0, 0, 0.04);
146
+ --dm-toc-row-active-color: rgba(55, 53, 47, 0.95);
147
+ --dm-toc-row-active-weight: 600;
148
+ --dm-toc-row-font-size: 13px;
149
+ --dm-toc-row-line-height: 1.4;
150
+ --dm-toc-block-bg: rgba(0, 0, 0, 0.02);
151
+ --dm-toc-block-border: 1px solid rgba(0, 0, 0, 0.08);
152
+ --dm-toc-block-radius: 6px;
153
+ --dm-toc-block-padding-block: 12px;
154
+ --dm-toc-block-padding-inline: 16px;
155
+ --dm-toc-block-margin-block: 1rem;
156
+ --dm-toc-block-empty-color: rgba(55, 53, 47, 0.5);
157
+ --dm-toc-block-empty-font-style: italic;
158
+ --dm-toc-block-link-color: rgba(55, 53, 47, 0.8);
159
+ --dm-toc-block-link-hover-color: rgba(55, 53, 47, 1);
160
+ --dm-toc-block-link-hover-bg: rgba(0, 0, 0, 0.04);
161
+ --dm-toc-block-link-active-color: rgba(55, 53, 47, 0.95);
162
+ --dm-toc-block-link-active-weight: 600;
163
+ --dm-toc-block-link-padding-block: 4px;
164
+ --dm-toc-block-link-padding-inline: 8px;
165
+ --dm-toc-block-link-indent: 16px;
166
+ --dm-toc-block-link-radius: 3px;
167
+ --dm-toc-block-link-font-size: 0.9375rem;
168
+ --dm-toc-block-link-line-height: 1.5;
169
+ }
170
+
80
171
  .dm-editor .ProseMirror {
81
172
  position: relative;
82
173
  word-wrap: break-word;
@@ -265,6 +356,9 @@ img.ProseMirror-separator {
265
356
  opacity: 1;
266
357
  }
267
358
  }
359
+ .dm-editor .ProseMirror :where(p, h1, h2, h3, h4, h5, h6) {
360
+ padding-inline: var(--dm-block-inline-padding);
361
+ }
268
362
  .dm-editor .ProseMirror h1,
269
363
  .dm-editor .ProseMirror h2,
270
364
  .dm-editor .ProseMirror h3,
@@ -314,20 +408,27 @@ img.ProseMirror-separator {
314
408
  border-left: var(--dm-blockquote-border);
315
409
  color: var(--dm-blockquote-color);
316
410
  margin: 0.5em 0;
317
- padding: 0.1em 0 0.1em 0.8em;
411
+ padding: 0.1em var(--dm-block-inline-padding) 0.1em 0.8em;
318
412
  }
319
413
  .dm-editor .ProseMirror ul,
320
414
  .dm-editor .ProseMirror ol {
321
415
  margin: 0.75em 0;
322
416
  padding-left: 1.5em;
417
+ padding-right: var(--dm-block-inline-padding);
323
418
  }
324
- .dm-editor .ProseMirror ul li,
419
+ .dm-editor .ProseMirror ul:not([data-type=taskList]) li,
325
420
  .dm-editor .ProseMirror ol li {
326
421
  margin: 0.25em 0;
327
422
  }
328
- .dm-editor .ProseMirror ul li > p,
423
+ .dm-editor .ProseMirror ul:not([data-type=taskList]) li > p,
329
424
  .dm-editor .ProseMirror ol li > p {
330
425
  margin: 0.1em 0;
426
+ padding-inline: 0.3em 0;
427
+ }
428
+ .dm-editor .ProseMirror ul:not([data-type=taskList]) li > :not(p:first-child):not(ul):not(ol),
429
+ .dm-editor .ProseMirror ol li > :not(p:first-child):not(ul):not(ol) {
430
+ margin-inline-start: var(--dm-block-children-indent, 1.5rem);
431
+ margin-top: 0.25rem;
331
432
  }
332
433
  .dm-editor .ProseMirror hr {
333
434
  border: none;
@@ -355,11 +456,13 @@ img.ProseMirror-separator {
355
456
  .dm-editor .ProseMirror table {
356
457
  border: var(--dm-table-border);
357
458
  margin: 0.75em 0;
459
+ font-size: 0.9375rem;
460
+ line-height: 1.5;
358
461
  }
359
462
  .dm-editor .ProseMirror table td,
360
463
  .dm-editor .ProseMirror table th {
361
464
  border: var(--dm-table-border);
362
- padding: 0.5em 0.75em;
465
+ padding: 0.375em 0.625em;
363
466
  min-width: 100px;
364
467
  }
365
468
  .dm-editor .ProseMirror table th {
@@ -717,7 +820,7 @@ img.ProseMirror-separator {
717
820
  --dm-button-active-color: var(--dm-accent, #2563eb);
718
821
  --dm-button-disabled-opacity: 0.4;
719
822
  }
720
- .dm-bubble-menu .dm-toolbar-button svg {
823
+ .dm-bubble-menu .dm-toolbar-button svg:not(.dm-dropdown-caret) {
721
824
  width: 1rem;
722
825
  height: 1rem;
723
826
  }
@@ -752,21 +855,121 @@ img.ProseMirror-separator {
752
855
  position: absolute;
753
856
  display: flex;
754
857
  flex-direction: column;
755
- gap: var(--dm-toolbar-gap);
756
- padding: var(--dm-toolbar-padding);
757
- background: var(--dm-toolbar-bg);
758
- border: var(--dm-toolbar-border);
759
- border-radius: var(--dm-button-border-radius);
760
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
858
+ gap: 0.25rem;
859
+ min-width: 16rem;
860
+ max-height: 22rem;
861
+ overflow-y: auto;
862
+ padding: 0.375rem;
863
+ background: var(--dm-toolbar-bg, var(--dm-bg, #ffffff));
864
+ border: 1px solid var(--dm-border-color, #e5e7eb);
865
+ border-radius: var(--dm-toolbar-border-radius, 0.5rem);
866
+ box-shadow: var(--dm-popover-shadow, 0 10px 25px rgba(0, 0, 0, 0.08), 0 4px 10px rgba(0, 0, 0, 0.04));
761
867
  visibility: hidden;
762
868
  opacity: 0;
763
- transition: opacity 0.2s ease, visibility 0.2s;
764
- z-index: 50;
869
+ transition: opacity 0.15s ease, visibility 0.15s;
870
+ z-index: var(--dm-z-popover, 50);
871
+ scrollbar-width: thin;
872
+ scrollbar-color: var(--dm-scrollbar-thumb, rgba(0, 0, 0, 0.18)) transparent;
873
+ }
874
+ .dm-floating-menu::-webkit-scrollbar {
875
+ width: 6px;
876
+ }
877
+ .dm-floating-menu::-webkit-scrollbar-track {
878
+ background: transparent;
879
+ margin: 0.375rem 0;
880
+ }
881
+ .dm-floating-menu::-webkit-scrollbar-thumb {
882
+ background: var(--dm-scrollbar-thumb, rgba(0, 0, 0, 0.18));
883
+ border-radius: 3px;
884
+ transition: background-color 0.15s;
885
+ }
886
+ .dm-floating-menu::-webkit-scrollbar-thumb:hover {
887
+ background: var(--dm-scrollbar-thumb-hover, rgba(0, 0, 0, 0.28));
765
888
  }
766
889
  .dm-floating-menu[data-show] {
767
890
  visibility: visible;
768
891
  opacity: 1;
769
892
  }
893
+ .dm-floating-menu-group-label {
894
+ padding: 0.375rem 0.5rem 0.125rem;
895
+ font-size: 0.6875rem;
896
+ font-weight: 600;
897
+ letter-spacing: 0.04em;
898
+ text-transform: uppercase;
899
+ color: var(--dm-muted, #999);
900
+ user-select: none;
901
+ }
902
+ .dm-floating-menu-group {
903
+ display: flex;
904
+ flex-direction: column;
905
+ gap: 0.125rem;
906
+ }
907
+ .dm-floating-menu-group + .dm-floating-menu-group:not(:has(+ .dm-floating-menu-group-label)) {
908
+ margin-top: 0.25rem;
909
+ }
910
+ .dm-floating-menu-group-wrapper {
911
+ display: flex;
912
+ flex-direction: column;
913
+ }
914
+ .dm-floating-menu-item {
915
+ display: flex;
916
+ align-items: center;
917
+ gap: 0.5rem;
918
+ width: 100%;
919
+ padding: 0.3125rem 0.5rem;
920
+ border: none;
921
+ border-radius: var(--dm-button-border-radius, 0.375rem);
922
+ background: transparent;
923
+ color: var(--dm-button-color, inherit);
924
+ text-align: left;
925
+ font: inherit;
926
+ cursor: pointer;
927
+ transition: background-color 0.12s;
928
+ }
929
+ .dm-floating-menu-item:hover:not([aria-disabled=true]), .dm-floating-menu-item:focus:not([aria-disabled=true]) {
930
+ background: var(--dm-button-hover-bg, rgba(0, 0, 0, 0.04));
931
+ }
932
+ .dm-floating-menu-item:focus-visible {
933
+ outline: 2px solid var(--dm-accent, #2563eb);
934
+ outline-offset: -2px;
935
+ }
936
+ .dm-floating-menu-item[aria-disabled=true], .dm-floating-menu-item:disabled {
937
+ opacity: var(--dm-button-disabled-opacity, 0.45);
938
+ cursor: not-allowed;
939
+ }
940
+ .dm-floating-menu-item-icon {
941
+ display: inline-flex;
942
+ align-items: center;
943
+ justify-content: center;
944
+ width: 1.25rem;
945
+ height: 1.25rem;
946
+ flex-shrink: 0;
947
+ color: var(--dm-editor-text, inherit);
948
+ }
949
+ .dm-floating-menu-item-icon svg {
950
+ width: 1.125rem;
951
+ height: 1.125rem;
952
+ }
953
+ .dm-floating-menu-item-label {
954
+ flex: 1;
955
+ min-width: 0;
956
+ font-size: 0.875rem;
957
+ color: var(--dm-editor-text, inherit);
958
+ white-space: nowrap;
959
+ overflow: hidden;
960
+ text-overflow: ellipsis;
961
+ }
962
+ .dm-floating-menu-item-shortcut {
963
+ flex-shrink: 0;
964
+ padding: 0.0625rem 0.375rem;
965
+ font-family: var(--dm-code-font, ui-monospace, monospace);
966
+ font-size: 0.6875rem;
967
+ color: var(--dm-muted, #999);
968
+ background: var(--dm-surface, #f8f9fa);
969
+ border: 1px solid var(--dm-border-color, #e5e7eb);
970
+ border-radius: 0.25rem;
971
+ user-select: none;
972
+ }
770
973
 
771
974
  .dm-link-popover {
772
975
  position: fixed;
@@ -774,10 +977,10 @@ img.ProseMirror-separator {
774
977
  align-items: center;
775
978
  gap: 0.25rem;
776
979
  padding: 0.25rem;
777
- background: #f8f9fa;
778
- border: 1px solid #e0e0e0;
980
+ background: var(--dm-surface);
981
+ border: 1px solid var(--dm-border-color);
779
982
  border-radius: 0.25rem;
780
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
983
+ box-shadow: var(--dm-popover-shadow, 0 4px 12px rgba(0, 0, 0, 0.12));
781
984
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
782
985
  visibility: hidden;
783
986
  opacity: 0;
@@ -790,18 +993,18 @@ img.ProseMirror-separator {
790
993
  }
791
994
 
792
995
  .dm-link-popover-input {
793
- border: 1px solid #e0e0e0;
996
+ border: 1px solid var(--dm-border-color);
794
997
  border-radius: 0.25rem;
795
998
  padding: 0.25rem 0.5rem;
796
999
  font-size: 0.8125rem;
797
1000
  font-family: inherit;
798
1001
  min-width: 14rem;
799
1002
  outline: none;
800
- background: #fff;
801
- color: #1a1a1a;
1003
+ background: var(--dm-bg);
1004
+ color: var(--dm-text);
802
1005
  }
803
1006
  .dm-link-popover-input:focus {
804
- border-color: #2563eb;
1007
+ border-color: var(--dm-accent);
805
1008
  }
806
1009
 
807
1010
  .dm-link-popover-btn {
@@ -814,15 +1017,15 @@ img.ProseMirror-separator {
814
1017
  border: none;
815
1018
  border-radius: 0.25rem;
816
1019
  background: transparent;
817
- color: #1a1a1a;
1020
+ color: var(--dm-text);
818
1021
  cursor: pointer;
819
1022
  transition: background-color 0.15s, color 0.15s;
820
1023
  }
821
1024
  .dm-link-popover-btn:hover {
822
- background: rgba(0, 0, 0, 0.06);
1025
+ background: var(--dm-hover);
823
1026
  }
824
1027
  .dm-link-popover-btn:focus-visible {
825
- outline: 2px solid var(--dm-accent, #2563eb);
1028
+ outline: 2px solid var(--dm-accent);
826
1029
  outline-offset: 1px;
827
1030
  }
828
1031
  .dm-link-popover-btn svg {
@@ -831,7 +1034,7 @@ img.ProseMirror-separator {
831
1034
  }
832
1035
 
833
1036
  .dm-link-popover-apply:hover {
834
- color: #2563eb;
1037
+ color: var(--dm-accent);
835
1038
  }
836
1039
 
837
1040
  .dm-link-popover-remove:hover {
@@ -839,181 +1042,476 @@ img.ProseMirror-separator {
839
1042
  }
840
1043
 
841
1044
  .dm-link-pending {
842
- background-color: rgba(37, 99, 235, 0.12);
1045
+ background-color: color-mix(in srgb, var(--dm-accent) 12%, transparent);
843
1046
  border-radius: 1px;
844
1047
  }
845
1048
 
846
- [data-theme=dark] .dm-link-popover,
847
- .dm-theme-dark .dm-link-popover {
848
- background: #2a2a2a;
849
- border-color: #404040;
1049
+ .dm-editor--has-block-handle {
1050
+ overflow: visible;
1051
+ }
1052
+ .dm-editor--has-block-handle .ProseMirror {
1053
+ padding-left: var(--dm-block-handle-gutter, 4rem);
1054
+ }
1055
+
1056
+ .dm-editor--has-block-handle .ProseMirror-selectednode,
1057
+ .dm-editor--has-block-handle .ProseMirror-selectednoderange {
1058
+ position: relative;
1059
+ outline: none;
850
1060
  }
851
- [data-theme=dark] .dm-link-popover .dm-link-popover-input,
852
- .dm-theme-dark .dm-link-popover .dm-link-popover-input {
853
- background: #1a1a1a;
854
- border-color: #404040;
855
- color: #e0e0e0;
1061
+ .dm-editor--has-block-handle .ProseMirror-selectednode::before,
1062
+ .dm-editor--has-block-handle .ProseMirror-selectednoderange::before {
1063
+ content: "";
1064
+ position: absolute;
1065
+ inset: -0.25rem;
1066
+ background-color: var(--dm-block-selected-halo, rgba(112, 207, 248, 0.25));
1067
+ border-radius: 0.25rem;
1068
+ pointer-events: none;
1069
+ z-index: -1;
856
1070
  }
857
- [data-theme=dark] .dm-link-popover .dm-link-popover-input:focus,
858
- .dm-theme-dark .dm-link-popover .dm-link-popover-input:focus {
859
- border-color: #3b82f6;
1071
+
1072
+ .dm-block-handle {
1073
+ position: absolute;
1074
+ left: var(--dm-block-handle-left, -0.5rem);
1075
+ display: flex;
1076
+ align-items: center;
1077
+ gap: 2px;
1078
+ padding: 2px;
1079
+ opacity: 0;
1080
+ visibility: hidden;
1081
+ pointer-events: none;
1082
+ transition: opacity 0.12s ease, visibility 0.12s;
1083
+ z-index: var(--dm-z-handle, 25);
860
1084
  }
861
- [data-theme=dark] .dm-link-popover .dm-link-popover-btn,
862
- .dm-theme-dark .dm-link-popover .dm-link-popover-btn {
863
- color: #e0e0e0;
1085
+ .dm-block-handle[data-show] {
1086
+ opacity: 1;
1087
+ visibility: visible;
1088
+ pointer-events: auto;
864
1089
  }
865
- [data-theme=dark] .dm-link-popover .dm-link-popover-btn:hover,
866
- .dm-theme-dark .dm-link-popover .dm-link-popover-btn:hover {
867
- background: rgba(255, 255, 255, 0.1);
1090
+ .dm-block-handle-btn {
1091
+ display: inline-flex;
1092
+ align-items: center;
1093
+ justify-content: center;
1094
+ width: 1.25rem;
1095
+ height: 1.5rem;
1096
+ padding: 0;
1097
+ border: none;
1098
+ background: transparent;
1099
+ color: var(--dm-muted, #999);
1100
+ cursor: pointer;
1101
+ border-radius: 3px;
1102
+ transition: background-color 0.1s, color 0.1s;
1103
+ user-select: none;
1104
+ -webkit-user-select: none;
1105
+ touch-action: none;
868
1106
  }
869
- [data-theme=dark] .dm-link-popover .dm-link-popover-apply:hover,
870
- .dm-theme-dark .dm-link-popover .dm-link-popover-apply:hover {
871
- color: #3b82f6;
1107
+ .dm-block-handle-btn:hover {
1108
+ background: var(--dm-button-hover-bg, rgba(0, 0, 0, 0.04));
1109
+ color: var(--dm-editor-text, inherit);
872
1110
  }
873
-
874
- @media (prefers-color-scheme: dark) {
875
- .dm-theme-auto .dm-link-popover {
876
- background: #2a2a2a;
877
- border-color: #404040;
878
- }
879
- .dm-theme-auto .dm-link-popover .dm-link-popover-input {
880
- background: #1a1a1a;
881
- border-color: #404040;
882
- color: #e0e0e0;
883
- }
884
- .dm-theme-auto .dm-link-popover .dm-link-popover-input:focus {
885
- border-color: #3b82f6;
886
- }
887
- .dm-theme-auto .dm-link-popover .dm-link-popover-btn {
888
- color: #e0e0e0;
889
- }
890
- .dm-theme-auto .dm-link-popover .dm-link-popover-btn:hover {
891
- background: rgba(255, 255, 255, 0.1);
892
- }
893
- .dm-theme-auto .dm-link-popover .dm-link-popover-apply:hover {
894
- color: #3b82f6;
895
- }
1111
+ .dm-block-handle-btn:focus-visible {
1112
+ outline: 2px solid var(--dm-accent, #2563eb);
1113
+ outline-offset: -1px;
896
1114
  }
897
- .dm-editor .ProseMirror .is-empty::before {
898
- content: attr(data-placeholder);
899
- float: left;
900
- color: var(--dm-placeholder-color);
1115
+ .dm-block-handle-btn svg {
1116
+ width: 1rem;
1117
+ height: 1rem;
901
1118
  pointer-events: none;
902
- height: 0;
1119
+ }
1120
+ .dm-block-handle-drag {
1121
+ cursor: grab;
1122
+ }
1123
+ .dm-block-handle-drag:active {
1124
+ cursor: grabbing;
1125
+ }
1126
+ .dm-block-handle-plus:hover {
1127
+ color: var(--dm-accent, #2563eb);
903
1128
  }
904
1129
 
905
- .dm-editor .ProseMirror ul[data-type=taskList] {
906
- list-style: none;
907
- padding-left: 0;
1130
+ .dm-block-drop-indicator {
1131
+ position: absolute;
1132
+ height: 2px;
1133
+ background: var(--dm-accent, #2563eb);
1134
+ border-radius: 1px;
1135
+ pointer-events: none;
1136
+ z-index: 5;
1137
+ display: none;
1138
+ box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.15);
1139
+ transform: translateY(3px);
1140
+ transition: left 80ms ease-out, width 80ms ease-out, top 80ms ease-out, transform 80ms ease-out;
908
1141
  }
909
- .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem] {
910
- display: flex;
911
- align-items: flex-start;
912
- gap: 0.5em;
1142
+ .dm-block-drop-indicator[data-show] {
1143
+ display: block;
913
1144
  }
914
- .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem] > label {
1145
+ .dm-block-drop-indicator[data-mode=nested] {
1146
+ height: 0;
1147
+ background: transparent;
1148
+ border-radius: 0;
1149
+ border-top: 2px dashed var(--dm-accent, #2563eb);
1150
+ box-shadow: none;
1151
+ transform: translateY(-2px);
1152
+ }
1153
+
1154
+ .dm-block-handle-dragging .ProseMirror-dropcursor {
1155
+ display: none;
1156
+ }
1157
+
1158
+ .dm-slash-command-menu {
1159
+ position: absolute;
915
1160
  display: flex;
916
- align-items: center;
917
- flex-shrink: 0;
918
- margin-top: 0.4em;
919
- user-select: none;
1161
+ flex-direction: column;
1162
+ gap: 0.25rem;
1163
+ min-width: 17rem;
1164
+ max-height: 22rem;
1165
+ overflow-y: auto;
1166
+ padding: 0.375rem;
1167
+ background: var(--dm-toolbar-bg, var(--dm-bg, #ffffff));
1168
+ border: 1px solid var(--dm-border-color, #e5e7eb);
1169
+ border-radius: var(--dm-toolbar-border-radius, 0.5rem);
1170
+ box-shadow: var(--dm-popover-shadow, 0 10px 25px rgba(0, 0, 0, 0.08), 0 4px 10px rgba(0, 0, 0, 0.04));
1171
+ z-index: var(--dm-z-popover, 50);
1172
+ scrollbar-width: thin;
1173
+ scrollbar-color: var(--dm-scrollbar-thumb, rgba(0, 0, 0, 0.18)) transparent;
920
1174
  }
921
- .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem] > label input[type=checkbox] {
922
- width: 1em;
923
- height: 1em;
924
- margin: 0;
925
- padding: 0;
926
- cursor: pointer;
927
- accent-color: var(--dm-accent, #2563eb);
1175
+ .dm-slash-command-menu::-webkit-scrollbar {
1176
+ width: 6px;
928
1177
  }
929
- .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem] > div {
930
- flex: 1;
931
- min-width: 0;
1178
+ .dm-slash-command-menu::-webkit-scrollbar-track {
1179
+ background: transparent;
1180
+ margin: 0.375rem 0;
932
1181
  }
933
- .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem] > div > p {
934
- margin: 0;
1182
+ .dm-slash-command-menu::-webkit-scrollbar-thumb {
1183
+ background: var(--dm-scrollbar-thumb, rgba(0, 0, 0, 0.18));
1184
+ border-radius: 3px;
1185
+ transition: background-color 0.15s;
935
1186
  }
936
- .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem][data-checked=true] > div {
937
- text-decoration: line-through;
938
- opacity: 0.6;
1187
+ .dm-slash-command-menu::-webkit-scrollbar-thumb:hover {
1188
+ background: var(--dm-scrollbar-thumb-hover, rgba(0, 0, 0, 0.28));
939
1189
  }
940
1190
 
941
- .dm-editor .ProseMirror .mention {
942
- display: inline;
943
- background: var(--dm-mention-bg);
944
- color: var(--dm-mention-color);
945
- border-radius: var(--dm-mention-border-radius);
946
- padding: 0.1em 0.3em;
947
- font-weight: 500;
948
- font-size: 0.95em;
949
- white-space: nowrap;
1191
+ .dm-slash-command-query {
1192
+ color: var(--dm-accent, #2563eb);
950
1193
  }
951
- .dm-editor .ProseMirror .mention-suggestion {
952
- text-decoration: underline;
953
- text-decoration-color: var(--dm-accent, #2563eb);
954
- text-underline-offset: 2px;
1194
+
1195
+ .dm-slash-command-group-label {
1196
+ padding: 0.375rem 0.5rem 0.125rem;
1197
+ font-size: 0.6875rem;
1198
+ font-weight: 600;
1199
+ letter-spacing: 0.04em;
1200
+ text-transform: uppercase;
1201
+ color: var(--dm-muted, #999);
1202
+ user-select: none;
955
1203
  }
956
1204
 
957
- .dm-mention-suggestion {
958
- position: absolute;
959
- z-index: 100;
960
- min-width: 12rem;
961
- max-width: 20rem;
962
- padding: 0.25rem;
963
- background: var(--dm-surface, #f8f9fa);
964
- border: 1px solid var(--dm-border-color, #e0e0e0);
965
- border-radius: 0.25rem;
966
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
967
- animation: dm-fade-in 0.2s ease;
1205
+ .dm-slash-command-group {
1206
+ display: flex;
1207
+ flex-direction: column;
1208
+ gap: 0.125rem;
968
1209
  }
969
1210
 
970
- .dm-mention-suggestion-item {
1211
+ .dm-slash-command-item {
971
1212
  display: flex;
972
1213
  align-items: center;
973
1214
  gap: 0.5rem;
974
1215
  width: 100%;
975
1216
  padding: 0.375rem 0.5rem;
976
1217
  border: none;
977
- border-radius: 0.25rem;
1218
+ border-radius: var(--dm-button-border-radius, 0.375rem);
978
1219
  background: transparent;
979
- color: var(--dm-text, #1a1a1a);
980
- cursor: pointer;
981
- font-size: 0.8125rem;
982
- line-height: 1.4;
1220
+ color: var(--dm-editor-text, inherit);
983
1221
  text-align: left;
1222
+ font: inherit;
1223
+ cursor: pointer;
984
1224
  transition: background-color 0.1s;
985
1225
  }
986
- .dm-mention-suggestion-item:hover, .dm-mention-suggestion-item--selected {
987
- background: var(--dm-hover, rgba(0, 0, 0, 0.06));
1226
+ .dm-slash-command-item[data-selected] {
1227
+ background: var(--dm-button-hover-bg, rgba(0, 0, 0, 0.04));
988
1228
  }
989
- .dm-mention-suggestion-item:focus-visible {
1229
+ .dm-slash-command-item:focus-visible {
990
1230
  outline: 2px solid var(--dm-accent, #2563eb);
991
- outline-offset: 1px;
1231
+ outline-offset: -2px;
992
1232
  }
993
1233
 
994
- .dm-mention-suggestion-label {
995
- overflow: hidden;
996
- text-overflow: ellipsis;
997
- white-space: nowrap;
1234
+ .dm-slash-command-item-icon {
1235
+ display: inline-flex;
1236
+ align-items: center;
1237
+ justify-content: center;
1238
+ width: 1.25rem;
1239
+ height: 1.25rem;
1240
+ flex-shrink: 0;
1241
+ color: var(--dm-editor-text, inherit);
1242
+ }
1243
+ .dm-slash-command-item-icon svg {
1244
+ width: 1.125rem;
1245
+ height: 1.125rem;
998
1246
  }
999
1247
 
1000
- .dm-mention-suggestion-empty {
1001
- padding: 0.5rem;
1002
- text-align: center;
1003
- color: var(--dm-text, #1a1a1a);
1004
- opacity: 0.5;
1005
- font-size: 0.8125rem;
1248
+ .dm-slash-command-item-text {
1249
+ display: flex;
1250
+ flex-direction: column;
1251
+ flex: 1;
1252
+ min-width: 0;
1253
+ line-height: 1.25;
1006
1254
  }
1007
1255
 
1008
- .dm-editor .ProseMirror img[style*="float: left"], .dm-editor .ProseMirror img[style*="float: right"] {
1009
- max-width: 60%;
1256
+ .dm-slash-command-item-label {
1257
+ font-size: 0.875rem;
1258
+ font-weight: 500;
1259
+ color: var(--dm-editor-text, inherit);
1260
+ white-space: nowrap;
1261
+ overflow: hidden;
1262
+ text-overflow: ellipsis;
1010
1263
  }
1011
1264
 
1012
- .dm-editor .ProseMirror .dm-image-resizable {
1013
- position: relative;
1014
- display: inline-block;
1015
- max-width: 100%;
1016
- margin: 0.75em 0;
1265
+ .dm-slash-command-item-description {
1266
+ font-size: 0.75rem;
1267
+ color: var(--dm-muted, #999);
1268
+ white-space: nowrap;
1269
+ overflow: hidden;
1270
+ text-overflow: ellipsis;
1271
+ }
1272
+
1273
+ .dm-slash-command-item-shortcut {
1274
+ flex-shrink: 0;
1275
+ padding: 0.0625rem 0.375rem;
1276
+ font-family: var(--dm-code-font, ui-monospace, monospace);
1277
+ font-size: 0.6875rem;
1278
+ color: var(--dm-muted, #999);
1279
+ background: var(--dm-surface, #f8f9fa);
1280
+ border: 1px solid var(--dm-border-color, #e5e7eb);
1281
+ border-radius: 0.25rem;
1282
+ user-select: none;
1283
+ }
1284
+
1285
+ .dm-slash-command-empty {
1286
+ padding: 0.5rem 0.75rem;
1287
+ font-size: 0.8125rem;
1288
+ color: var(--dm-muted, #999);
1289
+ user-select: none;
1290
+ }
1291
+
1292
+ .dm-block-context-menu {
1293
+ position: absolute;
1294
+ display: none;
1295
+ flex-direction: column;
1296
+ min-width: 12rem;
1297
+ max-height: 20rem;
1298
+ overflow-y: auto;
1299
+ overscroll-behavior: contain;
1300
+ padding: 0.25rem;
1301
+ background: var(--dm-toolbar-bg, var(--dm-bg, #ffffff));
1302
+ border: 1px solid var(--dm-border-color, #e5e7eb);
1303
+ border-radius: var(--dm-toolbar-border-radius, 0.5rem);
1304
+ box-shadow: var(--dm-popover-shadow, 0 10px 25px rgba(0, 0, 0, 0.08), 0 4px 10px rgba(0, 0, 0, 0.04));
1305
+ z-index: var(--dm-z-popover, 50);
1306
+ }
1307
+ .dm-block-context-menu[data-show] {
1308
+ display: flex;
1309
+ }
1310
+ .dm-block-context-menu {
1311
+ scrollbar-width: thin;
1312
+ scrollbar-color: var(--dm-scrollbar-thumb, rgba(0, 0, 0, 0.18)) transparent;
1313
+ }
1314
+ .dm-block-context-menu::-webkit-scrollbar {
1315
+ width: 6px;
1316
+ }
1317
+ .dm-block-context-menu::-webkit-scrollbar-track {
1318
+ background: transparent;
1319
+ }
1320
+ .dm-block-context-menu::-webkit-scrollbar-thumb {
1321
+ background: var(--dm-scrollbar-thumb, rgba(0, 0, 0, 0.18));
1322
+ border-radius: 3px;
1323
+ }
1324
+ .dm-block-context-menu::-webkit-scrollbar-thumb:hover {
1325
+ background: var(--dm-scrollbar-thumb-hover, rgba(0, 0, 0, 0.28));
1326
+ }
1327
+ .dm-block-context-menu-group {
1328
+ display: flex;
1329
+ flex-direction: column;
1330
+ gap: 1px;
1331
+ }
1332
+ .dm-block-context-menu-group-label {
1333
+ padding: 0.5rem 0.5rem 0.125rem;
1334
+ margin-top: 0.25rem;
1335
+ border-top: 1px solid var(--dm-border-color, #e5e7eb);
1336
+ font-size: 0.6875rem;
1337
+ font-weight: 600;
1338
+ letter-spacing: 0.04em;
1339
+ text-transform: uppercase;
1340
+ color: var(--dm-muted, #999);
1341
+ user-select: none;
1342
+ }
1343
+ .dm-block-context-menu-item {
1344
+ display: flex;
1345
+ align-items: center;
1346
+ gap: 0.5rem;
1347
+ width: 100%;
1348
+ padding: 0.3125rem 0.5rem;
1349
+ border: none;
1350
+ border-radius: var(--dm-button-border-radius, 0.375rem);
1351
+ background: transparent;
1352
+ color: var(--dm-editor-text, inherit);
1353
+ text-align: left;
1354
+ font: inherit;
1355
+ font-size: 0.875rem;
1356
+ cursor: pointer;
1357
+ transition: background-color 0.1s;
1358
+ }
1359
+ .dm-block-context-menu-item:hover, .dm-block-context-menu-item:focus-visible {
1360
+ background: var(--dm-button-hover-bg, rgba(0, 0, 0, 0.04));
1361
+ }
1362
+ .dm-block-context-menu-item:focus-visible {
1363
+ outline: 2px solid var(--dm-accent, #2563eb);
1364
+ outline-offset: -2px;
1365
+ }
1366
+ .dm-block-context-menu-item-icon {
1367
+ display: inline-flex;
1368
+ align-items: center;
1369
+ justify-content: center;
1370
+ width: 1.125rem;
1371
+ height: 1.125rem;
1372
+ flex-shrink: 0;
1373
+ color: var(--dm-muted, #999);
1374
+ }
1375
+ .dm-block-context-menu-item-icon svg {
1376
+ width: 1rem;
1377
+ height: 1rem;
1378
+ }
1379
+ .dm-block-context-menu-item-label {
1380
+ flex: 1;
1381
+ min-width: 0;
1382
+ white-space: nowrap;
1383
+ overflow: hidden;
1384
+ text-overflow: ellipsis;
1385
+ }
1386
+
1387
+ .ProseMirror .dm-block-context-active {
1388
+ background-color: var(--dm-block-context-active-bg, rgba(55, 53, 47, 0.06));
1389
+ border-radius: 0.25rem;
1390
+ box-shadow: 0 0 0 4px var(--dm-block-context-active-bg, rgba(55, 53, 47, 0.06));
1391
+ transition: background-color 0.12s ease, box-shadow 0.12s ease;
1392
+ }
1393
+
1394
+ .dm-editor .ProseMirror .is-empty::before {
1395
+ content: attr(data-placeholder);
1396
+ float: left;
1397
+ color: var(--dm-placeholder-color);
1398
+ pointer-events: none;
1399
+ height: 0;
1400
+ }
1401
+
1402
+ .dm-editor .ProseMirror ul[data-type=taskList] {
1403
+ list-style: none;
1404
+ padding-left: 1.5em;
1405
+ }
1406
+ .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem] {
1407
+ position: relative;
1408
+ margin: 0.25em 0;
1409
+ }
1410
+ .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem] > label {
1411
+ position: absolute;
1412
+ left: var(--dm-task-checkbox-left, -1.15em);
1413
+ top: var(--dm-task-checkbox-top, 0.45em);
1414
+ display: flex;
1415
+ align-items: center;
1416
+ user-select: none;
1417
+ }
1418
+ .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem] > label input[type=checkbox] {
1419
+ width: 1em;
1420
+ height: 1em;
1421
+ margin: 0;
1422
+ padding: 0;
1423
+ cursor: pointer;
1424
+ accent-color: var(--dm-accent, #2563eb);
1425
+ }
1426
+ .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem] > div > p {
1427
+ margin: 0.1em 0;
1428
+ padding-inline: 0.3em 0;
1429
+ }
1430
+ .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem] > div > :not(p:first-child):not(ul):not(ol) {
1431
+ margin-inline-start: var(--dm-block-children-indent, 1.5rem);
1432
+ margin-top: 0.25rem;
1433
+ }
1434
+ .dm-editor .ProseMirror ul[data-type=taskList] li[data-type=taskItem][data-checked=true] > div > p:first-child {
1435
+ text-decoration: line-through;
1436
+ opacity: 0.6;
1437
+ }
1438
+
1439
+ .dm-editor .ProseMirror .mention {
1440
+ display: inline;
1441
+ background: var(--dm-mention-bg);
1442
+ color: var(--dm-mention-color);
1443
+ border-radius: var(--dm-mention-border-radius);
1444
+ padding: 0.1em 0.3em;
1445
+ font-weight: 500;
1446
+ font-size: 0.95em;
1447
+ white-space: nowrap;
1448
+ }
1449
+ .dm-editor .ProseMirror .mention-suggestion {
1450
+ text-decoration: underline;
1451
+ text-decoration-color: var(--dm-accent, #2563eb);
1452
+ text-underline-offset: 2px;
1453
+ }
1454
+
1455
+ .dm-mention-suggestion {
1456
+ position: absolute;
1457
+ z-index: 100;
1458
+ min-width: 12rem;
1459
+ max-width: 20rem;
1460
+ padding: 0.25rem;
1461
+ background: var(--dm-surface, #f8f9fa);
1462
+ border: 1px solid var(--dm-border-color, #e0e0e0);
1463
+ border-radius: 0.25rem;
1464
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
1465
+ animation: dm-fade-in 0.2s ease;
1466
+ }
1467
+
1468
+ .dm-mention-suggestion-item {
1469
+ display: flex;
1470
+ align-items: center;
1471
+ gap: 0.5rem;
1472
+ width: 100%;
1473
+ padding: 0.375rem 0.5rem;
1474
+ border: none;
1475
+ border-radius: 0.25rem;
1476
+ background: transparent;
1477
+ color: var(--dm-text, #1a1a1a);
1478
+ cursor: pointer;
1479
+ font-size: 0.8125rem;
1480
+ line-height: 1.4;
1481
+ text-align: left;
1482
+ transition: background-color 0.1s;
1483
+ }
1484
+ .dm-mention-suggestion-item:hover, .dm-mention-suggestion-item--selected {
1485
+ background: var(--dm-hover, rgba(0, 0, 0, 0.06));
1486
+ }
1487
+ .dm-mention-suggestion-item:focus-visible {
1488
+ outline: 2px solid var(--dm-accent, #2563eb);
1489
+ outline-offset: 1px;
1490
+ }
1491
+
1492
+ .dm-mention-suggestion-label {
1493
+ overflow: hidden;
1494
+ text-overflow: ellipsis;
1495
+ white-space: nowrap;
1496
+ }
1497
+
1498
+ .dm-mention-suggestion-empty {
1499
+ padding: 0.5rem;
1500
+ text-align: center;
1501
+ color: var(--dm-text, #1a1a1a);
1502
+ opacity: 0.5;
1503
+ font-size: 0.8125rem;
1504
+ }
1505
+
1506
+ .dm-editor .ProseMirror img[style*="float: left"], .dm-editor .ProseMirror img[style*="float: right"] {
1507
+ max-width: 60%;
1508
+ }
1509
+
1510
+ .dm-editor .ProseMirror .dm-image-resizable {
1511
+ position: relative;
1512
+ display: inline-block;
1513
+ max-width: 100%;
1514
+ margin: 0.75em 0;
1017
1515
  line-height: 0;
1018
1516
  }
1019
1517
  .dm-editor .ProseMirror .dm-image-resizable img {
@@ -1082,10 +1580,10 @@ img.ProseMirror-separator {
1082
1580
  align-items: center;
1083
1581
  gap: 0.25rem;
1084
1582
  padding: 0.25rem;
1085
- background: #f8f9fa;
1086
- border: 1px solid #e0e0e0;
1583
+ background: var(--dm-surface);
1584
+ border: 1px solid var(--dm-border-color);
1087
1585
  border-radius: 0.25rem;
1088
- box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
1586
+ box-shadow: var(--dm-popover-shadow, 0 4px 12px rgba(0, 0, 0, 0.12));
1089
1587
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
1090
1588
  visibility: hidden;
1091
1589
  opacity: 0;
@@ -1098,18 +1596,18 @@ img.ProseMirror-separator {
1098
1596
  }
1099
1597
 
1100
1598
  .dm-image-popover-input {
1101
- border: 1px solid #e0e0e0;
1599
+ border: 1px solid var(--dm-border-color);
1102
1600
  border-radius: 0.25rem;
1103
1601
  padding: 0.25rem 0.5rem;
1104
1602
  font-size: 0.8125rem;
1105
1603
  font-family: inherit;
1106
1604
  min-width: 14rem;
1107
1605
  outline: none;
1108
- background: #fff;
1109
- color: #1a1a1a;
1606
+ background: var(--dm-bg);
1607
+ color: var(--dm-text);
1110
1608
  }
1111
1609
  .dm-image-popover-input:focus {
1112
- border-color: #2563eb;
1610
+ border-color: var(--dm-accent);
1113
1611
  }
1114
1612
 
1115
1613
  .dm-image-popover-btn {
@@ -1122,15 +1620,15 @@ img.ProseMirror-separator {
1122
1620
  border: none;
1123
1621
  border-radius: 0.25rem;
1124
1622
  background: transparent;
1125
- color: #1a1a1a;
1623
+ color: var(--dm-text);
1126
1624
  cursor: pointer;
1127
1625
  transition: background-color 0.15s, color 0.15s;
1128
1626
  }
1129
1627
  .dm-image-popover-btn:hover {
1130
- background: rgba(0, 0, 0, 0.06);
1628
+ background: var(--dm-hover);
1131
1629
  }
1132
1630
  .dm-image-popover-btn:focus-visible {
1133
- outline: 2px solid var(--dm-accent, #2563eb);
1631
+ outline: 2px solid var(--dm-accent);
1134
1632
  outline-offset: 1px;
1135
1633
  }
1136
1634
  .dm-image-popover-btn svg {
@@ -1138,65 +1636,11 @@ img.ProseMirror-separator {
1138
1636
  height: 0.875rem;
1139
1637
  }
1140
1638
 
1141
- .dm-image-popover-apply:hover {
1142
- color: #2563eb;
1143
- }
1144
-
1639
+ .dm-image-popover-apply:hover,
1145
1640
  .dm-image-popover-browse:hover {
1146
- color: #2563eb;
1147
- }
1148
-
1149
- [data-theme=dark] .dm-image-popover,
1150
- .dm-theme-dark .dm-image-popover {
1151
- background: #2a2a2a;
1152
- border-color: #404040;
1153
- }
1154
- [data-theme=dark] .dm-image-popover .dm-image-popover-input,
1155
- .dm-theme-dark .dm-image-popover .dm-image-popover-input {
1156
- background: #1a1a1a;
1157
- border-color: #404040;
1158
- color: #e0e0e0;
1159
- }
1160
- [data-theme=dark] .dm-image-popover .dm-image-popover-input:focus,
1161
- .dm-theme-dark .dm-image-popover .dm-image-popover-input:focus {
1162
- border-color: #3b82f6;
1163
- }
1164
- [data-theme=dark] .dm-image-popover .dm-image-popover-btn,
1165
- .dm-theme-dark .dm-image-popover .dm-image-popover-btn {
1166
- color: #e0e0e0;
1167
- }
1168
- [data-theme=dark] .dm-image-popover .dm-image-popover-btn:hover,
1169
- .dm-theme-dark .dm-image-popover .dm-image-popover-btn:hover {
1170
- background: rgba(255, 255, 255, 0.1);
1171
- }
1172
- [data-theme=dark] .dm-image-popover .dm-image-popover-apply:hover,
1173
- .dm-theme-dark .dm-image-popover .dm-image-popover-apply:hover {
1174
- color: #3b82f6;
1641
+ color: var(--dm-accent);
1175
1642
  }
1176
1643
 
1177
- @media (prefers-color-scheme: dark) {
1178
- .dm-theme-auto .dm-image-popover {
1179
- background: #2a2a2a;
1180
- border-color: #404040;
1181
- }
1182
- .dm-theme-auto .dm-image-popover .dm-image-popover-input {
1183
- background: #1a1a1a;
1184
- border-color: #404040;
1185
- color: #e0e0e0;
1186
- }
1187
- .dm-theme-auto .dm-image-popover .dm-image-popover-input:focus {
1188
- border-color: #3b82f6;
1189
- }
1190
- .dm-theme-auto .dm-image-popover .dm-image-popover-btn {
1191
- color: #e0e0e0;
1192
- }
1193
- .dm-theme-auto .dm-image-popover .dm-image-popover-btn:hover {
1194
- background: rgba(255, 255, 255, 0.1);
1195
- }
1196
- .dm-theme-auto .dm-image-popover .dm-image-popover-apply:hover {
1197
- color: #3b82f6;
1198
- }
1199
- }
1200
1644
  .dm-editor.dm-dragover {
1201
1645
  outline: 2px dashed var(--dm-accent);
1202
1646
  outline-offset: -2px;
@@ -1740,9 +2184,9 @@ img.ProseMirror-separator {
1740
2184
  width: 100%;
1741
2185
  padding: 0.375rem 0.5rem;
1742
2186
  border: none;
1743
- border-radius: var(--dm-button-border-radius);
2187
+ border-radius: var(--dm-button-border-radius, 0.375rem);
1744
2188
  background: transparent;
1745
- color: var(--dm-button-color);
2189
+ color: var(--dm-button-color, var(--dm-text));
1746
2190
  cursor: pointer;
1747
2191
  font-size: 0.8125rem;
1748
2192
  line-height: 1.4;
@@ -1783,46 +2227,742 @@ img.ProseMirror-separator {
1783
2227
  margin: 0.25rem 0;
1784
2228
  }
1785
2229
 
1786
- .dm-theme-light,
1787
- .dm-theme-light .dm-editor,
1788
- .dm-theme-light .dm-toolbar,
1789
- .dm-theme-light .dm-table-controls-dropdown {
1790
- --dm-bg: #ffffff;
1791
- --dm-text: #1a1a1a;
1792
- --dm-muted: #999999;
1793
- --dm-surface: #f8f9fa;
1794
- --dm-border-color: #e0e0e0;
1795
- --dm-hover: rgba(0, 0, 0, 0.06);
1796
- --dm-active: rgba(0, 0, 0, 0.12);
1797
- --dm-accent: #2563eb;
1798
- --dm-accent-hover: #1d4ed8;
1799
- --dm-accent-surface: rgba(37, 99, 235, 0.1);
1800
- --dm-focus-color: rgba(66, 133, 244, 0.3);
1801
- --dm-selection: rgba(66, 133, 244, 0.2);
1802
- --dm-code-surface: #f5f5f5;
1803
- --dm-code-color: #d63384;
1804
- --dm-highlight-bg: #fff3cd;
1805
- --dm-syntax-keyword: #c72031;
1806
- --dm-syntax-entity: #6f42c1;
1807
- --dm-syntax-constant: #005cc5;
1808
- --dm-syntax-string: #032f62;
1809
- --dm-syntax-variable: #d35400;
1810
- --dm-syntax-comment: #57606a;
1811
- --dm-syntax-tag: #22863a;
1812
- --dm-syntax-addition: #22863a;
1813
- --dm-syntax-addition-bg: #f0fff4;
1814
- --dm-syntax-deletion: #b31d28;
1815
- --dm-syntax-deletion-bg: #ffeef0;
2230
+ .dm-editor .ProseMirror [data-bg-color=gray] {
2231
+ background-color: var(--dm-block-bg-gray);
1816
2232
  }
1817
-
1818
- .dm-theme-dark,
1819
- .dm-theme-dark .dm-editor,
1820
- .dm-theme-dark .dm-toolbar,
1821
- .dm-theme-dark .dm-bubble-menu,
1822
- .dm-theme-dark .dm-emoji-picker,
1823
- .dm-theme-dark .dm-emoji-suggestion,
2233
+ .dm-editor .ProseMirror [data-bg-color=brown] {
2234
+ background-color: var(--dm-block-bg-brown);
2235
+ }
2236
+ .dm-editor .ProseMirror [data-bg-color=orange] {
2237
+ background-color: var(--dm-block-bg-orange);
2238
+ }
2239
+ .dm-editor .ProseMirror [data-bg-color=yellow] {
2240
+ background-color: var(--dm-block-bg-yellow);
2241
+ }
2242
+ .dm-editor .ProseMirror [data-bg-color=green] {
2243
+ background-color: var(--dm-block-bg-green);
2244
+ }
2245
+ .dm-editor .ProseMirror [data-bg-color=blue] {
2246
+ background-color: var(--dm-block-bg-blue);
2247
+ }
2248
+ .dm-editor .ProseMirror [data-bg-color=purple] {
2249
+ background-color: var(--dm-block-bg-purple);
2250
+ }
2251
+ .dm-editor .ProseMirror [data-bg-color=pink] {
2252
+ background-color: var(--dm-block-bg-pink);
2253
+ }
2254
+ .dm-editor .ProseMirror [data-bg-color=red] {
2255
+ background-color: var(--dm-block-bg-red);
2256
+ }
2257
+ .dm-editor .ProseMirror [data-bg-color] {
2258
+ padding-block: 0.125rem;
2259
+ border-radius: 0.25rem;
2260
+ }
2261
+ .dm-editor .ProseMirror [data-text-color=gray] {
2262
+ color: var(--dm-block-text-gray);
2263
+ }
2264
+ .dm-editor .ProseMirror [data-text-color=brown] {
2265
+ color: var(--dm-block-text-brown);
2266
+ }
2267
+ .dm-editor .ProseMirror [data-text-color=orange] {
2268
+ color: var(--dm-block-text-orange);
2269
+ }
2270
+ .dm-editor .ProseMirror [data-text-color=yellow] {
2271
+ color: var(--dm-block-text-yellow);
2272
+ }
2273
+ .dm-editor .ProseMirror [data-text-color=green] {
2274
+ color: var(--dm-block-text-green);
2275
+ }
2276
+ .dm-editor .ProseMirror [data-text-color=blue] {
2277
+ color: var(--dm-block-text-blue);
2278
+ }
2279
+ .dm-editor .ProseMirror [data-text-color=purple] {
2280
+ color: var(--dm-block-text-purple);
2281
+ }
2282
+ .dm-editor .ProseMirror [data-text-color=pink] {
2283
+ color: var(--dm-block-text-pink);
2284
+ }
2285
+ .dm-editor .ProseMirror [data-text-color=red] {
2286
+ color: var(--dm-block-text-red);
2287
+ }
2288
+
2289
+ .dm-block-color-row {
2290
+ display: flex;
2291
+ flex-wrap: wrap;
2292
+ align-items: center;
2293
+ gap: 0.25rem;
2294
+ padding: 0.25rem 0.5rem;
2295
+ }
2296
+
2297
+ .dm-block-color-row-label {
2298
+ position: absolute;
2299
+ width: 1px;
2300
+ height: 1px;
2301
+ padding: 0;
2302
+ overflow: hidden;
2303
+ clip: rect(0, 0, 0, 0);
2304
+ white-space: nowrap;
2305
+ border: 0;
2306
+ }
2307
+
2308
+ .dm-block-color-swatch {
2309
+ display: inline-flex;
2310
+ align-items: center;
2311
+ justify-content: center;
2312
+ width: 1.5rem;
2313
+ height: 1.5rem;
2314
+ padding: 0;
2315
+ border: 1px solid var(--dm-border-color, #e5e7eb);
2316
+ border-radius: 50%;
2317
+ background: transparent;
2318
+ cursor: pointer;
2319
+ transition: transform 0.08s ease, box-shadow 0.08s ease;
2320
+ }
2321
+ .dm-block-color-swatch:hover {
2322
+ transform: scale(1.1);
2323
+ box-shadow: 0 0 0 2px var(--dm-accent-surface, rgba(37, 99, 235, 0.15));
2324
+ }
2325
+ .dm-block-color-swatch:focus-visible, .dm-block-color-swatch[aria-pressed=true] {
2326
+ outline: 2px solid var(--dm-accent, #2563eb);
2327
+ outline-offset: 1px;
2328
+ }
2329
+ .dm-block-color-swatch::before {
2330
+ content: "";
2331
+ display: block;
2332
+ width: 1rem;
2333
+ height: 1rem;
2334
+ border-radius: 50%;
2335
+ }
2336
+ .dm-block-color-swatch[data-color=null]::before {
2337
+ background: linear-gradient(to top right, transparent calc(50% - 1px), var(--dm-muted, #999) calc(50% - 1px), var(--dm-muted, #999) calc(50% + 1px), transparent calc(50% + 1px));
2338
+ border: 1px solid var(--dm-border-color, #e5e7eb);
2339
+ }
2340
+
2341
+ .dm-block-color-swatch--bg[data-color=gray]::before {
2342
+ background: var(--dm-block-bg-gray);
2343
+ }
2344
+ .dm-block-color-swatch--bg[data-color=brown]::before {
2345
+ background: var(--dm-block-bg-brown);
2346
+ }
2347
+ .dm-block-color-swatch--bg[data-color=orange]::before {
2348
+ background: var(--dm-block-bg-orange);
2349
+ }
2350
+ .dm-block-color-swatch--bg[data-color=yellow]::before {
2351
+ background: var(--dm-block-bg-yellow);
2352
+ }
2353
+ .dm-block-color-swatch--bg[data-color=green]::before {
2354
+ background: var(--dm-block-bg-green);
2355
+ }
2356
+ .dm-block-color-swatch--bg[data-color=blue]::before {
2357
+ background: var(--dm-block-bg-blue);
2358
+ }
2359
+ .dm-block-color-swatch--bg[data-color=purple]::before {
2360
+ background: var(--dm-block-bg-purple);
2361
+ }
2362
+ .dm-block-color-swatch--bg[data-color=pink]::before {
2363
+ background: var(--dm-block-bg-pink);
2364
+ }
2365
+ .dm-block-color-swatch--bg[data-color=red]::before {
2366
+ background: var(--dm-block-bg-red);
2367
+ }
2368
+
2369
+ .dm-block-color-swatch--text::before {
2370
+ content: "A";
2371
+ display: flex;
2372
+ align-items: center;
2373
+ justify-content: center;
2374
+ font-family: var(--dm-editor-font-family, system-ui, sans-serif);
2375
+ font-size: 0.75rem;
2376
+ font-weight: 600;
2377
+ background: var(--dm-surface, #f8f9fa);
2378
+ color: var(--dm-editor-text, #333);
2379
+ }
2380
+ .dm-block-color-swatch--text[data-color=gray]::before {
2381
+ color: var(--dm-block-text-gray);
2382
+ }
2383
+ .dm-block-color-swatch--text[data-color=brown]::before {
2384
+ color: var(--dm-block-text-brown);
2385
+ }
2386
+ .dm-block-color-swatch--text[data-color=orange]::before {
2387
+ color: var(--dm-block-text-orange);
2388
+ }
2389
+ .dm-block-color-swatch--text[data-color=yellow]::before {
2390
+ color: var(--dm-block-text-yellow);
2391
+ }
2392
+ .dm-block-color-swatch--text[data-color=green]::before {
2393
+ color: var(--dm-block-text-green);
2394
+ }
2395
+ .dm-block-color-swatch--text[data-color=blue]::before {
2396
+ color: var(--dm-block-text-blue);
2397
+ }
2398
+ .dm-block-color-swatch--text[data-color=purple]::before {
2399
+ color: var(--dm-block-text-purple);
2400
+ }
2401
+ .dm-block-color-swatch--text[data-color=pink]::before {
2402
+ color: var(--dm-block-text-pink);
2403
+ }
2404
+ .dm-block-color-swatch--text[data-color=red]::before {
2405
+ color: var(--dm-block-text-red);
2406
+ }
2407
+
2408
+ .dm-editor .ProseMirror span[data-bg-color] {
2409
+ padding-block: 0;
2410
+ padding-inline: 0.2rem;
2411
+ border-radius: 0.25rem;
2412
+ }
2413
+
2414
+ .dm-ncp-trigger {
2415
+ position: relative;
2416
+ display: inline-flex;
2417
+ flex-direction: column;
2418
+ align-items: center;
2419
+ justify-content: center;
2420
+ gap: 0.125rem;
2421
+ }
2422
+
2423
+ .dm-ncp-trigger-glyph {
2424
+ font-family: var(--dm-editor-font-family, system-ui, sans-serif);
2425
+ font-size: 0.95rem;
2426
+ font-weight: 600;
2427
+ line-height: 1;
2428
+ transform: translateY(2px);
2429
+ }
2430
+
2431
+ .dm-ncp-trigger-underline {
2432
+ width: 0.875rem;
2433
+ height: 0.125rem;
2434
+ border-radius: 0.0625rem;
2435
+ background-color: transparent;
2436
+ }
2437
+
2438
+ .dm-notion-color-picker {
2439
+ position: absolute;
2440
+ z-index: 60;
2441
+ display: flex;
2442
+ flex-direction: column;
2443
+ gap: 0.25rem;
2444
+ padding: 0.25rem;
2445
+ background: var(--dm-surface-elevated, var(--dm-surface, #ffffff));
2446
+ color: var(--dm-editor-text, inherit);
2447
+ border: 1px solid var(--dm-border-color, #e5e7eb);
2448
+ border-radius: 0.5rem;
2449
+ box-shadow: 0 8px 24px rgba(0, 0, 0, 0.18);
2450
+ }
2451
+ .dm-notion-color-picker:not([data-show]) {
2452
+ display: none;
2453
+ }
2454
+
2455
+ .dm-ncp-section {
2456
+ display: flex;
2457
+ flex-direction: column;
2458
+ gap: 0.25rem;
2459
+ }
2460
+
2461
+ .dm-ncp-label {
2462
+ font-size: 0.75rem;
2463
+ line-height: 1;
2464
+ font-weight: 500;
2465
+ color: var(--dm-muted, #6b7280);
2466
+ padding: 0.125rem 0.25rem;
2467
+ }
2468
+
2469
+ .dm-ncp-grid {
2470
+ display: grid;
2471
+ grid-template-columns: repeat(5, 1.5rem);
2472
+ gap: 0.25rem;
2473
+ padding: 0.25rem 0.5rem;
2474
+ justify-content: start;
2475
+ }
2476
+
2477
+ .dm-ncp-swatch {
2478
+ position: relative;
2479
+ display: inline-flex;
2480
+ align-items: center;
2481
+ justify-content: center;
2482
+ width: 1.5rem;
2483
+ height: 1.5rem;
2484
+ padding: 0;
2485
+ border: 1px solid var(--dm-border-color, #e5e7eb);
2486
+ border-radius: 50%;
2487
+ background: transparent;
2488
+ color: var(--dm-editor-text, #333);
2489
+ font-family: var(--dm-editor-font-family, system-ui, sans-serif);
2490
+ font-size: 0.75rem;
2491
+ font-weight: 600;
2492
+ line-height: 1;
2493
+ cursor: pointer;
2494
+ transition: transform 0.08s ease, box-shadow 0.08s ease;
2495
+ }
2496
+ .dm-ncp-swatch:hover {
2497
+ transform: scale(1.1);
2498
+ box-shadow: 0 0 0 2px var(--dm-accent-surface, rgba(37, 99, 235, 0.15));
2499
+ }
2500
+ .dm-ncp-swatch:focus-visible, .dm-ncp-swatch.dm-ncp-active {
2501
+ outline: 2px solid var(--dm-accent, #2563eb);
2502
+ outline-offset: 1px;
2503
+ }
2504
+
2505
+ .dm-ncp-swatch--text {
2506
+ background-color: var(--dm-surface, #f8f9fa);
2507
+ }
2508
+ .dm-ncp-swatch--text::before {
2509
+ content: "A";
2510
+ }
2511
+ .dm-ncp-swatch--text[data-color=null]::after {
2512
+ content: "";
2513
+ position: absolute;
2514
+ inset: 0;
2515
+ border-radius: inherit;
2516
+ pointer-events: none;
2517
+ background-image: linear-gradient(to top right, transparent calc(50% - 1px), var(--dm-muted, #999) calc(50% - 1px), var(--dm-muted, #999) calc(50% + 1px), transparent calc(50% + 1px));
2518
+ }
2519
+ .dm-ncp-swatch--text[data-color=gray]::before {
2520
+ color: var(--dm-block-text-gray);
2521
+ }
2522
+ .dm-ncp-swatch--text[data-color=brown]::before {
2523
+ color: var(--dm-block-text-brown);
2524
+ }
2525
+ .dm-ncp-swatch--text[data-color=orange]::before {
2526
+ color: var(--dm-block-text-orange);
2527
+ }
2528
+ .dm-ncp-swatch--text[data-color=yellow]::before {
2529
+ color: var(--dm-block-text-yellow);
2530
+ }
2531
+ .dm-ncp-swatch--text[data-color=green]::before {
2532
+ color: var(--dm-block-text-green);
2533
+ }
2534
+ .dm-ncp-swatch--text[data-color=blue]::before {
2535
+ color: var(--dm-block-text-blue);
2536
+ }
2537
+ .dm-ncp-swatch--text[data-color=purple]::before {
2538
+ color: var(--dm-block-text-purple);
2539
+ }
2540
+ .dm-ncp-swatch--text[data-color=pink]::before {
2541
+ color: var(--dm-block-text-pink);
2542
+ }
2543
+ .dm-ncp-swatch--text[data-color=red]::before {
2544
+ color: var(--dm-block-text-red);
2545
+ }
2546
+
2547
+ .dm-ncp-swatch--bg[data-color=null]::after {
2548
+ content: "";
2549
+ position: absolute;
2550
+ inset: 0;
2551
+ border-radius: inherit;
2552
+ pointer-events: none;
2553
+ background-image: linear-gradient(to top right, transparent calc(50% - 1px), var(--dm-muted, #999) calc(50% - 1px), var(--dm-muted, #999) calc(50% + 1px), transparent calc(50% + 1px));
2554
+ }
2555
+ .dm-ncp-swatch--bg[data-color=gray] {
2556
+ background-color: var(--dm-block-bg-gray);
2557
+ }
2558
+ .dm-ncp-swatch--bg[data-color=brown] {
2559
+ background-color: var(--dm-block-bg-brown);
2560
+ }
2561
+ .dm-ncp-swatch--bg[data-color=orange] {
2562
+ background-color: var(--dm-block-bg-orange);
2563
+ }
2564
+ .dm-ncp-swatch--bg[data-color=yellow] {
2565
+ background-color: var(--dm-block-bg-yellow);
2566
+ }
2567
+ .dm-ncp-swatch--bg[data-color=green] {
2568
+ background-color: var(--dm-block-bg-green);
2569
+ }
2570
+ .dm-ncp-swatch--bg[data-color=blue] {
2571
+ background-color: var(--dm-block-bg-blue);
2572
+ }
2573
+ .dm-ncp-swatch--bg[data-color=purple] {
2574
+ background-color: var(--dm-block-bg-purple);
2575
+ }
2576
+ .dm-ncp-swatch--bg[data-color=pink] {
2577
+ background-color: var(--dm-block-bg-pink);
2578
+ }
2579
+ .dm-ncp-swatch--bg[data-color=red] {
2580
+ background-color: var(--dm-block-bg-red);
2581
+ }
2582
+
2583
+ @media (max-width: 480px) {
2584
+ .dm-notion-color-picker {
2585
+ max-width: calc(100vw - 1rem);
2586
+ }
2587
+ }
2588
+ .dm-toc-outline {
2589
+ display: flex;
2590
+ flex-direction: column;
2591
+ align-items: flex-end;
2592
+ gap: var(--dm-toc-tick-gap, 10px);
2593
+ padding: var(--dm-toc-padding-block, 12px) var(--dm-toc-padding-inline, 8px);
2594
+ z-index: var(--dm-toc-z-index, 10);
2595
+ background: transparent;
2596
+ border: 0;
2597
+ margin: 0;
2598
+ pointer-events: auto;
2599
+ }
2600
+ .dm-toc-outline[data-anchor=editor] {
2601
+ position: sticky;
2602
+ top: var(--dm-toc-mid-top, 50vh);
2603
+ }
2604
+ .dm-toc-outline[data-anchor=editor][data-bottom-visible=true] {
2605
+ top: var(--dm-toc-editor-top, 1rem);
2606
+ }
2607
+ .dm-toc-outline[data-anchor=viewport] {
2608
+ position: fixed;
2609
+ top: 50%;
2610
+ right: var(--dm-toc-right-offset, 24px);
2611
+ transform: translateY(-50%);
2612
+ }
2613
+ .dm-toc-outline[data-state=hidden], .dm-toc-outline[data-viewport=mobile] {
2614
+ display: none;
2615
+ }
2616
+
2617
+ .dm-toc-outline-shell[data-anchor=editor] {
2618
+ position: absolute;
2619
+ top: 25px;
2620
+ bottom: 25px;
2621
+ right: var(--dm-toc-page-offset, 8px);
2622
+ z-index: var(--dm-toc-z-index, 10);
2623
+ pointer-events: none;
2624
+ }
2625
+ .dm-toc-outline-shell[data-anchor=editor]:has(.dm-toc-outline[data-state=hidden]), .dm-toc-outline-shell[data-anchor=editor]:has(.dm-toc-outline[data-viewport=mobile]) {
2626
+ display: none;
2627
+ }
2628
+
2629
+ .dm-toc-outline-shell[data-anchor=editor][data-mode=center] {
2630
+ display: flex;
2631
+ align-items: center;
2632
+ justify-content: flex-end;
2633
+ }
2634
+
2635
+ .dm-toc-outline-tick {
2636
+ appearance: none;
2637
+ border: 0;
2638
+ margin: 0;
2639
+ padding: 0;
2640
+ font: inherit;
2641
+ cursor: pointer;
2642
+ background: var(--dm-toc-tick-color, rgba(55, 53, 47, 0.4));
2643
+ height: var(--dm-toc-tick-height, 2px);
2644
+ border-radius: var(--dm-toc-tick-radius, 1px);
2645
+ width: var(--dm-toc-tick-h3-width, 8px);
2646
+ transition: background-color 120ms ease-out, width 120ms ease-out;
2647
+ }
2648
+ .dm-toc-outline-tick:hover {
2649
+ background: var(--dm-toc-tick-hover-color, rgba(55, 53, 47, 0.7));
2650
+ }
2651
+ .dm-toc-outline-tick:focus-visible {
2652
+ background: var(--dm-toc-tick-hover-color, rgba(55, 53, 47, 0.7));
2653
+ outline: 2px solid var(--dm-accent, #2563eb);
2654
+ outline-offset: 3px;
2655
+ }
2656
+ .dm-toc-outline-tick.dm-toc--active, .dm-toc-outline-tick[aria-current=location] {
2657
+ background: var(--dm-toc-tick-active-color, rgba(55, 53, 47, 0.95));
2658
+ }
2659
+ .dm-toc-outline-tick[data-level="1"] {
2660
+ width: var(--dm-toc-tick-h1-width, 18px);
2661
+ }
2662
+ .dm-toc-outline-tick[data-level="2"] {
2663
+ width: var(--dm-toc-tick-h2-width, 12px);
2664
+ }
2665
+ .dm-toc-outline-tick[data-level="3"] {
2666
+ width: var(--dm-toc-tick-h3-width, 8px);
2667
+ }
2668
+ .dm-toc-outline-tick[data-level="4"] {
2669
+ width: var(--dm-toc-tick-h4-width, 6px);
2670
+ }
2671
+ .dm-toc-outline-tick[data-level="5"] {
2672
+ width: var(--dm-toc-tick-h5-width, 5px);
2673
+ }
2674
+ .dm-toc-outline-tick[data-level="6"] {
2675
+ width: var(--dm-toc-tick-h6-width, 4px);
2676
+ }
2677
+
2678
+ .dm-toc-outline[data-state=expanded] .dm-toc-outline-tick {
2679
+ opacity: 0;
2680
+ pointer-events: none;
2681
+ }
2682
+
2683
+ .dm-toc-outline-card {
2684
+ position: absolute;
2685
+ right: 0;
2686
+ top: 50%;
2687
+ transform: translateY(calc(-50% + var(--dm-toc-card-shift-y, 0px))) translateX(var(--dm-toc-card-offset, 8px));
2688
+ min-width: var(--dm-toc-card-min-width, 180px);
2689
+ max-width: var(--dm-toc-card-max-width, 260px);
2690
+ max-height: calc(100vh - 2 * var(--dm-toc-card-viewport-margin, 16px));
2691
+ overflow-y: auto;
2692
+ padding: var(--dm-toc-card-padding-block, 6px) 0;
2693
+ background: var(--dm-toc-card-bg, rgba(255, 255, 255, 0.98));
2694
+ border: var(--dm-toc-card-border, 1px solid rgba(0, 0, 0, 0.06));
2695
+ border-radius: var(--dm-toc-card-radius, 6px);
2696
+ box-shadow: var(--dm-toc-card-shadow, 0 8px 24px rgba(0, 0, 0, 0.08));
2697
+ display: flex;
2698
+ flex-direction: column;
2699
+ align-items: stretch;
2700
+ opacity: 0;
2701
+ pointer-events: none;
2702
+ transition: opacity var(--dm-toc-card-transition, 180ms) ease-out, transform var(--dm-toc-card-transition, 180ms) ease-out;
2703
+ }
2704
+
2705
+ .dm-toc-outline[data-state=expanded] .dm-toc-outline-card {
2706
+ opacity: 1;
2707
+ pointer-events: auto;
2708
+ transform: translateY(calc(-50% + var(--dm-toc-card-shift-y, 0px))) translateX(0);
2709
+ }
2710
+
2711
+ .dm-toc-outline-row {
2712
+ appearance: none;
2713
+ border: 0;
2714
+ margin: 0;
2715
+ background: transparent;
2716
+ cursor: pointer;
2717
+ text-align: start;
2718
+ font: inherit;
2719
+ font-size: var(--dm-toc-row-font-size, 13px);
2720
+ line-height: var(--dm-toc-row-line-height, 1.4);
2721
+ color: var(--dm-toc-row-color, rgba(55, 53, 47, 0.7));
2722
+ padding: var(--dm-toc-row-padding-block, 4px) var(--dm-toc-row-padding-inline-end, 16px) var(--dm-toc-row-padding-block, 4px) var(--dm-toc-row-padding-inline-start, 12px);
2723
+ white-space: nowrap;
2724
+ overflow: hidden;
2725
+ text-overflow: ellipsis;
2726
+ border-radius: 3px;
2727
+ transition: background-color 120ms ease-out, color 120ms ease-out;
2728
+ }
2729
+ .dm-toc-outline-row:hover {
2730
+ background: var(--dm-toc-row-hover-bg, rgba(0, 0, 0, 0.04));
2731
+ }
2732
+ .dm-toc-outline-row:focus-visible {
2733
+ outline: 2px solid var(--dm-accent, #2563eb);
2734
+ outline-offset: -2px;
2735
+ }
2736
+ .dm-toc-outline-row.dm-toc--active, .dm-toc-outline-row[aria-current=location] {
2737
+ color: var(--dm-toc-row-active-color, rgba(55, 53, 47, 0.95));
2738
+ font-weight: var(--dm-toc-row-active-weight, 600);
2739
+ }
2740
+ .dm-toc-outline-row[data-level="1"] {
2741
+ padding-inline-start: var(--dm-toc-row-padding-inline-start, 12px);
2742
+ }
2743
+ .dm-toc-outline-row[data-level="2"] {
2744
+ padding-inline-start: calc(var(--dm-toc-row-padding-inline-start, 12px) + var(--dm-toc-row-indent, 14px));
2745
+ }
2746
+ .dm-toc-outline-row[data-level="3"] {
2747
+ padding-inline-start: calc(var(--dm-toc-row-padding-inline-start, 12px) + var(--dm-toc-row-indent, 14px) * 2);
2748
+ }
2749
+ .dm-toc-outline-row[data-level="4"] {
2750
+ padding-inline-start: calc(var(--dm-toc-row-padding-inline-start, 12px) + var(--dm-toc-row-indent, 14px) * 3);
2751
+ }
2752
+ .dm-toc-outline-row[data-level="5"] {
2753
+ padding-inline-start: calc(var(--dm-toc-row-padding-inline-start, 12px) + var(--dm-toc-row-indent, 14px) * 4);
2754
+ }
2755
+ .dm-toc-outline-row[data-level="6"] {
2756
+ padding-inline-start: calc(var(--dm-toc-row-padding-inline-start, 12px) + var(--dm-toc-row-indent, 14px) * 5);
2757
+ }
2758
+
2759
+ .dm-toc-block {
2760
+ display: block;
2761
+ margin-block: var(--dm-toc-block-margin-block, 1rem);
2762
+ padding: var(--dm-toc-block-padding-block, 12px) var(--dm-toc-block-padding-inline, 16px);
2763
+ background: var(--dm-toc-block-bg, rgba(0, 0, 0, 0.02));
2764
+ border: var(--dm-toc-block-border, 1px solid rgba(0, 0, 0, 0.08));
2765
+ border-radius: var(--dm-toc-block-radius, 6px);
2766
+ }
2767
+ .dm-toc-block.ProseMirror-selectednode {
2768
+ outline: 2px solid var(--dm-accent, #2563eb);
2769
+ outline-offset: 2px;
2770
+ }
2771
+
2772
+ .dm-toc-block-empty {
2773
+ margin: 0;
2774
+ color: var(--dm-toc-block-empty-color, rgba(55, 53, 47, 0.5));
2775
+ font-style: var(--dm-toc-block-empty-font-style, italic);
2776
+ }
2777
+
2778
+ .dm-toc-block-list {
2779
+ list-style: none;
2780
+ padding: 0;
2781
+ margin: 0;
2782
+ }
2783
+
2784
+ .dm-toc-block-item {
2785
+ margin: 0;
2786
+ }
2787
+
2788
+ .dm-toc-block-link {
2789
+ appearance: none;
2790
+ border: 0;
2791
+ background: transparent;
2792
+ cursor: pointer;
2793
+ font: inherit;
2794
+ font-size: var(--dm-toc-block-link-font-size, 0.9375rem);
2795
+ line-height: var(--dm-toc-block-link-line-height, 1.5);
2796
+ color: var(--dm-toc-block-link-color, rgba(55, 53, 47, 0.8));
2797
+ text-align: start;
2798
+ width: 100%;
2799
+ display: block;
2800
+ padding: var(--dm-toc-block-link-padding-block, 4px) var(--dm-toc-block-link-padding-inline, 8px);
2801
+ border-radius: var(--dm-toc-block-link-radius, 3px);
2802
+ transition: background-color 120ms ease-out, color 120ms ease-out;
2803
+ }
2804
+ .dm-toc-block-link:hover {
2805
+ color: var(--dm-toc-block-link-hover-color, rgb(55, 53, 47));
2806
+ background: var(--dm-toc-block-link-hover-bg, rgba(0, 0, 0, 0.04));
2807
+ }
2808
+ .dm-toc-block-link:focus-visible {
2809
+ outline: 2px solid var(--dm-accent, #2563eb);
2810
+ outline-offset: -2px;
2811
+ }
2812
+ .dm-toc-block-link.dm-toc-block-link--active, .dm-toc-block-link[aria-current=location] {
2813
+ color: var(--dm-toc-block-link-active-color, rgba(55, 53, 47, 0.95));
2814
+ font-weight: var(--dm-toc-block-link-active-weight, 600);
2815
+ }
2816
+ .dm-toc-block-link[data-level="1"] {
2817
+ padding-inline-start: var(--dm-toc-block-link-padding-inline, 8px);
2818
+ }
2819
+ .dm-toc-block-link[data-level="2"] {
2820
+ padding-inline-start: calc(var(--dm-toc-block-link-padding-inline, 8px) + var(--dm-toc-block-link-indent, 16px));
2821
+ }
2822
+ .dm-toc-block-link[data-level="3"] {
2823
+ padding-inline-start: calc(var(--dm-toc-block-link-padding-inline, 8px) + var(--dm-toc-block-link-indent, 16px) * 2);
2824
+ }
2825
+ .dm-toc-block-link[data-level="4"] {
2826
+ padding-inline-start: calc(var(--dm-toc-block-link-padding-inline, 8px) + var(--dm-toc-block-link-indent, 16px) * 3);
2827
+ }
2828
+ .dm-toc-block-link[data-level="5"] {
2829
+ padding-inline-start: calc(var(--dm-toc-block-link-padding-inline, 8px) + var(--dm-toc-block-link-indent, 16px) * 4);
2830
+ }
2831
+ .dm-toc-block-link[data-level="6"] {
2832
+ padding-inline-start: calc(var(--dm-toc-block-link-padding-inline, 8px) + var(--dm-toc-block-link-indent, 16px) * 5);
2833
+ }
2834
+
2835
+ @media (prefers-reduced-motion: reduce) {
2836
+ .dm-toc-outline-tick,
2837
+ .dm-toc-outline-card,
2838
+ .dm-toc-outline-row,
2839
+ .dm-toc-block-link {
2840
+ transition: none;
2841
+ }
2842
+ .dm-toc-outline-card {
2843
+ transform: translateY(calc(-50% + var(--dm-toc-card-shift-y, 0px))) translateX(0);
2844
+ }
2845
+ }
2846
+ @media print {
2847
+ .dm-toc-outline {
2848
+ display: none;
2849
+ }
2850
+ .dm-toc-block {
2851
+ background: transparent;
2852
+ border-color: rgba(0, 0, 0, 0.2);
2853
+ }
2854
+ }
2855
+ @media (forced-colors: active) {
2856
+ .dm-toc-outline-tick {
2857
+ background: ButtonText;
2858
+ border: 1px solid ButtonText;
2859
+ }
2860
+ .dm-toc-outline-tick.dm-toc--active, .dm-toc-outline-tick[aria-current=location] {
2861
+ background: Highlight;
2862
+ border-color: Highlight;
2863
+ }
2864
+ .dm-toc-outline-card {
2865
+ border: 1px solid ButtonText;
2866
+ }
2867
+ .dm-toc-outline-row.dm-toc--active, .dm-toc-outline-row.dm-toc-block-link--active, .dm-toc-outline-row[aria-current=location],
2868
+ .dm-toc-block-link.dm-toc--active,
2869
+ .dm-toc-block-link.dm-toc-block-link--active,
2870
+ .dm-toc-block-link[aria-current=location] {
2871
+ color: Highlight;
2872
+ }
2873
+ .dm-toc-block {
2874
+ border: 1px solid ButtonText;
2875
+ }
2876
+ }
2877
+ .dm-editor.dm-notion-mode {
2878
+ border: none;
2879
+ border-radius: 0;
2880
+ box-shadow: none;
2881
+ background: transparent;
2882
+ max-width: 38rem;
2883
+ margin: 0 auto;
2884
+ --dm-editor-line-height: 1.7;
2885
+ --dm-editor-padding: 0;
2886
+ --dm-block-handle-gutter: 0;
2887
+ --dm-block-handle-left: -3.5rem;
2888
+ --dm-task-checkbox-top: 0.45em;
2889
+ }
2890
+ .dm-editor.dm-notion-mode .ProseMirror {
2891
+ min-height: 60vh;
2892
+ outline: none;
2893
+ }
2894
+ .dm-editor.dm-notion-mode .ProseMirror h1 {
2895
+ font-weight: 700;
2896
+ margin-top: 1.5rem;
2897
+ margin-bottom: 0.75rem;
2898
+ }
2899
+ .dm-editor.dm-notion-mode .ProseMirror h2 {
2900
+ font-weight: 600;
2901
+ margin-top: 1.5rem;
2902
+ margin-bottom: 0.5rem;
2903
+ }
2904
+ .dm-editor.dm-notion-mode .ProseMirror h3 {
2905
+ font-weight: 600;
2906
+ margin-top: 1.25rem;
2907
+ margin-bottom: 0.375rem;
2908
+ }
2909
+ .dm-editor.dm-notion-mode .ProseMirror p {
2910
+ margin: 0.25rem 0;
2911
+ }
2912
+ .dm-editor.dm-notion-mode .ProseMirror td > p,
2913
+ .dm-editor.dm-notion-mode .ProseMirror th > p {
2914
+ margin: 0;
2915
+ }
2916
+ .dm-editor.dm-notion-mode .ProseMirror td .is-empty::before,
2917
+ .dm-editor.dm-notion-mode .ProseMirror th .is-empty::before {
2918
+ content: none;
2919
+ }
2920
+
2921
+ .dm-theme-light,
2922
+ .dm-theme-light .dm-editor,
2923
+ .dm-theme-light .dm-toolbar,
2924
+ .dm-theme-light .dm-table-controls-dropdown {
2925
+ --dm-bg: #ffffff;
2926
+ --dm-text: #1a1a1a;
2927
+ --dm-muted: #999999;
2928
+ --dm-surface: #f8f9fa;
2929
+ --dm-border-color: #e0e0e0;
2930
+ --dm-hover: rgba(0, 0, 0, 0.06);
2931
+ --dm-active: rgba(0, 0, 0, 0.12);
2932
+ --dm-accent: #2563eb;
2933
+ --dm-accent-hover: #1d4ed8;
2934
+ --dm-accent-surface: rgba(37, 99, 235, 0.1);
2935
+ --dm-focus-color: rgba(66, 133, 244, 0.3);
2936
+ --dm-selection: rgba(66, 133, 244, 0.2);
2937
+ --dm-code-surface: #f5f5f5;
2938
+ --dm-code-color: #d63384;
2939
+ --dm-highlight-bg: #fff3cd;
2940
+ --dm-syntax-keyword: #c72031;
2941
+ --dm-syntax-entity: #6f42c1;
2942
+ --dm-syntax-constant: #005cc5;
2943
+ --dm-syntax-string: #032f62;
2944
+ --dm-syntax-variable: #d35400;
2945
+ --dm-syntax-comment: #57606a;
2946
+ --dm-syntax-tag: #22863a;
2947
+ --dm-syntax-addition: #22863a;
2948
+ --dm-syntax-addition-bg: #f0fff4;
2949
+ --dm-syntax-deletion: #b31d28;
2950
+ --dm-syntax-deletion-bg: #ffeef0;
2951
+ }
2952
+
2953
+ .dm-theme-dark,
2954
+ .dm-theme-dark .dm-editor,
2955
+ .dm-theme-dark .dm-toolbar,
2956
+ .dm-theme-dark .dm-bubble-menu,
2957
+ .dm-theme-dark .dm-floating-menu,
2958
+ .dm-theme-dark .dm-emoji-picker,
2959
+ .dm-theme-dark .dm-emoji-suggestion,
1824
2960
  .dm-theme-dark .dm-mention-suggestion,
1825
- .dm-theme-dark .dm-table-controls-dropdown {
2961
+ .dm-theme-dark .dm-table-controls-dropdown,
2962
+ .dm-theme-dark .dm-slash-command-menu,
2963
+ .dm-theme-dark .dm-block-context-menu,
2964
+ .dm-theme-dark .dm-link-popover,
2965
+ .dm-theme-dark .dm-image-popover {
1826
2966
  --dm-color-scheme: dark;
1827
2967
  --dm-bg: #1e1e1e;
1828
2968
  --dm-text: #e0e0e0;
@@ -1839,8 +2979,12 @@ img.ProseMirror-separator {
1839
2979
  --dm-code-surface: #2d2d2d;
1840
2980
  --dm-code-color: inherit;
1841
2981
  --dm-highlight-bg: rgba(255, 243, 205, 0.2);
2982
+ --dm-scrollbar-thumb: rgba(255, 255, 255, 0.18);
2983
+ --dm-scrollbar-thumb-hover: rgba(255, 255, 255, 0.32);
2984
+ --dm-popover-shadow: 0 10px 25px rgba(0, 0, 0, 0.4), 0 4px 10px rgba(0, 0, 0, 0.25);
1842
2985
  --dm-blockquote-border: 3px solid #555555;
1843
2986
  --dm-blockquote-color: #a0a0a0;
2987
+ --dm-block-context-active-bg: rgba(255, 255, 255, 0.05);
1844
2988
  --dm-syntax-keyword: #ff7b72;
1845
2989
  --dm-syntax-entity: #d2a8ff;
1846
2990
  --dm-syntax-constant: #79c0ff;
@@ -1852,6 +2996,25 @@ img.ProseMirror-separator {
1852
2996
  --dm-syntax-addition-bg: #033a16;
1853
2997
  --dm-syntax-deletion: #ffdcd7;
1854
2998
  --dm-syntax-deletion-bg: #67060c;
2999
+ --dm-block-bg-gray: #2f2f2f;
3000
+ --dm-block-bg-brown: #4a3228;
3001
+ --dm-block-bg-orange: #5c3b1e;
3002
+ --dm-block-bg-yellow: #564328;
3003
+ --dm-block-bg-green: #243d30;
3004
+ --dm-block-bg-blue: #143a4e;
3005
+ --dm-block-bg-purple: #3c2d49;
3006
+ --dm-block-bg-pink: #4e2c3c;
3007
+ --dm-block-bg-red: #5c1e1e;
3008
+ --dm-block-text-gray: #9b9a97;
3009
+ --dm-block-text-brown: #ba856f;
3010
+ --dm-block-text-orange: #d68a52;
3011
+ --dm-block-text-yellow: #ca9849;
3012
+ --dm-block-text-green: #6db285;
3013
+ --dm-block-text-blue: #7a9bd6;
3014
+ --dm-block-text-purple: #a877d8;
3015
+ --dm-block-text-pink: #dc6da4;
3016
+ --dm-block-text-red: #df5452;
3017
+ --dm-block-selected-halo: rgba(112, 207, 248, 0.35);
1855
3018
  }
1856
3019
 
1857
3020
  @media (prefers-color-scheme: dark) {
@@ -1859,10 +3022,15 @@ img.ProseMirror-separator {
1859
3022
  .dm-theme-auto .dm-editor,
1860
3023
  .dm-theme-auto .dm-toolbar,
1861
3024
  .dm-theme-auto .dm-bubble-menu,
3025
+ .dm-theme-auto .dm-floating-menu,
1862
3026
  .dm-theme-auto .dm-emoji-picker,
1863
3027
  .dm-theme-auto .dm-emoji-suggestion,
1864
3028
  .dm-theme-auto .dm-mention-suggestion,
1865
- .dm-theme-auto .dm-table-controls-dropdown {
3029
+ .dm-theme-auto .dm-table-controls-dropdown,
3030
+ .dm-theme-auto .dm-slash-command-menu,
3031
+ .dm-theme-auto .dm-block-context-menu,
3032
+ .dm-theme-auto .dm-link-popover,
3033
+ .dm-theme-auto .dm-image-popover {
1866
3034
  --dm-color-scheme: dark;
1867
3035
  --dm-bg: #1e1e1e;
1868
3036
  --dm-text: #e0e0e0;
@@ -1879,8 +3047,12 @@ img.ProseMirror-separator {
1879
3047
  --dm-code-surface: #2d2d2d;
1880
3048
  --dm-code-color: inherit;
1881
3049
  --dm-highlight-bg: rgba(255, 243, 205, 0.2);
3050
+ --dm-scrollbar-thumb: rgba(255, 255, 255, 0.18);
3051
+ --dm-scrollbar-thumb-hover: rgba(255, 255, 255, 0.32);
3052
+ --dm-popover-shadow: 0 10px 25px rgba(0, 0, 0, 0.4), 0 4px 10px rgba(0, 0, 0, 0.25);
1882
3053
  --dm-blockquote-border: 3px solid #555555;
1883
3054
  --dm-blockquote-color: #a0a0a0;
3055
+ --dm-block-context-active-bg: rgba(255, 255, 255, 0.05);
1884
3056
  --dm-syntax-keyword: #ff7b72;
1885
3057
  --dm-syntax-entity: #d2a8ff;
1886
3058
  --dm-syntax-constant: #79c0ff;
@@ -1892,6 +3064,75 @@ img.ProseMirror-separator {
1892
3064
  --dm-syntax-addition-bg: #033a16;
1893
3065
  --dm-syntax-deletion: #ffdcd7;
1894
3066
  --dm-syntax-deletion-bg: #67060c;
3067
+ --dm-block-bg-gray: #2f2f2f;
3068
+ --dm-block-bg-brown: #4a3228;
3069
+ --dm-block-bg-orange: #5c3b1e;
3070
+ --dm-block-bg-yellow: #564328;
3071
+ --dm-block-bg-green: #243d30;
3072
+ --dm-block-bg-blue: #143a4e;
3073
+ --dm-block-bg-purple: #3c2d49;
3074
+ --dm-block-bg-pink: #4e2c3c;
3075
+ --dm-block-bg-red: #5c1e1e;
3076
+ --dm-block-text-gray: #9b9a97;
3077
+ --dm-block-text-brown: #ba856f;
3078
+ --dm-block-text-orange: #d68a52;
3079
+ --dm-block-text-yellow: #ca9849;
3080
+ --dm-block-text-green: #6db285;
3081
+ --dm-block-text-blue: #7a9bd6;
3082
+ --dm-block-text-purple: #a877d8;
3083
+ --dm-block-text-pink: #dc6da4;
3084
+ --dm-block-text-red: #df5452;
3085
+ --dm-block-selected-halo: rgba(112, 207, 248, 0.35);
3086
+ }
3087
+ }
3088
+ .dm-theme-dark .dm-toc-outline,
3089
+ .dm-theme-dark.dm-toc-outline {
3090
+ --dm-toc-tick-color: rgba(255, 255, 255, 0.3);
3091
+ --dm-toc-tick-hover-color: rgba(255, 255, 255, 0.6);
3092
+ --dm-toc-tick-active-color: rgba(255, 255, 255, 0.95);
3093
+ --dm-toc-card-bg: rgba(45, 50, 56, 0.98);
3094
+ --dm-toc-card-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
3095
+ --dm-toc-card-border: 1px solid rgba(255, 255, 255, 0.08);
3096
+ --dm-toc-row-color: rgba(255, 255, 255, 0.7);
3097
+ --dm-toc-row-hover-bg: rgba(255, 255, 255, 0.06);
3098
+ --dm-toc-row-active-color: rgba(255, 255, 255, 0.95);
3099
+ }
3100
+
3101
+ .dm-theme-dark .dm-toc-block,
3102
+ .dm-theme-dark.dm-toc-block {
3103
+ --dm-toc-block-bg: rgba(255, 255, 255, 0.04);
3104
+ --dm-toc-block-border: 1px solid rgba(255, 255, 255, 0.08);
3105
+ --dm-toc-block-empty-color: rgba(255, 255, 255, 0.4);
3106
+ --dm-toc-block-link-color: rgba(255, 255, 255, 0.7);
3107
+ --dm-toc-block-link-hover-color: rgba(255, 255, 255, 0.95);
3108
+ --dm-toc-block-link-hover-bg: rgba(255, 255, 255, 0.06);
3109
+ --dm-toc-block-link-active-color: rgba(255, 255, 255, 0.95);
3110
+ }
3111
+
3112
+ @media (prefers-color-scheme: dark) {
3113
+ .dm-theme-auto .dm-toc-block,
3114
+ .dm-theme-auto.dm-toc-block {
3115
+ --dm-toc-block-bg: rgba(255, 255, 255, 0.04);
3116
+ --dm-toc-block-border: 1px solid rgba(255, 255, 255, 0.08);
3117
+ --dm-toc-block-empty-color: rgba(255, 255, 255, 0.4);
3118
+ --dm-toc-block-link-color: rgba(255, 255, 255, 0.7);
3119
+ --dm-toc-block-link-hover-color: rgba(255, 255, 255, 0.95);
3120
+ --dm-toc-block-link-hover-bg: rgba(255, 255, 255, 0.06);
3121
+ --dm-toc-block-link-active-color: rgba(255, 255, 255, 0.95);
3122
+ }
3123
+ }
3124
+ @media (prefers-color-scheme: dark) {
3125
+ .dm-theme-auto .dm-toc-outline,
3126
+ .dm-theme-auto.dm-toc-outline {
3127
+ --dm-toc-tick-color: rgba(255, 255, 255, 0.3);
3128
+ --dm-toc-tick-hover-color: rgba(255, 255, 255, 0.6);
3129
+ --dm-toc-tick-active-color: rgba(255, 255, 255, 0.95);
3130
+ --dm-toc-card-bg: rgba(45, 50, 56, 0.98);
3131
+ --dm-toc-card-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
3132
+ --dm-toc-card-border: 1px solid rgba(255, 255, 255, 0.08);
3133
+ --dm-toc-row-color: rgba(255, 255, 255, 0.7);
3134
+ --dm-toc-row-hover-bg: rgba(255, 255, 255, 0.06);
3135
+ --dm-toc-row-active-color: rgba(255, 255, 255, 0.95);
1895
3136
  }
1896
3137
  }
1897
3138
  @media (prefers-reduced-motion: reduce) {
@@ -1926,7 +3167,13 @@ img.ProseMirror-separator {
1926
3167
  .dm-table-align-item,
1927
3168
  .dm-image-popover-btn,
1928
3169
  .dm-link-popover-btn,
3170
+ .dm-block-handle,
3171
+ .dm-block-handle-btn,
3172
+ .dm-block-color-swatch,
3173
+ .dm-slash-command-item,
3174
+ .dm-block-context-menu-item,
1929
3175
  .dm-editor .ProseMirror div[data-type=details] > button[type=button]::before {
1930
3176
  transition: none;
3177
+ transform: none;
1931
3178
  }
1932
3179
  }