platformcommons-web-lib 1.0.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 (208) hide show
  1. package/commons-shared-web-ui-1.0.0.tgz +0 -0
  2. package/documentation/alert.md +123 -0
  3. package/documentation/button-dropdown.md +126 -0
  4. package/documentation/button.md +184 -0
  5. package/documentation/cards-usage-guidelines.md +131 -0
  6. package/documentation/configurable-form.md +605 -0
  7. package/documentation/confirmation-modal.md +250 -0
  8. package/documentation/filter-sidebar.md +178 -0
  9. package/documentation/filter-table-selector.md +228 -0
  10. package/documentation/form-builder.md +597 -0
  11. package/documentation/form-components.md +384 -0
  12. package/documentation/nav.md +427 -0
  13. package/documentation/pagination.md +181 -0
  14. package/documentation/side-nav-documentation.md +169 -0
  15. package/documentation/smart-form.md +2177 -0
  16. package/documentation/smart-table.md +1198 -0
  17. package/documentation/snackbar.md +118 -0
  18. package/documentation/style-externalization.md +88 -0
  19. package/documentation/summary-card.md +279 -0
  20. package/ng-package.json +28 -0
  21. package/package.json +54 -0
  22. package/src/lib/modules/alert/alert.models.ts +6 -0
  23. package/src/lib/modules/alert/alert.module.ts +16 -0
  24. package/src/lib/modules/alert/alert.theme.scss +85 -0
  25. package/src/lib/modules/alert/components/alert/alert.component.html +27 -0
  26. package/src/lib/modules/alert/components/alert/alert.component.scss +92 -0
  27. package/src/lib/modules/alert/components/alert/alert.component.ts +81 -0
  28. package/src/lib/modules/button/button.models.ts +13 -0
  29. package/src/lib/modules/button/button.module.ts +16 -0
  30. package/src/lib/modules/button/button.theme.scss +121 -0
  31. package/src/lib/modules/button/components/button/button.component.html +22 -0
  32. package/src/lib/modules/button/components/button/button.component.scss +88 -0
  33. package/src/lib/modules/button/components/button/button.component.ts +67 -0
  34. package/src/lib/modules/button-dropdown/button-dropdown.models.ts +26 -0
  35. package/src/lib/modules/button-dropdown/button-dropdown.module.ts +22 -0
  36. package/src/lib/modules/button-dropdown/button-dropdown.theme.scss +87 -0
  37. package/src/lib/modules/button-dropdown/components/button-dropdown/button-dropdown.component.html +41 -0
  38. package/src/lib/modules/button-dropdown/components/button-dropdown/button-dropdown.component.scss +135 -0
  39. package/src/lib/modules/button-dropdown/components/button-dropdown/button-dropdown.component.ts +160 -0
  40. package/src/lib/modules/configurable-form/component/configurable-form.component.html +294 -0
  41. package/src/lib/modules/configurable-form/component/configurable-form.component.scss +503 -0
  42. package/src/lib/modules/configurable-form/component/configurable-form.component.ts +628 -0
  43. package/src/lib/modules/configurable-form/configurable-form.examples.ts +154 -0
  44. package/src/lib/modules/configurable-form/configurable-form.model.ts +131 -0
  45. package/src/lib/modules/configurable-form/configurable-form.module.ts +19 -0
  46. package/src/lib/modules/configurable-form/configurable-form.theme.scss +78 -0
  47. package/src/lib/modules/confirmation-modal/components/confirmation-modal/confirmation-modal.component.html +77 -0
  48. package/src/lib/modules/confirmation-modal/components/confirmation-modal/confirmation-modal.component.scss +395 -0
  49. package/src/lib/modules/confirmation-modal/components/confirmation-modal/confirmation-modal.component.ts +266 -0
  50. package/src/lib/modules/confirmation-modal/confirmation-modal.models.ts +71 -0
  51. package/src/lib/modules/confirmation-modal/confirmation-modal.module.ts +20 -0
  52. package/src/lib/modules/confirmation-modal/confirmation-modal.theme.scss +87 -0
  53. package/src/lib/modules/filter/components/filter/filter.component.html +131 -0
  54. package/src/lib/modules/filter/components/filter/filter.component.scss +245 -0
  55. package/src/lib/modules/filter/components/filter/filter.component.ts +216 -0
  56. package/src/lib/modules/filter/filter.models.ts +88 -0
  57. package/src/lib/modules/filter/filter.module.ts +24 -0
  58. package/src/lib/modules/filter/filter.theme.scss +92 -0
  59. package/src/lib/modules/filter-sidebar/components/filter-sidebar/filter-sidebar.component.html +112 -0
  60. package/src/lib/modules/filter-sidebar/components/filter-sidebar/filter-sidebar.component.scss +186 -0
  61. package/src/lib/modules/filter-sidebar/components/filter-sidebar/filter-sidebar.component.ts +163 -0
  62. package/src/lib/modules/filter-sidebar/filter-sidebar.models.ts +95 -0
  63. package/src/lib/modules/filter-sidebar/filter-sidebar.module.ts +24 -0
  64. package/src/lib/modules/filter-sidebar/filter-sidebar.theme.scss +38 -0
  65. package/src/lib/modules/filter-table-selector/components/filter-table-selector/filter-table-selector.component.html +73 -0
  66. package/src/lib/modules/filter-table-selector/components/filter-table-selector/filter-table-selector.component.scss +321 -0
  67. package/src/lib/modules/filter-table-selector/components/filter-table-selector/filter-table-selector.component.ts +361 -0
  68. package/src/lib/modules/filter-table-selector/filter-table-selector.models.ts +91 -0
  69. package/src/lib/modules/filter-table-selector/filter-table-selector.module.ts +22 -0
  70. package/src/lib/modules/filter-table-selector/filter-table-selector.theme.scss +36 -0
  71. package/src/lib/modules/form-builder/components/field-configurator/configurator-config-panel/configurator-config-panel.component.html +63 -0
  72. package/src/lib/modules/form-builder/components/field-configurator/configurator-config-panel/configurator-config-panel.component.scss +496 -0
  73. package/src/lib/modules/form-builder/components/field-configurator/configurator-config-panel/configurator-config-panel.component.ts +445 -0
  74. package/src/lib/modules/form-builder/components/field-configurator/configurator-tree/configurator-tree.component.html +75 -0
  75. package/src/lib/modules/form-builder/components/field-configurator/configurator-tree/configurator-tree.component.scss +210 -0
  76. package/src/lib/modules/form-builder/components/field-configurator/configurator-tree/configurator-tree.component.ts +55 -0
  77. package/src/lib/modules/form-builder/components/field-configurator/field-configurator.component.html +25 -0
  78. package/src/lib/modules/form-builder/components/field-configurator/field-configurator.component.scss +82 -0
  79. package/src/lib/modules/form-builder/components/field-configurator/field-configurator.component.ts +95 -0
  80. package/src/lib/modules/form-builder/components/field-selection/field-selection.component.html +20 -0
  81. package/src/lib/modules/form-builder/components/field-selection/field-selection.component.scss +37 -0
  82. package/src/lib/modules/form-builder/components/field-selection/field-selection.component.ts +94 -0
  83. package/src/lib/modules/form-builder/components/field-selection/group-node/group-node.component.html +46 -0
  84. package/src/lib/modules/form-builder/components/field-selection/group-node/group-node.component.scss +102 -0
  85. package/src/lib/modules/form-builder/components/field-selection/group-node/group-node.component.ts +50 -0
  86. package/src/lib/modules/form-builder/components/field-selection/selection-field-node/selection-field-node.component.html +35 -0
  87. package/src/lib/modules/form-builder/components/field-selection/selection-field-node/selection-field-node.component.scss +67 -0
  88. package/src/lib/modules/form-builder/components/field-selection/selection-field-node/selection-field-node.component.ts +34 -0
  89. package/src/lib/modules/form-builder/components/field-selection/selection-section-node/selection-section-node.component.html +68 -0
  90. package/src/lib/modules/form-builder/components/field-selection/selection-section-node/selection-section-node.component.scss +113 -0
  91. package/src/lib/modules/form-builder/components/field-selection/selection-section-node/selection-section-node.component.ts +74 -0
  92. package/src/lib/modules/form-builder/configs/field-type-schema.map.ts +533 -0
  93. package/src/lib/modules/form-builder/form-builder.module.ts +36 -0
  94. package/src/lib/modules/form-builder/form-builder.theme.scss +212 -0
  95. package/src/lib/modules/form-builder/index.ts +9 -0
  96. package/src/lib/modules/form-builder/models/builder.models.ts +7 -0
  97. package/src/lib/modules/form-builder/models/field-configurator.models.ts +38 -0
  98. package/src/lib/modules/form-builder/models/field-selection.models.ts +51 -0
  99. package/src/lib/modules/form-builder/services/field-configurator.service.ts +258 -0
  100. package/src/lib/modules/form-builder/services/field-selection.service.ts +300 -0
  101. package/src/lib/modules/form-builder/services/form-schema-tree.service.ts +652 -0
  102. package/src/lib/modules/form-builder/tokens/builder.tokens.ts +10 -0
  103. package/src/lib/modules/form-builder/utils/constants.ts +43 -0
  104. package/src/lib/modules/form-components/components/checkbox/_theme.scss +63 -0
  105. package/src/lib/modules/form-components/components/checkbox/checkbox.component.html +29 -0
  106. package/src/lib/modules/form-components/components/checkbox/checkbox.component.scss +111 -0
  107. package/src/lib/modules/form-components/components/checkbox/checkbox.component.ts +207 -0
  108. package/src/lib/modules/form-components/components/checkbox/checkbox.models.ts +35 -0
  109. package/src/lib/modules/form-components/components/datepicker/_theme.scss +82 -0
  110. package/src/lib/modules/form-components/components/datepicker/datepicker.component.html +42 -0
  111. package/src/lib/modules/form-components/components/datepicker/datepicker.component.scss +115 -0
  112. package/src/lib/modules/form-components/components/datepicker/datepicker.component.ts +267 -0
  113. package/src/lib/modules/form-components/components/datepicker/datepicker.models.ts +45 -0
  114. package/src/lib/modules/form-components/components/dropdown/_theme.scss +91 -0
  115. package/src/lib/modules/form-components/components/dropdown/dropdown.component.html +74 -0
  116. package/src/lib/modules/form-components/components/dropdown/dropdown.component.scss +252 -0
  117. package/src/lib/modules/form-components/components/dropdown/dropdown.component.ts +377 -0
  118. package/src/lib/modules/form-components/components/dropdown/dropdown.models.ts +53 -0
  119. package/src/lib/modules/form-components/components/input/_theme.scss +77 -0
  120. package/src/lib/modules/form-components/components/input/input.component.html +51 -0
  121. package/src/lib/modules/form-components/components/input/input.component.scss +128 -0
  122. package/src/lib/modules/form-components/components/input/input.component.ts +250 -0
  123. package/src/lib/modules/form-components/components/input/input.models.ts +55 -0
  124. package/src/lib/modules/form-components/components/radio/_theme.scss +61 -0
  125. package/src/lib/modules/form-components/components/radio/radio.component.html +22 -0
  126. package/src/lib/modules/form-components/components/radio/radio.component.scss +107 -0
  127. package/src/lib/modules/form-components/components/radio/radio.component.ts +181 -0
  128. package/src/lib/modules/form-components/components/radio/radio.models.ts +39 -0
  129. package/src/lib/modules/form-components/components/search/_theme.scss +73 -0
  130. package/src/lib/modules/form-components/components/search/search.component.html +15 -0
  131. package/src/lib/modules/form-components/components/search/search.component.scss +87 -0
  132. package/src/lib/modules/form-components/components/search/search.component.ts +213 -0
  133. package/src/lib/modules/form-components/components/search/search.models.ts +40 -0
  134. package/src/lib/modules/form-components/components/toggle/_theme.scss +45 -0
  135. package/src/lib/modules/form-components/components/toggle/toggle.component.html +15 -0
  136. package/src/lib/modules/form-components/components/toggle/toggle.component.scss +81 -0
  137. package/src/lib/modules/form-components/components/toggle/toggle.component.ts +166 -0
  138. package/src/lib/modules/form-components/components/toggle/toggle.models.ts +27 -0
  139. package/src/lib/modules/form-components/directives/click-outside.directive.ts +22 -0
  140. package/src/lib/modules/form-components/form-components.module.ts +41 -0
  141. package/src/lib/modules/form-components/form-components.theme.scss +25 -0
  142. package/src/lib/modules/material/material.module.ts +94 -0
  143. package/src/lib/modules/nav/components/nav/nav.component.html +34 -0
  144. package/src/lib/modules/nav/components/nav/nav.component.scss +171 -0
  145. package/src/lib/modules/nav/components/nav/nav.component.ts +82 -0
  146. package/src/lib/modules/nav/nav.models.ts +31 -0
  147. package/src/lib/modules/nav/nav.module.ts +17 -0
  148. package/src/lib/modules/nav/nav.theme.scss +86 -0
  149. package/src/lib/modules/pagination/components/pagination/pagination.component.html +52 -0
  150. package/src/lib/modules/pagination/components/pagination/pagination.component.scss +155 -0
  151. package/src/lib/modules/pagination/components/pagination/pagination.component.ts +109 -0
  152. package/src/lib/modules/pagination/pagination.module.ts +17 -0
  153. package/src/lib/modules/pagination/pagination.theme.scss +66 -0
  154. package/src/lib/modules/side-nav/components/side-nav/side-nav.component.html +56 -0
  155. package/src/lib/modules/side-nav/components/side-nav/side-nav.component.scss +342 -0
  156. package/src/lib/modules/side-nav/components/side-nav/side-nav.component.ts +135 -0
  157. package/src/lib/modules/side-nav/side-nav.models.ts +38 -0
  158. package/src/lib/modules/side-nav/side-nav.module.ts +16 -0
  159. package/src/lib/modules/side-nav/side-nav.theme.scss +111 -0
  160. package/src/lib/modules/smart-form/components/form-field/form-field.component.html +1109 -0
  161. package/src/lib/modules/smart-form/components/form-field/form-field.component.scss +1860 -0
  162. package/src/lib/modules/smart-form/components/form-field/form-field.component.ts +2232 -0
  163. package/src/lib/modules/smart-form/components/form-section/form-section.component.html +64 -0
  164. package/src/lib/modules/smart-form/components/form-section/form-section.component.scss +209 -0
  165. package/src/lib/modules/smart-form/components/form-section/form-section.component.ts +119 -0
  166. package/src/lib/modules/smart-form/components/smart-form/smart-form.component.html +253 -0
  167. package/src/lib/modules/smart-form/components/smart-form/smart-form.component.scss +689 -0
  168. package/src/lib/modules/smart-form/components/smart-form/smart-form.component.ts +1087 -0
  169. package/src/lib/modules/smart-form/index.ts +10 -0
  170. package/src/lib/modules/smart-form/models/form-schema.model.ts +700 -0
  171. package/src/lib/modules/smart-form/models/hierarchy-config.model.ts +21 -0
  172. package/src/lib/modules/smart-form/services/expression.service.ts +75 -0
  173. package/src/lib/modules/smart-form/services/smart-form-controller.service.ts +65 -0
  174. package/src/lib/modules/smart-form/smart-form.examples.ts +1324 -0
  175. package/src/lib/modules/smart-form/smart-form.module.ts +36 -0
  176. package/src/lib/modules/smart-form/smart-form.theme.scss +890 -0
  177. package/src/lib/modules/smart-form/utils/translation.utils.ts +82 -0
  178. package/src/lib/modules/smart-form/utils/trusted-url.pipe.ts +25 -0
  179. package/src/lib/modules/smart-form/utils/validation.utils.ts +98 -0
  180. package/src/lib/modules/smart-table/components/smart-table/smart-table.component.html +283 -0
  181. package/src/lib/modules/smart-table/components/smart-table/smart-table.component.scss +685 -0
  182. package/src/lib/modules/smart-table/components/smart-table/smart-table.component.ts +1118 -0
  183. package/src/lib/modules/smart-table/models/table-config.model.ts +202 -0
  184. package/src/lib/modules/smart-table/smart-table.module.ts +30 -0
  185. package/src/lib/modules/smart-table/smart-table.theme.scss +335 -0
  186. package/src/lib/modules/smart-table/utils/safe-html.pipe.ts +22 -0
  187. package/src/lib/modules/smart-table/utils/smart-table.utils.ts +18 -0
  188. package/src/lib/modules/snackbar/components/snackbar.component.html +41 -0
  189. package/src/lib/modules/snackbar/components/snackbar.component.scss +99 -0
  190. package/src/lib/modules/snackbar/components/snackbar.component.ts +18 -0
  191. package/src/lib/modules/snackbar/models/snackbar.models.ts +10 -0
  192. package/src/lib/modules/snackbar/services/snackbar.service.ts +40 -0
  193. package/src/lib/modules/snackbar/snackbar.module.ts +11 -0
  194. package/src/lib/modules/snackbar/snackbar.theme.scss +93 -0
  195. package/src/lib/modules/summary-card/components/summary-card/summary-card.component.html +47 -0
  196. package/src/lib/modules/summary-card/components/summary-card/summary-card.component.scss +199 -0
  197. package/src/lib/modules/summary-card/components/summary-card/summary-card.component.ts +126 -0
  198. package/src/lib/modules/summary-card/summary-card.module.ts +18 -0
  199. package/src/lib/modules/summary-card/summary-card.theme.scss +176 -0
  200. package/src/lib/shared-ui.module.ts +44 -0
  201. package/src/lib/styles/global.scss +152 -0
  202. package/src/lib/styles/utilities.scss +250 -0
  203. package/src/lib/utils/constants.ts +11 -0
  204. package/src/lib/utils/storage.utils.ts +37 -0
  205. package/src/lib/utils/string.utils.ts +23 -0
  206. package/src/lib/utils/translation.utils.ts +87 -0
  207. package/src/public-api.ts +104 -0
  208. package/tsconfig.lib.json +15 -0
@@ -0,0 +1,689 @@
1
+ // ── Skeleton shimmer animation ───────────────────────────────────────────────
2
+ @keyframes skel-wave {
3
+ 0% {
4
+ transform: translateX(-100%);
5
+ }
6
+
7
+ 100% {
8
+ transform: translateX(200%);
9
+ }
10
+ }
11
+
12
+ @keyframes skel-fade-in {
13
+ from {
14
+ opacity: 0;
15
+ transform: translateY(6px);
16
+ }
17
+
18
+ to {
19
+ opacity: 1;
20
+ transform: translateY(0);
21
+ }
22
+ }
23
+
24
+ @keyframes form-reveal {
25
+ from {
26
+ opacity: 0;
27
+ transform: translateY(8px);
28
+ }
29
+
30
+ to {
31
+ opacity: 1;
32
+ transform: translateY(0);
33
+ }
34
+ }
35
+
36
+ // ── Skeleton wrapper ─────────────────────────────────────────────────────────
37
+ .smart-form-skeleton {
38
+ background: var(--cc-sf-form-bg, #ffffff);
39
+ border-radius: var(--cc-sf-form-border-radius, 12px);
40
+ border: var(--cc-sf-form-border, none);
41
+ box-shadow: var(--cc-sf-form-shadow, 0 1px 3px rgba(0, 0, 0, 0.06));
42
+ padding: 1.5rem;
43
+ display: flex;
44
+ flex-direction: column;
45
+ gap: var(--cc-sf-form-section-gap, 24px);
46
+ animation: skel-fade-in 0.3s ease both;
47
+ }
48
+
49
+ // ── Base shimmer block ───────────────────────────────────────────────────────
50
+ .skel-block {
51
+ position: relative;
52
+ overflow: hidden;
53
+ border-radius: 6px;
54
+ background: var(--cc-sf-input-disabled-bg, #F0F2F5);
55
+
56
+ &::after {
57
+ content: '';
58
+ position: absolute;
59
+ inset: 0;
60
+ transform: translateX(-100%);
61
+ background: linear-gradient(90deg,
62
+ transparent 0%,
63
+ rgba(255, 255, 255, 0.55) 45%,
64
+ rgba(255, 255, 255, 0.75) 50%,
65
+ rgba(255, 255, 255, 0.55) 55%,
66
+ transparent 100%);
67
+ animation: skel-wave 1.8s ease-in-out infinite;
68
+ animation-delay: var(--sd, 0s);
69
+ }
70
+ }
71
+
72
+ // ── Header ───────────────────────────────────────────────────────────────────
73
+ .skel-header {
74
+ display: flex;
75
+ flex-direction: column;
76
+ gap: 10px;
77
+
78
+ .skel-title {
79
+ height: 26px;
80
+ border-radius: 8px;
81
+ }
82
+
83
+ .skel-desc {
84
+ height: 14px;
85
+ border-radius: 5px;
86
+ opacity: 0.7;
87
+ }
88
+ }
89
+
90
+ // ── Section ──────────────────────────────────────────────────────────────────
91
+ .skel-section {
92
+ display: flex;
93
+ flex-direction: column;
94
+ gap: 14px;
95
+ }
96
+
97
+ .skel-section-label {
98
+ height: 16px;
99
+ border-radius: 0 5px 5px 0;
100
+ border-left: var(--cc-sf-section-header-accent-width, 4px) solid var(--cc-sf-section-header-accent-color, #3B82F6);
101
+ background: var(--cc-sf-input-disabled-bg, #F0F2F5);
102
+ opacity: 0.85;
103
+ }
104
+
105
+ // ── Field grids ──────────────────────────────────────────────────────────────
106
+ .skel-fields {
107
+ display: grid;
108
+ gap: var(--cc-sf-grid-gap, 16px);
109
+ align-items: start;
110
+
111
+ &--two {
112
+ grid-template-columns: 1fr 1fr;
113
+ }
114
+
115
+ &--three {
116
+ grid-template-columns: 1fr 1fr 1fr;
117
+ }
118
+
119
+ @media (max-width: 640px) {
120
+
121
+ &--two,
122
+ &--three {
123
+ grid-template-columns: 1fr;
124
+ }
125
+ }
126
+ }
127
+
128
+ .skel-field {
129
+ display: flex;
130
+ flex-direction: column;
131
+ gap: 7px;
132
+
133
+ &--full {
134
+ grid-column: 1 / -1;
135
+ }
136
+ }
137
+
138
+ .skel-label {
139
+ height: 12px;
140
+ border-radius: 4px;
141
+ opacity: 0.75;
142
+ }
143
+
144
+ .skel-input {
145
+ height: 42px;
146
+ border-radius: 8px;
147
+
148
+ &--textarea {
149
+ height: 80px;
150
+ }
151
+ }
152
+
153
+ // ── Chip row ─────────────────────────────────────────────────────────────────
154
+ .skel-chips {
155
+ display: flex;
156
+ flex-wrap: wrap;
157
+ gap: 8px;
158
+ }
159
+
160
+ .skel-chip {
161
+ height: 32px;
162
+ border-radius: 20px;
163
+ opacity: 0.8;
164
+ }
165
+
166
+ // ── Action bar ───────────────────────────────────────────────────────────────
167
+ .skel-actions {
168
+ display: flex;
169
+ justify-content: flex-end;
170
+ align-items: center;
171
+ gap: 12px;
172
+ padding-top: 20px;
173
+ border-top: var(--cc-sf-actions-border, 1px solid #E5E7EB);
174
+ }
175
+
176
+ .skel-btn {
177
+ height: 40px;
178
+ border-radius: 8px;
179
+
180
+ &--primary {
181
+ background: color-mix(in srgb, var(--cc-sf-accent-color, #3B82F6) 18%, var(--cc-sf-input-disabled-bg, #F0F2F5));
182
+ }
183
+ }
184
+
185
+ // ── Container ────────────────────────────────────────────────────────────────
186
+ .smart-form-container {
187
+ width: 100%;
188
+ // max-width: var(--cc-sf-form-max-width, 1200px);
189
+ // margin: 0 auto;
190
+ // padding: var(--cc-sf-form-padding, 24px);
191
+ font-family: var(--cc-sf-font-family, 'Inter', sans-serif);
192
+ }
193
+
194
+ .smart-form-wrapper {
195
+ background: var(--cc-sf-form-bg, #ffffff);
196
+ border-radius: var(--cc-sf-form-border-radius, 12px);
197
+ border: var(--cc-sf-form-border, none);
198
+ // box-shadow: var(--cc-sf-form-shadow, 0 1px 3px rgba(0, 0, 0, 0.06));
199
+ // padding: 1.5rem;
200
+ animation: form-reveal 0.3s ease both;
201
+
202
+ .form-alert-feedback {
203
+ margin-bottom: 1rem;
204
+ }
205
+ }
206
+
207
+ .form-header {
208
+ // margin-bottom: 24px;
209
+ margin-bottom: 1rem;
210
+
211
+ .form-title {
212
+ font-size: var(--cc-sf-form-title-size, 1.5rem);
213
+ font-weight: var(--cc-sf-form-title-weight, 700);
214
+ color: var(--cc-sf-form-title-color, #111827);
215
+ margin: 0 0 8px 0;
216
+ line-height: 1.25;
217
+ }
218
+
219
+ .form-description {
220
+ font-size: var(--cc-sf-form-desc-size, 0.875rem);
221
+ color: var(--cc-sf-form-desc-color, #6B7280);
222
+ margin: 0;
223
+ }
224
+ }
225
+
226
+ // ────────────────────────────────────────────────────────────────────────────
227
+ // Section Stepper — modern horizontal nav card
228
+ // ────────────────────────────────────────────────────────────────────────────
229
+
230
+ // Keyframes
231
+ @keyframes ss-badge-pop {
232
+ 0% {
233
+ transform: scale(0.6);
234
+ opacity: 0;
235
+ }
236
+
237
+ 70% {
238
+ transform: scale(1.12);
239
+ }
240
+
241
+ 100% {
242
+ transform: scale(1);
243
+ opacity: 1;
244
+ }
245
+ }
246
+
247
+ @keyframes ss-pulse-ring {
248
+ 0% {
249
+ box-shadow: 0 0 0 0 rgba(99, 102, 241, 0.45);
250
+ }
251
+
252
+ 70% {
253
+ box-shadow: 0 0 0 10px rgba(99, 102, 241, 0);
254
+ }
255
+
256
+ 100% {
257
+ box-shadow: 0 0 0 0 rgba(99, 102, 241, 0);
258
+ }
259
+ }
260
+
261
+ @keyframes ss-panel-in {
262
+ from {
263
+ opacity: 0;
264
+ transform: translateY(14px);
265
+ }
266
+
267
+ to {
268
+ opacity: 1;
269
+ transform: translateY(0);
270
+ }
271
+ }
272
+
273
+ @keyframes ss-connector-fill {
274
+ from {
275
+ transform: scaleX(0);
276
+ }
277
+
278
+ to {
279
+ transform: scaleX(1);
280
+ }
281
+ }
282
+
283
+ // ── Nav card ─────────────────────────────────────────────────────────────────
284
+ .section-stepper-nav {
285
+ position: relative;
286
+ background: #ffffff;
287
+ border-radius: 16px;
288
+ border: 1px solid #E8EAF0;
289
+ box-shadow:
290
+ 0 1px 3px rgba(0, 0, 0, .05),
291
+ 0 4px 16px rgba(99, 102, 241, .06);
292
+ // Bottom padding = gap(8) + tooltip-pill(24) + breathing-room(8) = 40px.
293
+ // The tooltip lives entirely inside this space — overflow-y:hidden clips
294
+ // cleanly without ever producing a scrollbar.
295
+ padding: 24px 28px 48px;
296
+ margin-bottom: 14px;
297
+ overflow-x: clip; // horizontal clip without scroll context
298
+ overflow-y: hidden; // vertical clip — no scrollbar, tooltip stays inside card
299
+
300
+ // Coloured top accent stripe
301
+ &::before {
302
+ content: '';
303
+ position: absolute;
304
+ inset: 0 0 auto 0;
305
+ height: 3px;
306
+ border-radius: 16px 16px 0 0;
307
+ background: linear-gradient(90deg, #6366F1 0%, #8B5CF6 50%, #EC4899 100%);
308
+ }
309
+ }
310
+
311
+ // ── Track ─────────────────────────────────────────────────────────────────────
312
+ .section-stepper-track {
313
+ display: flex;
314
+ align-items: flex-start;
315
+ justify-content: space-between;
316
+ min-width: max-content;
317
+ width: 100%;
318
+ }
319
+
320
+ // ── Individual step ───────────────────────────────────────────────────────────
321
+ .section-stepper-step {
322
+ display: flex;
323
+ flex-direction: column;
324
+ align-items: center;
325
+ position: relative;
326
+ flex: 1;
327
+ cursor: pointer;
328
+ padding: 0 4px;
329
+
330
+ // ── Tooltip — appears below the step label, inside the nav's bottom padding ──
331
+ // top: 100% = bottom edge of the step flex-column (badge + gap + label).
332
+ // The extra 48px bottom padding on .section-stepper-nav is the exact pocket
333
+ // this tooltip lives in. overflow-y: hidden on the nav clips it cleanly
334
+ // without producing any scrollbar.
335
+ &::after {
336
+ content: attr(data-tooltip);
337
+ position: absolute;
338
+ top: calc(100% + 8px); // 8 px below the label text
339
+ left: 50%;
340
+ transform: translateX(-50%) translateY(4px);
341
+ white-space: nowrap;
342
+ background: #1E1B4B;
343
+ color: #ffffff;
344
+ font-size: 0.6875rem;
345
+ font-weight: 500;
346
+ letter-spacing: .02em;
347
+ padding: 5px 11px;
348
+ border-radius: 6px;
349
+ pointer-events: none;
350
+ opacity: 0;
351
+ transition: opacity 0.2s ease, transform 0.2s ease;
352
+ z-index: 200;
353
+ box-shadow: 0 4px 14px rgba(0, 0, 0, .2);
354
+ }
355
+
356
+ &:hover::after {
357
+ opacity: 1;
358
+ transform: translateX(-50%) translateY(0);
359
+ }
360
+
361
+ // ── Badge ──────────────────────────────────────────────────────────────────
362
+ .ss-badge {
363
+ width: 38px;
364
+ height: 38px;
365
+ min-width: 38px;
366
+ border-radius: 50%;
367
+ background: #F1F2F6;
368
+ color: #9CA3AF;
369
+ border: 2px solid #E5E7EB;
370
+ display: flex;
371
+ align-items: center;
372
+ justify-content: center;
373
+ font-size: 0.8125rem;
374
+ font-weight: 700;
375
+ position: relative;
376
+ z-index: 1;
377
+ transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
378
+
379
+ span {
380
+ line-height: 1;
381
+ letter-spacing: -.01em;
382
+ }
383
+
384
+ svg {
385
+ flex-shrink: 0;
386
+ }
387
+
388
+ .ss-warning-mark {
389
+ font-size: 1.25rem;
390
+ font-weight: 900;
391
+ line-height: 1;
392
+ letter-spacing: 0;
393
+ color: #ffffff;
394
+ }
395
+ }
396
+
397
+ // ── Label ──────────────────────────────────────────────────────────────────
398
+ .ss-label {
399
+ margin-top: 9px;
400
+ font-size: 0.6875rem;
401
+ font-weight: 500;
402
+ color: #B0B7C3;
403
+ white-space: nowrap;
404
+ text-align: center;
405
+ transition: color 0.25s ease, font-weight 0.25s ease;
406
+ max-width: 88px;
407
+ overflow: hidden;
408
+ text-overflow: ellipsis;
409
+ letter-spacing: .01em;
410
+ }
411
+
412
+ // ── Connector lines ────────────────────────────────────────────────────────
413
+ .ss-connector {
414
+ height: 2px;
415
+ background: #E8EAF0;
416
+ position: absolute;
417
+ top: 19px;
418
+ z-index: 0;
419
+ overflow: hidden;
420
+ border-radius: 2px;
421
+
422
+ &--left {
423
+ left: 0;
424
+ right: calc(50% + 19px);
425
+ }
426
+
427
+ &--right {
428
+ left: calc(50% + 19px);
429
+ right: 0;
430
+ }
431
+
432
+ &::after {
433
+ content: '';
434
+ position: absolute;
435
+ inset: 0;
436
+ background: linear-gradient(90deg, #6366F1, #8B5CF6);
437
+ transform: scaleX(0);
438
+ transform-origin: left;
439
+ transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
440
+ }
441
+ }
442
+
443
+ // ── ACTIVE ─────────────────────────────────────────────────────────────────
444
+ &.ss-active {
445
+ cursor: default;
446
+
447
+ .ss-badge {
448
+ background: linear-gradient(135deg, #6366F1 0%, #8B5CF6 100%);
449
+ color: #ffffff;
450
+ border-color: transparent;
451
+ box-shadow:
452
+ 0 0 0 4px rgba(99, 102, 241, .18),
453
+ 0 4px 12px rgba(99, 102, 241, .35);
454
+ animation: ss-badge-pop 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) both,
455
+ ss-pulse-ring 2s 0.4s ease-out infinite;
456
+ }
457
+
458
+ .ss-label {
459
+ color: #4F46E5;
460
+ font-weight: 700;
461
+ }
462
+ }
463
+
464
+ // ── COMPLETED ──────────────────────────────────────────────────────────────
465
+ &.ss-completed {
466
+ .ss-badge {
467
+ background: linear-gradient(135deg, #10B981 0%, #059669 100%);
468
+ color: #ffffff;
469
+ border-color: transparent;
470
+ box-shadow: 0 2px 8px rgba(16, 185, 129, .3);
471
+ }
472
+
473
+ .ss-label {
474
+ color: #6B7280;
475
+ font-weight: 500;
476
+ }
477
+
478
+ // Fill both connectors for completed steps
479
+ .ss-connector--left::after,
480
+ .ss-connector--right::after {
481
+ transform: scaleX(1);
482
+ }
483
+ }
484
+
485
+ // ── WARNING — visited but has unfilled required fields ─────────────────────
486
+ &.ss-warning {
487
+ .ss-badge {
488
+ background: linear-gradient(135deg, #F59E0B 0%, #D97706 100%);
489
+ color: #ffffff;
490
+ border-color: transparent;
491
+ box-shadow: 0 2px 8px rgba(245, 158, 11, .35);
492
+ animation: ss-badge-pop 0.35s cubic-bezier(0.34, 1.56, 0.64, 1) both;
493
+ }
494
+
495
+ .ss-label {
496
+ color: #B45309;
497
+ font-weight: 600;
498
+ }
499
+
500
+ // Connector stays grey — step wasn't cleanly completed
501
+ .ss-connector--left::after {
502
+ transform: scaleX(0);
503
+ }
504
+
505
+ .ss-connector--right::after {
506
+ transform: scaleX(0);
507
+ }
508
+ }
509
+
510
+ // ── HOVER (future steps) ───────────────────────────────────────────────────
511
+ &:not(.ss-active):not(.ss-completed):not(.ss-warning):hover {
512
+ .ss-badge {
513
+ background: #E8EAF0;
514
+ color: #6366F1;
515
+ border-color: #C7D2FE;
516
+ transform: translateY(-2px);
517
+ }
518
+
519
+ .ss-label {
520
+ color: #6B7280;
521
+ }
522
+ }
523
+ }
524
+
525
+ // ── Step panel (content area) ─────────────────────────────────────────────────
526
+ .ss-step-panel {
527
+ animation: ss-panel-in 0.35s cubic-bezier(0.4, 0, 0.2, 1) both;
528
+ }
529
+
530
+ // No outer card padding in section-stepper mode
531
+ .ss-form {
532
+ padding-top: 0;
533
+ }
534
+
535
+ // ── Responsive ───────────────────────────────────────────────────────────────
536
+ @media (max-width: 768px) {
537
+ .section-stepper-nav {
538
+ padding: 20px 16px 16px;
539
+ }
540
+
541
+ .section-stepper-step {
542
+ .ss-label {
543
+ font-size: 0.625rem;
544
+ max-width: 64px;
545
+ }
546
+
547
+ .ss-badge {
548
+ width: 32px;
549
+ height: 32px;
550
+ min-width: 32px;
551
+ font-size: 0.75rem;
552
+ }
553
+
554
+ .ss-connector {
555
+ top: 16px;
556
+
557
+ &--left {
558
+ right: calc(50% + 16px);
559
+ }
560
+
561
+ &--right {
562
+ left: calc(50% + 16px);
563
+ }
564
+ }
565
+ }
566
+ }
567
+
568
+ // ── Stepper navigation ───────────────────────────────────────────────────────
569
+ .stepper-nav {
570
+ margin-bottom: 32px;
571
+
572
+ .stepper-steps {
573
+ display: flex;
574
+ gap: 16px;
575
+
576
+ &.horizontal {
577
+ flex-direction: row;
578
+ justify-content: space-between;
579
+ }
580
+
581
+ &:not(.horizontal) {
582
+ flex-direction: column;
583
+ }
584
+ }
585
+
586
+ .stepper-step {
587
+ display: flex;
588
+ align-items: center;
589
+ gap: 12px;
590
+ flex: 1;
591
+ position: relative;
592
+
593
+ &:not(:last-child)::after {
594
+ content: '';
595
+ position: absolute;
596
+ top: calc(var(--cc-sf-step-number-size, 40px) / 2);
597
+ left: calc(100% + 8px);
598
+ width: calc(100% - 40px);
599
+ height: 2px;
600
+ background: var(--cc-sf-step-connector-color, #E5E7EB);
601
+ transition: background var(--cc-sf-btn-transition, 0.2s ease);
602
+ }
603
+
604
+ &.completed::after {
605
+ background: var(--cc-sf-step-connector-done, #22C55E);
606
+ }
607
+
608
+ .step-number {
609
+ width: var(--cc-sf-step-number-size, 40px);
610
+ height: var(--cc-sf-step-number-size, 40px);
611
+ min-width: var(--cc-sf-step-number-size, 40px);
612
+ border-radius: 50%;
613
+ background: var(--cc-sf-step-number-bg, #E5E7EB);
614
+ color: var(--cc-sf-step-number-color, #6B7280);
615
+ display: flex;
616
+ align-items: center;
617
+ justify-content: center;
618
+ font-size: var(--cc-sf-step-number-font-size, 0.875rem);
619
+ font-weight: var(--cc-sf-step-number-weight, 600);
620
+ transition: var(--cc-sf-btn-transition, all 0.2s ease);
621
+ }
622
+
623
+ .step-label {
624
+ font-size: var(--cc-sf-step-label-size, 0.875rem);
625
+ color: var(--cc-sf-step-label-color, #6B7280);
626
+ font-weight: var(--cc-sf-step-label-weight, 500);
627
+ transition: var(--cc-sf-btn-transition, all 0.2s ease);
628
+ }
629
+
630
+ &.active {
631
+ .step-number {
632
+ background: var(--cc-sf-step-active-bg, #3B82F6);
633
+ color: var(--cc-sf-step-active-color, #ffffff);
634
+ }
635
+
636
+ .step-label {
637
+ color: var(--cc-sf-step-active-label, #1D4ED8);
638
+ font-weight: var(--cc-sf-step-active-label-weight, 700);
639
+ }
640
+ }
641
+
642
+ &.completed {
643
+ .step-number {
644
+ background: var(--cc-sf-step-done-bg, #22C55E);
645
+ color: var(--cc-sf-step-done-color, #ffffff);
646
+ }
647
+ }
648
+ }
649
+ }
650
+
651
+ // ── Form wrapper ─────────────────────────────────────────────────────────────
652
+ .smart-form {
653
+ // padding-top: var(--cc-sf-form-padding, 24px);
654
+ display: flex;
655
+ flex-direction: column;
656
+ gap: var(--cc-sf-form-section-gap, 24px);
657
+
658
+ // Reset individual section margins so gap controls spacing
659
+ >* {
660
+ margin-bottom: 0 !important;
661
+ }
662
+ }
663
+
664
+ // ── Form action bar ──────────────────────────────────────────────────────────
665
+ .form-actions {
666
+ display: flex;
667
+ justify-content: space-between;
668
+ align-items: center;
669
+ gap: var(--cc-sf-actions-gap, 12px);
670
+ padding: var(--cc-sf-actions-padding, 20px 10px 0);
671
+ margin-top: 8px;
672
+ // border-top: var(--cc-sf-actions-border, 1px solid #E5E7EB);
673
+
674
+ // ── Button groups ─────────────────────────────────────────────────────────
675
+ .action-group {
676
+ display: flex;
677
+ align-items: center;
678
+ gap: var(--cc-sf-actions-gap, 12px);
679
+
680
+ &--left {
681
+ justify-content: flex-start;
682
+ }
683
+
684
+ &--right {
685
+ justify-content: flex-end;
686
+ margin-left: auto; // Push to right if only one group present
687
+ }
688
+ }
689
+ }