synthos 0.8.0 → 0.10.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 (368) 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 +1803 -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} +16 -30
  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} +15 -12
  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 +1 -1
  100. package/dist/connectors/index.d.ts.map +1 -1
  101. package/dist/connectors/index.js +3 -2
  102. package/dist/connectors/index.js.map +1 -1
  103. package/dist/connectors/registry.d.ts +2 -1
  104. package/dist/connectors/registry.d.ts.map +1 -1
  105. package/dist/connectors/registry.js +31 -8
  106. package/dist/connectors/registry.js.map +1 -1
  107. package/dist/customizer/Customizer.d.ts +62 -0
  108. package/dist/customizer/Customizer.d.ts.map +1 -0
  109. package/dist/customizer/Customizer.js +134 -0
  110. package/dist/customizer/Customizer.js.map +1 -0
  111. package/dist/customizer/index.d.ts +4 -0
  112. package/dist/customizer/index.d.ts.map +1 -0
  113. package/dist/customizer/index.js +9 -0
  114. package/dist/customizer/index.js.map +1 -0
  115. package/dist/files.d.ts +16 -0
  116. package/dist/files.d.ts.map +1 -1
  117. package/dist/files.js +60 -1
  118. package/dist/files.js.map +1 -1
  119. package/dist/index.d.ts +2 -0
  120. package/dist/index.d.ts.map +1 -1
  121. package/dist/index.js +2 -0
  122. package/dist/index.js.map +1 -1
  123. package/dist/init.d.ts +12 -6
  124. package/dist/init.d.ts.map +1 -1
  125. package/dist/init.js +150 -133
  126. package/dist/init.js.map +1 -1
  127. package/dist/migrations.d.ts.map +1 -1
  128. package/dist/migrations.js +23 -10
  129. package/dist/migrations.js.map +1 -1
  130. package/dist/models/anthropic.d.ts +4 -2
  131. package/dist/models/anthropic.d.ts.map +1 -1
  132. package/dist/models/anthropic.js +33 -6
  133. package/dist/models/anthropic.js.map +1 -1
  134. package/dist/models/fireworksai.d.ts.map +1 -1
  135. package/dist/models/fireworksai.js +9 -1
  136. package/dist/models/fireworksai.js.map +1 -1
  137. package/dist/models/index.d.ts +1 -1
  138. package/dist/models/index.d.ts.map +1 -1
  139. package/dist/models/index.js +2 -1
  140. package/dist/models/index.js.map +1 -1
  141. package/dist/models/openai.d.ts +1 -1
  142. package/dist/models/openai.d.ts.map +1 -1
  143. package/dist/models/openai.js +24 -3
  144. package/dist/models/openai.js.map +1 -1
  145. package/dist/models/types.d.ts +20 -1
  146. package/dist/models/types.d.ts.map +1 -1
  147. package/dist/models/types.js +6 -1
  148. package/dist/models/types.js.map +1 -1
  149. package/dist/pages.d.ts +34 -10
  150. package/dist/pages.d.ts.map +1 -1
  151. package/dist/pages.js +229 -79
  152. package/dist/pages.js.map +1 -1
  153. package/dist/service/createCompletePrompt.d.ts +2 -1
  154. package/dist/service/createCompletePrompt.d.ts.map +1 -1
  155. package/dist/service/createCompletePrompt.js +2 -2
  156. package/dist/service/createCompletePrompt.js.map +1 -1
  157. package/dist/service/requiresSettings.d.ts +2 -1
  158. package/dist/service/requiresSettings.d.ts.map +1 -1
  159. package/dist/service/requiresSettings.js +3 -3
  160. package/dist/service/requiresSettings.js.map +1 -1
  161. package/dist/service/server.d.ts +2 -1
  162. package/dist/service/server.d.ts.map +1 -1
  163. package/dist/service/server.js +37 -8
  164. package/dist/service/server.js.map +1 -1
  165. package/dist/service/transformPage.d.ts +47 -20
  166. package/dist/service/transformPage.d.ts.map +1 -1
  167. package/dist/service/transformPage.js +514 -293
  168. package/dist/service/transformPage.js.map +1 -1
  169. package/dist/service/useAgentRoutes.d.ts +2 -1
  170. package/dist/service/useAgentRoutes.d.ts.map +1 -1
  171. package/dist/service/useAgentRoutes.js +17 -14
  172. package/dist/service/useAgentRoutes.js.map +1 -1
  173. package/dist/service/useApiRoutes.d.ts +2 -1
  174. package/dist/service/useApiRoutes.d.ts.map +1 -1
  175. package/dist/service/useApiRoutes.js +287 -172
  176. package/dist/service/useApiRoutes.js.map +1 -1
  177. package/dist/service/useConnectorRoutes.js +17 -17
  178. package/dist/service/useConnectorRoutes.js.map +1 -1
  179. package/dist/service/useDataRoutes.d.ts.map +1 -1
  180. package/dist/service/useDataRoutes.js +13 -10
  181. package/dist/service/useDataRoutes.js.map +1 -1
  182. package/dist/service/useFileRoutes.d.ts +4 -0
  183. package/dist/service/useFileRoutes.d.ts.map +1 -0
  184. package/dist/service/useFileRoutes.js +122 -0
  185. package/dist/service/useFileRoutes.js.map +1 -0
  186. package/dist/service/usePageRoutes.d.ts +2 -1
  187. package/dist/service/usePageRoutes.d.ts.map +1 -1
  188. package/dist/service/usePageRoutes.js +671 -74
  189. package/dist/service/usePageRoutes.js.map +1 -1
  190. package/dist/service/useSharedDataRoutes.d.ts +4 -0
  191. package/dist/service/useSharedDataRoutes.d.ts.map +1 -0
  192. package/dist/service/useSharedDataRoutes.js +107 -0
  193. package/dist/service/useSharedDataRoutes.js.map +1 -0
  194. package/dist/service/useSharedFileRoutes.d.ts +4 -0
  195. package/dist/service/useSharedFileRoutes.d.ts.map +1 -0
  196. package/dist/service/useSharedFileRoutes.js +121 -0
  197. package/dist/service/useSharedFileRoutes.js.map +1 -0
  198. package/dist/settings.d.ts +5 -3
  199. package/dist/settings.d.ts.map +1 -1
  200. package/dist/settings.js +12 -10
  201. package/dist/settings.js.map +1 -1
  202. package/dist/storage/FsStorageProvider.d.ts +25 -0
  203. package/dist/storage/FsStorageProvider.d.ts.map +1 -0
  204. package/dist/storage/FsStorageProvider.js +103 -0
  205. package/dist/storage/FsStorageProvider.js.map +1 -0
  206. package/dist/storage/StorageProvider.d.ts +31 -0
  207. package/dist/storage/StorageProvider.d.ts.map +1 -0
  208. package/dist/storage/StorageProvider.js +3 -0
  209. package/dist/storage/StorageProvider.js.map +1 -0
  210. package/dist/storage/index.d.ts +3 -0
  211. package/dist/storage/index.d.ts.map +1 -0
  212. package/dist/storage/index.js +6 -0
  213. package/dist/storage/index.js.map +1 -0
  214. package/dist/synthos-cli.d.ts.map +1 -1
  215. package/dist/synthos-cli.js +4 -3
  216. package/dist/synthos-cli.js.map +1 -1
  217. package/dist/themes.d.ts +1 -0
  218. package/dist/themes.d.ts.map +1 -1
  219. package/dist/themes.js +65 -28
  220. package/dist/themes.js.map +1 -1
  221. package/migration-rules/v1-to-v2.md +193 -0
  222. package/migration-rules/v2-to-v3.md +481 -0
  223. package/package.json +11 -10
  224. package/required-pages/builder/page.html +43 -0
  225. package/required-pages/builder/page.json +10 -0
  226. package/required-pages/{pages.html → pages/page.html} +238 -233
  227. package/required-pages/pages/page.json +10 -0
  228. package/required-pages/{settings.html → settings/page.html} +389 -275
  229. package/required-pages/settings/page.json +10 -0
  230. package/required-pages/synthos_apis/page.html +846 -0
  231. package/required-pages/synthos_apis/page.json +10 -0
  232. package/required-pages/{synthos_scripts.html → synthos_scripts/page.html} +13 -11
  233. package/required-pages/synthos_scripts/page.json +10 -0
  234. package/src/agents/index.ts +1 -1
  235. package/src/agents/openclaw/gatewayManager.ts +22 -11
  236. package/src/agents/openclaw/openclawProvider.ts +2 -4
  237. package/src/agents/openclaw/sshTunnelManager.ts +19 -11
  238. package/src/builders/anthropic.ts +283 -0
  239. package/src/builders/fireworksai.ts +59 -0
  240. package/src/builders/index.ts +33 -0
  241. package/src/builders/openai.ts +89 -0
  242. package/src/builders/types.ts +261 -0
  243. package/src/connectors/index.ts +1 -1
  244. package/src/connectors/registry.ts +28 -8
  245. package/src/customizer/Customizer.ts +163 -0
  246. package/src/customizer/index.ts +5 -0
  247. package/src/files.ts +57 -0
  248. package/src/index.ts +3 -1
  249. package/src/init.ts +195 -145
  250. package/src/migrations.ts +30 -10
  251. package/src/models/anthropic.ts +40 -10
  252. package/src/models/fireworksai.ts +9 -2
  253. package/src/models/index.ts +1 -1
  254. package/src/models/openai.ts +26 -6
  255. package/src/models/types.ts +31 -1
  256. package/src/pages.ts +230 -77
  257. package/src/service/createCompletePrompt.ts +3 -2
  258. package/src/service/requiresSettings.ts +4 -3
  259. package/src/service/server.ts +36 -9
  260. package/src/service/transformPage.ts +557 -326
  261. package/src/service/useAgentRoutes.ts +19 -14
  262. package/src/service/useApiRoutes.ts +208 -84
  263. package/src/service/useConnectorRoutes.ts +18 -18
  264. package/src/service/useDataRoutes.ts +13 -10
  265. package/src/service/useFileRoutes.ts +128 -0
  266. package/src/service/usePageRoutes.ts +730 -81
  267. package/src/service/useSharedDataRoutes.ts +109 -0
  268. package/src/service/useSharedFileRoutes.ts +127 -0
  269. package/src/settings.ts +14 -10
  270. package/src/storage/FsStorageProvider.ts +87 -0
  271. package/src/storage/StorageProvider.ts +34 -0
  272. package/src/storage/index.ts +2 -0
  273. package/src/synthos-cli.ts +4 -3
  274. package/src/themes.ts +64 -27
  275. package/static-files/favicon.svg +12 -0
  276. package/static-files/fluentlm-instructions.llmd +868 -0
  277. package/static-files/fluentlm-instructions.md +1595 -0
  278. package/static-files/fluentlm.css +4844 -0
  279. package/static-files/fluentlm.js +3602 -0
  280. package/static-files/fluentlm.min.css +1 -0
  281. package/static-files/fluentlm.min.js +1 -0
  282. package/{page-scripts/helpers-v2.js → static-files/helpers.v3.js} +82 -0
  283. package/static-files/page.v3.js +1290 -0
  284. package/static-files/recommended-frameworks.llmd +81 -0
  285. package/static-files/recommended-frameworks.md +137 -0
  286. package/static-files/retro-game.js +877 -0
  287. package/static-files/shell.css +797 -0
  288. package/static-files/theme-dark.css +169 -0
  289. package/static-files/theme-light.css +169 -0
  290. package/tests/builders.spec.ts +139 -0
  291. package/tests/pages.spec.ts +54 -84
  292. package/tests/transformPage.spec.ts +299 -360
  293. package/default-pages/application.html +0 -40
  294. package/default-pages/application.json +0 -1
  295. package/default-pages/json_tools.json +0 -1
  296. package/default-pages/my_notes.html +0 -33
  297. package/default-pages/neon_asteroids.html +0 -77
  298. package/default-pages/sidebar_page.json +0 -1
  299. package/default-pages/solar_tutorial.json +0 -1
  300. package/default-pages/two-panel_page.json +0 -1
  301. package/dist/service/useGatewayRoutes.d.ts +0 -4
  302. package/dist/service/useGatewayRoutes.d.ts.map +0 -1
  303. package/dist/service/useGatewayRoutes.js +0 -168
  304. package/dist/service/useGatewayRoutes.js.map +0 -1
  305. package/page-scripts/page-v2.js +0 -656
  306. package/required-pages/builder.html +0 -48
  307. package/required-pages/builder.json +0 -1
  308. package/required-pages/pages.json +0 -1
  309. package/required-pages/settings.json +0 -1
  310. package/required-pages/synthos_apis.html +0 -327
  311. package/required-pages/synthos_apis.json +0 -1
  312. package/required-pages/synthos_scripts.json +0 -1
  313. package/src/connectors/airtable/connector.json +0 -27
  314. package/src/connectors/alpha-vantage/connector.json +0 -26
  315. package/src/connectors/brave-search/connector.json +0 -26
  316. package/src/connectors/cloudinary/connector.json +0 -27
  317. package/src/connectors/deepl/connector.json +0 -28
  318. package/src/connectors/elevenlabs/connector.json +0 -30
  319. package/src/connectors/giphy/connector.json +0 -27
  320. package/src/connectors/github/connector.json +0 -29
  321. package/src/connectors/huggingface/connector.json +0 -27
  322. package/src/connectors/imgur/connector.json +0 -29
  323. package/src/connectors/instagram/connector.json +0 -43
  324. package/src/connectors/jira/connector.json +0 -28
  325. package/src/connectors/mapbox/connector.json +0 -26
  326. package/src/connectors/nasa/connector.json +0 -27
  327. package/src/connectors/newsapi/connector.json +0 -27
  328. package/src/connectors/notion/connector.json +0 -28
  329. package/src/connectors/open-exchange-rates/connector.json +0 -27
  330. package/src/connectors/openweathermap/connector.json +0 -26
  331. package/src/connectors/pexels/connector.json +0 -27
  332. package/src/connectors/resend/connector.json +0 -29
  333. package/src/connectors/rss2json/connector.json +0 -27
  334. package/src/connectors/sendgrid/connector.json +0 -27
  335. package/src/connectors/spoonacular/connector.json +0 -28
  336. package/src/connectors/stability-ai/connector.json +0 -27
  337. package/src/connectors/twilio/connector.json +0 -28
  338. package/src/connectors/unsplash/connector.json +0 -27
  339. package/src/connectors/wolfram-alpha/connector.json +0 -26
  340. package/src/connectors/youtube-data/connector.json +0 -30
  341. /package/{dist/connectors → service-connectors}/airtable/connector.json +0 -0
  342. /package/{dist/connectors → service-connectors}/alpha-vantage/connector.json +0 -0
  343. /package/{dist/connectors → service-connectors}/brave-search/connector.json +0 -0
  344. /package/{dist/connectors → service-connectors}/cloudinary/connector.json +0 -0
  345. /package/{dist/connectors → service-connectors}/deepl/connector.json +0 -0
  346. /package/{dist/connectors → service-connectors}/elevenlabs/connector.json +0 -0
  347. /package/{dist/connectors → service-connectors}/giphy/connector.json +0 -0
  348. /package/{dist/connectors → service-connectors}/github/connector.json +0 -0
  349. /package/{dist/connectors → service-connectors}/huggingface/connector.json +0 -0
  350. /package/{dist/connectors → service-connectors}/imgur/connector.json +0 -0
  351. /package/{dist/connectors → service-connectors}/instagram/connector.json +0 -0
  352. /package/{dist/connectors → service-connectors}/jira/connector.json +0 -0
  353. /package/{dist/connectors → service-connectors}/mapbox/connector.json +0 -0
  354. /package/{dist/connectors → service-connectors}/nasa/connector.json +0 -0
  355. /package/{dist/connectors → service-connectors}/newsapi/connector.json +0 -0
  356. /package/{dist/connectors → service-connectors}/notion/connector.json +0 -0
  357. /package/{dist/connectors → service-connectors}/open-exchange-rates/connector.json +0 -0
  358. /package/{dist/connectors → service-connectors}/openweathermap/connector.json +0 -0
  359. /package/{dist/connectors → service-connectors}/pexels/connector.json +0 -0
  360. /package/{dist/connectors → service-connectors}/resend/connector.json +0 -0
  361. /package/{dist/connectors → service-connectors}/rss2json/connector.json +0 -0
  362. /package/{dist/connectors → service-connectors}/sendgrid/connector.json +0 -0
  363. /package/{dist/connectors → service-connectors}/spoonacular/connector.json +0 -0
  364. /package/{dist/connectors → service-connectors}/stability-ai/connector.json +0 -0
  365. /package/{dist/connectors → service-connectors}/twilio/connector.json +0 -0
  366. /package/{dist/connectors → service-connectors}/unsplash/connector.json +0 -0
  367. /package/{dist/connectors → service-connectors}/wolfram-alpha/connector.json +0 -0
  368. /package/{dist/connectors → service-connectors}/youtube-data/connector.json +0 -0
@@ -0,0 +1,797 @@
1
+ /* ==========================================================================
2
+ SynthOS Shell — Layout & Chrome
3
+ Provides structural styles for the SynthOS page shell (chat panel, viewer
4
+ panel, modals, toggle, brainstorm, attachments, etc.).
5
+ Uses FluentLM semantic tokens so it adapts to any v3 theme.
6
+ ========================================================================== */
7
+
8
+ /* --- Reset ---------------------------------------------------------------- */
9
+ *, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
10
+
11
+ :root { --toolbar-width: 48px; }
12
+
13
+ body {
14
+ font-family: var(--fontFamily, 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif);
15
+ background: var(--bodyBackground);
16
+ color: var(--bodyText);
17
+ height: 100vh;
18
+ display: flex;
19
+ padding-left: var(--toolbar-width);
20
+ }
21
+
22
+ /* --- Shell Toolbar -------------------------------------------------------- */
23
+ .shell-toolbar {
24
+ width: var(--toolbar-width);
25
+ height: 100vh;
26
+ position: fixed;
27
+ left: 0;
28
+ top: 0;
29
+ z-index: 1001;
30
+ display: flex;
31
+ flex-direction: column;
32
+ align-items: center;
33
+ padding-top: 12px;
34
+ gap: 4px;
35
+ background: var(--bodyStandoutBackground);
36
+ border-right: 1px solid var(--bodyDivider);
37
+ }
38
+
39
+ .shell-toolbar-btn {
40
+ width: 40px;
41
+ height: 40px;
42
+ display: flex;
43
+ align-items: center;
44
+ justify-content: center;
45
+ background: transparent;
46
+ border: none;
47
+ border-radius: 8px;
48
+ color: var(--bodySubtext);
49
+ cursor: pointer;
50
+ position: relative;
51
+ transition: background 0.2s, color 0.2s;
52
+ }
53
+
54
+ .shell-toolbar-btn:hover {
55
+ background: var(--bodyBackgroundHovered);
56
+ color: var(--themePrimary);
57
+ }
58
+
59
+ body:not(.chat-collapsed) .shell-toolbar-btn#builderToggle {
60
+ color: var(--themePrimary);
61
+ }
62
+
63
+ .shell-toolbar-btn svg {
64
+ width: 28px;
65
+ height: 28px;
66
+ }
67
+
68
+ .shell-toolbar-spacer {
69
+ flex: 1;
70
+ }
71
+
72
+ /* Tooltip — CSS-only, right of button */
73
+ .shell-toolbar-btn::after {
74
+ content: attr(aria-label);
75
+ position: absolute;
76
+ left: calc(100% + 8px);
77
+ top: 50%;
78
+ transform: translateY(-50%);
79
+ background: var(--bodyStandoutBackground);
80
+ color: var(--bodyText);
81
+ border: 1px solid var(--bodyDivider);
82
+ border-radius: 6px;
83
+ padding: 4px 10px;
84
+ font-size: 12px;
85
+ white-space: nowrap;
86
+ pointer-events: none;
87
+ opacity: 0;
88
+ transition: opacity 0.15s ease;
89
+ z-index: 1002;
90
+ }
91
+
92
+ .shell-toolbar-btn:hover::after {
93
+ opacity: 1;
94
+ }
95
+
96
+ /* --- Toolbar: dock right ------------------------------------------------- */
97
+ [data-toolbar="right"] body { padding-left: 0; padding-right: var(--toolbar-width); overflow: hidden; }
98
+ [data-toolbar="right"] .shell-toolbar {
99
+ left: auto; right: 0;
100
+ border-right: none; border-left: 1px solid var(--bodyDivider);
101
+ }
102
+ [data-toolbar="right"] .shell-toolbar-btn::after {
103
+ left: auto; right: calc(100% + 8px);
104
+ }
105
+ [data-toolbar="right"] .chat-panel {
106
+ order: 2;
107
+ border-right: none;
108
+ border-left: 1px solid var(--bodyDivider);
109
+ transition: margin-right 0.3s ease, border-left-color 0.3s ease;
110
+ }
111
+ [data-toolbar="right"] .viewer-panel { order: 1; }
112
+ [data-toolbar="right"] .chat-collapsed .chat-panel {
113
+ margin-left: 0; margin-right: -30%;
114
+ border-left-color: transparent;
115
+ }
116
+
117
+ /* --- Chat Panel ----------------------------------------------------------- */
118
+ .chat-panel {
119
+ width: 30%;
120
+ background: var(--bodyStandoutBackground);
121
+ padding: 20px;
122
+ display: flex;
123
+ flex-direction: column;
124
+ border-right: 1px solid var(--bodyDivider);
125
+ position: relative;
126
+ transition: margin-left 0.3s ease, border-right-color 0.3s ease;
127
+ }
128
+
129
+ .chat-header {
130
+ display: flex;
131
+ align-items: center;
132
+ justify-content: space-between;
133
+ padding: 8px 0;
134
+ font-size: 20px;
135
+ font-weight: 600;
136
+ color: var(--themePrimary);
137
+ letter-spacing: 1px;
138
+ }
139
+
140
+ .chat-header-close {
141
+ background: none;
142
+ border: none;
143
+ color: var(--bodySubtext);
144
+ font-size: 18px;
145
+ cursor: pointer;
146
+ padding: 2px 6px;
147
+ line-height: 1;
148
+ border-radius: 4px;
149
+ transition: color 0.2s, background 0.2s;
150
+ }
151
+
152
+ .chat-header-close:hover {
153
+ color: var(--themePrimary);
154
+ background: var(--bodyBackgroundHovered);
155
+ }
156
+
157
+ /* --- Chat Messages -------------------------------------------------------- */
158
+ .chat-messages {
159
+ flex-grow: 1;
160
+ overflow-y: auto;
161
+ padding: 15px;
162
+ margin-top: 15px;
163
+ background: var(--defaultStateBackground);
164
+ border-radius: 15px;
165
+ border: 1px solid var(--bodyDivider);
166
+ }
167
+
168
+ .chat-message {
169
+ margin-bottom: 15px;
170
+ padding: 12px 15px;
171
+ background: var(--bodyBackgroundHovered);
172
+ border-radius: 15px;
173
+ border: 1px solid var(--bodyDivider);
174
+ }
175
+
176
+ .chat-message p {
177
+ margin-bottom: 5px;
178
+ line-height: 1.5;
179
+ }
180
+
181
+ .chat-message p strong {
182
+ font-weight: 600;
183
+ color: var(--themePrimary);
184
+ }
185
+
186
+ .chat-message p code {
187
+ background: var(--bodyBackgroundChecked);
188
+ padding: 2px 6px;
189
+ border-radius: 5px;
190
+ font-family: 'Courier New', Courier, monospace;
191
+ color: var(--themeSecondary);
192
+ border: 1px solid var(--bodyDivider);
193
+ }
194
+
195
+ /* --- Chat Form ------------------------------------------------------------ */
196
+ #chatForm {
197
+ display: flex;
198
+ flex-direction: column;
199
+ border: 1px solid var(--inputBorder);
200
+ border-radius: 16px;
201
+ background: var(--inputBackground);
202
+ padding: 8px 12px;
203
+ gap: 4px;
204
+ margin-top: 8px;
205
+ }
206
+
207
+ #chatForm:focus-within {
208
+ border-color: var(--inputFocusBorderAlt);
209
+ }
210
+
211
+ .chat-input {
212
+ border: none;
213
+ background: transparent;
214
+ resize: none;
215
+ min-height: 48px;
216
+ outline: none;
217
+ font-family: inherit;
218
+ font-size: 14px;
219
+ line-height: 1.5;
220
+ color: var(--inputText);
221
+ flex-grow: 1;
222
+ }
223
+
224
+ .chat-input::placeholder {
225
+ color: var(--inputPlaceholderText);
226
+ }
227
+
228
+ /* --- Viewer Panel --------------------------------------------------------- */
229
+ .viewer-panel {
230
+ flex: 1;
231
+ min-width: 0;
232
+ padding: 20px;
233
+ background: var(--bodyBackground);
234
+ display: flex;
235
+ flex-direction: column;
236
+ justify-content: center;
237
+ align-items: center;
238
+ position: relative;
239
+ overflow: hidden;
240
+ }
241
+
242
+ .viewer-panel.full-viewer {
243
+ padding: 0;
244
+ }
245
+
246
+ /* --- Chat error messages -------------------------------------------------- */
247
+ .chat-message-error {
248
+ border-left: 3px solid var(--errorText, #e81123);
249
+ background-color: var(--errorBackground, rgba(232, 17, 35, 0.06));
250
+ border-radius: var(--roundedCorner4, 4px);
251
+ padding: 8px 12px;
252
+ margin-top: 4px;
253
+ }
254
+
255
+ .chat-error-details {
256
+ font-size: 0.78rem;
257
+ color: var(--bodySubtext, #605e5c);
258
+ margin-top: 4px;
259
+ font-family: var(--fontFamilyMonospace, monospace);
260
+ word-break: break-word;
261
+ }
262
+
263
+ /* --- Loading -------------------------------------------------------------- */
264
+ .loading-overlay {
265
+ display: none;
266
+ position: fixed;
267
+ top: 0;
268
+ left: 0;
269
+ width: 100%;
270
+ height: 100%;
271
+ background: var(--overlayBackground, rgba(0,0,0,0.5));
272
+ justify-content: center;
273
+ align-items: center;
274
+ z-index: 1000;
275
+ }
276
+
277
+ .spinner {
278
+ width: 50px;
279
+ height: 50px;
280
+ border: 4px solid var(--themeTertiary, #71afe5);
281
+ border-top-color: var(--themePrimary, #0078d4);
282
+ border-radius: 50%;
283
+ animation: shell-spin 1s linear infinite;
284
+ }
285
+
286
+ @keyframes shell-spin {
287
+ to { transform: rotate(360deg); }
288
+ }
289
+
290
+ /* --- Scrollbar ------------------------------------------------------------ */
291
+ ::-webkit-scrollbar { width: 10px; height: 10px; }
292
+ ::-webkit-scrollbar-track { background: var(--defaultStateBackground); border-radius: 10px; }
293
+ ::-webkit-scrollbar-thumb {
294
+ background: var(--themePrimary);
295
+ border-radius: 10px;
296
+ border: 2px solid var(--defaultStateBackground);
297
+ }
298
+ ::-webkit-scrollbar-thumb:hover {
299
+ background: var(--themeSecondary);
300
+ }
301
+ ::-webkit-scrollbar-corner { background: var(--defaultStateBackground); }
302
+ * { scrollbar-width: thin; scrollbar-color: var(--themePrimary) var(--defaultStateBackground); }
303
+
304
+ /* --- Chat Collapsed State ------------------------------------------------- */
305
+ body.chat-collapsed .chat-panel {
306
+ margin-left: -30%;
307
+ border-right-color: transparent;
308
+ }
309
+
310
+ /* --- Modal ---------------------------------------------------------------- */
311
+ .modal-overlay {
312
+ position: fixed;
313
+ top: 0; left: 0; right: 0; bottom: 0;
314
+ background: var(--overlayBackground, rgba(0,0,0,0.6));
315
+ display: none;
316
+ align-items: center;
317
+ justify-content: center;
318
+ z-index: 2000;
319
+ backdrop-filter: blur(4px);
320
+ }
321
+
322
+ .modal-overlay.show { display: flex; }
323
+
324
+ .modal-content {
325
+ background: var(--bodyBackground);
326
+ border: 1px solid var(--bodyDivider);
327
+ border-radius: 12px;
328
+ width: 90%;
329
+ max-width: 450px;
330
+ box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4);
331
+ overflow: hidden;
332
+ }
333
+
334
+ .modal-header {
335
+ background: var(--primaryButtonBackground);
336
+ color: var(--primaryButtonText);
337
+ padding: 16px 20px;
338
+ font-size: 18px;
339
+ font-weight: 600;
340
+ }
341
+
342
+ .modal-body { padding: 20px; }
343
+
344
+ .modal-footer {
345
+ padding: 16px 20px;
346
+ border-top: 1px solid var(--bodyDivider);
347
+ display: flex;
348
+ justify-content: space-between;
349
+ align-items: center;
350
+ gap: 12px;
351
+ }
352
+
353
+ .modal-footer-right { display: flex; gap: 10px; margin-left: auto; }
354
+
355
+ /* --- Form Elements (modals) ----------------------------------------------- */
356
+ .form-group { margin-bottom: 16px; }
357
+ .form-group:last-child { margin-bottom: 0; }
358
+
359
+ .form-label {
360
+ display: block;
361
+ font-size: 13px;
362
+ color: var(--bodySubtext);
363
+ margin-bottom: 6px;
364
+ font-weight: 500;
365
+ }
366
+
367
+ .form-input {
368
+ width: 100%;
369
+ padding: 10px 14px;
370
+ border: 1px solid var(--inputBorder);
371
+ border-radius: 8px;
372
+ background: var(--inputBackground);
373
+ color: var(--inputText);
374
+ font-size: 14px;
375
+ outline: none;
376
+ transition: border-color 0.2s ease;
377
+ box-sizing: border-box;
378
+ }
379
+
380
+ .form-input:focus { border-color: var(--inputFocusBorderAlt); }
381
+ .form-input:read-only { opacity: 0.7; cursor: not-allowed; }
382
+ .form-input::placeholder { color: var(--inputPlaceholderText); opacity: 0.7; }
383
+
384
+ .checkbox-label {
385
+ display: flex;
386
+ align-items: center;
387
+ gap: 8px;
388
+ cursor: pointer;
389
+ }
390
+
391
+ .checkbox-label input[type="checkbox"] {
392
+ width: 18px;
393
+ height: 18px;
394
+ accent-color: var(--themePrimary);
395
+ cursor: pointer;
396
+ }
397
+
398
+ .checkbox-label span { font-size: 14px; color: var(--bodyText); }
399
+
400
+ /* --- Modal Buttons -------------------------------------------------------- */
401
+ .modal-btn {
402
+ padding: 10px 20px;
403
+ border-radius: 8px;
404
+ font-size: 14px;
405
+ font-weight: 500;
406
+ cursor: pointer;
407
+ transition: all 0.2s ease;
408
+ border: none;
409
+ }
410
+
411
+ .modal-btn-primary {
412
+ background: var(--primaryButtonBackground);
413
+ color: var(--primaryButtonText);
414
+ }
415
+
416
+ .modal-btn-primary:hover {
417
+ background: var(--primaryButtonBackgroundHovered);
418
+ }
419
+
420
+ .modal-btn-secondary {
421
+ background: var(--buttonBackground);
422
+ color: var(--buttonText);
423
+ border: 1px solid var(--buttonBorder);
424
+ }
425
+
426
+ .modal-btn-secondary:hover {
427
+ background: var(--buttonBackgroundHovered);
428
+ border-color: var(--buttonBorder);
429
+ }
430
+
431
+ .modal-btn-danger { background: #dc3545; color: white; }
432
+
433
+ .modal-btn-danger:hover {
434
+ background: #c82333;
435
+ box-shadow: 0 4px 15px rgba(220, 53, 69, 0.3);
436
+ }
437
+
438
+ /* --- Chat Input Wrapper (icon row) & Brainstorm Icon --------------------- */
439
+ .chat-input-wrapper {
440
+ display: flex;
441
+ align-items: center;
442
+ gap: 4px;
443
+ position: relative;
444
+ }
445
+
446
+ .brainstorm-icon-btn {
447
+ background: transparent;
448
+ border: none;
449
+ color: var(--bodySubtext);
450
+ cursor: pointer;
451
+ padding: 4px;
452
+ border-radius: 4px;
453
+ display: flex;
454
+ align-items: center;
455
+ justify-content: center;
456
+ transition: color 0.2s, background 0.2s;
457
+ }
458
+
459
+ .brainstorm-icon-btn:hover {
460
+ color: var(--themePrimary);
461
+ background: var(--bodyBackgroundHovered);
462
+ }
463
+
464
+ /* --- Chat Send Button ---------------------------------------------------- */
465
+ .chat-send-btn {
466
+ margin-left: auto;
467
+ width: 32px;
468
+ height: 32px;
469
+ border-radius: 50%;
470
+ background: var(--primaryButtonBackground);
471
+ color: var(--primaryButtonText);
472
+ border: none;
473
+ cursor: pointer;
474
+ display: flex;
475
+ align-items: center;
476
+ justify-content: center;
477
+ transition: background 0.2s;
478
+ flex-shrink: 0;
479
+ }
480
+
481
+ .chat-send-btn:hover {
482
+ background: var(--primaryButtonBackgroundHovered);
483
+ }
484
+
485
+ .chat-send-btn:disabled {
486
+ opacity: 0.5;
487
+ cursor: not-allowed;
488
+ }
489
+
490
+ /* --- Brainstorm Modal ----------------------------------------------------- */
491
+ .brainstorm-modal .modal-content {
492
+ max-width: none;
493
+ width: calc(100% - 80px);
494
+ height: calc(100% - 80px);
495
+ display: flex;
496
+ flex-direction: column;
497
+ }
498
+
499
+ .brainstorm-modal .modal-header {
500
+ display: flex;
501
+ justify-content: space-between;
502
+ align-items: center;
503
+ flex-shrink: 0;
504
+ }
505
+
506
+ .brainstorm-close-btn {
507
+ background: none;
508
+ border: none;
509
+ color: white;
510
+ font-size: 24px;
511
+ cursor: pointer;
512
+ padding: 0 4px;
513
+ line-height: 1;
514
+ opacity: 0.7;
515
+ transition: opacity 0.2s;
516
+ }
517
+
518
+ .brainstorm-close-btn:hover { opacity: 1; }
519
+
520
+ .brainstorm-messages {
521
+ flex: 1;
522
+ overflow-y: auto;
523
+ scrollbar-gutter: stable;
524
+ padding: 20px;
525
+ display: flex;
526
+ flex-direction: column;
527
+ gap: 16px;
528
+ }
529
+
530
+ .brainstorm-message {
531
+ padding: 12px 16px;
532
+ border-radius: 10px;
533
+ font-size: 14px;
534
+ line-height: 1.5;
535
+ max-width: 85%;
536
+ word-wrap: break-word;
537
+ }
538
+
539
+ .brainstorm-user {
540
+ background: var(--primaryButtonBackground);
541
+ color: var(--primaryButtonText);
542
+ align-self: flex-end;
543
+ }
544
+
545
+ .brainstorm-assistant {
546
+ background: var(--bodyStandoutBackground);
547
+ color: var(--bodyText);
548
+ border: 1px solid var(--bodyDivider);
549
+ align-self: flex-start;
550
+ }
551
+
552
+ .brainstorm-input-row {
553
+ display: flex;
554
+ gap: 8px;
555
+ padding: 16px 20px;
556
+ border-top: 1px solid var(--bodyDivider);
557
+ flex-shrink: 0;
558
+ }
559
+
560
+ .brainstorm-input {
561
+ flex: 1;
562
+ padding: 10px 14px;
563
+ border: 1px solid var(--inputBorder);
564
+ border-radius: 8px;
565
+ background: var(--inputBackground);
566
+ color: var(--inputText);
567
+ font-size: 14px;
568
+ outline: none;
569
+ transition: border-color 0.2s;
570
+ }
571
+
572
+ .brainstorm-input:focus { border-color: var(--inputFocusBorderAlt); }
573
+ .brainstorm-input::placeholder { color: var(--inputPlaceholderText); opacity: 0.7; }
574
+
575
+ .brainstorm-send-btn {
576
+ padding: 10px 20px;
577
+ border: none;
578
+ border-radius: 8px;
579
+ background: var(--primaryButtonBackground);
580
+ color: var(--primaryButtonText);
581
+ font-size: 14px;
582
+ font-weight: 500;
583
+ cursor: pointer;
584
+ transition: all 0.2s;
585
+ }
586
+
587
+ .brainstorm-send-btn:hover {
588
+ background: var(--primaryButtonBackgroundHovered);
589
+ }
590
+
591
+ .brainstorm-send-btn:disabled {
592
+ opacity: 0.5;
593
+ cursor: not-allowed;
594
+ }
595
+
596
+ .brainstorm-assistant p { margin: 4px 0; }
597
+ .brainstorm-assistant pre { background: var(--defaultStateBackground); padding: 10px; border-radius: 6px; overflow-x: auto; margin: 8px 0; }
598
+ .brainstorm-assistant code { font-size: 13px; }
599
+ .brainstorm-assistant ul, .brainstorm-assistant ol { margin: 4px 0; padding-left: 20px; }
600
+
601
+ .brainstorm-build-row {
602
+ display: flex;
603
+ justify-content: flex-end;
604
+ margin-top: 10px;
605
+ }
606
+
607
+ .brainstorm-build-btn {
608
+ padding: 6px 16px;
609
+ font-size: 12px;
610
+ font-weight: 600;
611
+ border: none;
612
+ border-radius: 6px;
613
+ background: var(--primaryButtonBackground);
614
+ color: var(--primaryButtonText);
615
+ cursor: pointer;
616
+ transition: all 0.2s;
617
+ }
618
+
619
+ .brainstorm-build-btn:hover {
620
+ background: var(--primaryButtonBackgroundHovered);
621
+ }
622
+
623
+ .brainstorm-suggestions {
624
+ display: flex;
625
+ flex-wrap: wrap;
626
+ gap: 6px;
627
+ margin-top: 10px;
628
+ }
629
+
630
+ .brainstorm-suggestion-chip {
631
+ padding: 5px 12px;
632
+ font-size: 12px;
633
+ border: 1px solid var(--bodyDivider);
634
+ border-radius: 16px;
635
+ background: var(--defaultStateBackground);
636
+ color: var(--bodySubtext);
637
+ cursor: pointer;
638
+ transition: all 0.2s;
639
+ line-height: 1.4;
640
+ }
641
+
642
+ .brainstorm-suggestion-chip:hover {
643
+ border-color: var(--themePrimary);
644
+ color: var(--themePrimary);
645
+ background: var(--bodyBackgroundHovered);
646
+ }
647
+
648
+ .brainstorm-suggestion-chip:disabled {
649
+ opacity: 0.4;
650
+ cursor: default;
651
+ pointer-events: none;
652
+ }
653
+
654
+ .brainstorm-thinking {
655
+ align-self: flex-start;
656
+ padding: 12px 16px;
657
+ background: var(--bodyStandoutBackground);
658
+ border: 1px solid var(--bodyDivider);
659
+ border-radius: 10px;
660
+ color: var(--bodySubtext);
661
+ font-size: 14px;
662
+ font-style: italic;
663
+ }
664
+
665
+ /* --- Save Line ------------------------------------------------------------ */
666
+ .save-line {
667
+ display: flex;
668
+ align-items: center;
669
+ gap: 10px;
670
+ margin: 8px 0 15px;
671
+ font-size: 11px;
672
+ color: var(--bodySubtext);
673
+ opacity: 0.7;
674
+ }
675
+
676
+ .save-line::before,
677
+ .save-line::after {
678
+ content: '';
679
+ flex: 1;
680
+ height: 1px;
681
+ background: var(--bodyDivider);
682
+ }
683
+
684
+ .save-line-label {
685
+ white-space: nowrap;
686
+ letter-spacing: 0.5px;
687
+ }
688
+
689
+ /* --- Shared page rules ---------------------------------------------------- */
690
+ #loadingOverlay { position: absolute; }
691
+ .chat-input:disabled { opacity: 0.5; cursor: not-allowed; }
692
+
693
+ /* --- Attach Button -------------------------------------------------------- */
694
+ .attach-btn {
695
+ background: transparent;
696
+ border: none;
697
+ color: var(--bodySubtext);
698
+ cursor: pointer;
699
+ padding: 4px;
700
+ border-radius: 4px;
701
+ display: flex;
702
+ align-items: center;
703
+ justify-content: center;
704
+ transition: color 0.2s, background 0.2s;
705
+ }
706
+
707
+ .attach-btn:hover {
708
+ color: var(--themePrimary);
709
+ background: var(--bodyBackgroundHovered);
710
+ }
711
+
712
+ /* --- Attach Menu ---------------------------------------------------------- */
713
+ .attach-menu {
714
+ display: none;
715
+ flex-direction: column;
716
+ position: absolute;
717
+ bottom: calc(100% + 6px);
718
+ left: 0;
719
+ background: var(--menuBackground);
720
+ border: 1px solid var(--bodyDivider);
721
+ border-radius: 8px;
722
+ box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
723
+ overflow: hidden;
724
+ z-index: 100;
725
+ min-width: 160px;
726
+ }
727
+
728
+ .attach-menu-item {
729
+ display: flex;
730
+ align-items: center;
731
+ gap: 8px;
732
+ padding: 8px 14px;
733
+ font-size: 13px;
734
+ color: var(--menuItemText);
735
+ cursor: pointer;
736
+ transition: background 0.15s;
737
+ }
738
+
739
+ .attach-menu-item:hover {
740
+ background: var(--menuItemBackgroundHovered);
741
+ }
742
+
743
+ /* --- Attachment Pills ----------------------------------------------------- */
744
+ .attachment-pills {
745
+ display: flex;
746
+ flex-wrap: wrap;
747
+ gap: 6px;
748
+ padding: 0 4px;
749
+ min-height: 0;
750
+ }
751
+
752
+ .attachment-pills:empty { display: none; }
753
+
754
+ .attachment-pill {
755
+ display: flex;
756
+ align-items: center;
757
+ gap: 6px;
758
+ background: var(--defaultStateBackground);
759
+ border: 1px solid var(--bodyDivider);
760
+ border-radius: 6px;
761
+ padding: 4px 8px;
762
+ max-width: 180px;
763
+ }
764
+
765
+ .attachment-pill-remove {
766
+ background: none;
767
+ border: none;
768
+ color: var(--bodySubtext);
769
+ cursor: pointer;
770
+ font-size: 14px;
771
+ padding: 0 2px;
772
+ line-height: 1;
773
+ }
774
+
775
+ .attachment-pill-remove:hover {
776
+ color: #ff6b6b;
777
+ }
778
+
779
+ /* --- Screenshot Overlay --------------------------------------------------- */
780
+ .screenshot-overlay {
781
+ position: absolute;
782
+ top: 0;
783
+ left: 0;
784
+ width: 100%;
785
+ height: 100%;
786
+ background: rgba(0, 0, 0, 0.2);
787
+ cursor: crosshair;
788
+ z-index: 1000;
789
+ }
790
+
791
+ .screenshot-rect {
792
+ display: none;
793
+ position: absolute;
794
+ border: 2px solid red;
795
+ background: rgba(255, 0, 0, 0.05);
796
+ pointer-events: none;
797
+ }