synthos 0.8.0 → 0.9.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 (359) hide show
  1. package/README.md +1 -1
  2. package/default-pages/application/page.html +42 -0
  3. package/default-pages/application/page.json +10 -0
  4. package/default-pages/elevenlabs_effects_studio/page.html +1363 -0
  5. package/default-pages/elevenlabs_effects_studio/page.json +11 -0
  6. package/default-pages/elevenlabs_voice_studio/page.html +801 -0
  7. package/default-pages/elevenlabs_voice_studio/page.json +11 -0
  8. package/default-pages/{json_tools.html → json_tools/page.html} +13 -11
  9. package/default-pages/json_tools/page.json +10 -0
  10. package/default-pages/my_notes/notes/a1b2c3d4-e5f6-7890-abcd-ef1234567890.json +5 -0
  11. package/default-pages/my_notes/page.html +132 -0
  12. package/default-pages/{my_notes.json → my_notes/page.json} +2 -2
  13. package/default-pages/neon_asteroids/files/Ambient_Space.mp3 +0 -0
  14. package/default-pages/neon_asteroids/files/Ambient_Space2.mp3 +0 -0
  15. package/default-pages/neon_asteroids/files/Ambient_Space3.mp3 +0 -0
  16. package/default-pages/neon_asteroids/files/Asteroid_Explosion.mp3 +0 -0
  17. package/default-pages/neon_asteroids/files/Hyperspace_Jump.mp3 +0 -0
  18. package/default-pages/neon_asteroids/files/Laser_Fire.mp3 +0 -0
  19. package/default-pages/neon_asteroids/files/Menu_Navigate.mp3 +0 -0
  20. package/default-pages/neon_asteroids/files/Power_Up_Collect.mp3 +0 -0
  21. package/default-pages/neon_asteroids/files/Saucer_Alert.mp3 +0 -0
  22. package/default-pages/neon_asteroids/files/Ship_Thrust.mp3 +0 -0
  23. package/default-pages/neon_asteroids/files/effects.json +74 -0
  24. package/default-pages/neon_asteroids/page.html +1822 -0
  25. package/default-pages/{neon_asteroids.json → neon_asteroids/page.json} +3 -3
  26. package/default-pages/{oregon_trail.html → oregon_trail/page.html} +14 -12
  27. package/default-pages/{oregon_trail.json → oregon_trail/page.json} +2 -2
  28. package/default-pages/retro_game_starter/page.html +1308 -0
  29. package/default-pages/retro_game_starter/page.json +12 -0
  30. package/default-pages/{sidebar_page.html → sidebar_page/page.html} +12 -10
  31. package/default-pages/sidebar_page/page.json +10 -0
  32. package/default-pages/{solar_explorer.html → solar_explorer/page.html} +14 -11
  33. package/default-pages/{solar_explorer.json → solar_explorer/page.json} +2 -2
  34. package/default-pages/{solar_tutorial.html → solar_tutorial/page.html} +12 -10
  35. package/default-pages/solar_tutorial/page.json +10 -0
  36. package/default-pages/{two-panel_page.html → two-panel_page/page.html} +13 -11
  37. package/default-pages/two-panel_page/page.json +10 -0
  38. package/default-pages/{us_map.html → us_map/page.html} +193 -192
  39. package/default-pages/{us_map.json → us_map/page.json} +12 -12
  40. package/default-pages/{us_map_1850.html → us_map_1850/page.html} +326 -325
  41. package/default-pages/{us_map_1850.json → us_map_1850/page.json} +12 -12
  42. package/default-pages/{western_cities_1850.html → western_cities_1850/page.html} +527 -526
  43. package/default-pages/{western_cities_1850.json → western_cities_1850/page.json} +12 -12
  44. package/default-themes/aurora-dawn.json +19 -0
  45. package/default-themes/aurora-dawn.v3.css +198 -0
  46. package/default-themes/aurora-dusk.json +19 -0
  47. package/default-themes/aurora-dusk.v3.css +200 -0
  48. package/default-themes/cosmos-dawn.json +19 -0
  49. package/default-themes/cosmos-dawn.v3.css +198 -0
  50. package/default-themes/cosmos-dusk.json +19 -0
  51. package/default-themes/cosmos-dusk.v3.css +200 -0
  52. package/default-themes/high-contrast-dark.json +19 -0
  53. package/default-themes/high-contrast-dark.v3.css +200 -0
  54. package/default-themes/high-contrast-light.json +19 -0
  55. package/default-themes/high-contrast-light.v3.css +198 -0
  56. package/default-themes/nebula-dawn.v2.css +110 -0
  57. package/default-themes/nebula-dawn.v3.css +199 -0
  58. package/default-themes/nebula-dusk.v2.css +104 -0
  59. package/default-themes/nebula-dusk.v3.css +201 -0
  60. package/default-themes/solar-flare-dawn.json +19 -0
  61. package/default-themes/solar-flare-dawn.v3.css +198 -0
  62. package/default-themes/solar-flare-dusk.json +19 -0
  63. package/default-themes/solar-flare-dusk.v3.css +200 -0
  64. package/dist/agents/index.d.ts +1 -1
  65. package/dist/agents/index.d.ts.map +1 -1
  66. package/dist/agents/index.js +2 -1
  67. package/dist/agents/index.js.map +1 -1
  68. package/dist/agents/openclaw/gatewayManager.d.ts +4 -0
  69. package/dist/agents/openclaw/gatewayManager.d.ts.map +1 -1
  70. package/dist/agents/openclaw/gatewayManager.js +27 -11
  71. package/dist/agents/openclaw/gatewayManager.js.map +1 -1
  72. package/dist/agents/openclaw/openclawProvider.d.ts.map +1 -1
  73. package/dist/agents/openclaw/openclawProvider.js +2 -4
  74. package/dist/agents/openclaw/openclawProvider.js.map +1 -1
  75. package/dist/agents/openclaw/sshTunnelManager.d.ts +2 -0
  76. package/dist/agents/openclaw/sshTunnelManager.d.ts.map +1 -1
  77. package/dist/agents/openclaw/sshTunnelManager.js +31 -12
  78. package/dist/agents/openclaw/sshTunnelManager.js.map +1 -1
  79. package/dist/builders/anthropic.d.ts +31 -0
  80. package/dist/builders/anthropic.d.ts.map +1 -0
  81. package/dist/builders/anthropic.js +227 -0
  82. package/dist/builders/anthropic.js.map +1 -0
  83. package/dist/builders/fireworksai.d.ts +9 -0
  84. package/dist/builders/fireworksai.d.ts.map +1 -0
  85. package/dist/builders/fireworksai.js +57 -0
  86. package/dist/builders/fireworksai.js.map +1 -0
  87. package/dist/builders/index.d.ts +13 -0
  88. package/dist/builders/index.d.ts.map +1 -0
  89. package/dist/builders/index.js +31 -0
  90. package/dist/builders/index.js.map +1 -0
  91. package/dist/builders/openai.d.ts +8 -0
  92. package/dist/builders/openai.d.ts.map +1 -0
  93. package/dist/builders/openai.js +87 -0
  94. package/dist/builders/openai.js.map +1 -0
  95. package/dist/builders/types.d.ts +54 -0
  96. package/dist/builders/types.d.ts.map +1 -0
  97. package/dist/builders/types.js +211 -0
  98. package/dist/builders/types.js.map +1 -0
  99. package/dist/connectors/index.d.ts.map +1 -1
  100. package/dist/connectors/index.js +3 -2
  101. package/dist/connectors/index.js.map +1 -1
  102. package/dist/connectors/registry.d.ts +2 -1
  103. package/dist/connectors/registry.d.ts.map +1 -1
  104. package/dist/connectors/registry.js +31 -8
  105. package/dist/connectors/registry.js.map +1 -1
  106. package/dist/customizer/Customizer.d.ts +57 -0
  107. package/dist/customizer/Customizer.d.ts.map +1 -0
  108. package/dist/customizer/Customizer.js +124 -0
  109. package/dist/customizer/Customizer.js.map +1 -0
  110. package/dist/customizer/index.d.ts.map +1 -0
  111. package/dist/customizer/index.js +9 -0
  112. package/dist/customizer/index.js.map +1 -0
  113. package/dist/files.d.ts +16 -0
  114. package/dist/files.d.ts.map +1 -1
  115. package/dist/files.js +60 -1
  116. package/dist/files.js.map +1 -1
  117. package/dist/index.d.ts.map +1 -1
  118. package/dist/index.js +1 -0
  119. package/dist/index.js.map +1 -1
  120. package/dist/init.d.ts +10 -6
  121. package/dist/init.d.ts.map +1 -1
  122. package/dist/init.js +96 -113
  123. package/dist/init.js.map +1 -1
  124. package/dist/migrations.d.ts.map +1 -1
  125. package/dist/migrations.js +23 -10
  126. package/dist/migrations.js.map +1 -1
  127. package/dist/models/anthropic.d.ts +4 -2
  128. package/dist/models/anthropic.d.ts.map +1 -1
  129. package/dist/models/anthropic.js +33 -6
  130. package/dist/models/anthropic.js.map +1 -1
  131. package/dist/models/fireworksai.d.ts.map +1 -1
  132. package/dist/models/fireworksai.js +9 -1
  133. package/dist/models/fireworksai.js.map +1 -1
  134. package/dist/models/index.d.ts +1 -1
  135. package/dist/models/index.d.ts.map +1 -1
  136. package/dist/models/index.js +2 -1
  137. package/dist/models/index.js.map +1 -1
  138. package/dist/models/openai.d.ts +1 -1
  139. package/dist/models/openai.d.ts.map +1 -1
  140. package/dist/models/openai.js +24 -3
  141. package/dist/models/openai.js.map +1 -1
  142. package/dist/models/types.d.ts +20 -1
  143. package/dist/models/types.d.ts.map +1 -1
  144. package/dist/models/types.js +6 -1
  145. package/dist/models/types.js.map +1 -1
  146. package/dist/pages.d.ts +30 -7
  147. package/dist/pages.d.ts.map +1 -1
  148. package/dist/pages.js +177 -55
  149. package/dist/pages.js.map +1 -1
  150. package/dist/service/server.d.ts.map +1 -1
  151. package/dist/service/server.js +37 -8
  152. package/dist/service/server.js.map +1 -1
  153. package/dist/service/transformPage.d.ts +47 -20
  154. package/dist/service/transformPage.d.ts.map +1 -1
  155. package/dist/service/transformPage.js +514 -293
  156. package/dist/service/transformPage.js.map +1 -1
  157. package/dist/service/useAgentRoutes.d.ts +2 -1
  158. package/dist/service/useAgentRoutes.d.ts.map +1 -1
  159. package/dist/service/useAgentRoutes.js +5 -2
  160. package/dist/service/useAgentRoutes.js.map +1 -1
  161. package/dist/service/useApiRoutes.d.ts.map +1 -1
  162. package/dist/service/useApiRoutes.js +237 -136
  163. package/dist/service/useApiRoutes.js.map +1 -1
  164. package/dist/service/useConnectorRoutes.js +6 -6
  165. package/dist/service/useConnectorRoutes.js.map +1 -1
  166. package/dist/service/useFileRoutes.d.ts +4 -0
  167. package/dist/service/useFileRoutes.d.ts.map +1 -0
  168. package/dist/service/useFileRoutes.js +122 -0
  169. package/dist/service/useFileRoutes.js.map +1 -0
  170. package/dist/service/usePageRoutes.d.ts.map +1 -1
  171. package/dist/service/usePageRoutes.js +648 -67
  172. package/dist/service/usePageRoutes.js.map +1 -1
  173. package/dist/service/useSharedDataRoutes.d.ts +4 -0
  174. package/dist/service/useSharedDataRoutes.d.ts.map +1 -0
  175. package/dist/service/useSharedDataRoutes.js +104 -0
  176. package/dist/service/useSharedDataRoutes.js.map +1 -0
  177. package/dist/service/useSharedFileRoutes.d.ts +4 -0
  178. package/dist/service/useSharedFileRoutes.d.ts.map +1 -0
  179. package/dist/service/useSharedFileRoutes.js +121 -0
  180. package/dist/service/useSharedFileRoutes.js.map +1 -0
  181. package/dist/settings.d.ts +1 -0
  182. package/dist/settings.d.ts.map +1 -1
  183. package/dist/settings.js +1 -0
  184. package/dist/settings.js.map +1 -1
  185. package/dist/synthos-cli.d.ts.map +1 -1
  186. package/dist/synthos-cli.js +4 -3
  187. package/dist/synthos-cli.js.map +1 -1
  188. package/dist/themes.d.ts +1 -0
  189. package/dist/themes.d.ts.map +1 -1
  190. package/dist/themes.js +28 -15
  191. package/dist/themes.js.map +1 -1
  192. package/migration-rules/v1-to-v2.md +193 -0
  193. package/migration-rules/v2-to-v3.md +481 -0
  194. package/package.json +11 -10
  195. package/required-pages/builder/page.html +43 -0
  196. package/required-pages/builder/page.json +10 -0
  197. package/required-pages/{pages.html → pages/page.html} +238 -233
  198. package/required-pages/pages/page.json +10 -0
  199. package/required-pages/{settings.html → settings/page.html} +389 -275
  200. package/required-pages/settings/page.json +10 -0
  201. package/required-pages/synthos_apis/page.html +846 -0
  202. package/required-pages/synthos_apis/page.json +10 -0
  203. package/required-pages/{synthos_scripts.html → synthos_scripts/page.html} +13 -11
  204. package/required-pages/synthos_scripts/page.json +10 -0
  205. package/src/agents/index.ts +1 -1
  206. package/src/agents/openclaw/gatewayManager.ts +22 -11
  207. package/src/agents/openclaw/openclawProvider.ts +2 -4
  208. package/src/agents/openclaw/sshTunnelManager.ts +19 -11
  209. package/src/builders/anthropic.ts +283 -0
  210. package/src/builders/fireworksai.ts +59 -0
  211. package/src/builders/index.ts +33 -0
  212. package/src/builders/openai.ts +89 -0
  213. package/src/builders/types.ts +261 -0
  214. package/src/connectors/index.ts +1 -1
  215. package/src/connectors/registry.ts +28 -8
  216. package/src/customizer/Customizer.ts +151 -0
  217. package/src/customizer/index.ts +5 -0
  218. package/src/files.ts +57 -0
  219. package/src/index.ts +2 -1
  220. package/src/init.ts +137 -123
  221. package/src/migrations.ts +30 -10
  222. package/src/models/anthropic.ts +40 -10
  223. package/src/models/fireworksai.ts +9 -2
  224. package/src/models/index.ts +1 -1
  225. package/src/models/openai.ts +26 -6
  226. package/src/models/types.ts +31 -1
  227. package/src/pages.ts +176 -54
  228. package/src/service/server.ts +36 -9
  229. package/src/service/transformPage.ts +557 -326
  230. package/src/service/useAgentRoutes.ts +7 -2
  231. package/src/service/useApiRoutes.ts +150 -41
  232. package/src/service/useConnectorRoutes.ts +7 -7
  233. package/src/service/useFileRoutes.ts +127 -0
  234. package/src/service/usePageRoutes.ts +720 -73
  235. package/src/service/useSharedDataRoutes.ts +106 -0
  236. package/src/service/useSharedFileRoutes.ts +126 -0
  237. package/src/settings.ts +2 -0
  238. package/src/synthos-cli.ts +4 -3
  239. package/src/themes.ts +25 -14
  240. package/static-files/favicon.svg +12 -0
  241. package/static-files/fluentlm-instructions.llmd +868 -0
  242. package/static-files/fluentlm-instructions.md +1595 -0
  243. package/static-files/fluentlm.css +4844 -0
  244. package/static-files/fluentlm.js +3602 -0
  245. package/static-files/fluentlm.min.css +1 -0
  246. package/static-files/fluentlm.min.js +1 -0
  247. package/{page-scripts/helpers-v2.js → static-files/helpers.v3.js} +82 -0
  248. package/static-files/page.v3.js +1290 -0
  249. package/static-files/recommended-frameworks.llmd +81 -0
  250. package/static-files/recommended-frameworks.md +137 -0
  251. package/static-files/retro-game.js +877 -0
  252. package/static-files/shell.css +797 -0
  253. package/static-files/theme-dark.css +169 -0
  254. package/static-files/theme-light.css +169 -0
  255. package/tests/builders.spec.ts +139 -0
  256. package/tests/pages.spec.ts +8 -8
  257. package/tests/transformPage.spec.ts +299 -360
  258. package/default-pages/application.html +0 -40
  259. package/default-pages/application.json +0 -1
  260. package/default-pages/json_tools.json +0 -1
  261. package/default-pages/my_notes.html +0 -33
  262. package/default-pages/neon_asteroids.html +0 -77
  263. package/default-pages/sidebar_page.json +0 -1
  264. package/default-pages/solar_tutorial.json +0 -1
  265. package/default-pages/two-panel_page.json +0 -1
  266. package/dist/agents/a2a/a2aProvider.d.ts +0 -3
  267. package/dist/agents/discovery.d.ts +0 -30
  268. package/dist/agents/openclaw/openclawProvider.d.ts +0 -3
  269. package/dist/agents/types.d.ts +0 -64
  270. package/dist/connectors/index.d.ts +0 -3
  271. package/dist/connectors/types.d.ts +0 -84
  272. package/dist/index.d.ts +0 -7
  273. package/dist/migrations.d.ts +0 -12
  274. package/dist/models/chainOfThought.d.ts +0 -12
  275. package/dist/models/fireworksai.d.ts +0 -30
  276. package/dist/models/logCompletePrompt.d.ts +0 -3
  277. package/dist/models/providers.d.ts +0 -8
  278. package/dist/models/utils.d.ts +0 -6
  279. package/dist/scripts.d.ts +0 -15
  280. package/dist/service/createCompletePrompt.d.ts +0 -5
  281. package/dist/service/debugLog.d.ts +0 -11
  282. package/dist/service/generateImage.d.ts +0 -32
  283. package/dist/service/index.d.ts +0 -8
  284. package/dist/service/modelInstructions.d.ts +0 -7
  285. package/dist/service/requiresSettings.d.ts +0 -3
  286. package/dist/service/server.d.ts +0 -4
  287. package/dist/service/useApiRoutes.d.ts +0 -4
  288. package/dist/service/useConnectorRoutes.d.ts +0 -4
  289. package/dist/service/useDataRoutes.d.ts +0 -4
  290. package/dist/service/useGatewayRoutes.d.ts +0 -4
  291. package/dist/service/useGatewayRoutes.d.ts.map +0 -1
  292. package/dist/service/useGatewayRoutes.js +0 -168
  293. package/dist/service/useGatewayRoutes.js.map +0 -1
  294. package/dist/service/usePageRoutes.d.ts +0 -5
  295. package/dist/synthos-cli.d.ts +0 -2
  296. package/page-scripts/page-v2.js +0 -656
  297. package/required-pages/builder.html +0 -48
  298. package/required-pages/builder.json +0 -1
  299. package/required-pages/pages.json +0 -1
  300. package/required-pages/settings.json +0 -1
  301. package/required-pages/synthos_apis.html +0 -327
  302. package/required-pages/synthos_apis.json +0 -1
  303. package/required-pages/synthos_scripts.json +0 -1
  304. package/src/connectors/airtable/connector.json +0 -27
  305. package/src/connectors/alpha-vantage/connector.json +0 -26
  306. package/src/connectors/brave-search/connector.json +0 -26
  307. package/src/connectors/cloudinary/connector.json +0 -27
  308. package/src/connectors/deepl/connector.json +0 -28
  309. package/src/connectors/elevenlabs/connector.json +0 -30
  310. package/src/connectors/giphy/connector.json +0 -27
  311. package/src/connectors/github/connector.json +0 -29
  312. package/src/connectors/huggingface/connector.json +0 -27
  313. package/src/connectors/imgur/connector.json +0 -29
  314. package/src/connectors/instagram/connector.json +0 -43
  315. package/src/connectors/jira/connector.json +0 -28
  316. package/src/connectors/mapbox/connector.json +0 -26
  317. package/src/connectors/nasa/connector.json +0 -27
  318. package/src/connectors/newsapi/connector.json +0 -27
  319. package/src/connectors/notion/connector.json +0 -28
  320. package/src/connectors/open-exchange-rates/connector.json +0 -27
  321. package/src/connectors/openweathermap/connector.json +0 -26
  322. package/src/connectors/pexels/connector.json +0 -27
  323. package/src/connectors/resend/connector.json +0 -29
  324. package/src/connectors/rss2json/connector.json +0 -27
  325. package/src/connectors/sendgrid/connector.json +0 -27
  326. package/src/connectors/spoonacular/connector.json +0 -28
  327. package/src/connectors/stability-ai/connector.json +0 -27
  328. package/src/connectors/twilio/connector.json +0 -28
  329. package/src/connectors/unsplash/connector.json +0 -27
  330. package/src/connectors/wolfram-alpha/connector.json +0 -26
  331. package/src/connectors/youtube-data/connector.json +0 -30
  332. /package/{dist/connectors → service-connectors}/airtable/connector.json +0 -0
  333. /package/{dist/connectors → service-connectors}/alpha-vantage/connector.json +0 -0
  334. /package/{dist/connectors → service-connectors}/brave-search/connector.json +0 -0
  335. /package/{dist/connectors → service-connectors}/cloudinary/connector.json +0 -0
  336. /package/{dist/connectors → service-connectors}/deepl/connector.json +0 -0
  337. /package/{dist/connectors → service-connectors}/elevenlabs/connector.json +0 -0
  338. /package/{dist/connectors → service-connectors}/giphy/connector.json +0 -0
  339. /package/{dist/connectors → service-connectors}/github/connector.json +0 -0
  340. /package/{dist/connectors → service-connectors}/huggingface/connector.json +0 -0
  341. /package/{dist/connectors → service-connectors}/imgur/connector.json +0 -0
  342. /package/{dist/connectors → service-connectors}/instagram/connector.json +0 -0
  343. /package/{dist/connectors → service-connectors}/jira/connector.json +0 -0
  344. /package/{dist/connectors → service-connectors}/mapbox/connector.json +0 -0
  345. /package/{dist/connectors → service-connectors}/nasa/connector.json +0 -0
  346. /package/{dist/connectors → service-connectors}/newsapi/connector.json +0 -0
  347. /package/{dist/connectors → service-connectors}/notion/connector.json +0 -0
  348. /package/{dist/connectors → service-connectors}/open-exchange-rates/connector.json +0 -0
  349. /package/{dist/connectors → service-connectors}/openweathermap/connector.json +0 -0
  350. /package/{dist/connectors → service-connectors}/pexels/connector.json +0 -0
  351. /package/{dist/connectors → service-connectors}/resend/connector.json +0 -0
  352. /package/{dist/connectors → service-connectors}/rss2json/connector.json +0 -0
  353. /package/{dist/connectors → service-connectors}/sendgrid/connector.json +0 -0
  354. /package/{dist/connectors → service-connectors}/spoonacular/connector.json +0 -0
  355. /package/{dist/connectors → service-connectors}/stability-ai/connector.json +0 -0
  356. /package/{dist/connectors → service-connectors}/twilio/connector.json +0 -0
  357. /package/{dist/connectors → service-connectors}/unsplash/connector.json +0 -0
  358. /package/{dist/connectors → service-connectors}/wolfram-alpha/connector.json +0 -0
  359. /package/{dist/connectors → service-connectors}/youtube-data/connector.json +0 -0
@@ -0,0 +1,198 @@
1
+ /* ==========================================================================
2
+ High Contrast Light — Light Theme (v3)
3
+ Maximum contrast for accessibility (WCAG AAA 7:1+).
4
+ Pure grayscale neutrals, black primary.
5
+ ========================================================================== */
6
+
7
+ .high-contrast-light {
8
+ /* -----------------------------------------------------------------------
9
+ PALETTE — Brand / Theme Colors (pure black ramp)
10
+ ----------------------------------------------------------------------- */
11
+ --themePrimary: #000000;
12
+ --themeDark: #000000;
13
+ --themeDarkAlt: #000000;
14
+ --themeDarker: #000000;
15
+ --themeSecondary: #333333;
16
+ --themeTertiary: #666666;
17
+ --themeLight: #cccccc;
18
+ --themeLighter: #e6e6e6;
19
+ --themeLighterAlt: #f5f5f5;
20
+
21
+ /* -----------------------------------------------------------------------
22
+ PALETTE — Neutrals (pure untinted grayscale)
23
+ ----------------------------------------------------------------------- */
24
+ --neutralDark: #000000;
25
+ --neutralPrimary: #1a1a1a;
26
+ --neutralPrimaryAlt: #2e2e2e;
27
+ --neutralSecondary: #555555;
28
+ --neutralSecondaryAlt: #444444;
29
+ --neutralTertiary: #767676;
30
+ --neutralTertiaryAlt: #999999;
31
+ --neutralQuaternary: #c8c8c8;
32
+ --neutralQuaternaryAlt: #d0d0d0;
33
+ --neutralLight: #e0e0e0;
34
+ --neutralLighter: #f0f0f0;
35
+ --neutralLighterAlt: #f8f8f8;
36
+ --white: #ffffff;
37
+
38
+ /* -----------------------------------------------------------------------
39
+ BODY / BACKGROUND
40
+ ----------------------------------------------------------------------- */
41
+ --bodyBackground: var(--white);
42
+ --bodyBackgroundHovered: var(--neutralLighter);
43
+ --bodyBackgroundChecked: var(--neutralLight);
44
+ --bodyStandoutBackground: var(--neutralLighterAlt);
45
+ --bodyFrameBackground: var(--white);
46
+ --bodyFrameDivider: #000000;
47
+ --bodyDivider: #000000;
48
+
49
+ /* -----------------------------------------------------------------------
50
+ TEXT
51
+ ----------------------------------------------------------------------- */
52
+ --bodyText: #000000;
53
+ --bodyTextChecked: #000000;
54
+ --bodySubtext: #1a1a1a;
55
+ --disabledText: #767676;
56
+ --disabledBodyText: #767676;
57
+ --disabledSubtext: #999999;
58
+ --disabledBodySubtext: #999999;
59
+
60
+ /* -----------------------------------------------------------------------
61
+ LINKS
62
+ ----------------------------------------------------------------------- */
63
+ --link: #0000cc;
64
+ --linkHovered: #000066;
65
+ --actionLink: #000000;
66
+ --actionLinkHovered: #000000;
67
+
68
+ /* -----------------------------------------------------------------------
69
+ BUTTONS — Default
70
+ ----------------------------------------------------------------------- */
71
+ --buttonBackground: var(--white);
72
+ --buttonBackgroundHovered: var(--neutralLighter);
73
+ --buttonBackgroundChecked: var(--neutralLight);
74
+ --buttonBackgroundCheckedHovered: var(--neutralQuaternaryAlt);
75
+ --buttonBackgroundPressed: var(--neutralLight);
76
+ --buttonBackgroundDisabled: var(--neutralLighter);
77
+ --buttonBorder: #000000;
78
+ --buttonBorderDisabled: #767676;
79
+ --buttonText: #000000;
80
+ --buttonTextHovered: #000000;
81
+ --buttonTextChecked: #000000;
82
+ --buttonTextCheckedHovered: #000000;
83
+ --buttonTextPressed: #000000;
84
+ --buttonTextDisabled: #767676;
85
+
86
+ /* -----------------------------------------------------------------------
87
+ BUTTONS — Primary
88
+ ----------------------------------------------------------------------- */
89
+ --primaryButtonBackground: #000000;
90
+ --primaryButtonBackgroundHovered: #1a1a1a;
91
+ --primaryButtonBackgroundPressed: #333333;
92
+ --primaryButtonBackgroundDisabled: #767676;
93
+ --primaryButtonBorder: transparent;
94
+ --primaryButtonText: var(--white);
95
+ --primaryButtonTextHovered: var(--white);
96
+ --primaryButtonTextPressed: var(--white);
97
+ --primaryButtonTextDisabled: var(--neutralQuaternary);
98
+
99
+ /* -----------------------------------------------------------------------
100
+ BUTTONS — Accent
101
+ ----------------------------------------------------------------------- */
102
+ --accentButtonBackground: #000000;
103
+ --accentButtonText: var(--white);
104
+
105
+ /* -----------------------------------------------------------------------
106
+ INPUTS
107
+ ----------------------------------------------------------------------- */
108
+ --inputBackground: var(--white);
109
+ --inputBackgroundChecked: #000000;
110
+ --inputBackgroundCheckedHovered: #1a1a1a;
111
+ --inputPlaceholderBackgroundChecked: var(--neutralLighter);
112
+ --inputForegroundChecked: var(--white);
113
+ --inputBorder: #000000;
114
+ --smallInputBorder: #000000;
115
+ --inputBorderHovered: #000000;
116
+ --inputFocusBorderAlt: #000000;
117
+ --inputText: #000000;
118
+ --inputTextHovered: #000000;
119
+ --inputPlaceholderText: #555555;
120
+ --inputIcon: #000000;
121
+ --inputIconHovered: #000000;
122
+ --inputIconDisabled: #767676;
123
+
124
+ /* -----------------------------------------------------------------------
125
+ LISTS
126
+ ----------------------------------------------------------------------- */
127
+ --listBackground: var(--white);
128
+ --listText: #000000;
129
+ --listItemBackgroundHovered: var(--neutralLighter);
130
+ --listItemBackgroundChecked: var(--neutralLight);
131
+ --listItemBackgroundCheckedHovered: var(--neutralQuaternaryAlt);
132
+ --listHeaderBackgroundHovered: var(--neutralLighter);
133
+ --listHeaderBackgroundPressed: var(--neutralLight);
134
+
135
+ /* -----------------------------------------------------------------------
136
+ MENUS
137
+ ----------------------------------------------------------------------- */
138
+ --menuBackground: var(--white);
139
+ --menuDivider: #000000;
140
+ --menuIcon: #000000;
141
+ --menuHeader: #000000;
142
+ --menuItemBackgroundHovered: var(--neutralLighter);
143
+ --menuItemBackgroundPressed: var(--neutralLight);
144
+ --menuItemText: #000000;
145
+ --menuItemTextHovered: #000000;
146
+
147
+ /* -----------------------------------------------------------------------
148
+ CARDS
149
+ ----------------------------------------------------------------------- */
150
+ --cardStandoutBackground: var(--white);
151
+ --cardShadow: none;
152
+ --cardShadowHovered: none;
153
+ --variantBorder: #000000;
154
+ --variantBorderHovered: #000000;
155
+
156
+ /* -----------------------------------------------------------------------
157
+ DISABLED / FOCUS
158
+ ----------------------------------------------------------------------- */
159
+ --disabledBackground: var(--neutralLighter);
160
+ --disabledBorder: #767676;
161
+ --focusBorder: #000000;
162
+
163
+ /* -----------------------------------------------------------------------
164
+ STATUS — Backgrounds
165
+ ----------------------------------------------------------------------- */
166
+ --infoBackground: var(--neutralLighter);
167
+ --errorBackground: #FDE7E9;
168
+ --blockingBackground: #FDE7E9;
169
+ --warningBackground: #FFF4CE;
170
+ --severeWarningBackground: #FED9CC;
171
+ --successBackground: #DFF6DD;
172
+
173
+ /* -----------------------------------------------------------------------
174
+ STATUS — Icons
175
+ ----------------------------------------------------------------------- */
176
+ --infoIcon: #000000;
177
+ --errorIcon: #A80000;
178
+ --blockingIcon: #A80000;
179
+ --warningIcon: #333333;
180
+ --severeWarningIcon: #A80000;
181
+ --successIcon: #107C10;
182
+
183
+ /* -----------------------------------------------------------------------
184
+ STATUS — Text
185
+ ----------------------------------------------------------------------- */
186
+ --errorText: #A80000;
187
+ --messageText: #000000;
188
+ --messageLink: #0000cc;
189
+ --messageLinkHovered: #000066;
190
+ --warningText: #000000;
191
+ --successText: #107C10;
192
+
193
+ /* -----------------------------------------------------------------------
194
+ MISC
195
+ ----------------------------------------------------------------------- */
196
+ --defaultStateBackground: var(--neutralLighterAlt);
197
+ --overlayBackground: rgba(0, 0, 0, 0.5);
198
+ }
@@ -466,6 +466,7 @@ body.chat-collapsed .chat-toggle {
466
466
 
467
467
  .chat-input-wrapper .chat-input {
468
468
  width: 100%;
469
+ padding-left: 36px;
469
470
  padding-right: 36px;
470
471
  }
471
472
 
@@ -704,3 +705,112 @@ body.chat-collapsed .chat-toggle {
704
705
  #loadingOverlay { position: absolute; }
705
706
  .chat-submit:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }
706
707
  .chat-input:disabled { opacity: 0.5; cursor: not-allowed; }
708
+
709
+ /* ---- Attach button (left side of input) ---- */
710
+ .attach-btn {
711
+ position: absolute;
712
+ left: 6px;
713
+ top: 50%;
714
+ transform: translateY(-50%);
715
+ background: transparent;
716
+ border: none;
717
+ color: var(--text-secondary);
718
+ cursor: pointer;
719
+ padding: 4px;
720
+ border-radius: 4px;
721
+ display: flex;
722
+ align-items: center;
723
+ justify-content: center;
724
+ transition: color 0.2s, background 0.2s;
725
+ z-index: 2;
726
+ }
727
+ .attach-btn:hover {
728
+ color: var(--accent-primary);
729
+ background: var(--accent-glow);
730
+ }
731
+ .light-mode .attach-btn {
732
+ color: var(--text-secondary);
733
+ }
734
+ .light-mode .attach-btn:hover {
735
+ color: var(--accent-primary);
736
+ }
737
+
738
+ /* ---- Attach popup menu ---- */
739
+ .attach-menu {
740
+ display: none;
741
+ flex-direction: column;
742
+ position: absolute;
743
+ bottom: calc(100% + 6px);
744
+ left: 0;
745
+ background: var(--bg-tertiary);
746
+ border: 1px solid var(--border-color);
747
+ border-radius: 8px;
748
+ box-shadow: 0 4px 12px rgba(0,0,0,0.12);
749
+ overflow: hidden;
750
+ z-index: 100;
751
+ min-width: 160px;
752
+ }
753
+ .attach-menu-item {
754
+ display: flex;
755
+ align-items: center;
756
+ gap: 8px;
757
+ padding: 8px 14px;
758
+ font-size: 13px;
759
+ color: var(--text-primary);
760
+ cursor: pointer;
761
+ transition: background 0.15s;
762
+ }
763
+ .attach-menu-item:hover {
764
+ background: var(--accent-glow);
765
+ }
766
+
767
+ /* ---- Attachment pills ---- */
768
+ .attachment-pills {
769
+ display: flex;
770
+ flex-wrap: wrap;
771
+ gap: 6px;
772
+ padding: 0 4px;
773
+ min-height: 0;
774
+ }
775
+ .attachment-pills:empty { display: none; }
776
+ .attachment-pill {
777
+ display: flex;
778
+ align-items: center;
779
+ gap: 6px;
780
+ background: var(--bg-tertiary);
781
+ border: 1px solid var(--border-color);
782
+ border-radius: 6px;
783
+ padding: 4px 8px;
784
+ max-width: 180px;
785
+ }
786
+ .attachment-pill-remove {
787
+ background: none;
788
+ border: none;
789
+ color: var(--text-secondary);
790
+ cursor: pointer;
791
+ font-size: 14px;
792
+ padding: 0 2px;
793
+ line-height: 1;
794
+ }
795
+ .attachment-pill-remove:hover {
796
+ color: #ff6b6b;
797
+ }
798
+
799
+ /* ---- Screenshot overlay ---- */
800
+ .screenshot-overlay {
801
+ position: absolute;
802
+ top: 0;
803
+ left: 0;
804
+ width: 100%;
805
+ height: 100%;
806
+ background: rgba(0,0,0,0.15);
807
+ cursor: crosshair;
808
+ z-index: 1000;
809
+ }
810
+ .screenshot-rect {
811
+ display: none;
812
+ position: absolute;
813
+ border: 2px solid red;
814
+ background: rgba(255,0,0,0.05);
815
+ pointer-events: none;
816
+ }
@@ -0,0 +1,199 @@
1
+ /* ==========================================================================
2
+ Nebula Dawn — Light Theme (v3)
3
+ Palette overrides + semantic tokens for FluentLM.
4
+ Rebrands from default blue to Nebula purple.
5
+ ========================================================================== */
6
+
7
+ :root,
8
+ .nebula-dawn {
9
+ /* -----------------------------------------------------------------------
10
+ PALETTE — Brand / Theme Colors (Nebula purple ramp)
11
+ ----------------------------------------------------------------------- */
12
+ --themePrimary: #764ba2;
13
+ --themeDark: #5a3580;
14
+ --themeDarkAlt: #663d91;
15
+ --themeDarker: #3b2054;
16
+ --themeSecondary: #9670b8;
17
+ --themeTertiary: #b49bce;
18
+ --themeLight: #d3c3e3;
19
+ --themeLighter: #e8ddf1;
20
+ --themeLighterAlt: #f5f1fa;
21
+
22
+ /* -----------------------------------------------------------------------
23
+ PALETTE — Neutrals (warm purple-tinted)
24
+ ----------------------------------------------------------------------- */
25
+ --neutralDark: #1e1830;
26
+ --neutralPrimary: #2d2640;
27
+ --neutralPrimaryAlt: #3d2e56;
28
+ --neutralSecondary: #6b4f8a;
29
+ --neutralSecondaryAlt: #5e4579;
30
+ --neutralTertiary: #8a7a9d;
31
+ --neutralTertiaryAlt: #a898b5;
32
+ --neutralQuaternary: #cbc0d6;
33
+ --neutralQuaternaryAlt: #d5cae0;
34
+ --neutralLight: #e8dff0;
35
+ --neutralLighter: #f0e6f6;
36
+ --neutralLighterAlt: #f7f2fa;
37
+ --white: #ffffff;
38
+
39
+ /* -----------------------------------------------------------------------
40
+ BODY / BACKGROUND
41
+ ----------------------------------------------------------------------- */
42
+ --bodyBackground: var(--white);
43
+ --bodyBackgroundHovered: var(--neutralLighter);
44
+ --bodyBackgroundChecked: var(--neutralLight);
45
+ --bodyStandoutBackground: var(--neutralLighterAlt);
46
+ --bodyFrameBackground: var(--white);
47
+ --bodyFrameDivider: var(--neutralLight);
48
+ --bodyDivider: var(--neutralLight);
49
+
50
+ /* -----------------------------------------------------------------------
51
+ TEXT
52
+ ----------------------------------------------------------------------- */
53
+ --bodyText: var(--neutralPrimary);
54
+ --bodyTextChecked: var(--neutralDark);
55
+ --bodySubtext: var(--neutralSecondary);
56
+ --disabledText: var(--neutralTertiary);
57
+ --disabledBodyText: var(--neutralTertiary);
58
+ --disabledSubtext: var(--neutralQuaternary);
59
+ --disabledBodySubtext: var(--neutralTertiaryAlt);
60
+
61
+ /* -----------------------------------------------------------------------
62
+ LINKS
63
+ ----------------------------------------------------------------------- */
64
+ --link: var(--themePrimary);
65
+ --linkHovered: var(--themeDarker);
66
+ --actionLink: var(--neutralPrimary);
67
+ --actionLinkHovered: var(--neutralDark);
68
+
69
+ /* -----------------------------------------------------------------------
70
+ BUTTONS — Default
71
+ ----------------------------------------------------------------------- */
72
+ --buttonBackground: var(--white);
73
+ --buttonBackgroundHovered: var(--neutralLighter);
74
+ --buttonBackgroundChecked: var(--neutralLight);
75
+ --buttonBackgroundCheckedHovered: var(--neutralQuaternaryAlt);
76
+ --buttonBackgroundPressed: var(--neutralLight);
77
+ --buttonBackgroundDisabled: var(--neutralLighter);
78
+ --buttonBorder: var(--neutralSecondaryAlt);
79
+ --buttonBorderDisabled: var(--neutralLighter);
80
+ --buttonText: var(--neutralPrimary);
81
+ --buttonTextHovered: var(--neutralDark);
82
+ --buttonTextChecked: var(--neutralDark);
83
+ --buttonTextCheckedHovered: var(--black);
84
+ --buttonTextPressed: var(--neutralDark);
85
+ --buttonTextDisabled: var(--neutralTertiary);
86
+
87
+ /* -----------------------------------------------------------------------
88
+ BUTTONS — Primary
89
+ ----------------------------------------------------------------------- */
90
+ --primaryButtonBackground: var(--themePrimary);
91
+ --primaryButtonBackgroundHovered: var(--themeDarkAlt);
92
+ --primaryButtonBackgroundPressed: var(--themeDark);
93
+ --primaryButtonBackgroundDisabled: var(--neutralLighter);
94
+ --primaryButtonBorder: transparent;
95
+ --primaryButtonText: var(--white);
96
+ --primaryButtonTextHovered: var(--white);
97
+ --primaryButtonTextPressed: var(--white);
98
+ --primaryButtonTextDisabled: var(--neutralQuaternary);
99
+
100
+ /* -----------------------------------------------------------------------
101
+ BUTTONS — Accent
102
+ ----------------------------------------------------------------------- */
103
+ --accentButtonBackground: var(--themePrimary);
104
+ --accentButtonText: var(--white);
105
+
106
+ /* -----------------------------------------------------------------------
107
+ INPUTS
108
+ ----------------------------------------------------------------------- */
109
+ --inputBackground: var(--white);
110
+ --inputBackgroundChecked: var(--themePrimary);
111
+ --inputBackgroundCheckedHovered: var(--themeDarkAlt);
112
+ --inputPlaceholderBackgroundChecked: var(--themeLighter);
113
+ --inputForegroundChecked: var(--white);
114
+ --inputBorder: var(--neutralSecondary);
115
+ --smallInputBorder: var(--neutralSecondary);
116
+ --inputBorderHovered: var(--neutralPrimary);
117
+ --inputFocusBorderAlt: var(--themePrimary);
118
+ --inputText: var(--neutralPrimary);
119
+ --inputTextHovered: var(--neutralDark);
120
+ --inputPlaceholderText: var(--neutralSecondary);
121
+ --inputIcon: var(--themePrimary);
122
+ --inputIconHovered: var(--themeDark);
123
+ --inputIconDisabled: var(--neutralTertiary);
124
+
125
+ /* -----------------------------------------------------------------------
126
+ LISTS
127
+ ----------------------------------------------------------------------- */
128
+ --listBackground: var(--white);
129
+ --listText: var(--neutralPrimary);
130
+ --listItemBackgroundHovered: var(--neutralLighter);
131
+ --listItemBackgroundChecked: var(--neutralLight);
132
+ --listItemBackgroundCheckedHovered: var(--neutralQuaternaryAlt);
133
+ --listHeaderBackgroundHovered: var(--neutralLighter);
134
+ --listHeaderBackgroundPressed: var(--neutralLight);
135
+
136
+ /* -----------------------------------------------------------------------
137
+ MENUS
138
+ ----------------------------------------------------------------------- */
139
+ --menuBackground: var(--white);
140
+ --menuDivider: var(--neutralTertiaryAlt);
141
+ --menuIcon: var(--themePrimary);
142
+ --menuHeader: var(--themePrimary);
143
+ --menuItemBackgroundHovered: var(--neutralLighter);
144
+ --menuItemBackgroundPressed: var(--neutralLight);
145
+ --menuItemText: var(--neutralPrimary);
146
+ --menuItemTextHovered: var(--neutralDark);
147
+
148
+ /* -----------------------------------------------------------------------
149
+ CARDS
150
+ ----------------------------------------------------------------------- */
151
+ --cardStandoutBackground: var(--white);
152
+ --cardShadow: var(--elevation4);
153
+ --cardShadowHovered: var(--elevation8);
154
+ --variantBorder: var(--neutralLight);
155
+ --variantBorderHovered: var(--neutralTertiaryAlt);
156
+
157
+ /* -----------------------------------------------------------------------
158
+ DISABLED / FOCUS
159
+ ----------------------------------------------------------------------- */
160
+ --disabledBackground: var(--neutralLighter);
161
+ --disabledBorder: var(--neutralLighter);
162
+ --focusBorder: var(--neutralSecondary);
163
+
164
+ /* -----------------------------------------------------------------------
165
+ STATUS — Backgrounds
166
+ ----------------------------------------------------------------------- */
167
+ --infoBackground: var(--neutralLighter);
168
+ --errorBackground: #FDE7E9;
169
+ --blockingBackground: #FDE7E9;
170
+ --warningBackground: #FFF4CE;
171
+ --severeWarningBackground: #FED9CC;
172
+ --successBackground: #DFF6DD;
173
+
174
+ /* -----------------------------------------------------------------------
175
+ STATUS — Icons
176
+ ----------------------------------------------------------------------- */
177
+ --infoIcon: var(--neutralSecondary);
178
+ --errorIcon: #A80000;
179
+ --blockingIcon: #FDE7E9;
180
+ --warningIcon: #797775;
181
+ --severeWarningIcon: var(--orange);
182
+ --successIcon: var(--green);
183
+
184
+ /* -----------------------------------------------------------------------
185
+ STATUS — Text
186
+ ----------------------------------------------------------------------- */
187
+ --errorText: var(--redDark);
188
+ --messageText: var(--neutralPrimary);
189
+ --messageLink: var(--themeDark);
190
+ --messageLinkHovered: var(--themeDarker);
191
+ --warningText: var(--neutralPrimary);
192
+ --successText: var(--green);
193
+
194
+ /* -----------------------------------------------------------------------
195
+ MISC
196
+ ----------------------------------------------------------------------- */
197
+ --defaultStateBackground: var(--neutralLighterAlt);
198
+ --overlayBackground: var(--blackTranslucent40);
199
+ }
@@ -466,6 +466,7 @@ body.chat-collapsed .chat-toggle {
466
466
 
467
467
  .chat-input-wrapper .chat-input {
468
468
  width: 100%;
469
+ padding-left: 36px;
469
470
  padding-right: 36px;
470
471
  }
471
472
 
@@ -696,3 +697,106 @@ body.chat-collapsed .chat-toggle {
696
697
  #loadingOverlay { position: absolute; }
697
698
  .chat-submit:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }
698
699
  .chat-input:disabled { opacity: 0.5; cursor: not-allowed; }
700
+
701
+ /* ---- Attach button (left side of input) ---- */
702
+ .attach-btn {
703
+ position: absolute;
704
+ left: 6px;
705
+ top: 50%;
706
+ transform: translateY(-50%);
707
+ background: transparent;
708
+ border: none;
709
+ color: var(--text-secondary);
710
+ cursor: pointer;
711
+ padding: 4px;
712
+ border-radius: 4px;
713
+ display: flex;
714
+ align-items: center;
715
+ justify-content: center;
716
+ transition: color 0.2s, background 0.2s;
717
+ z-index: 2;
718
+ }
719
+ .attach-btn:hover {
720
+ color: var(--accent-primary);
721
+ background: var(--accent-glow);
722
+ }
723
+
724
+ /* ---- Attach popup menu ---- */
725
+ .attach-menu {
726
+ display: none;
727
+ flex-direction: column;
728
+ position: absolute;
729
+ bottom: calc(100% + 6px);
730
+ left: 0;
731
+ background: var(--bg-tertiary);
732
+ border: 1px solid var(--border-color);
733
+ border-radius: 8px;
734
+ box-shadow: 0 4px 16px rgba(0,0,0,0.3);
735
+ overflow: hidden;
736
+ z-index: 100;
737
+ min-width: 160px;
738
+ }
739
+ .attach-menu-item {
740
+ display: flex;
741
+ align-items: center;
742
+ gap: 8px;
743
+ padding: 8px 14px;
744
+ font-size: 13px;
745
+ color: var(--text-primary);
746
+ cursor: pointer;
747
+ transition: background 0.15s;
748
+ }
749
+ .attach-menu-item:hover {
750
+ background: var(--accent-glow);
751
+ }
752
+
753
+ /* ---- Attachment pills ---- */
754
+ .attachment-pills {
755
+ display: flex;
756
+ flex-wrap: wrap;
757
+ gap: 6px;
758
+ padding: 0 4px;
759
+ min-height: 0;
760
+ }
761
+ .attachment-pills:empty { display: none; }
762
+ .attachment-pill {
763
+ display: flex;
764
+ align-items: center;
765
+ gap: 6px;
766
+ background: var(--bg-tertiary);
767
+ border: 1px solid var(--border-color);
768
+ border-radius: 6px;
769
+ padding: 4px 8px;
770
+ max-width: 180px;
771
+ }
772
+ .attachment-pill-remove {
773
+ background: none;
774
+ border: none;
775
+ color: var(--text-secondary);
776
+ cursor: pointer;
777
+ font-size: 14px;
778
+ padding: 0 2px;
779
+ line-height: 1;
780
+ }
781
+ .attachment-pill-remove:hover {
782
+ color: #ff6b6b;
783
+ }
784
+
785
+ /* ---- Screenshot overlay ---- */
786
+ .screenshot-overlay {
787
+ position: absolute;
788
+ top: 0;
789
+ left: 0;
790
+ width: 100%;
791
+ height: 100%;
792
+ background: rgba(0,0,0,0.2);
793
+ cursor: crosshair;
794
+ z-index: 1000;
795
+ }
796
+ .screenshot-rect {
797
+ display: none;
798
+ position: absolute;
799
+ border: 2px solid red;
800
+ background: rgba(255,0,0,0.05);
801
+ pointer-events: none;
802
+ }