@byline/admin 2.5.1 → 2.6.0

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 (260) hide show
  1. package/dist/fields/array/array-field.d.ts +14 -0
  2. package/dist/fields/array/array-field.js +177 -0
  3. package/dist/fields/array/array-field.module.js +11 -0
  4. package/dist/fields/array/array-field_module.css +32 -0
  5. package/dist/fields/blocks/blocks-field.d.ts +13 -0
  6. package/dist/fields/blocks/blocks-field.js +245 -0
  7. package/dist/fields/blocks/blocks-field.module.js +26 -0
  8. package/dist/fields/blocks/blocks-field_module.css +107 -0
  9. package/dist/fields/checkbox/checkbox-field.d.ts +16 -0
  10. package/dist/fields/checkbox/checkbox-field.js +28 -0
  11. package/dist/fields/checkbox/checkbox-field.module.js +6 -0
  12. package/dist/fields/checkbox/checkbox-field_module.css +4 -0
  13. package/dist/fields/column-formatter.d.ts +20 -0
  14. package/dist/fields/column-formatter.js +15 -0
  15. package/dist/fields/date-time-formatter.d.ts +16 -0
  16. package/dist/fields/date-time-formatter.js +8 -0
  17. package/dist/fields/datetime/datetime-field.d.ts +16 -0
  18. package/dist/fields/datetime/datetime-field.js +37 -0
  19. package/dist/fields/datetime/datetime-field.module.js +5 -0
  20. package/dist/fields/datetime/datetime-field_module.css +4 -0
  21. package/dist/fields/draggable-context-menu.d.ts +6 -0
  22. package/dist/fields/draggable-context-menu.js +85 -0
  23. package/dist/fields/draggable-context-menu.module.js +15 -0
  24. package/dist/fields/draggable-context-menu_module.css +91 -0
  25. package/dist/fields/field-helpers.d.ts +26 -0
  26. package/dist/fields/field-helpers.js +50 -0
  27. package/dist/fields/field-renderer.d.ts +37 -0
  28. package/dist/fields/field-renderer.js +206 -0
  29. package/dist/fields/field-renderer.module.js +8 -0
  30. package/dist/fields/field-renderer_module.css +11 -0
  31. package/dist/fields/field-services-context.d.ts +16 -0
  32. package/dist/fields/field-services-context.js +13 -0
  33. package/dist/fields/field-services-types.d.ts +63 -0
  34. package/dist/fields/field-services-types.js +1 -0
  35. package/dist/fields/file/file-field.d.ts +19 -0
  36. package/dist/fields/file/file-field.js +225 -0
  37. package/dist/fields/file/file-field.module.js +18 -0
  38. package/dist/fields/file/file-field_module.css +131 -0
  39. package/dist/fields/file/file-upload-field.d.ts +21 -0
  40. package/dist/fields/file/file-upload-field.js +130 -0
  41. package/dist/fields/file/file-upload-field.module.js +15 -0
  42. package/dist/fields/file/file-upload-field_module.css +74 -0
  43. package/dist/fields/group/group-field.d.ts +15 -0
  44. package/dist/fields/group/group-field.js +59 -0
  45. package/dist/fields/group/group-field.module.js +9 -0
  46. package/dist/fields/group/group-field_module.css +27 -0
  47. package/dist/fields/image/image-field.d.ts +19 -0
  48. package/dist/fields/image/image-field.js +241 -0
  49. package/dist/fields/image/image-field.module.js +22 -0
  50. package/dist/fields/image/image-field_module.css +121 -0
  51. package/dist/fields/image/image-upload-field.d.ts +21 -0
  52. package/dist/fields/image/image-upload-field.js +190 -0
  53. package/dist/fields/image/image-upload-field.module.js +19 -0
  54. package/dist/fields/image/image-upload-field_module.css +92 -0
  55. package/dist/fields/local-date-time.d.ts +27 -0
  56. package/dist/fields/local-date-time.js +49 -0
  57. package/dist/fields/locale-badge.d.ts +18 -0
  58. package/dist/fields/locale-badge.js +10 -0
  59. package/dist/fields/locale-badge.module.js +5 -0
  60. package/dist/fields/locale-badge_module.css +27 -0
  61. package/dist/fields/numerical/numerical-field.d.ts +18 -0
  62. package/dist/fields/numerical/numerical-field.js +74 -0
  63. package/dist/fields/relation/relation-display.d.ts +40 -0
  64. package/dist/fields/relation/relation-display.js +58 -0
  65. package/dist/fields/relation/relation-display.module.js +9 -0
  66. package/dist/fields/relation/relation-display_module.css +21 -0
  67. package/dist/fields/relation/relation-field.d.ts +18 -0
  68. package/dist/fields/relation/relation-field.js +138 -0
  69. package/dist/fields/relation/relation-field.module.js +13 -0
  70. package/dist/fields/relation/relation-field_module.css +62 -0
  71. package/dist/fields/relation/relation-picker.d.ts +49 -0
  72. package/dist/fields/relation/relation-picker.js +236 -0
  73. package/dist/fields/relation/relation-picker.module.js +26 -0
  74. package/dist/fields/relation/relation-picker_module.css +124 -0
  75. package/dist/fields/relation/relation-summary.d.ts +31 -0
  76. package/dist/fields/relation/relation-summary.js +50 -0
  77. package/dist/fields/relation/relation-summary.module.js +11 -0
  78. package/dist/fields/relation/relation-summary_module.css +37 -0
  79. package/dist/fields/select/select-field.d.ts +16 -0
  80. package/dist/fields/select/select-field.js +50 -0
  81. package/dist/fields/select/select-field.module.js +5 -0
  82. package/dist/fields/select/select-field_module.css +4 -0
  83. package/dist/fields/sortable-item.d.ts +15 -0
  84. package/dist/fields/sortable-item.js +81 -0
  85. package/dist/fields/sortable-item.module.js +22 -0
  86. package/dist/fields/sortable-item_module.css +124 -0
  87. package/dist/fields/text/text-field.d.ts +20 -0
  88. package/dist/fields/text/text-field.js +104 -0
  89. package/dist/fields/text/text-field.module.js +6 -0
  90. package/dist/fields/text/text-field_module.css +5 -0
  91. package/dist/fields/text-area/text-area-field.d.ts +20 -0
  92. package/dist/fields/text-area/text-area-field.js +105 -0
  93. package/dist/fields/text-area/text-area-field.module.js +6 -0
  94. package/dist/fields/text-area/text-area-field_module.css +5 -0
  95. package/dist/fields/use-field-change-handler.d.ts +23 -0
  96. package/dist/fields/use-field-change-handler.js +52 -0
  97. package/dist/forms/document-actions.d.ts +48 -0
  98. package/dist/forms/document-actions.js +475 -0
  99. package/dist/forms/document-actions.module.js +34 -0
  100. package/dist/forms/document-actions_module.css +118 -0
  101. package/dist/forms/form-context.d.ts +89 -0
  102. package/dist/forms/form-context.js +466 -0
  103. package/dist/forms/form-renderer.d.ts +98 -0
  104. package/dist/forms/form-renderer.js +597 -0
  105. package/dist/forms/form-renderer.module.js +46 -0
  106. package/dist/forms/form-renderer_module.css +245 -0
  107. package/dist/forms/navigation-guard.d.ts +54 -0
  108. package/dist/forms/navigation-guard.js +22 -0
  109. package/dist/forms/path-widget.d.ts +36 -0
  110. package/dist/forms/path-widget.js +116 -0
  111. package/dist/forms/path-widget.module.js +8 -0
  112. package/dist/forms/path-widget_module.css +29 -0
  113. package/dist/forms/upload-executor.d.ts +57 -0
  114. package/dist/forms/upload-executor.js +94 -0
  115. package/dist/lib/translate-validation-error.d.ts +36 -0
  116. package/dist/lib/translate-validation-error.js +11 -0
  117. package/dist/modules/admin-account/commands.d.ts +2 -1
  118. package/dist/modules/admin-account/commands.js +13 -2
  119. package/dist/modules/admin-account/components/change-password.js +45 -36
  120. package/dist/modules/admin-account/components/container.js +185 -134
  121. package/dist/modules/admin-account/components/preferences.d.ts +8 -0
  122. package/dist/modules/admin-account/components/preferences.js +152 -0
  123. package/dist/modules/admin-account/components/preferences.module.js +11 -0
  124. package/dist/modules/admin-account/components/preferences_module.css +41 -0
  125. package/dist/modules/admin-account/components/update.js +50 -31
  126. package/dist/modules/admin-account/index.d.ts +3 -3
  127. package/dist/modules/admin-account/index.js +2 -2
  128. package/dist/modules/admin-account/schemas.d.ts +4 -0
  129. package/dist/modules/admin-account/schemas.js +4 -1
  130. package/dist/modules/admin-account/service.d.ts +1 -0
  131. package/dist/modules/admin-account/service.js +8 -0
  132. package/dist/modules/admin-permissions/components/inspector.js +31 -41
  133. package/dist/modules/admin-roles/components/create.js +43 -26
  134. package/dist/modules/admin-roles/components/permissions.js +26 -35
  135. package/dist/modules/admin-roles/components/update.js +26 -16
  136. package/dist/modules/admin-users/components/create.js +60 -40
  137. package/dist/modules/admin-users/components/roles.js +9 -15
  138. package/dist/modules/admin-users/components/set-password.js +30 -31
  139. package/dist/modules/admin-users/components/update.js +58 -39
  140. package/dist/modules/admin-users/dto.js +1 -0
  141. package/dist/modules/admin-users/repository.d.ts +17 -0
  142. package/dist/modules/admin-users/schemas.d.ts +4 -0
  143. package/dist/modules/admin-users/schemas.js +6 -2
  144. package/dist/modules/auth/components/sign-in-form.js +10 -8
  145. package/dist/presentation/group.d.ts +27 -0
  146. package/dist/presentation/group.js +14 -0
  147. package/dist/presentation/group.module.js +6 -0
  148. package/dist/presentation/group_module.css +19 -0
  149. package/dist/presentation/row.d.ts +25 -0
  150. package/dist/presentation/row.js +8 -0
  151. package/dist/presentation/row.module.js +5 -0
  152. package/dist/presentation/row_module.css +18 -0
  153. package/dist/presentation/tabs.d.ts +25 -0
  154. package/dist/presentation/tabs.js +39 -0
  155. package/dist/presentation/tabs.module.js +10 -0
  156. package/dist/presentation/tabs_module.css +68 -0
  157. package/dist/react.d.ts +66 -0
  158. package/dist/react.js +36 -0
  159. package/dist/services/admin-services-types.d.ts +16 -0
  160. package/dist/widgets/diff-viewer/diff-modal.d.ts +22 -0
  161. package/dist/widgets/diff-viewer/diff-modal.js +149 -0
  162. package/dist/widgets/diff-viewer/diff-modal.module.js +14 -0
  163. package/dist/widgets/diff-viewer/diff-modal_module.css +56 -0
  164. package/dist/widgets/status-badge/status-badge.d.ts +25 -0
  165. package/dist/widgets/status-badge/status-badge.js +37 -0
  166. package/dist/widgets/status-badge/status-badge.module.js +7 -0
  167. package/dist/widgets/status-badge/status-badge_module.css +20 -0
  168. package/package.json +14 -4
  169. package/src/fields/array/array-field.module.css +48 -0
  170. package/src/fields/array/array-field.tsx +267 -0
  171. package/src/fields/blocks/blocks-field.module.css +148 -0
  172. package/src/fields/blocks/blocks-field.tsx +323 -0
  173. package/src/fields/checkbox/checkbox-field.module.css +4 -0
  174. package/src/fields/checkbox/checkbox-field.tsx +54 -0
  175. package/src/fields/column-formatter.tsx +31 -0
  176. package/src/fields/date-time-formatter.tsx +22 -0
  177. package/src/fields/datetime/datetime-field.module.css +13 -0
  178. package/src/fields/datetime/datetime-field.tsx +54 -0
  179. package/src/fields/draggable-context-menu.module.css +127 -0
  180. package/src/fields/draggable-context-menu.tsx +87 -0
  181. package/src/fields/field-helpers.ts +69 -0
  182. package/src/fields/field-renderer.module.css +22 -0
  183. package/src/fields/field-renderer.tsx +288 -0
  184. package/src/fields/field-services-context.tsx +35 -0
  185. package/src/fields/field-services-types.ts +68 -0
  186. package/src/fields/file/file-field.module.css +153 -0
  187. package/src/fields/file/file-field.tsx +286 -0
  188. package/src/fields/file/file-upload-field.module.css +101 -0
  189. package/src/fields/file/file-upload-field.tsx +187 -0
  190. package/src/fields/group/group-field.module.css +43 -0
  191. package/src/fields/group/group-field.tsx +84 -0
  192. package/src/fields/image/image-field.module.css +155 -0
  193. package/src/fields/image/image-field.tsx +306 -0
  194. package/src/fields/image/image-upload-field.module.css +123 -0
  195. package/src/fields/image/image-upload-field.tsx +276 -0
  196. package/src/fields/local-date-time.tsx +88 -0
  197. package/src/fields/locale-badge.module.css +37 -0
  198. package/src/fields/locale-badge.tsx +32 -0
  199. package/src/fields/numerical/numerical-field.tsx +114 -0
  200. package/src/fields/relation/relation-display.module.css +36 -0
  201. package/src/fields/relation/relation-display.tsx +130 -0
  202. package/src/fields/relation/relation-field.module.css +83 -0
  203. package/src/fields/relation/relation-field.tsx +211 -0
  204. package/src/fields/relation/relation-picker.module.css +168 -0
  205. package/src/fields/relation/relation-picker.tsx +326 -0
  206. package/src/fields/relation/relation-summary.module.css +55 -0
  207. package/src/fields/relation/relation-summary.tsx +123 -0
  208. package/src/fields/select/select-field.module.css +13 -0
  209. package/src/fields/select/select-field.tsx +61 -0
  210. package/src/fields/sortable-item.module.css +167 -0
  211. package/src/fields/sortable-item.tsx +106 -0
  212. package/src/fields/text/text-field.module.css +13 -0
  213. package/src/fields/text/text-field.tsx +146 -0
  214. package/src/fields/text-area/text-area-field.module.css +13 -0
  215. package/src/fields/text-area/text-area-field.tsx +147 -0
  216. package/src/fields/use-field-change-handler.ts +112 -0
  217. package/src/forms/document-actions.module.css +160 -0
  218. package/src/forms/document-actions.tsx +482 -0
  219. package/src/forms/form-context.tsx +704 -0
  220. package/src/forms/form-renderer.module.css +321 -0
  221. package/src/forms/form-renderer.tsx +891 -0
  222. package/src/forms/navigation-guard.tsx +98 -0
  223. package/src/forms/path-widget.module.css +41 -0
  224. package/src/forms/path-widget.test.tsx +217 -0
  225. package/src/forms/path-widget.tsx +183 -0
  226. package/src/forms/upload-executor.ts +192 -0
  227. package/src/lib/translate-validation-error.ts +56 -0
  228. package/src/modules/admin-account/commands.ts +13 -0
  229. package/src/modules/admin-account/components/change-password.tsx +46 -31
  230. package/src/modules/admin-account/components/container.tsx +83 -38
  231. package/src/modules/admin-account/components/preferences.module.css +60 -0
  232. package/src/modules/admin-account/components/preferences.tsx +203 -0
  233. package/src/modules/admin-account/components/update.tsx +53 -27
  234. package/src/modules/admin-account/index.ts +3 -0
  235. package/src/modules/admin-account/schemas.ts +13 -0
  236. package/src/modules/admin-account/service.ts +12 -0
  237. package/src/modules/admin-permissions/components/inspector.tsx +22 -14
  238. package/src/modules/admin-roles/components/create.tsx +51 -23
  239. package/src/modules/admin-roles/components/permissions.tsx +25 -21
  240. package/src/modules/admin-roles/components/update.tsx +37 -19
  241. package/src/modules/admin-users/components/create.tsx +63 -34
  242. package/src/modules/admin-users/components/roles.tsx +9 -8
  243. package/src/modules/admin-users/components/set-password.tsx +34 -28
  244. package/src/modules/admin-users/components/update.tsx +58 -36
  245. package/src/modules/admin-users/dto.ts +1 -0
  246. package/src/modules/admin-users/repository.ts +17 -0
  247. package/src/modules/admin-users/schemas.ts +12 -0
  248. package/src/modules/auth/components/sign-in-form.tsx +14 -8
  249. package/src/presentation/group.module.css +41 -0
  250. package/src/presentation/group.tsx +40 -0
  251. package/src/presentation/row.module.css +32 -0
  252. package/src/presentation/row.tsx +33 -0
  253. package/src/presentation/tabs.module.css +107 -0
  254. package/src/presentation/tabs.tsx +84 -0
  255. package/src/react.ts +84 -0
  256. package/src/services/admin-services-types.ts +18 -0
  257. package/src/widgets/diff-viewer/diff-modal.module.css +79 -0
  258. package/src/widgets/diff-viewer/diff-modal.tsx +186 -0
  259. package/src/widgets/status-badge/status-badge.module.css +31 -0
  260. package/src/widgets/status-badge/status-badge.tsx +71 -0
@@ -0,0 +1,321 @@
1
+ /**
2
+ * FormRenderer — primary admin form layout/orchestrator.
3
+ *
4
+ * Override handles (parent-by-section):
5
+ *
6
+ * .byline-form — root <form>
7
+ * .byline-form-heading-row — heading + headerSlot row
8
+ * .byline-form-heading — h1 heading
9
+ * .byline-form-status-bar — sticky status + actions container
10
+ * .byline-form-status — status display group
11
+ * .byline-form-status-meta — flex row of status / updated / created
12
+ * .byline-form-status-cell — individual status / updated / created
13
+ * .byline-form-status-muted — muted label text
14
+ * .byline-form-status-trunc — truncate ellipsis
15
+ * .byline-form-status-published — "a published version is live" notice
16
+ * .byline-form-status-unpublish — Unpublish text-link button
17
+ *
18
+ * .byline-form-actions — flex container for cancel/save/status/menu
19
+ * .byline-form-actions-button — min-sized Cancel / Save buttons
20
+ * .byline-form-actions-status-wrap — relative positioned wrapper around the ComboButton
21
+ * .byline-form-actions-combo-button — ComboButton's main button minimums
22
+ * .byline-form-actions-combo-trigger — ComboButton's trigger button minimums
23
+ *
24
+ * .byline-form-layout — main + sidebar grid wrapper
25
+ * .byline-form-content — main column
26
+ * .byline-form-sidebar — right column
27
+ *
28
+ * .byline-form-tabset — vertical stack wrapping a tab set
29
+ * .byline-form-tabset-tabs — Tabs.className overrides for tabset placement
30
+ * .byline-form-tabset-fields — vertical stack of tab body fields
31
+ *
32
+ * .byline-form-guard-modal-head — leave-without-saving modal header
33
+ * .byline-form-guard-modal-title — guard modal title
34
+ * .byline-form-guard-modal-text — guard modal body paragraph
35
+ */
36
+
37
+ .form,
38
+ :global(.byline-form) {
39
+ display: flex;
40
+ flex-direction: column;
41
+ width: 100%;
42
+ }
43
+
44
+ .heading-row,
45
+ :global(.byline-form-heading-row) {
46
+ display: grid;
47
+ grid-template-columns: 1fr;
48
+ align-items: start;
49
+ gap: 0.25rem var(--spacing-16);
50
+ margin-bottom: var(--spacing-8);
51
+ }
52
+
53
+ @media (min-width: 40rem) {
54
+ .heading-row,
55
+ :global(.byline-form-heading-row) {
56
+ grid-template-columns: 1fr auto;
57
+ }
58
+ }
59
+
60
+ .heading,
61
+ :global(.byline-form-heading) {
62
+ margin-bottom: 0;
63
+ font-size: 1.75rem;
64
+ }
65
+
66
+ .status-bar,
67
+ :global(.byline-form-status-bar) {
68
+ position: sticky;
69
+ top: 45px;
70
+ z-index: 20;
71
+ display: grid;
72
+ grid-template-columns: 1fr;
73
+ align-items: start;
74
+ gap: 0.25rem var(--spacing-16);
75
+ padding: var(--spacing-8);
76
+ margin-bottom: 0.25rem;
77
+ border: var(--border-width-thin) var(--border-style-solid) var(--gray-100);
78
+ border-radius: var(--border-radius-sm);
79
+ background-color: var(--canvas-25);
80
+ }
81
+
82
+ @media (min-width: 40rem) {
83
+ .status-bar,
84
+ :global(.byline-form-status-bar) {
85
+ grid-template-columns: 1fr auto;
86
+ }
87
+ }
88
+
89
+ @media (min-width: 66rem) {
90
+ .status-bar,
91
+ :global(.byline-form-status-bar) {
92
+ margin-bottom: 0;
93
+ }
94
+ }
95
+
96
+ .status,
97
+ :global(.byline-form-status) {
98
+ display: flex;
99
+ height: 100%;
100
+ flex-direction: column;
101
+ justify-content: center;
102
+ }
103
+
104
+ .status-meta,
105
+ :global(.byline-form-status-meta) {
106
+ display: flex;
107
+ flex-direction: column;
108
+ font-size: 0.8rem;
109
+ line-height: 1.25;
110
+ }
111
+
112
+ @media (min-width: 48rem) {
113
+ .status-meta,
114
+ :global(.byline-form-status-meta) {
115
+ margin-bottom: 0.25rem;
116
+ line-height: 0.75rem;
117
+ }
118
+ }
119
+
120
+ @media (min-width: 66rem) {
121
+ .status-meta,
122
+ :global(.byline-form-status-meta) {
123
+ flex-direction: row;
124
+ align-items: center;
125
+ }
126
+ }
127
+
128
+ @media (min-width: 40rem) {
129
+ .status-meta,
130
+ :global(.byline-form-status-meta) {
131
+ gap: var(--spacing-8);
132
+ }
133
+ }
134
+
135
+ .status-cell,
136
+ :global(.byline-form-status-cell) {
137
+ display: flex;
138
+ align-items: center;
139
+ gap: 0.25rem;
140
+ min-width: 0;
141
+ }
142
+
143
+ .status-muted,
144
+ :global(.byline-form-status-muted) {
145
+ flex-shrink: 0;
146
+ color: var(--gray-500);
147
+ }
148
+
149
+ .status-trunc,
150
+ :global(.byline-form-status-trunc) {
151
+ overflow: hidden;
152
+ text-overflow: ellipsis;
153
+ white-space: nowrap;
154
+ }
155
+
156
+ .status-published,
157
+ :global(.byline-form-status-published) {
158
+ font-size: 0.8rem;
159
+ display: inline;
160
+ line-height: 1rem;
161
+ }
162
+
163
+ @media (min-width: 48rem) {
164
+ .status-published,
165
+ :global(.byline-form-status-published) {
166
+ line-height: 0.875rem;
167
+ }
168
+ }
169
+
170
+ .status-unpublish,
171
+ :global(.byline-form-status-unpublish) {
172
+ background: none;
173
+ border: none;
174
+ padding: 0;
175
+ color: inherit;
176
+ font-size: 0.8rem;
177
+ text-decoration: underline;
178
+ cursor: pointer;
179
+ }
180
+
181
+ .actions,
182
+ :global(.byline-form-actions) {
183
+ display: flex;
184
+ align-items: center;
185
+ gap: var(--spacing-8);
186
+ }
187
+
188
+ .actions-button,
189
+ :global(.byline-form-actions-button) {
190
+ min-width: 70px;
191
+ min-height: 28px;
192
+ }
193
+
194
+ .actions-status-wrap,
195
+ :global(.byline-form-actions-status-wrap) {
196
+ position: relative;
197
+ z-index: 10;
198
+ }
199
+
200
+ .actions-combo-button,
201
+ :global(.byline-form-actions-combo-button) {
202
+ min-width: 100px;
203
+ min-height: 28px;
204
+ }
205
+
206
+ .actions-combo-trigger,
207
+ :global(.byline-form-actions-combo-trigger) {
208
+ min-height: 28px;
209
+ }
210
+
211
+ .layout,
212
+ :global(.byline-form-layout) {
213
+ display: flex;
214
+ flex-direction: column;
215
+ gap: var(--spacing-12);
216
+ padding-top: var(--spacing-32);
217
+ }
218
+
219
+ @media (min-width: 60rem) {
220
+ .layout,
221
+ :global(.byline-form-layout) {
222
+ gap: var(--spacing-32);
223
+ display: grid;
224
+ grid-template-columns: minmax(0, 1fr) 0.4fr;
225
+ grid-column-gap: 36px;
226
+ align-items: start;
227
+ }
228
+ }
229
+
230
+ .content,
231
+ :global(.byline-form-content) {
232
+ display: flex;
233
+ flex-direction: column;
234
+ gap: var(--spacing-20);
235
+ max-width: 100%;
236
+ margin-bottom: 2.75rem;
237
+ }
238
+
239
+ @media (min-width: 60rem) {
240
+ .content,
241
+ :global(.byline-form-content) {
242
+ margin-bottom: 3.75rem;
243
+ }
244
+ }
245
+
246
+ .sidebar,
247
+ :global(.byline-form-sidebar) {
248
+ display: flex;
249
+ flex-direction: column;
250
+ gap: var(--spacing-20);
251
+ margin-top: 0;
252
+ background-color: oklch(from var(--canvas-50) l c h / 0.2);
253
+ max-width: 100%;
254
+ margin-bottom: 4rem;
255
+ }
256
+
257
+ @media (min-width: 60rem) {
258
+ .sidebar,
259
+ :global(.byline-form-sidebar) {
260
+ margin-bottom: 0;
261
+ padding-right: 12px;
262
+ padding-top: 0.25rem;
263
+ padding-left: var(--spacing-16);
264
+ border-left: var(--border-width-thin) var(--border-style-solid) var(--gray-100);
265
+ position: sticky;
266
+ top: 95px;
267
+ }
268
+ }
269
+
270
+ .tabset,
271
+ :global(.byline-form-tabset) {
272
+ display: flex;
273
+ flex-direction: column;
274
+ gap: var(--spacing-20);
275
+ }
276
+
277
+ .tabset-tabs,
278
+ :global(.byline-form-tabset-tabs) {
279
+ margin-top: -1rem;
280
+ margin-bottom: 0;
281
+ }
282
+
283
+ .tabset-fields,
284
+ :global(.byline-form-tabset-fields) {
285
+ display: flex;
286
+ flex-direction: column;
287
+ gap: var(--spacing-20);
288
+ }
289
+
290
+ .guard-modal-head,
291
+ :global(.byline-form-guard-modal-head) {
292
+ padding-top: 1rem;
293
+ margin-bottom: var(--spacing-8);
294
+ }
295
+
296
+ .guard-modal-title,
297
+ :global(.byline-form-guard-modal-title) {
298
+ margin: 0 0 var(--spacing-8) 0;
299
+ font-size: var(--font-size-2xl);
300
+ }
301
+
302
+ .guard-modal-text,
303
+ :global(.byline-form-guard-modal-text) {
304
+ font-size: var(--font-size-sm);
305
+ }
306
+
307
+ /* ─── Dark theme variants ───────────────────────────────────── */
308
+
309
+ :is([data-theme="dark"], :global(.dark)) {
310
+ .status-bar,
311
+ :global(.byline-form-status-bar) {
312
+ background-color: var(--canvas-800);
313
+ border: var(--border-width-thin) var(--border-style-solid) var(--gray-700);
314
+ }
315
+
316
+ .sidebar,
317
+ :global(.byline-form-sidebar) {
318
+ border-left-color: var(--gray-800);
319
+ background-color: var(--canvas-900);
320
+ }
321
+ }