@qwickapps/cms 0.2.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 (259) hide show
  1. package/LICENSE +45 -0
  2. package/README.md +203 -0
  3. package/dist/admin/components/AccordionItemRowLabel.d.ts +20 -0
  4. package/dist/admin/components/AccordionItemRowLabel.d.ts.map +1 -0
  5. package/dist/admin/components/AccordionItemRowLabel.js +47 -0
  6. package/dist/admin/components/AccordionItemRowLabel.js.map +1 -0
  7. package/dist/admin/components/BlockRowLabel.d.ts +19 -0
  8. package/dist/admin/components/BlockRowLabel.d.ts.map +1 -0
  9. package/dist/admin/components/BlockRowLabel.js +52 -0
  10. package/dist/admin/components/BlockRowLabel.js.map +1 -0
  11. package/dist/admin/components/ButtonRowLabel.d.ts +23 -0
  12. package/dist/admin/components/ButtonRowLabel.d.ts.map +1 -0
  13. package/dist/admin/components/ButtonRowLabel.js +63 -0
  14. package/dist/admin/components/ButtonRowLabel.js.map +1 -0
  15. package/dist/admin/components/CardRowLabel.d.ts +23 -0
  16. package/dist/admin/components/CardRowLabel.d.ts.map +1 -0
  17. package/dist/admin/components/CardRowLabel.js +59 -0
  18. package/dist/admin/components/CardRowLabel.js.map +1 -0
  19. package/dist/admin/components/ContentPreview.d.ts +12 -0
  20. package/dist/admin/components/ContentPreview.d.ts.map +1 -0
  21. package/dist/admin/components/ContentPreview.js +95 -0
  22. package/dist/admin/components/ContentPreview.js.map +1 -0
  23. package/dist/admin/components/Dashboard.d.ts +13 -0
  24. package/dist/admin/components/Dashboard.d.ts.map +1 -0
  25. package/dist/admin/components/Dashboard.js +7 -0
  26. package/dist/admin/components/Dashboard.js.map +1 -0
  27. package/dist/admin/components/DashboardContent.d.ts +11 -0
  28. package/dist/admin/components/DashboardContent.d.ts.map +1 -0
  29. package/dist/admin/components/DashboardContent.js +129 -0
  30. package/dist/admin/components/DashboardContent.js.map +1 -0
  31. package/dist/admin/components/FormFieldRowLabel.d.ts +21 -0
  32. package/dist/admin/components/FormFieldRowLabel.d.ts.map +1 -0
  33. package/dist/admin/components/FormFieldRowLabel.js +47 -0
  34. package/dist/admin/components/FormFieldRowLabel.js.map +1 -0
  35. package/dist/admin/components/Icon.d.ts +10 -0
  36. package/dist/admin/components/Icon.d.ts.map +1 -0
  37. package/dist/admin/components/Icon.js +16 -0
  38. package/dist/admin/components/Icon.js.map +1 -0
  39. package/dist/admin/components/Logo.d.ts +10 -0
  40. package/dist/admin/components/Logo.d.ts.map +1 -0
  41. package/dist/admin/components/Logo.js +16 -0
  42. package/dist/admin/components/Logo.js.map +1 -0
  43. package/dist/admin/components/NavigationItemRowLabel.d.ts +21 -0
  44. package/dist/admin/components/NavigationItemRowLabel.d.ts.map +1 -0
  45. package/dist/admin/components/NavigationItemRowLabel.js +43 -0
  46. package/dist/admin/components/NavigationItemRowLabel.js.map +1 -0
  47. package/dist/admin/components/NavigationSubItemRowLabel.d.ts +19 -0
  48. package/dist/admin/components/NavigationSubItemRowLabel.d.ts.map +1 -0
  49. package/dist/admin/components/NavigationSubItemRowLabel.js +32 -0
  50. package/dist/admin/components/NavigationSubItemRowLabel.js.map +1 -0
  51. package/dist/admin/components/PagesListHeader.d.ts +13 -0
  52. package/dist/admin/components/PagesListHeader.d.ts.map +1 -0
  53. package/dist/admin/components/PagesListHeader.js +48 -0
  54. package/dist/admin/components/PagesListHeader.js.map +1 -0
  55. package/dist/admin/components/ProductsListHeader.d.ts +13 -0
  56. package/dist/admin/components/ProductsListHeader.d.ts.map +1 -0
  57. package/dist/admin/components/ProductsListHeader.js +55 -0
  58. package/dist/admin/components/ProductsListHeader.js.map +1 -0
  59. package/dist/admin/components/styles/CollectionListHeader.css +161 -0
  60. package/dist/admin/components/styles/ContentPreview.css +416 -0
  61. package/dist/admin/components/styles/Dashboard.css +338 -0
  62. package/dist/admin/fields/ColorInput.d.ts +13 -0
  63. package/dist/admin/fields/ColorInput.d.ts.map +1 -0
  64. package/dist/admin/fields/ColorInput.js +201 -0
  65. package/dist/admin/fields/ColorInput.js.map +1 -0
  66. package/dist/admin/fields/index.d.ts +9 -0
  67. package/dist/admin/fields/index.d.ts.map +1 -0
  68. package/dist/admin/fields/index.js +9 -0
  69. package/dist/admin/fields/index.js.map +1 -0
  70. package/dist/admin/index.d.ts +24 -0
  71. package/dist/admin/index.d.ts.map +1 -0
  72. package/dist/admin/index.js +30 -0
  73. package/dist/admin/index.js.map +1 -0
  74. package/dist/blocks/ContentBlocks.d.ts +75 -0
  75. package/dist/blocks/ContentBlocks.d.ts.map +1 -0
  76. package/dist/blocks/ContentBlocks.js +1241 -0
  77. package/dist/blocks/ContentBlocks.js.map +1 -0
  78. package/dist/blocks/index.d.ts +2 -0
  79. package/dist/blocks/index.d.ts.map +1 -0
  80. package/dist/blocks/index.js +3 -0
  81. package/dist/blocks/index.js.map +1 -0
  82. package/dist/client/PayloadAPIClient.d.ts +65 -0
  83. package/dist/client/PayloadAPIClient.d.ts.map +1 -0
  84. package/dist/client/PayloadAPIClient.js +167 -0
  85. package/dist/client/PayloadAPIClient.js.map +1 -0
  86. package/dist/collections/Automations.d.ts +12 -0
  87. package/dist/collections/Automations.d.ts.map +1 -0
  88. package/dist/collections/Automations.js +741 -0
  89. package/dist/collections/Automations.js.map +1 -0
  90. package/dist/collections/Features.d.ts +3 -0
  91. package/dist/collections/Features.d.ts.map +1 -0
  92. package/dist/collections/Features.js +69 -0
  93. package/dist/collections/Features.js.map +1 -0
  94. package/dist/collections/Footer.d.ts +11 -0
  95. package/dist/collections/Footer.d.ts.map +1 -0
  96. package/dist/collections/Footer.js +130 -0
  97. package/dist/collections/Footer.js.map +1 -0
  98. package/dist/collections/FormSubmissions.d.ts +3 -0
  99. package/dist/collections/FormSubmissions.d.ts.map +1 -0
  100. package/dist/collections/FormSubmissions.js +119 -0
  101. package/dist/collections/FormSubmissions.js.map +1 -0
  102. package/dist/collections/Forms.d.ts +16 -0
  103. package/dist/collections/Forms.d.ts.map +1 -0
  104. package/dist/collections/Forms.js +308 -0
  105. package/dist/collections/Forms.js.map +1 -0
  106. package/dist/collections/HeroBlocks.d.ts +3 -0
  107. package/dist/collections/HeroBlocks.d.ts.map +1 -0
  108. package/dist/collections/HeroBlocks.js +115 -0
  109. package/dist/collections/HeroBlocks.js.map +1 -0
  110. package/dist/collections/Media.d.ts +3 -0
  111. package/dist/collections/Media.d.ts.map +1 -0
  112. package/dist/collections/Media.js +26 -0
  113. package/dist/collections/Media.js.map +1 -0
  114. package/dist/collections/Navigation.d.ts +3 -0
  115. package/dist/collections/Navigation.d.ts.map +1 -0
  116. package/dist/collections/Navigation.js +106 -0
  117. package/dist/collections/Navigation.js.map +1 -0
  118. package/dist/collections/Pages.d.ts +3 -0
  119. package/dist/collections/Pages.d.ts.map +1 -0
  120. package/dist/collections/Pages.js +94 -0
  121. package/dist/collections/Pages.js.map +1 -0
  122. package/dist/collections/Posts.d.ts +3 -0
  123. package/dist/collections/Posts.d.ts.map +1 -0
  124. package/dist/collections/Posts.js +134 -0
  125. package/dist/collections/Posts.js.map +1 -0
  126. package/dist/collections/Products.d.ts +3 -0
  127. package/dist/collections/Products.d.ts.map +1 -0
  128. package/dist/collections/Products.js +264 -0
  129. package/dist/collections/Products.js.map +1 -0
  130. package/dist/collections/Users.d.ts +3 -0
  131. package/dist/collections/Users.d.ts.map +1 -0
  132. package/dist/collections/Users.js +53 -0
  133. package/dist/collections/Users.js.map +1 -0
  134. package/dist/collections/hooks/index.d.ts +9 -0
  135. package/dist/collections/hooks/index.d.ts.map +1 -0
  136. package/dist/collections/hooks/index.js +9 -0
  137. package/dist/collections/hooks/index.js.map +1 -0
  138. package/dist/collections/hooks/loggingHooks.d.ts +45 -0
  139. package/dist/collections/hooks/loggingHooks.d.ts.map +1 -0
  140. package/dist/collections/hooks/loggingHooks.js +109 -0
  141. package/dist/collections/hooks/loggingHooks.js.map +1 -0
  142. package/dist/collections/index.d.ts +14 -0
  143. package/dist/collections/index.d.ts.map +1 -0
  144. package/dist/collections/index.js +16 -0
  145. package/dist/collections/index.js.map +1 -0
  146. package/dist/components/index.d.ts +2 -0
  147. package/dist/components/index.d.ts.map +1 -0
  148. package/dist/components/index.js +4 -0
  149. package/dist/components/index.js.map +1 -0
  150. package/dist/globals/AdvancedSettings.d.ts +8 -0
  151. package/dist/globals/AdvancedSettings.d.ts.map +1 -0
  152. package/dist/globals/AdvancedSettings.js +157 -0
  153. package/dist/globals/AdvancedSettings.js.map +1 -0
  154. package/dist/globals/Integrations.d.ts +8 -0
  155. package/dist/globals/Integrations.d.ts.map +1 -0
  156. package/dist/globals/Integrations.js +270 -0
  157. package/dist/globals/Integrations.js.map +1 -0
  158. package/dist/globals/SiteSettings.d.ts +8 -0
  159. package/dist/globals/SiteSettings.d.ts.map +1 -0
  160. package/dist/globals/SiteSettings.js +258 -0
  161. package/dist/globals/SiteSettings.js.map +1 -0
  162. package/dist/globals/ThemeSettings.d.ts +11 -0
  163. package/dist/globals/ThemeSettings.d.ts.map +1 -0
  164. package/dist/globals/ThemeSettings.js +92 -0
  165. package/dist/globals/ThemeSettings.js.map +1 -0
  166. package/dist/globals/index.d.ts +5 -0
  167. package/dist/globals/index.d.ts.map +1 -0
  168. package/dist/globals/index.js +6 -0
  169. package/dist/globals/index.js.map +1 -0
  170. package/dist/index.d.ts +9 -0
  171. package/dist/index.d.ts.map +1 -0
  172. package/dist/index.js +14 -0
  173. package/dist/index.js.map +1 -0
  174. package/dist/logging/index.d.ts +73 -0
  175. package/dist/logging/index.d.ts.map +1 -0
  176. package/dist/logging/index.js +190 -0
  177. package/dist/logging/index.js.map +1 -0
  178. package/dist/nextjs/BlockRenderer.d.ts +227 -0
  179. package/dist/nextjs/BlockRenderer.d.ts.map +1 -0
  180. package/dist/nextjs/BlockRenderer.js +358 -0
  181. package/dist/nextjs/BlockRenderer.js.map +1 -0
  182. package/dist/nextjs/ClientHomePage.d.ts +6 -0
  183. package/dist/nextjs/ClientHomePage.d.ts.map +1 -0
  184. package/dist/nextjs/ClientHomePage.js +17 -0
  185. package/dist/nextjs/ClientHomePage.js.map +1 -0
  186. package/dist/nextjs/ClientSideQwickApp.d.ts +23 -0
  187. package/dist/nextjs/ClientSideQwickApp.d.ts.map +1 -0
  188. package/dist/nextjs/ClientSideQwickApp.js +50 -0
  189. package/dist/nextjs/ClientSideQwickApp.js.map +1 -0
  190. package/dist/nextjs/DynamicQwickApp.d.ts +9 -0
  191. package/dist/nextjs/DynamicQwickApp.d.ts.map +1 -0
  192. package/dist/nextjs/DynamicQwickApp.js +19 -0
  193. package/dist/nextjs/DynamicQwickApp.js.map +1 -0
  194. package/dist/nextjs/FooterFromSettings.d.ts +6 -0
  195. package/dist/nextjs/FooterFromSettings.d.ts.map +1 -0
  196. package/dist/nextjs/FooterFromSettings.js +72 -0
  197. package/dist/nextjs/FooterFromSettings.js.map +1 -0
  198. package/dist/nextjs/FormBlockComponent.d.ts +25 -0
  199. package/dist/nextjs/FormBlockComponent.d.ts.map +1 -0
  200. package/dist/nextjs/FormBlockComponent.js +110 -0
  201. package/dist/nextjs/FormBlockComponent.js.map +1 -0
  202. package/dist/nextjs/HomePageContent.d.ts +6 -0
  203. package/dist/nextjs/HomePageContent.d.ts.map +1 -0
  204. package/dist/nextjs/HomePageContent.js +50 -0
  205. package/dist/nextjs/HomePageContent.js.map +1 -0
  206. package/dist/nextjs/LivePreviewClient.d.ts +40 -0
  207. package/dist/nextjs/LivePreviewClient.d.ts.map +1 -0
  208. package/dist/nextjs/LivePreviewClient.js +35 -0
  209. package/dist/nextjs/LivePreviewClient.js.map +1 -0
  210. package/dist/nextjs/RefreshRouteOnSave.d.ts +31 -0
  211. package/dist/nextjs/RefreshRouteOnSave.d.ts.map +1 -0
  212. package/dist/nextjs/RefreshRouteOnSave.js +59 -0
  213. package/dist/nextjs/RefreshRouteOnSave.js.map +1 -0
  214. package/dist/nextjs/ScriptsInjector.d.ts +2 -0
  215. package/dist/nextjs/ScriptsInjector.d.ts.map +1 -0
  216. package/dist/nextjs/ScriptsInjector.js +73 -0
  217. package/dist/nextjs/ScriptsInjector.js.map +1 -0
  218. package/dist/nextjs/ServerQwickApp.d.ts +13 -0
  219. package/dist/nextjs/ServerQwickApp.d.ts.map +1 -0
  220. package/dist/nextjs/ServerQwickApp.js +159 -0
  221. package/dist/nextjs/ServerQwickApp.js.map +1 -0
  222. package/dist/nextjs/SettingsProvider.d.ts +110 -0
  223. package/dist/nextjs/SettingsProvider.d.ts.map +1 -0
  224. package/dist/nextjs/SettingsProvider.js +107 -0
  225. package/dist/nextjs/SettingsProvider.js.map +1 -0
  226. package/dist/nextjs/SiteLogo.d.ts +35 -0
  227. package/dist/nextjs/SiteLogo.d.ts.map +1 -0
  228. package/dist/nextjs/SiteLogo.js +105 -0
  229. package/dist/nextjs/SiteLogo.js.map +1 -0
  230. package/dist/nextjs/framework.d.ts +19 -0
  231. package/dist/nextjs/framework.d.ts.map +1 -0
  232. package/dist/nextjs/framework.js +35 -0
  233. package/dist/nextjs/framework.js.map +1 -0
  234. package/dist/nextjs/index.d.ts +38 -0
  235. package/dist/nextjs/index.d.ts.map +1 -0
  236. package/dist/nextjs/index.js +47 -0
  237. package/dist/nextjs/index.js.map +1 -0
  238. package/dist/nextjs/metadata.d.ts +20 -0
  239. package/dist/nextjs/metadata.d.ts.map +1 -0
  240. package/dist/nextjs/metadata.js +107 -0
  241. package/dist/nextjs/metadata.js.map +1 -0
  242. package/dist/plugins/index.d.ts +2 -0
  243. package/dist/plugins/index.d.ts.map +1 -0
  244. package/dist/plugins/index.js +3 -0
  245. package/dist/plugins/index.js.map +1 -0
  246. package/dist/plugins/qwickapps-plugin.d.ts +78 -0
  247. package/dist/plugins/qwickapps-plugin.d.ts.map +1 -0
  248. package/dist/plugins/qwickapps-plugin.js +154 -0
  249. package/dist/plugins/qwickapps-plugin.js.map +1 -0
  250. package/dist/providers/PayloadDataProvider.d.ts +72 -0
  251. package/dist/providers/PayloadDataProvider.d.ts.map +1 -0
  252. package/dist/providers/PayloadDataProvider.js +222 -0
  253. package/dist/providers/PayloadDataProvider.js.map +1 -0
  254. package/dist/providers/index.d.ts +2 -0
  255. package/dist/providers/index.d.ts.map +1 -0
  256. package/dist/providers/index.js +3 -0
  257. package/dist/providers/index.js.map +1 -0
  258. package/dist/styles/admin-theme.css +352 -0
  259. package/package.json +104 -0
@@ -0,0 +1,416 @@
1
+ /**
2
+ * Content Preview Styles
3
+ *
4
+ * Copyright (c) 2025 QwickApps.com. All rights reserved.
5
+ */
6
+
7
+ .content-preview {
8
+ position: sticky;
9
+ top: 0;
10
+ background: var(--theme-elevation-50);
11
+ border: 2px solid var(--theme-elevation-200);
12
+ border-radius: 12px;
13
+ overflow: hidden;
14
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
15
+ max-height: calc(100vh - 100px);
16
+ display: flex;
17
+ flex-direction: column;
18
+ }
19
+
20
+ .preview-header {
21
+ display: flex;
22
+ align-items: center;
23
+ justify-content: space-between;
24
+ padding: 1rem;
25
+ background: var(--theme-elevation-100);
26
+ border-bottom: 1px solid var(--theme-elevation-200);
27
+ gap: 1rem;
28
+ flex-wrap: wrap;
29
+ }
30
+
31
+ .preview-header h3 {
32
+ margin: 0;
33
+ font-size: 1rem;
34
+ font-weight: 600;
35
+ color: var(--theme-elevation-900);
36
+ }
37
+
38
+ .preview-device-selector {
39
+ display: flex;
40
+ gap: 0.5rem;
41
+ background: var(--theme-elevation-50);
42
+ padding: 0.25rem;
43
+ border-radius: 8px;
44
+ border: 1px solid var(--theme-elevation-300);
45
+ }
46
+
47
+ .preview-device-selector button {
48
+ background: transparent;
49
+ border: none;
50
+ padding: 0.5rem 0.75rem;
51
+ border-radius: 6px;
52
+ cursor: pointer;
53
+ font-size: 1.1rem;
54
+ transition: all 0.2s ease;
55
+ opacity: 0.6;
56
+ }
57
+
58
+ .preview-device-selector button:hover {
59
+ opacity: 0.8;
60
+ background: var(--theme-elevation-100);
61
+ }
62
+
63
+ .preview-device-selector button.active {
64
+ opacity: 1;
65
+ background: var(--theme-elevation-200);
66
+ box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
67
+ }
68
+
69
+ .preview-status {
70
+ padding: 0.35rem 0.75rem;
71
+ border-radius: 6px;
72
+ font-size: 0.875rem;
73
+ font-weight: 600;
74
+ text-transform: capitalize;
75
+ }
76
+
77
+ .preview-status.status-draft {
78
+ background: #fef3c7;
79
+ color: #92400e;
80
+ }
81
+
82
+ .preview-status.status-published {
83
+ background: #d1fae5;
84
+ color: #065f46;
85
+ }
86
+
87
+ .preview-viewport {
88
+ flex: 1;
89
+ overflow-y: auto;
90
+ background: white;
91
+ margin: 1rem auto;
92
+ width: 100%;
93
+ transition: max-width 0.3s ease;
94
+ }
95
+
96
+ .viewport-desktop {
97
+ max-width: 100%;
98
+ }
99
+
100
+ .viewport-tablet {
101
+ max-width: 768px;
102
+ border-left: 2px solid var(--theme-elevation-200);
103
+ border-right: 2px solid var(--theme-elevation-200);
104
+ }
105
+
106
+ .viewport-mobile {
107
+ max-width: 375px;
108
+ border-left: 2px solid var(--theme-elevation-200);
109
+ border-right: 2px solid var(--theme-elevation-200);
110
+ }
111
+
112
+ .preview-content {
113
+ padding: 1.5rem;
114
+ }
115
+
116
+ .preview-title {
117
+ font-size: 2rem;
118
+ font-weight: 700;
119
+ margin: 0 0 1.5rem 0;
120
+ color: #1a202c;
121
+ }
122
+
123
+ .preview-blocks {
124
+ display: flex;
125
+ flex-direction: column;
126
+ gap: 1.5rem;
127
+ }
128
+
129
+ .preview-block {
130
+ padding: 1.5rem;
131
+ border: 1px solid var(--theme-elevation-200);
132
+ border-radius: 8px;
133
+ background: var(--theme-elevation-50);
134
+ transition: all 0.2s ease;
135
+ }
136
+
137
+ .preview-block:hover {
138
+ border-color: #667eea;
139
+ box-shadow: 0 2px 8px rgba(102, 126, 234, 0.15);
140
+ }
141
+
142
+ .preview-hero {
143
+ text-align: center;
144
+ padding: 3rem 2rem;
145
+ color: white;
146
+ background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
147
+ border: none;
148
+ }
149
+
150
+ .preview-hero h2 {
151
+ font-size: 2rem;
152
+ margin: 0 0 1rem 0;
153
+ }
154
+
155
+ .preview-hero p {
156
+ font-size: 1.1rem;
157
+ margin: 0 0 1.5rem 0;
158
+ opacity: 0.95;
159
+ }
160
+
161
+ .preview-actions {
162
+ display: flex;
163
+ gap: 1rem;
164
+ justify-content: center;
165
+ flex-wrap: wrap;
166
+ }
167
+
168
+ .preview-button {
169
+ padding: 0.75rem 1.5rem;
170
+ border-radius: 6px;
171
+ font-weight: 600;
172
+ cursor: pointer;
173
+ transition: all 0.2s ease;
174
+ border: 2px solid transparent;
175
+ }
176
+
177
+ .preview-button.contained {
178
+ background: white;
179
+ color: #667eea;
180
+ border-color: white;
181
+ }
182
+
183
+ .preview-button.outlined {
184
+ background: transparent;
185
+ color: white;
186
+ border-color: white;
187
+ }
188
+
189
+ .preview-button.text {
190
+ background: transparent;
191
+ color: white;
192
+ border: none;
193
+ }
194
+
195
+ .preview-text-section h3 {
196
+ margin: 0 0 1rem 0;
197
+ font-size: 1.5rem;
198
+ color: #1a202c;
199
+ }
200
+
201
+ .preview-rich-text {
202
+ color: #4a5568;
203
+ line-height: 1.6;
204
+ }
205
+
206
+ .preview-grid {
207
+ display: grid;
208
+ gap: 1rem;
209
+ }
210
+
211
+ .preview-feature-card,
212
+ .preview-product-card,
213
+ .preview-card {
214
+ padding: 1.5rem;
215
+ background: white;
216
+ border: 1px solid var(--theme-elevation-200);
217
+ border-radius: 8px;
218
+ text-align: center;
219
+ transition: all 0.2s ease;
220
+ }
221
+
222
+ .preview-feature-card:hover,
223
+ .preview-product-card:hover,
224
+ .preview-card:hover {
225
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
226
+ transform: translateY(-2px);
227
+ }
228
+
229
+ .feature-icon,
230
+ .card-icon {
231
+ font-size: 2rem;
232
+ margin-bottom: 0.5rem;
233
+ display: flex;
234
+ align-items: center;
235
+ justify-content: center;
236
+ }
237
+
238
+ .feature-icon svg,
239
+ .card-icon svg {
240
+ width: 2rem;
241
+ height: 2rem;
242
+ color: #667eea;
243
+ }
244
+
245
+ .feature-title,
246
+ .product-title,
247
+ .preview-card h4 {
248
+ font-weight: 600;
249
+ color: #1a202c;
250
+ margin: 0.5rem 0;
251
+ }
252
+
253
+ .preview-image {
254
+ text-align: center;
255
+ }
256
+
257
+ .preview-image-placeholder {
258
+ background: var(--theme-elevation-100);
259
+ padding: 3rem;
260
+ border-radius: 8px;
261
+ font-size: 1.5rem;
262
+ color: var(--theme-elevation-600);
263
+ }
264
+
265
+ .image-caption {
266
+ margin-top: 0.5rem;
267
+ font-size: 0.875rem;
268
+ color: #6b7280;
269
+ font-style: italic;
270
+ }
271
+
272
+ .preview-code {
273
+ background: #1e293b;
274
+ color: #e2e8f0;
275
+ }
276
+
277
+ .preview-code h4 {
278
+ margin: 0 0 1rem 0;
279
+ color: #e2e8f0;
280
+ }
281
+
282
+ .code-block {
283
+ margin: 0;
284
+ padding: 1rem;
285
+ background: #0f172a;
286
+ border-radius: 6px;
287
+ overflow-x: auto;
288
+ font-family: 'Courier New', monospace;
289
+ font-size: 0.875rem;
290
+ line-height: 1.5;
291
+ }
292
+
293
+ .preview-cta {
294
+ text-align: center;
295
+ background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
296
+ padding: 2.5rem 2rem;
297
+ }
298
+
299
+ .preview-cta h3 {
300
+ margin: 0 0 0.75rem 0;
301
+ font-size: 1.75rem;
302
+ color: #1a202c;
303
+ }
304
+
305
+ .preview-cta p {
306
+ margin: 0 0 1.5rem 0;
307
+ color: #4a5568;
308
+ }
309
+
310
+ .preview-spacer {
311
+ background: repeating-linear-gradient(
312
+ 45deg,
313
+ transparent,
314
+ transparent 10px,
315
+ var(--theme-elevation-100) 10px,
316
+ var(--theme-elevation-100) 20px
317
+ );
318
+ display: flex;
319
+ align-items: center;
320
+ justify-content: center;
321
+ border-style: dashed;
322
+ }
323
+
324
+ .spacer-indicator {
325
+ background: var(--theme-elevation-200);
326
+ padding: 0.5rem 1rem;
327
+ border-radius: 6px;
328
+ font-size: 0.875rem;
329
+ font-weight: 600;
330
+ color: var(--theme-elevation-700);
331
+ }
332
+
333
+ .accordion-item {
334
+ padding: 1rem;
335
+ background: white;
336
+ border: 1px solid var(--theme-elevation-200);
337
+ border-radius: 6px;
338
+ margin-bottom: 0.5rem;
339
+ font-weight: 500;
340
+ color: #1a202c;
341
+ }
342
+
343
+ .preview-empty {
344
+ padding: 4rem 2rem;
345
+ text-align: center;
346
+ color: var(--theme-elevation-600);
347
+ }
348
+
349
+ .preview-empty p {
350
+ margin: 0.5rem 0;
351
+ font-size: 0.95rem;
352
+ }
353
+
354
+ .preview-info {
355
+ padding: 0.75rem 1rem;
356
+ background: var(--theme-elevation-100);
357
+ border-top: 1px solid var(--theme-elevation-200);
358
+ text-align: center;
359
+ }
360
+
361
+ .preview-info small {
362
+ color: var(--theme-elevation-700);
363
+ font-weight: 500;
364
+ }
365
+
366
+ @media (max-width: 768px) {
367
+ .content-preview {
368
+ max-height: 400px;
369
+ }
370
+
371
+ .preview-title {
372
+ font-size: 1.5rem;
373
+ }
374
+ }
375
+
376
+ @media (prefers-color-scheme: dark) {
377
+ .content-preview {
378
+ background: var(--theme-elevation-900);
379
+ border-color: var(--theme-elevation-700);
380
+ }
381
+
382
+ .preview-header {
383
+ background: var(--theme-elevation-800);
384
+ border-color: var(--theme-elevation-700);
385
+ }
386
+
387
+ .preview-viewport {
388
+ background: var(--theme-elevation-800);
389
+ }
390
+
391
+ .preview-block {
392
+ background: var(--theme-elevation-800);
393
+ border-color: var(--theme-elevation-700);
394
+ }
395
+
396
+ .preview-title {
397
+ color: var(--theme-elevation-50);
398
+ }
399
+
400
+ .feature-title,
401
+ .product-title,
402
+ .preview-card h4 {
403
+ color: var(--theme-elevation-50);
404
+ }
405
+
406
+ .preview-feature-card,
407
+ .preview-product-card,
408
+ .preview-card {
409
+ background: var(--theme-elevation-700);
410
+ }
411
+
412
+ .accordion-item {
413
+ background: var(--theme-elevation-700);
414
+ color: var(--theme-elevation-50);
415
+ }
416
+ }