failproofai 0.0.11-beta.2 → 0.0.11-beta.4

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 (474) hide show
  1. package/.next/standalone/.next/BUILD_ID +1 -1
  2. package/.next/standalone/.next/app-path-routes-manifest.json +8 -1
  3. package/.next/standalone/.next/build-manifest.json +10 -10
  4. package/.next/standalone/.next/prerender-manifest.json +3 -32
  5. package/.next/standalone/.next/required-server-files.json +2 -1
  6. package/.next/standalone/.next/routes-manifest.json +45 -3
  7. package/.next/standalone/.next/server/app/_global-error/page/build-manifest.json +7 -7
  8. package/.next/standalone/.next/server/app/_global-error/page/server-reference-manifest.json +1 -1
  9. package/.next/standalone/.next/server/app/_global-error/page.js +6 -6
  10. package/.next/standalone/.next/server/app/_global-error/page.js.nft.json +1 -1
  11. package/.next/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  12. package/.next/standalone/.next/server/app/_global-error.html +1 -1
  13. package/.next/standalone/.next/server/app/_global-error.rsc +7 -7
  14. package/.next/standalone/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +2 -2
  15. package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +7 -7
  16. package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +3 -3
  17. package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +3 -3
  18. package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  19. package/.next/standalone/.next/server/app/_not-found/page/build-manifest.json +7 -7
  20. package/.next/standalone/.next/server/app/_not-found/page/next-font-manifest.json +2 -6
  21. package/.next/standalone/.next/server/app/_not-found/page/server-reference-manifest.json +1 -1
  22. package/.next/standalone/.next/server/app/_not-found/page.js +12 -13
  23. package/.next/standalone/.next/server/app/_not-found/page.js.nft.json +1 -1
  24. package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  25. package/.next/standalone/.next/server/app/_not-found.html +1 -1
  26. package/.next/standalone/.next/server/app/_not-found.rsc +16 -16
  27. package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +16 -16
  28. package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
  29. package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +10 -10
  30. package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
  31. package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
  32. package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  33. package/.next/standalone/.next/server/app/api/audit/run/route/app-paths-manifest.json +3 -0
  34. package/.next/standalone/.next/server/app/api/audit/run/route/server-reference-manifest.json +4 -0
  35. package/.next/standalone/.next/server/app/api/audit/run/route.js +8 -0
  36. package/.next/standalone/.next/server/app/api/audit/run/route.js.nft.json +1 -0
  37. package/.next/standalone/.next/server/app/api/audit/run/route_client-reference-manifest.js +3 -0
  38. package/.next/standalone/.next/server/app/api/audit/status/route/app-paths-manifest.json +3 -0
  39. package/.next/standalone/.next/server/app/api/audit/status/route/build-manifest.json +9 -0
  40. package/.next/standalone/.next/server/app/api/audit/status/route/server-reference-manifest.json +4 -0
  41. package/.next/standalone/.next/server/app/api/audit/status/route.js +6 -0
  42. package/.next/standalone/.next/server/app/api/audit/status/route.js.map +5 -0
  43. package/.next/standalone/.next/server/app/api/audit/status/route.js.nft.json +1 -0
  44. package/.next/standalone/.next/server/app/api/audit/status/route_client-reference-manifest.js +3 -0
  45. package/.next/standalone/.next/server/app/api/auth/login-request/route/app-paths-manifest.json +3 -0
  46. package/.next/standalone/.next/server/app/api/auth/login-request/route/build-manifest.json +9 -0
  47. package/.next/standalone/.next/server/app/api/auth/login-request/route/server-reference-manifest.json +4 -0
  48. package/.next/standalone/.next/server/app/api/auth/login-request/route.js +6 -0
  49. package/.next/standalone/.next/server/app/api/auth/login-request/route.js.map +5 -0
  50. package/.next/standalone/.next/server/app/api/auth/login-request/route.js.nft.json +1 -0
  51. package/.next/standalone/.next/server/app/api/auth/login-request/route_client-reference-manifest.js +3 -0
  52. package/.next/standalone/.next/server/app/api/auth/login-verify/route/app-paths-manifest.json +3 -0
  53. package/.next/standalone/.next/server/app/api/auth/login-verify/route/build-manifest.json +9 -0
  54. package/.next/standalone/.next/server/app/api/auth/login-verify/route/server-reference-manifest.json +4 -0
  55. package/.next/standalone/.next/server/app/api/auth/login-verify/route.js +7 -0
  56. package/.next/standalone/.next/server/app/api/auth/login-verify/route.js.map +5 -0
  57. package/.next/standalone/.next/server/app/api/auth/login-verify/route.js.nft.json +1 -0
  58. package/.next/standalone/.next/server/app/api/auth/login-verify/route_client-reference-manifest.js +3 -0
  59. package/.next/standalone/.next/server/app/api/auth/logout/route/app-paths-manifest.json +3 -0
  60. package/.next/standalone/.next/server/app/api/auth/logout/route/build-manifest.json +9 -0
  61. package/.next/standalone/.next/server/app/api/auth/logout/route/server-reference-manifest.json +4 -0
  62. package/.next/standalone/.next/server/app/api/auth/logout/route.js +7 -0
  63. package/.next/standalone/.next/server/app/api/auth/logout/route.js.map +5 -0
  64. package/.next/standalone/.next/server/app/api/auth/logout/route.js.nft.json +1 -0
  65. package/.next/standalone/.next/server/app/api/auth/logout/route_client-reference-manifest.js +3 -0
  66. package/.next/standalone/.next/server/app/api/auth/reminder/route/app-paths-manifest.json +3 -0
  67. package/.next/standalone/.next/server/app/api/auth/reminder/route/build-manifest.json +9 -0
  68. package/.next/standalone/.next/server/app/api/auth/reminder/route/server-reference-manifest.json +4 -0
  69. package/.next/standalone/.next/server/app/api/auth/reminder/route.js +7 -0
  70. package/.next/standalone/.next/server/app/api/auth/reminder/route.js.map +5 -0
  71. package/.next/standalone/.next/server/app/api/auth/reminder/route.js.nft.json +1 -0
  72. package/.next/standalone/.next/server/app/api/auth/reminder/route_client-reference-manifest.js +3 -0
  73. package/.next/standalone/.next/server/app/api/auth/status/route/app-paths-manifest.json +3 -0
  74. package/.next/standalone/.next/server/app/api/auth/status/route/build-manifest.json +9 -0
  75. package/.next/standalone/.next/server/app/api/auth/status/route/server-reference-manifest.json +4 -0
  76. package/.next/standalone/.next/server/app/api/auth/status/route.js +7 -0
  77. package/.next/standalone/.next/server/app/api/auth/status/route.js.map +5 -0
  78. package/.next/standalone/.next/server/app/api/auth/status/route.js.nft.json +1 -0
  79. package/.next/standalone/.next/server/app/api/auth/status/route_client-reference-manifest.js +3 -0
  80. package/.next/standalone/.next/server/app/api/download/[project]/[session]/route.js +3 -3
  81. package/.next/standalone/.next/server/app/api/download/[project]/[session]/route.js.nft.json +1 -1
  82. package/.next/standalone/.next/server/app/audit/page/app-paths-manifest.json +3 -0
  83. package/.next/standalone/.next/server/app/audit/page/build-manifest.json +18 -0
  84. package/.next/standalone/.next/server/app/audit/page/next-font-manifest.json +6 -0
  85. package/.next/standalone/.next/server/app/audit/page/react-loadable-manifest.json +1 -0
  86. package/.next/standalone/.next/server/app/audit/page/server-reference-manifest.json +29 -0
  87. package/.next/standalone/.next/server/app/audit/page.js +17 -0
  88. package/.next/standalone/.next/server/app/audit/page.js.map +5 -0
  89. package/.next/standalone/.next/server/app/audit/page.js.nft.json +1 -0
  90. package/.next/standalone/.next/server/app/audit/page_client-reference-manifest.js +3 -0
  91. package/.next/standalone/.next/server/app/index.html +1 -1
  92. package/.next/standalone/.next/server/app/index.rsc +16 -17
  93. package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  94. package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +16 -17
  95. package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +4 -4
  96. package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +10 -10
  97. package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -3
  98. package/.next/standalone/.next/server/app/page/build-manifest.json +7 -7
  99. package/.next/standalone/.next/server/app/page/next-font-manifest.json +2 -6
  100. package/.next/standalone/.next/server/app/page/server-reference-manifest.json +1 -1
  101. package/.next/standalone/.next/server/app/page.js +14 -15
  102. package/.next/standalone/.next/server/app/page.js.nft.json +1 -1
  103. package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
  104. package/.next/standalone/.next/server/app/policies/page/build-manifest.json +7 -7
  105. package/.next/standalone/.next/server/app/policies/page/next-font-manifest.json +2 -6
  106. package/.next/standalone/.next/server/app/policies/page/server-reference-manifest.json +8 -8
  107. package/.next/standalone/.next/server/app/policies/page.js +16 -16
  108. package/.next/standalone/.next/server/app/policies/page.js.nft.json +1 -1
  109. package/.next/standalone/.next/server/app/policies/page_client-reference-manifest.js +1 -1
  110. package/.next/standalone/.next/server/app/project/[name]/page/build-manifest.json +7 -7
  111. package/.next/standalone/.next/server/app/project/[name]/page/next-font-manifest.json +2 -6
  112. package/.next/standalone/.next/server/app/project/[name]/page/server-reference-manifest.json +1 -1
  113. package/.next/standalone/.next/server/app/project/[name]/page.js +16 -17
  114. package/.next/standalone/.next/server/app/project/[name]/page.js.nft.json +1 -1
  115. package/.next/standalone/.next/server/app/project/[name]/page_client-reference-manifest.js +1 -1
  116. package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/build-manifest.json +7 -7
  117. package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/next-font-manifest.json +2 -6
  118. package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/react-loadable-manifest.json +2 -2
  119. package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/server-reference-manifest.json +2 -2
  120. package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page.js +19 -20
  121. package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page.js.nft.json +1 -1
  122. package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page_client-reference-manifest.js +1 -1
  123. package/.next/standalone/.next/server/app/projects/page/build-manifest.json +7 -7
  124. package/.next/standalone/.next/server/app/projects/page/next-font-manifest.json +2 -6
  125. package/.next/standalone/.next/server/app/projects/page/server-reference-manifest.json +1 -1
  126. package/.next/standalone/.next/server/app/projects/page.js +15 -16
  127. package/.next/standalone/.next/server/app/projects/page.js.nft.json +1 -1
  128. package/.next/standalone/.next/server/app/projects/page_client-reference-manifest.js +1 -1
  129. package/.next/standalone/.next/server/app-paths-manifest.json +8 -1
  130. package/.next/standalone/.next/server/chunks/[externals]__14odj07._.js +3 -0
  131. package/.next/standalone/.next/server/chunks/{[externals]__0z0j--b._.js → [externals]__1nl3dvw._.js} +1 -1
  132. package/.next/standalone/.next/server/chunks/{[externals]__0-p9.k~._.js → [externals]__1s61mel._.js} +1 -1
  133. package/.next/standalone/.next/server/chunks/{[externals]_node_os_06ur78j._.js → [externals]_node_os_0by37l-._.js} +1 -1
  134. package/.next/standalone/.next/server/chunks/[root-of-the-server]__07tgnzi._.js +3 -0
  135. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0kjo7d_._.js → [root-of-the-server]__0_0xu5z._.js} +2 -2
  136. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0cag8qd._.js +3 -0
  137. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0z-180.._.js → [root-of-the-server]__0cycwg6._.js} +2 -2
  138. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__08px0ym._.js → [root-of-the-server]__0f7mikp._.js} +1 -1
  139. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0oeun7z._.js +3 -0
  140. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0q-v9z2._.js +3 -0
  141. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0rv7m0k._.js +3 -0
  142. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0g48iv.._.js → [root-of-the-server]__0sb_5m8._.js} +3 -3
  143. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0j8-xkl._.js → [root-of-the-server]__0xuaoik._.js} +2 -2
  144. package/.next/standalone/.next/server/chunks/[root-of-the-server]__12pit4m._.js +3 -0
  145. package/.next/standalone/.next/server/chunks/[root-of-the-server]__13h8pzr._.js +3 -0
  146. package/.next/standalone/.next/server/chunks/[root-of-the-server]__13ra2jq._.js +3 -0
  147. package/.next/standalone/.next/server/chunks/[root-of-the-server]__17g9wh7._.js +3 -0
  148. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0d_ob4n._.js → [root-of-the-server]__1_mqemn._.js} +2 -2
  149. package/.next/standalone/.next/server/chunks/[root-of-the-server]__1b9z5-i._.js +3 -0
  150. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0vlhtkc._.js → [root-of-the-server]__1hgv_75._.js} +1 -1
  151. package/.next/standalone/.next/server/chunks/[root-of-the-server]__1ixjiy8._.js +3 -0
  152. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0wu7fr7._.js → [root-of-the-server]__1jm9fw6._.js} +1 -1
  153. package/.next/standalone/.next/server/chunks/[root-of-the-server]__1legmza._.js +3 -0
  154. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0fwb7ao._.js → [root-of-the-server]__1m2_4t0._.js} +2 -2
  155. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0yfq1yr._.js → [root-of-the-server]__1mhmdzs._.js} +1 -1
  156. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0zso~62._.js → [root-of-the-server]__1ou2ehh._.js} +1 -1
  157. package/.next/standalone/.next/server/chunks/[root-of-the-server]__1qxztj-._.js +3 -0
  158. package/.next/standalone/.next/server/chunks/[root-of-the-server]__1rhmvod._.js +3 -0
  159. package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0.~nmr9._.js → [root-of-the-server]__1w9zl9-._.js} +1 -1
  160. package/.next/standalone/.next/server/chunks/{_0ebx_lc._.js → _0p53ge1._.js} +2 -2
  161. package/.next/standalone/.next/server/chunks/_1-1804f._.js +3 -0
  162. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_audit_run_route_actions_1qgp9io.js +3 -0
  163. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_audit_status_route_actions_1f7pjof.js +3 -0
  164. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_auth_login-request_route_actions_1c49co0.js +3 -0
  165. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_auth_login-verify_route_actions_1r3slzk.js +3 -0
  166. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_auth_logout_route_actions_0regwyr.js +3 -0
  167. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_auth_reminder_route_actions_1kjgxf8.js +3 -0
  168. package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_auth_status_route_actions_1aho9zu.js +3 -0
  169. package/.next/standalone/.next/server/chunks/{_next-internal_server_app_api_download_[project]_[session]_route_actions_0wb00i-.js → _next-internal_server_app_api_download_[project]_[session]_route_actions_1is7vs7.js} +1 -1
  170. package/.next/standalone/.next/server/chunks/{lib_logger_ts_047tt9f._.js → lib_logger_ts_07e65t5._.js} +1 -1
  171. package/.next/standalone/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_17k9e3w.js +23 -0
  172. package/.next/standalone/.next/server/chunks/node_modules_posthog-node_dist_entrypoints_index_node_mjs_01r25oi._.js +3 -0
  173. package/.next/standalone/.next/server/chunks/node_modules_posthog-node_dist_entrypoints_index_node_mjs_09z9-p7._.js +3 -0
  174. package/.next/standalone/.next/server/chunks/{package_json_[json]_cjs_0z7w.hh._.js → package_json_[json]_cjs_1nxcc4v._.js} +2 -2
  175. package/.next/standalone/.next/server/chunks/ssr/{[externals]__12dv.x0._.js → [externals]__1_g_b3t._.js} +1 -1
  176. package/.next/standalone/.next/server/chunks/ssr/{[externals]_node_async_hooks_0v0ln8c._.js → [externals]_node_async_hooks_1gjz99j._.js} +1 -1
  177. package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0ts150~._.js → [root-of-the-server]__0-wdurj._.js} +2 -2
  178. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__00jkjmt._.js +4 -0
  179. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__013du6r._.js +4 -0
  180. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__06f-yix._.js +3 -0
  181. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0989_dx._.js +3 -0
  182. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0e85wxv._.js +4 -0
  183. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0gfxvb1._.js +3 -0
  184. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0h12me5._.js +3 -0
  185. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0l13qf2._.js +3 -0
  186. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1-scthx._.js +3 -0
  187. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__11rtg6s._.js +3 -0
  188. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__14dd6h8._.js +3 -0
  189. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1cd25c7._.js +4 -0
  190. package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0t5l7a5._.js → [root-of-the-server]__1d8omgc._.js} +1 -1
  191. package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0tcyn68._.js → [root-of-the-server]__1dky4g0._.js} +1 -1
  192. package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__098zro9._.js → [root-of-the-server]__1fax1sl._.js} +4 -4
  193. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1hlrq6y._.js +4 -0
  194. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1ihxdo5._.js +4 -0
  195. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1mt35_w._.js +221 -0
  196. package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0-wn51s._.js → [root-of-the-server]__1pcxxwg._.js} +3 -3
  197. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1usf8v2._.js +3 -0
  198. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1vvfde2._.js +4 -0
  199. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__212nf49._.js +3 -0
  200. package/.next/standalone/.next/server/chunks/ssr/{_03d7qyt._.js → _05whahf._.js} +1 -1
  201. package/.next/standalone/.next/server/chunks/ssr/_11_p9y8._.js +3 -0
  202. package/.next/standalone/.next/server/chunks/ssr/{_0xb8ngh._.js → _1kje4fm._.js} +1 -1
  203. package/.next/standalone/.next/server/chunks/ssr/{_0zx~s__._.js → _1p0-leb._.js} +1 -1
  204. package/.next/standalone/.next/server/chunks/ssr/{app_04qfs8z._.js → app_087bt9w._.js} +1 -1
  205. package/.next/standalone/.next/server/chunks/ssr/{app_0uosk1e._.js → app_1fvisnp._.js} +1 -1
  206. package/.next/standalone/.next/server/chunks/ssr/{app_13f0ohr._.js → app_209u41o._.js} +1 -1
  207. package/.next/standalone/.next/server/chunks/ssr/app_audit__components_audit-dashboard_tsx_0p9ud47._.js +43 -0
  208. package/.next/standalone/.next/server/chunks/ssr/app_audit_loading_tsx_1j1kc6j._.js +3 -0
  209. package/.next/standalone/.next/server/chunks/ssr/{app_error_tsx_11t4ysq._.js → app_error_tsx_1zds1ns._.js} +1 -1
  210. package/.next/standalone/.next/server/chunks/ssr/{app_global-error_tsx_0m9qisk._.js → app_global-error_tsx_113y3za._.js} +1 -1
  211. package/.next/standalone/.next/server/chunks/ssr/{app_global-error_tsx_0xerkr6._.js → app_global-error_tsx_1kp6l3x._.js} +2 -2
  212. package/.next/standalone/.next/server/chunks/ssr/app_policies_hooks-client_tsx_19dqvpc._.js +8 -0
  213. package/.next/standalone/.next/server/chunks/ssr/{app_project_[name]_error_tsx_0.9-fod._.js → app_project_[name]_error_tsx_1v02_5n._.js} +1 -1
  214. package/.next/standalone/.next/server/chunks/ssr/{app_project_[name]_loading_tsx_03g9xy0._.js → app_project_[name]_loading_tsx_05-l4uf._.js} +1 -1
  215. package/.next/standalone/.next/server/chunks/ssr/{app_project_[name]_session_[sessionId]_error_tsx_0ler-mr._.js → app_project_[name]_session_[sessionId]_error_tsx_0-lj3nd._.js} +1 -1
  216. package/.next/standalone/.next/server/chunks/ssr/{app_project_[name]_session_[sessionId]_loading_tsx_0c0e3yx._.js → app_project_[name]_session_[sessionId]_loading_tsx_0l4aixs._.js} +1 -1
  217. package/.next/standalone/.next/server/chunks/ssr/app_projects_loading_tsx_20-3u8b._.js +3 -0
  218. package/.next/standalone/.next/server/chunks/ssr/{lib_codex-projects_ts_0eosib~._.js → lib_codex-projects_ts_0pqlw37._.js} +1 -1
  219. package/.next/standalone/.next/server/chunks/ssr/{lib_copilot-projects_ts_0r8xkn8._.js → lib_copilot-projects_ts_19wl7tp._.js} +1 -1
  220. package/.next/standalone/.next/server/chunks/ssr/{lib_cursor-projects_ts_0qt1scg._.js → lib_cursor-projects_ts_18-iwyk._.js} +1 -1
  221. package/.next/standalone/.next/server/chunks/ssr/{lib_gemini-projects_ts_0sl~yqr._.js → lib_gemini-projects_ts_1c7bgx-._.js} +1 -1
  222. package/.next/standalone/.next/server/chunks/ssr/{lib_opencode-projects_ts_0op9gyp._.js → lib_opencode-projects_ts_15bjxkm._.js} +1 -1
  223. package/.next/standalone/.next/server/chunks/ssr/{lib_pi-projects_ts_103tsh1._.js → lib_pi-projects_ts_1wikofb._.js} +1 -1
  224. package/.next/standalone/.next/server/chunks/ssr/{lib_utils_ts_068jk73._.js → lib_utils_ts_0az0sfq._.js} +1 -1
  225. package/.next/standalone/.next/server/chunks/ssr/node_modules_1ynf7el._.js +3 -0
  226. package/.next/standalone/.next/server/chunks/ssr/node_modules_html2canvas_dist_html2canvas_esm_0hmsdod.js +3 -0
  227. package/.next/standalone/.next/server/chunks/ssr/node_modules_html2canvas_dist_html2canvas_esm_1n-0xws.js +3 -0
  228. package/.next/standalone/.next/server/chunks/ssr/{node_modules_next_0rd0oc-._.js → node_modules_next_1a1kch7._.js} +1 -1
  229. package/.next/standalone/.next/server/chunks/ssr/{node_modules_next_dist_0h9llsw._.js → node_modules_next_dist_0uboya6._.js} +2 -2
  230. package/.next/standalone/.next/server/chunks/ssr/{node_modules_next_dist_11dij6w._.js → node_modules_next_dist_1d_onnt._.js} +3 -3
  231. package/.next/standalone/.next/server/chunks/ssr/{node_modules_next_dist_client_components_0inhx6q._.js → node_modules_next_dist_client_components_0wpq8j3._.js} +1 -1
  232. package/.next/standalone/.next/server/chunks/ssr/{node_modules_next_dist_client_components_builtin_forbidden_0ghu-f7.js → node_modules_next_dist_client_components_builtin_forbidden_0symwr9.js} +1 -1
  233. package/.next/standalone/.next/server/chunks/ssr/{node_modules_next_dist_client_components_builtin_unauthorized_0cjv-23.js → node_modules_next_dist_client_components_builtin_unauthorized_0l_sp0x.js} +1 -1
  234. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0-uvagv.js +4 -0
  235. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_03c7gi5.js +4 -0
  236. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_09p-8om.js +4 -0
  237. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0v-kfiu.js +4 -0
  238. package/.next/standalone/.next/server/chunks/ssr/{node_modules_next_dist_esm_build_templates_app-page_0j79~gv.js → node_modules_next_dist_esm_build_templates_app-page_0xrgzyz.js} +1 -1
  239. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_1806lsc.js +4 -0
  240. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_1j6dd-e.js +4 -0
  241. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_1sa65r-.js +4 -0
  242. package/.next/standalone/.next/server/chunks/ssr/node_modules_posthog-node_dist_entrypoints_index_node_mjs_11bnuzn._.js +3 -0
  243. package/.next/standalone/.next/server/chunks/ssr/src_hooks_1ezd2jf._.js +5 -0
  244. package/.next/standalone/.next/server/chunks/ssr/src_hooks_1tnuifj._.js +5 -0
  245. package/.next/standalone/.next/server/functions-config-manifest.json +3 -0
  246. package/.next/standalone/.next/server/instrumentation.js +1 -1
  247. package/.next/standalone/.next/server/middleware-build-manifest.js +10 -10
  248. package/.next/standalone/.next/server/middleware.js +2 -2
  249. package/.next/standalone/.next/server/next-font-manifest.js +1 -1
  250. package/.next/standalone/.next/server/next-font-manifest.json +2 -21
  251. package/.next/standalone/.next/server/pages/404.html +1 -1
  252. package/.next/standalone/.next/server/pages/500.html +1 -1
  253. package/.next/standalone/.next/server/server-reference-manifest.js +1 -1
  254. package/.next/standalone/.next/server/server-reference-manifest.json +27 -9
  255. package/.next/standalone/.next/static/chunks/{07uz2g0_38qia.js → 03fmihek9n986.js} +1 -1
  256. package/.next/standalone/.next/static/chunks/09ueq8s1as8xs.css +2 -0
  257. package/.next/standalone/.next/static/chunks/0fkntmojmibda.js +6 -0
  258. package/.next/standalone/.next/static/chunks/{11w14gnqzprir.js → 0nbmu4_n1j2-c.js} +1 -1
  259. package/.next/standalone/.next/static/chunks/0qassxjx1ef04.js +1 -0
  260. package/.next/standalone/.next/static/chunks/0zbxssxh53n-3.js +1 -0
  261. package/.next/standalone/.next/static/chunks/13f1kmjea-0md.js +2 -0
  262. package/.next/standalone/.next/static/chunks/1btx2c49fk9xt.css +1 -0
  263. package/.next/standalone/.next/static/chunks/1bxdpd036n3l9.js +41 -0
  264. package/.next/standalone/.next/static/chunks/{0bke.~atnsbeb.js → 1e0o-6kjfnwzh.js} +1 -1
  265. package/.next/standalone/.next/static/chunks/20b5bz43so-1k.js +1 -0
  266. package/.next/standalone/.next/static/chunks/2zjavpea8glet.js +1 -0
  267. package/.next/standalone/.next/static/chunks/{0d3shmwh5_nmn.js → 33u59vf_8xpd-.js} +1 -1
  268. package/.next/standalone/.next/static/chunks/{0dvhi-prcsh3~.js → 36l507r2mbf5h.js} +1 -1
  269. package/.next/standalone/.next/static/chunks/3gti1qdk5epqn.js +1 -0
  270. package/.next/standalone/.next/static/chunks/{17mubwtqwijpu.js → 3w8d8k_dca5rp.js} +1 -1
  271. package/.next/standalone/.next/static/chunks/{0bv1oyxspkpkb.js → 3y3l184vijlfg.js} +1 -1
  272. package/.next/standalone/.next/static/chunks/41jjdgqqpl7em.js +1 -0
  273. package/.next/standalone/.next/static/chunks/{turbopack-0nh.aopesgj~5.js → turbopack-00qy7zfa7m--m.js} +1 -1
  274. package/.next/standalone/SECURITY.md +73 -0
  275. package/.next/standalone/app/actions/get-audit-result.ts +24 -0
  276. package/.next/standalone/app/api/audit/_state.ts +72 -0
  277. package/.next/standalone/app/api/audit/run/route.ts +89 -0
  278. package/.next/standalone/app/api/audit/status/route.ts +23 -0
  279. package/.next/standalone/app/api/auth/login-request/route.ts +91 -0
  280. package/.next/standalone/app/api/auth/login-verify/route.ts +98 -0
  281. package/.next/standalone/app/api/auth/logout/route.ts +48 -0
  282. package/.next/standalone/app/api/auth/reminder/route.ts +213 -0
  283. package/.next/standalone/app/api/auth/status/route.ts +42 -0
  284. package/.next/standalone/app/audit/_components/audit-dashboard.tsx +364 -0
  285. package/.next/standalone/app/audit/_components/auth-dialog.tsx +401 -0
  286. package/.next/standalone/app/audit/_components/empty-state.tsx +146 -0
  287. package/.next/standalone/app/audit/_components/findings-section.tsx +135 -0
  288. package/.next/standalone/app/audit/_components/identity-section.tsx +126 -0
  289. package/.next/standalone/app/audit/_components/policies-section.tsx +194 -0
  290. package/.next/standalone/app/audit/_components/report-footer.tsx +35 -0
  291. package/.next/standalone/app/audit/_components/rerun-button.tsx +81 -0
  292. package/.next/standalone/app/audit/_components/return-section.tsx +428 -0
  293. package/.next/standalone/app/audit/_components/run-progress.tsx +120 -0
  294. package/.next/standalone/app/audit/_components/score-section.tsx +179 -0
  295. package/.next/standalone/app/audit/_components/share-dock.tsx +265 -0
  296. package/.next/standalone/app/audit/_components/share-templates.ts +67 -0
  297. package/.next/standalone/app/audit/_components/show-off-cta.tsx +135 -0
  298. package/.next/standalone/app/audit/_components/sigil.tsx +93 -0
  299. package/.next/standalone/app/audit/_components/strengths-section.tsx +57 -0
  300. package/.next/standalone/app/audit/audit-styles.css +2066 -0
  301. package/.next/standalone/app/audit/loading.tsx +24 -0
  302. package/.next/standalone/app/audit/page.tsx +53 -0
  303. package/.next/standalone/app/globals.css +570 -137
  304. package/.next/standalone/app/layout.tsx +16 -9
  305. package/.next/standalone/app/policies/hooks-client.tsx +223 -129
  306. package/.next/standalone/app/project/[name]/page.tsx +89 -39
  307. package/.next/standalone/app/projects/loading.tsx +30 -8
  308. package/.next/standalone/app/projects/page.tsx +76 -18
  309. package/.next/standalone/assets/audit/Audit Report.html +22 -0
  310. package/.next/standalone/assets/audit/Show Off Your Agent.html +22 -0
  311. package/.next/standalone/assets/audit/archetypes.jsx +277 -0
  312. package/.next/standalone/assets/audit/assets/fonts/bitcount-prop-single.woff2 +0 -0
  313. package/.next/standalone/assets/audit/audit.jsx +825 -0
  314. package/.next/standalone/assets/audit/poster-styles.css +424 -0
  315. package/.next/standalone/assets/audit/poster.jsx +247 -0
  316. package/.next/standalone/assets/audit/screenshots/poster-optimist.png +0 -0
  317. package/.next/standalone/assets/audit/screenshots/poster-scrolled.png +0 -0
  318. package/.next/standalone/assets/audit/styles.css +1225 -0
  319. package/.next/standalone/assets/audit/tweaks-panel.jsx +425 -0
  320. package/.next/standalone/assets/logos/company/icon.svg +1 -0
  321. package/.next/standalone/assets/logos/company/logo.svg +1 -0
  322. package/.next/standalone/components/navbar.tsx +154 -65
  323. package/.next/standalone/components/reach-developers.tsx +37 -9
  324. package/.next/standalone/lib/atomic-write.ts +67 -0
  325. package/.next/standalone/lib/auth/api-server-client.ts +281 -0
  326. package/.next/standalone/lib/auth/auth-store.ts +250 -0
  327. package/.next/standalone/lib/client-telemetry.ts +2 -0
  328. package/.next/standalone/lib/fetch-with-timeout.ts +42 -0
  329. package/.next/standalone/lib/share-card.ts +144 -0
  330. package/.next/standalone/lib/telemetry.ts +12 -7
  331. package/.next/standalone/node_modules/@next/env/package.json +1 -1
  332. package/.next/standalone/node_modules/next/dist/build/swc/index.js +1 -1
  333. package/.next/standalone/node_modules/next/dist/client/dev/debug-channel.js +102 -2
  334. package/.next/standalone/node_modules/next/dist/compiled/next-server/app-page-turbo-experimental.runtime.prod.js +11 -11
  335. package/.next/standalone/node_modules/next/dist/compiled/next-server/app-page-turbo.runtime.prod.js +13 -13
  336. package/.next/standalone/node_modules/next/dist/compiled/next-server/app-route-turbo.runtime.prod.js +2 -2
  337. package/.next/standalone/node_modules/next/dist/compiled/next-server/pages-turbo.runtime.prod.js +1 -1
  338. package/.next/standalone/node_modules/next/dist/lib/patch-incorrect-lockfile.js +3 -3
  339. package/.next/standalone/node_modules/next/dist/server/app-render/action-handler.js +18 -8
  340. package/.next/standalone/node_modules/next/dist/server/config-schema.js +1 -0
  341. package/.next/standalone/node_modules/next/dist/server/config.js +1 -1
  342. package/.next/standalone/node_modules/next/dist/server/dev/hot-reloader-turbopack.js +2 -2
  343. package/.next/standalone/node_modules/next/dist/server/dev/hot-reloader-webpack.js +1 -1
  344. package/.next/standalone/node_modules/next/dist/server/lib/app-info-log.js +1 -1
  345. package/.next/standalone/node_modules/next/dist/server/lib/encode-cache-tag.js +45 -0
  346. package/.next/standalone/node_modules/next/dist/server/lib/implicit-tags.js +6 -3
  347. package/.next/standalone/node_modules/next/dist/server/lib/patch-fetch.js +5 -1
  348. package/.next/standalone/node_modules/next/dist/server/lib/start-server.js +1 -1
  349. package/.next/standalone/node_modules/next/dist/server/web/spec-extension/revalidate.js +4 -3
  350. package/.next/standalone/node_modules/next/dist/server/web/spec-extension/unstable-cache.js +6 -2
  351. package/.next/standalone/node_modules/next/dist/shared/lib/errors/canary-only-config-error.js +1 -1
  352. package/.next/standalone/node_modules/next/dist/telemetry/anonymous-meta.js +1 -1
  353. package/.next/standalone/node_modules/next/dist/telemetry/events/swc-load-failure.js +1 -1
  354. package/.next/standalone/node_modules/next/dist/telemetry/events/version.js +2 -2
  355. package/.next/standalone/node_modules/next/package.json +15 -15
  356. package/.next/standalone/node_modules/react/cjs/react.development.js +1 -1
  357. package/.next/standalone/node_modules/react/cjs/react.production.js +1 -1
  358. package/.next/standalone/node_modules/react/package.json +1 -1
  359. package/.next/standalone/node_modules/react-dom/cjs/react-dom-server-legacy.browser.production.js +1 -1
  360. package/.next/standalone/node_modules/react-dom/cjs/react-dom-server-legacy.node.production.js +1 -1
  361. package/.next/standalone/node_modules/react-dom/cjs/react-dom-server.browser.production.js +3 -3
  362. package/.next/standalone/node_modules/react-dom/cjs/react-dom-server.edge.production.js +3 -3
  363. package/.next/standalone/node_modules/react-dom/cjs/react-dom-server.node.production.js +3 -3
  364. package/.next/standalone/node_modules/react-dom/cjs/react-dom.production.js +1 -1
  365. package/.next/standalone/node_modules/react-dom/package.json +2 -2
  366. package/.next/standalone/osv-scanner.toml +17 -0
  367. package/.next/standalone/package.json +8 -3
  368. package/.next/standalone/public/audit/fonts/bitcount-prop-single.woff2 +0 -0
  369. package/.next/standalone/public/icon.svg +1 -0
  370. package/.next/standalone/public/logo.svg +1 -0
  371. package/.next/standalone/server.js +1 -1
  372. package/.next/standalone/templates/bitcount-font/README.md +42 -0
  373. package/.next/standalone/templates/bitcount-font/bitcount-prop-single.woff2 +0 -0
  374. package/.next/standalone/templates/bitcount-font/bitcount.css +49 -0
  375. package/.next/standalone/templates/bitcount-font/fonts.ts.example +23 -0
  376. package/README.md +2 -1
  377. package/bin/failproofai.mjs +165 -144
  378. package/dist/cli.mjs +607 -1858
  379. package/lib/atomic-write.ts +67 -0
  380. package/lib/auth/api-server-client.ts +281 -0
  381. package/lib/auth/auth-store.ts +250 -0
  382. package/lib/client-telemetry.ts +2 -0
  383. package/lib/fetch-with-timeout.ts +42 -0
  384. package/lib/share-card.ts +144 -0
  385. package/lib/telemetry.ts +12 -7
  386. package/package.json +8 -3
  387. package/scripts/install-telemetry.mjs +4 -0
  388. package/src/audit/archetypes.ts +924 -0
  389. package/src/audit/cache.ts +21 -2
  390. package/src/audit/dashboard-cache.ts +111 -0
  391. package/src/audit/features.ts +268 -0
  392. package/src/audit/findings.ts +298 -0
  393. package/src/audit/index.ts +39 -21
  394. package/src/audit/replay.ts +29 -3
  395. package/src/audit/scoring.ts +174 -0
  396. package/src/audit/strengths.ts +138 -0
  397. package/src/audit/types.ts +24 -1
  398. package/src/auth/cli.ts +359 -0
  399. package/src/hooks/builtin-policies.ts +2 -1
  400. package/src/hooks/hook-telemetry.ts +2 -2
  401. package/src/hooks/policy-registry.ts +20 -0
  402. package/src/posthog-key.ts +9 -0
  403. package/.next/standalone/.next/server/app/icon.png/route/app-paths-manifest.json +0 -3
  404. package/.next/standalone/.next/server/app/icon.png/route.js +0 -7
  405. package/.next/standalone/.next/server/app/icon.png/route.js.nft.json +0 -1
  406. package/.next/standalone/.next/server/app/icon.png.body +0 -0
  407. package/.next/standalone/.next/server/app/icon.png.meta +0 -1
  408. package/.next/standalone/.next/server/chunks/[externals]_next_dist_0sqmaqd._.js +0 -3
  409. package/.next/standalone/.next/server/chunks/[root-of-the-server]__06.arfm._.js +0 -3
  410. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0__i0h0._.js +0 -3
  411. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0fe7_q_._.js +0 -3
  412. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0fw.e.h._.js +0 -3
  413. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0pxn0e1._.js +0 -3
  414. package/.next/standalone/.next/server/chunks/[root-of-the-server]__0xv0jh2._.js +0 -3
  415. package/.next/standalone/.next/server/chunks/_next-internal_server_app_icon_png_route_actions_12.gv.r.js +0 -3
  416. package/.next/standalone/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_0bdfoky.js +0 -3
  417. package/.next/standalone/.next/server/chunks/node_modules_posthog-node_dist_entrypoints_index_node_mjs_05pz9._._.js +0 -3
  418. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__01as125._.js +0 -3
  419. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0370~qj._.js +0 -3
  420. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__09v.ljl._.js +0 -3
  421. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0agrcb8._.js +0 -4
  422. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0b7hkr~._.js +0 -3
  423. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0ehh6vp._.js +0 -4
  424. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0g8l0tu._.js +0 -3
  425. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0j4l6hl._.js +0 -3
  426. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0k5n2kz._.js +0 -4
  427. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0lp08ll._.js +0 -3
  428. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0n0yaqw._.js +0 -4
  429. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0o21f.o._.js +0 -3
  430. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0t8juvy._.js +0 -4
  431. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0uylufv._.js +0 -4
  432. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0ymlddl._.js +0 -223
  433. package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0~03grs._.js +0 -3
  434. package/.next/standalone/.next/server/chunks/ssr/app_0cdqd9w._.js +0 -3
  435. package/.next/standalone/.next/server/chunks/ssr/app_policies_hooks-client_tsx_0q-m0y-._.js +0 -8
  436. package/.next/standalone/.next/server/chunks/ssr/app_projects_loading_tsx_13veom4._.js +0 -3
  437. package/.next/standalone/.next/server/chunks/ssr/node_modules_0ttbz1~._.js +0 -3
  438. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_06u0kr8._.js +0 -3
  439. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0a_7sdg.js +0 -4
  440. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0ef3uwk.js +0 -4
  441. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0pbja1x.js +0 -4
  442. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0r6o0i2.js +0 -4
  443. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_11y81~_.js +0 -4
  444. package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_12or2kf.js +0 -4
  445. package/.next/standalone/.next/server/chunks/ssr/node_modules_posthog-node_dist_entrypoints_index_node_mjs_0mebn66._.js +0 -3
  446. package/.next/standalone/.next/static/chunks/07kpqoo7kuckx.js +0 -6
  447. package/.next/standalone/.next/static/chunks/0azb~vy9ds_uy.js +0 -1
  448. package/.next/standalone/.next/static/chunks/0f5p9plm.aqlp.css +0 -2
  449. package/.next/standalone/.next/static/chunks/0ffvlbgzgnlw7.js +0 -2
  450. package/.next/standalone/.next/static/chunks/0spktq7xqab9h.js +0 -1
  451. package/.next/standalone/.next/static/chunks/118q3uljozd5z.js +0 -4
  452. package/.next/standalone/.next/static/chunks/12pt~2f.c1sha.js +0 -1
  453. package/.next/standalone/.next/static/media/4fa387ec64143e14-s.0.qu-9752pffj.woff2 +0 -0
  454. package/.next/standalone/.next/static/media/5ce348bf30bf5439-s.0ee55_hj9qcer.woff2 +0 -0
  455. package/.next/standalone/.next/static/media/6306c77e7c8268e4-s.0mao5jbfbduzp.woff2 +0 -0
  456. package/.next/standalone/.next/static/media/797e433ab948586e-s.p.09zddjkbdep5a.woff2 +0 -0
  457. package/.next/standalone/.next/static/media/7d817b4c03b0c5f1-s.0uzt.a6d44yda.woff2 +0 -0
  458. package/.next/standalone/.next/static/media/bbc41e54d2fcbd21-s.0mvwgmnhv29no.woff2 +0 -0
  459. package/.next/standalone/.next/static/media/icon.0a.gigb3_x5pd.png +0 -0
  460. package/.next/standalone/app/icon.png +0 -0
  461. package/src/audit/telemetry.ts +0 -113
  462. /package/.next/standalone/.next/server/app/{icon.png → api/audit/run}/route/build-manifest.json +0 -0
  463. /package/.next/standalone/.next/server/app/{icon.png → api/audit/run}/route.js.map +0 -0
  464. /package/.next/standalone/.next/static/chunks/{03~yq9q893hmn.js → 0cz1d0mv5g_q7.js} +0 -0
  465. /package/.next/standalone/.next/static/chunks/{0a40sy4tk8ioe.js → 0wwt5o04i4zwh.js} +0 -0
  466. /package/.next/standalone/.next/static/chunks/{0n1n67imq.udf.js → 1__i9af9g78vd.js} +0 -0
  467. /package/.next/standalone/.next/static/chunks/{0w6fzf.07a24u.js → 2so39wg7mjbi7.js} +0 -0
  468. /package/.next/standalone/.next/static/chunks/{0xbo5nl6w4lka.js → 2wbuxnsvux4di.js} +0 -0
  469. /package/.next/standalone/.next/static/chunks/{0_s0luks5tay-.js → 35fgpd_feci6x.js} +0 -0
  470. /package/.next/standalone/.next/static/chunks/{15fklyav5py5m.js → 3xpjn3cdgm-7m.js} +0 -0
  471. /package/.next/standalone/.next/static/chunks/{17.b3suj8zjjj.js → 4448_qq7bd963.js} +0 -0
  472. /package/.next/standalone/.next/static/{tGVQM5SE3NvbVu0gbAJm7 → t4nu8RTRp3Z2srol-9pVb}/_buildManifest.js +0 -0
  473. /package/.next/standalone/.next/static/{tGVQM5SE3NvbVu0gbAJm7 → t4nu8RTRp3Z2srol-9pVb}/_clientMiddlewareManifest.js +0 -0
  474. /package/.next/standalone/.next/static/{tGVQM5SE3NvbVu0gbAJm7 → t4nu8RTRp3Z2srol-9pVb}/_ssgManifest.js +0 -0
@@ -0,0 +1,2066 @@
1
+ /* ============================================================
2
+ failproof_ai — audit-page-specific styles
3
+ Brutalist pixel-craft, /audit-only widgets.
4
+ Site-wide tokens, fonts, body atmosphere, .app-header / .btn /
5
+ .tab / .section / .panel / .report all moved to globals.css
6
+ so they apply everywhere (and no longer leak when navigating
7
+ away from /audit back to /policies or /projects).
8
+ ============================================================ */
9
+
10
+ /* legacy scanline overlay used by audit-dashboard */
11
+ .scanline-overlay {
12
+ position: fixed; inset: 0; pointer-events: none; z-index: 9999;
13
+ background: repeating-linear-gradient(to bottom,
14
+ rgba(255,255,255,0) 0, rgba(255,255,255,0) 2px,
15
+ rgba(255,255,255,0.018) 2px, rgba(255,255,255,0.018) 3px);
16
+ mix-blend-mode: overlay;
17
+ }
18
+
19
+ /* ───────────────────────── 00 EMPTY + RUNNING (full-page states) ───────────────────────── */
20
+
21
+ .empty-section, .running-section { padding-top: 80px; padding-bottom: 96px; }
22
+
23
+ .empty-panel, .running-panel {
24
+ padding: 48px 56px;
25
+ display: flex; flex-direction: column;
26
+ background:
27
+ repeating-linear-gradient(0deg, rgba(228,88,125,0.025) 0 1px, transparent 1px 16px),
28
+ repeating-linear-gradient(90deg, rgba(102,209,181,0.025) 0 1px, transparent 1px 16px),
29
+ var(--bg-2);
30
+ }
31
+
32
+ .empty-glyph { align-self: center; text-align: center; margin-bottom: 28px; }
33
+ .empty-glyph-grid {
34
+ display: grid;
35
+ grid-template-columns: repeat(6, 14px);
36
+ grid-template-rows: repeat(6, 14px);
37
+ gap: 3px;
38
+ padding: 16px;
39
+ border: 1px solid var(--line-2);
40
+ background: var(--bg);
41
+ margin: 0 auto 14px;
42
+ box-shadow: 6px 6px 0 0 var(--accent-pink-shadow);
43
+ }
44
+ .empty-glyph-grid .px { background: transparent; }
45
+ .empty-glyph-grid .px.on { background: var(--accent-pink); }
46
+ .empty-glyph-label {
47
+ font-family: var(--font-mono); font-size: 11px;
48
+ letter-spacing: 0.22em; text-transform: uppercase;
49
+ color: var(--dim);
50
+ }
51
+
52
+ .empty-headline {
53
+ font-family: var(--font-display);
54
+ font-size: clamp(32px, 4.6vw, 48px);
55
+ letter-spacing: 0.1em; line-height: 1.05;
56
+ text-transform: lowercase;
57
+ color: var(--ink);
58
+ text-shadow: 3px 3px 0 var(--accent-pink-shadow);
59
+ margin: 0 0 16px;
60
+ text-wrap: balance;
61
+ text-align: center;
62
+ }
63
+ .empty-sub {
64
+ font-family: var(--font-mono); font-size: 14px;
65
+ line-height: 1.65; color: var(--ink-2);
66
+ max-width: 580px;
67
+ margin: 0 auto 32px;
68
+ text-align: center;
69
+ }
70
+
71
+ .empty-actions {
72
+ display: flex; flex-direction: column; align-items: center;
73
+ gap: 12px;
74
+ }
75
+ .empty-cta {
76
+ padding: 12px 24px;
77
+ font-size: 14px;
78
+ letter-spacing: 0.08em;
79
+ text-decoration: none;
80
+ }
81
+ .empty-meta {
82
+ font-family: var(--font-mono); font-size: 11px;
83
+ letter-spacing: 0.15em; text-transform: uppercase;
84
+ color: var(--dim);
85
+ }
86
+
87
+ .running-panel { padding: 36px 40px; }
88
+ .running-header {
89
+ display: flex; align-items: center; gap: 10px;
90
+ padding-bottom: 18px;
91
+ border-bottom: 1px dashed var(--line);
92
+ margin-bottom: 22px;
93
+ font-family: var(--font-mono); font-size: 13px;
94
+ }
95
+ .running-prompt { color: var(--accent-green); }
96
+ .running-cmd { color: var(--ink); letter-spacing: 0.02em; }
97
+ .running-cursor {
98
+ color: var(--accent-pink);
99
+ margin-left: 4px;
100
+ animation: cursor-blink 900ms steps(2, end) infinite;
101
+ }
102
+ @keyframes cursor-blink { 50% { opacity: 0; } }
103
+
104
+ .running-stages {
105
+ list-style: none; padding: 0; margin: 0 0 28px;
106
+ display: flex; flex-direction: column;
107
+ }
108
+ .running-stage {
109
+ display: grid;
110
+ grid-template-columns: 28px 1fr auto;
111
+ gap: 14px; align-items: start;
112
+ padding: 12px 0;
113
+ border-bottom: 1px dashed var(--line);
114
+ font-family: var(--font-mono);
115
+ }
116
+ .running-stage:last-child { border-bottom: none; }
117
+ .running-marker {
118
+ font-family: var(--font-mono); font-size: 12px;
119
+ letter-spacing: -1px;
120
+ margin-top: 1px;
121
+ }
122
+ .running-stage.queued { color: var(--dim); }
123
+ .running-stage.queued .running-marker { color: var(--line-2); }
124
+ .running-stage.active { color: var(--ink); }
125
+ .running-stage.active .running-marker { color: var(--accent-pink); }
126
+ .running-stage.done { color: var(--ink-2); }
127
+ .running-stage.done .running-marker { color: var(--accent-green); }
128
+ .running-stage.done .running-stage-label {
129
+ text-decoration: line-through;
130
+ text-decoration-color: var(--line-2);
131
+ }
132
+ .running-stage-label { font-size: 13px; letter-spacing: 0.04em; }
133
+ .running-stage-detail {
134
+ font-size: 11px; color: var(--ink-2);
135
+ letter-spacing: 0.02em;
136
+ margin-top: 4px;
137
+ }
138
+ .running-stage-spin {
139
+ font-family: var(--font-mono); font-size: 16px;
140
+ color: var(--accent-pink);
141
+ align-self: center;
142
+ animation: spin-step 700ms steps(4, end) infinite;
143
+ }
144
+ @keyframes spin-step { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }
145
+
146
+ .running-bar-label {
147
+ display: flex; justify-content: space-between;
148
+ font-family: var(--font-mono); font-size: 10px;
149
+ letter-spacing: 0.22em; text-transform: uppercase;
150
+ color: var(--ink-2);
151
+ margin-bottom: 8px;
152
+ }
153
+ .running-bar-track {
154
+ position: relative;
155
+ height: 6px; background: var(--bg);
156
+ border: 1px solid var(--line);
157
+ overflow: hidden;
158
+ }
159
+ .running-bar-fill {
160
+ position: relative;
161
+ height: 100%;
162
+ background: linear-gradient(90deg, var(--accent-pink) 0%, #e89aaf 100%);
163
+ transition: width 600ms cubic-bezier(0.22, 1, 0.36, 1);
164
+ }
165
+ .running-bar-fill::after {
166
+ content: "";
167
+ position: absolute; inset: 0;
168
+ background: linear-gradient(
169
+ 90deg,
170
+ transparent 0%, transparent 40%,
171
+ rgba(255,255,255,0.35) 50%,
172
+ transparent 60%, transparent 100%
173
+ );
174
+ animation: bar-shine 1600ms linear infinite;
175
+ }
176
+ @keyframes bar-shine {
177
+ from { transform: translateX(-100%); }
178
+ to { transform: translateX(100%); }
179
+ }
180
+
181
+ .running-foot {
182
+ margin-top: 22px;
183
+ font-family: var(--font-mono); font-size: 11px;
184
+ letter-spacing: 0.05em;
185
+ color: var(--dim);
186
+ text-align: center;
187
+ }
188
+
189
+ @media (max-width: 720px) {
190
+ .empty-panel, .running-panel { padding: 32px 24px; }
191
+ }
192
+
193
+ /* ───────────────────────── audit page shell ───────────────────────── */
194
+
195
+ /* the audit page intentionally runs narrower than the global .report — the
196
+ archetype hero, findings cards, and score-share card are tuned for a
197
+ ~1400px-max layout where the headline line measure stays "billboard"
198
+ tight. On a 2400px+ monitor we still want to break out of the 1180px
199
+ feel that used to leave too much black on both flanks; clamp up to
200
+ 1480px and let `.archetype-frame` cap itself further so the hero doesn't
201
+ stretch past its compositional break-point. */
202
+ .report {
203
+ width: 100%;
204
+ max-width: clamp(720px, 92vw, 1480px);
205
+ margin: 0 auto;
206
+ padding: 0 clamp(20px, 3vw, 48px);
207
+ }
208
+
209
+ .section {
210
+ padding: 64px 0;
211
+ border-bottom: 1px solid var(--line);
212
+ position: relative;
213
+ }
214
+ .section:last-child { border-bottom: none; }
215
+
216
+ .section-mast {
217
+ display: flex; align-items: baseline; justify-content: space-between;
218
+ gap: 24px; margin-bottom: 28px; flex-wrap: wrap;
219
+ }
220
+ .section-label {
221
+ font-family: var(--font-mono);
222
+ font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
223
+ color: var(--accent-green);
224
+ display: inline-flex; align-items: baseline; gap: 10px;
225
+ }
226
+ .section-label .glyph { color: var(--accent-pink); letter-spacing: -2px; }
227
+ .section-meta {
228
+ font-family: var(--font-mono);
229
+ font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
230
+ color: var(--dim);
231
+ }
232
+ .section-meta .g { color: var(--accent-green); }
233
+ .section-meta .p { color: var(--accent-pink); }
234
+ .section-h {
235
+ font-family: var(--font-display);
236
+ font-size: clamp(28px, 4vw, 44px);
237
+ line-height: 1.05; letter-spacing: 0.11em;
238
+ font-weight: 400; color: var(--ink);
239
+ margin: 0 0 18px;
240
+ text-transform: lowercase;
241
+ text-wrap: balance;
242
+ }
243
+
244
+ /* ───────────────────────── 01 IDENTITY (the hero moment) ───────────────────────── */
245
+
246
+ .identity {
247
+ padding: 80px 0 96px;
248
+ position: relative;
249
+ }
250
+
251
+ .archetype-frame {
252
+ position: relative;
253
+ /* hero composition was tuned for ~1180px max — let it grow a little but
254
+ don't let the giant Bitcount name turn into a billboard on 4K */
255
+ max-width: 1320px;
256
+ margin-left: auto;
257
+ margin-right: auto;
258
+ border: 1px solid var(--line-2);
259
+ background:
260
+ repeating-linear-gradient(0deg, rgba(228,88,125,0.025) 0 1px, transparent 1px 16px),
261
+ repeating-linear-gradient(90deg, rgba(102,209,181,0.025) 0 1px, transparent 1px 16px),
262
+ var(--bg-2);
263
+ padding: 56px 56px 48px;
264
+ box-shadow: 8px 8px 0 0 var(--accent-pink-shadow);
265
+ }
266
+ .archetype-frame .corner {
267
+ position: absolute; font-family: var(--font-mono); font-size: 11px;
268
+ color: var(--accent-pink); opacity: 0.6; letter-spacing: 0.1em;
269
+ }
270
+ .archetype-frame .corner.tl { top: 8px; left: 12px; }
271
+ .archetype-frame .corner.tr { top: 8px; right: 12px; }
272
+ .archetype-frame .corner.bl { bottom: 8px; left: 12px; }
273
+ .archetype-frame .corner.br { bottom: 8px; right: 12px; }
274
+
275
+ .arch-mast {
276
+ display: flex; align-items: center; justify-content: space-between;
277
+ gap: 24px; margin-bottom: 32px;
278
+ border-bottom: 1px dashed var(--line);
279
+ padding-bottom: 22px;
280
+ flex-wrap: wrap;
281
+ }
282
+ .arch-mast-left {
283
+ display: flex; flex-direction: column; gap: 8px;
284
+ }
285
+ .arch-eyebrow {
286
+ font-family: var(--font-mono); font-size: 11px;
287
+ letter-spacing: 0.22em; text-transform: uppercase;
288
+ color: var(--accent-green);
289
+ }
290
+ .arch-eyebrow .ix { color: var(--accent-pink); }
291
+ .arch-target {
292
+ font-family: var(--font-mono); font-size: 12px;
293
+ color: var(--ink-2); letter-spacing: 0.05em;
294
+ }
295
+ .arch-target .slash { color: var(--dim); margin: 0 6px; }
296
+ .arch-target .live {
297
+ margin-left: 10px; color: var(--accent-green);
298
+ font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
299
+ display: inline-flex; align-items: center; gap: 6px;
300
+ }
301
+ .arch-target .dot-live {
302
+ width: 7px; height: 7px; background: var(--accent-green);
303
+ display: inline-block;
304
+ animation: pulseDot 1.6s ease-in-out infinite;
305
+ box-shadow: 0 0 8px rgba(102,209,181,0.6);
306
+ }
307
+ @keyframes pulseDot {
308
+ 0%, 100% { opacity: 1; transform: scale(1); }
309
+ 50% { opacity: 0.4; transform: scale(0.85); }
310
+ }
311
+ @media (prefers-reduced-motion: reduce) {
312
+ .arch-target .dot-live { animation: none; }
313
+ }
314
+ .arch-counter {
315
+ font-family: var(--font-mono); font-size: 11px;
316
+ letter-spacing: 0.18em; text-transform: uppercase; color: var(--dim);
317
+ text-align: right;
318
+ }
319
+ .arch-counter .of { color: var(--ink-2); }
320
+
321
+ .arch-body {
322
+ display: grid;
323
+ grid-template-columns: 1.7fr 1fr;
324
+ gap: 56px;
325
+ align-items: center;
326
+ }
327
+
328
+ .arch-name {
329
+ font-family: var(--font-display);
330
+ font-size: clamp(56px, 10vw, 124px);
331
+ line-height: 0.95;
332
+ letter-spacing: 0.08em;
333
+ margin: 0 0 16px;
334
+ text-transform: lowercase;
335
+ color: var(--ink);
336
+ text-wrap: balance;
337
+ /* hard-offset stamp */
338
+ text-shadow: 4px 4px 0 var(--accent-pink-shadow);
339
+ }
340
+ .arch-tagline {
341
+ font-family: var(--font-mono); font-size: 16px;
342
+ line-height: 1.5; color: var(--ink-2);
343
+ max-width: 580px; margin: 0 0 28px;
344
+ text-wrap: pretty;
345
+ }
346
+ .arch-desc {
347
+ font-family: var(--font-mono); font-size: 13px;
348
+ line-height: 1.65; color: var(--ink);
349
+ max-width: 580px;
350
+ margin: 0 0 28px;
351
+ text-wrap: pretty;
352
+ }
353
+
354
+ .arch-secondary {
355
+ display: inline-flex; align-items: center; gap: 10px;
356
+ padding: 6px 12px;
357
+ border: 1px dashed var(--line-2);
358
+ font-family: var(--font-mono); font-size: 11px;
359
+ letter-spacing: 0.15em; text-transform: uppercase;
360
+ color: var(--ink-2);
361
+ margin-bottom: 24px;
362
+ }
363
+ .arch-secondary .with { color: var(--dim); }
364
+ .arch-secondary .name { color: var(--accent-pink); }
365
+
366
+ /* keyword strip — replaces the wordy description */
367
+ .arch-keywords {
368
+ display: flex;
369
+ align-items: baseline;
370
+ flex-wrap: wrap;
371
+ gap: 16px;
372
+ padding: 18px 0 4px;
373
+ font-family: var(--font-display);
374
+ font-size: clamp(20px, 2.4vw, 28px);
375
+ letter-spacing: 0.11em;
376
+ text-transform: lowercase;
377
+ line-height: 1.1;
378
+ }
379
+ .arch-keywords .kw {
380
+ color: var(--ink);
381
+ }
382
+ .arch-keywords .kw:nth-child(1) { color: var(--accent-green); }
383
+ .arch-keywords .kw:nth-child(3) { color: var(--ink); }
384
+ .arch-keywords .kw:nth-child(5) { color: var(--accent-pink); }
385
+ .arch-keywords .kw-sep {
386
+ color: var(--dim);
387
+ font-family: var(--font-mono);
388
+ font-size: 18px;
389
+ letter-spacing: 0;
390
+ }
391
+
392
+ .signature-block {
393
+ background: var(--bg);
394
+ border: 1px solid var(--line);
395
+ padding: 18px 20px;
396
+ font-family: var(--font-mono); font-size: 13px;
397
+ line-height: 1.75;
398
+ white-space: pre;
399
+ overflow-x: auto;
400
+ max-width: 580px;
401
+ position: relative;
402
+ }
403
+ .signature-block::before {
404
+ content: ""; position: absolute; top: -1px; left: -1px;
405
+ width: 8px; height: 8px;
406
+ border-top: 1px solid var(--accent-pink);
407
+ border-left: 1px solid var(--accent-pink);
408
+ }
409
+ .signature-block::after {
410
+ content: ""; position: absolute; bottom: -1px; right: -1px;
411
+ width: 8px; height: 8px;
412
+ border-bottom: 1px solid var(--accent-pink);
413
+ border-right: 1px solid var(--accent-pink);
414
+ }
415
+ .sig-line { color: var(--ink); display: block; }
416
+ .sig-line .arrow { color: var(--accent-green); margin-right: 6px; }
417
+ .sig-line .comment { color: var(--dim); }
418
+ .sig-line .err { color: var(--accent-pink); }
419
+
420
+ .arch-meta-grid {
421
+ display: grid;
422
+ grid-template-columns: 1fr 1fr;
423
+ gap: 24px;
424
+ margin-top: 28px;
425
+ border-top: 1px dashed var(--line);
426
+ padding-top: 22px;
427
+ }
428
+ .arch-meta-item .label {
429
+ display: block;
430
+ font-family: var(--font-mono); font-size: 10px;
431
+ letter-spacing: 0.22em; text-transform: uppercase;
432
+ color: var(--accent-green);
433
+ margin-bottom: 8px;
434
+ }
435
+ .arch-meta-item .label.p { color: var(--accent-pink); }
436
+ .arch-meta-item .body {
437
+ font-family: var(--font-mono); font-size: 12px;
438
+ color: var(--ink-2); line-height: 1.55;
439
+ }
440
+
441
+ .arch-closing {
442
+ margin-top: 28px;
443
+ font-family: var(--font-display);
444
+ font-size: 22px; letter-spacing: 0.11em;
445
+ color: var(--accent-pink);
446
+ text-transform: lowercase;
447
+ border-top: 1px dashed var(--line);
448
+ padding-top: 22px;
449
+ }
450
+
451
+ /* ───────────────────────── sigil — brutalist instrument plate ─────────────
452
+ The audit hero's central image. Was a bare 16px-cell pixel grid that
453
+ felt visually underweight next to the 124px Bitcount archetype name
454
+ and underdesigned compared to the dashed-frame panels everywhere else.
455
+
456
+ Treatment: an "instrument card" — register crosshairs at corners, header
457
+ strip with index + 8×8 coordinate, the grid on a dashed inner frame
458
+ with 20px cells, footer strip with the archetype slug, and a stacked
459
+ pink + black hard-offset shadow for depth.
460
+
461
+ The `data-bare` variant (used by the ShowOff CTA via `hideLabel`)
462
+ skips the plate and renders a bare grid so the showoff card can scale
463
+ the sigil down independently and the html2canvas poster export doesn't
464
+ need to capture the new plate chrome. */
465
+
466
+ .sigil-wrap {
467
+ display: flex; flex-direction: column; align-items: center;
468
+ justify-self: center;
469
+ }
470
+
471
+ .sigil-plate {
472
+ position: relative;
473
+ padding: 18px 22px;
474
+ background:
475
+ /* faint pink+green gridlines — same recipe as `.archetype-frame` so the
476
+ sigil reads as a smaller specimen of the same instrument family */
477
+ repeating-linear-gradient(0deg, rgba(228,88,125,0.04) 0 1px, transparent 1px 12px),
478
+ repeating-linear-gradient(90deg, rgba(102,209,181,0.04) 0 1px, transparent 1px 12px),
479
+ var(--bg);
480
+ border: 1px solid var(--line-2);
481
+ /* stacked hard-offsets: pink at the front, black behind for depth */
482
+ box-shadow:
483
+ 8px 8px 0 0 var(--accent-pink-shadow),
484
+ 16px 16px 0 0 rgba(0, 0, 0, 0.55);
485
+ }
486
+
487
+ /* register crosshair marks at the four corners — CSS-only "+" rendered
488
+ from two 1px bars so they stay pixel-crisp at any zoom */
489
+ .sigil-mark {
490
+ position: absolute;
491
+ width: 10px; height: 10px;
492
+ color: var(--accent-pink);
493
+ opacity: 0.75;
494
+ pointer-events: none;
495
+ }
496
+ .sigil-mark::before,
497
+ .sigil-mark::after {
498
+ content: "";
499
+ position: absolute;
500
+ background: currentColor;
501
+ }
502
+ .sigil-mark::before { top: 50%; left: 0; right: 0; height: 1px; }
503
+ .sigil-mark::after { left: 50%; top: 0; bottom: 0; width: 1px; }
504
+ .sigil-mark.tl { top: 6px; left: 6px; }
505
+ .sigil-mark.tr { top: 6px; right: 6px; }
506
+ .sigil-mark.bl { bottom: 6px; left: 6px; }
507
+ .sigil-mark.br { bottom: 6px; right: 6px; }
508
+
509
+ /* the header (top) and footer (bottom) strips of the plate */
510
+ .sigil-strip {
511
+ display: flex; justify-content: space-between; align-items: baseline;
512
+ font-family: var(--font-mono); font-size: 10px;
513
+ letter-spacing: 0.22em; text-transform: uppercase;
514
+ color: var(--dim);
515
+ }
516
+ .sigil-strip--top {
517
+ padding-bottom: 10px;
518
+ margin-bottom: 14px;
519
+ border-bottom: 1px dashed var(--line);
520
+ }
521
+ .sigil-strip--bot {
522
+ padding-top: 10px;
523
+ margin-top: 14px;
524
+ border-top: 1px dashed var(--line);
525
+ }
526
+ .sigil-ix { color: var(--accent-pink); }
527
+ .sigil-coord { color: var(--dim); }
528
+ .sigil-strip-key { color: var(--dim); }
529
+ .sigil-strip-val { color: var(--accent-green); }
530
+
531
+ /* the actual 8×8 grid — bumped from 16px → 20px cells so the sigil
532
+ carries enough visual weight to sit next to the archetype name */
533
+ .sigil {
534
+ display: grid;
535
+ grid-template-columns: repeat(8, 20px);
536
+ grid-template-rows: repeat(8, 20px);
537
+ gap: 2px;
538
+ padding: 12px;
539
+ background: var(--bg-2);
540
+ border: 1px dashed var(--line);
541
+ margin: 0 auto;
542
+ }
543
+ /* When the sigil is rendered bare (ShowOff path), restore the original
544
+ single-shadow look so the showoff card stays compositionally what it
545
+ was before the plate landed. */
546
+ .sigil-wrap[data-bare="true"] .sigil {
547
+ background: var(--bg);
548
+ border: 1px solid var(--line-2);
549
+ box-shadow: 6px 6px 0 0 var(--accent-pink-shadow);
550
+ }
551
+
552
+ .sigil .px {
553
+ background: transparent;
554
+ /* diagonal fade-in: cells light up along an (x+y) wave starting from
555
+ the top-left when the hero first paints. Total animation ≈ 600ms. */
556
+ opacity: 0;
557
+ animation: sigil-cell-in 280ms cubic-bezier(0.22, 1, 0.36, 1) forwards;
558
+ animation-delay: calc((var(--cx, 0) + var(--cy, 0)) * 22ms);
559
+ }
560
+ .sigil .px.on { background: var(--ink); }
561
+ .sigil .px.p {
562
+ background: var(--accent-pink);
563
+ /* subtle inner glow on accent cells so they pop without breaking pixel-craft */
564
+ box-shadow: 0 0 4px rgba(228, 88, 125, 0.45);
565
+ }
566
+ .sigil .px.g {
567
+ background: var(--accent-green);
568
+ box-shadow: 0 0 4px rgba(102, 209, 181, 0.35);
569
+ }
570
+ .sigil .px.d { background: var(--dim); }
571
+
572
+ @keyframes sigil-cell-in {
573
+ from { opacity: 0; transform: scale(0.4); }
574
+ to { opacity: 1; transform: scale(1); }
575
+ }
576
+
577
+ @media (prefers-reduced-motion: reduce) {
578
+ .sigil .px {
579
+ animation: none;
580
+ opacity: 1;
581
+ transform: none;
582
+ }
583
+ }
584
+
585
+ /* ───────────── poster capture mode (applied during html2canvas) ─────────────
586
+ The live layout uses clamp()/vw font sizes, soft grid columns, and a
587
+ stamp text-shadow. html2canvas does NOT support clamp() or text-shadow
588
+ reliably — it picks a fallback that misaligns metrics and the giant
589
+ archetype name ends up overlapping the tagline + sigil column.
590
+
591
+ `.capturing` is added by show-off-cta.tsx right before capture and
592
+ removed in the finally block. It locks every viewport-relative size to
593
+ an absolute value tuned for the ~1100px capture width, fixes the grid
594
+ columns, and clears the stamp shadow + box shadow that html2canvas
595
+ would otherwise crop. */
596
+ .archetype-frame.capturing {
597
+ min-width: 1080px;
598
+ max-width: 1180px;
599
+ padding: 52px 52px 44px;
600
+ box-shadow: none;
601
+ }
602
+ .archetype-frame.capturing .arch-name {
603
+ font-size: 88px;
604
+ line-height: 1;
605
+ margin: 0 0 24px;
606
+ text-shadow: none;
607
+ letter-spacing: 0.06em;
608
+ }
609
+ .archetype-frame.capturing .arch-tagline {
610
+ font-size: 16px;
611
+ max-width: 560px;
612
+ margin: 0 0 32px;
613
+ }
614
+ .archetype-frame.capturing .arch-secondary {
615
+ margin-bottom: 32px;
616
+ }
617
+ .archetype-frame.capturing .arch-keywords {
618
+ font-size: 24px;
619
+ letter-spacing: 0.09em;
620
+ padding: 16px 0 12px;
621
+ gap: 14px;
622
+ max-width: 560px;
623
+ }
624
+ .archetype-frame.capturing .arch-body {
625
+ grid-template-columns: minmax(0, 1.6fr) minmax(220px, 1fr);
626
+ gap: 56px;
627
+ align-items: start;
628
+ }
629
+ .archetype-frame.capturing .arch-meta-grid {
630
+ margin-top: 32px;
631
+ padding-top: 26px;
632
+ gap: 28px;
633
+ }
634
+ .archetype-frame.capturing .arch-closing {
635
+ font-size: 22px;
636
+ margin-top: 32px;
637
+ padding-top: 26px;
638
+ }
639
+ .archetype-frame.capturing .sigil-wrap {
640
+ position: static;
641
+ align-self: center;
642
+ justify-self: center;
643
+ padding-top: 0;
644
+ }
645
+ /* html2canvas renders stacked box-shadows unreliably and won't run our
646
+ sigil-cell-in animation. Collapse to a single hard offset on the plate
647
+ and force every cell to its final state for the capture. */
648
+ .archetype-frame.capturing .sigil-plate {
649
+ box-shadow: 8px 8px 0 0 var(--accent-pink-shadow);
650
+ }
651
+ .archetype-frame.capturing .sigil { box-shadow: none; }
652
+ .archetype-frame.capturing .sigil .px {
653
+ animation: none;
654
+ opacity: 1;
655
+ transform: none;
656
+ }
657
+
658
+ /* ──────────────── identity share buttons (chunky CTAs) ────────────────
659
+ Three branded buttons that sit below the archetype card. Each leads
660
+ with a platform mark tile (𝕏 / in / ↓), then a small "share on" / "save"
661
+ eyebrow above the platform label, then a trailing arrow. The buttons
662
+ read as armed at rest via a 2px pink right-edge stroke; on hover the
663
+ stroke fills the full border and a hard-offset pink shadow appears.
664
+ On press they translate (2px, 2px) and the shadow collapses — matches
665
+ the .btn-press motion language used elsewhere.
666
+
667
+ The shared `.share-btn` class is also used by the floating ShareDock so
668
+ the visual rhythm carries between surfaces. */
669
+
670
+ .identity-share-grid {
671
+ display: grid;
672
+ grid-template-columns: repeat(3, 1fr);
673
+ gap: 12px;
674
+ margin-top: 22px;
675
+ padding-top: 18px;
676
+ border-top: 1px dashed var(--line);
677
+ }
678
+ @media (max-width: 720px) {
679
+ .identity-share-grid { grid-template-columns: 1fr; }
680
+ }
681
+
682
+ .share-btn {
683
+ position: relative;
684
+ display: grid;
685
+ grid-template-columns: 44px 1fr auto;
686
+ align-items: center;
687
+ gap: 14px;
688
+ padding: 12px 18px;
689
+ background: var(--bg);
690
+ border: 1px solid var(--line-2);
691
+ /* pink right-edge stroke at rest — reads as armed */
692
+ border-right: 2px solid var(--accent-pink-soft);
693
+ color: var(--ink);
694
+ font-family: var(--font-mono);
695
+ text-align: left;
696
+ cursor: pointer;
697
+ transition:
698
+ border-color 160ms cubic-bezier(0.22, 1, 0.36, 1),
699
+ background-color 160ms cubic-bezier(0.22, 1, 0.36, 1),
700
+ box-shadow 160ms cubic-bezier(0.22, 1, 0.36, 1),
701
+ transform 160ms cubic-bezier(0.22, 1, 0.36, 1);
702
+ }
703
+ .share-btn:hover {
704
+ border-color: var(--accent-pink);
705
+ background: var(--accent-pink-bg);
706
+ box-shadow: 4px 4px 0 0 var(--accent-pink-shadow);
707
+ transform: translate(-1px, -1px);
708
+ }
709
+ .share-btn:active {
710
+ box-shadow: 0 0 0 0 var(--accent-pink-shadow);
711
+ transform: translate(2px, 2px);
712
+ }
713
+ .share-btn:disabled {
714
+ opacity: 0.55;
715
+ cursor: not-allowed;
716
+ border-right-color: var(--line);
717
+ }
718
+ .share-btn:disabled:hover {
719
+ background: var(--bg);
720
+ border-color: var(--line-2);
721
+ border-right-color: var(--line);
722
+ box-shadow: none;
723
+ transform: none;
724
+ }
725
+
726
+ .share-btn-mark {
727
+ display: grid; place-items: center;
728
+ width: 44px; height: 44px;
729
+ font-family: var(--font-mono);
730
+ font-size: 22px;
731
+ font-weight: 700;
732
+ line-height: 1;
733
+ border: 1px solid var(--line-2);
734
+ /* corner-crosshair adornment — matches the sigil-plate's register marks */
735
+ background:
736
+ linear-gradient(to right, var(--accent-pink) 0 6px, transparent 6px) top left/100% 1px no-repeat,
737
+ linear-gradient(to bottom, var(--accent-pink) 0 6px, transparent 6px) top left/1px 100% no-repeat,
738
+ linear-gradient(to left, var(--accent-pink) 0 6px, transparent 6px) bottom right/100% 1px no-repeat,
739
+ linear-gradient(to top, var(--accent-pink) 0 6px, transparent 6px) bottom right/1px 100% no-repeat,
740
+ var(--bg-2);
741
+ color: var(--ink);
742
+ }
743
+ .share-btn-mark--x { color: #ffffff; background-color: #000000; }
744
+ .share-btn-mark--li {
745
+ color: #ffffff;
746
+ background-color: #0a66c2;
747
+ /* override the pink-crosshair gradients so the LinkedIn blue tile reads cleanly */
748
+ background-image: none;
749
+ }
750
+ .share-btn-mark--dl { color: var(--accent-pink); }
751
+
752
+ .share-btn-body {
753
+ display: flex; flex-direction: column;
754
+ gap: 2px; min-width: 0;
755
+ }
756
+ .share-btn-eyebrow {
757
+ font-size: 10px;
758
+ letter-spacing: 0.22em;
759
+ text-transform: uppercase;
760
+ color: var(--accent-green);
761
+ }
762
+ .share-btn-label {
763
+ font-size: 13px;
764
+ letter-spacing: 0.05em;
765
+ color: var(--ink);
766
+ font-weight: 500;
767
+ /* avoid spilling on long localized labels */
768
+ overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
769
+ }
770
+ .share-btn-arrow {
771
+ font-family: var(--font-mono);
772
+ font-size: 18px;
773
+ color: var(--accent-pink);
774
+ opacity: 0.7;
775
+ transition: opacity 160ms cubic-bezier(0.22, 1, 0.36, 1), transform 160ms cubic-bezier(0.22, 1, 0.36, 1);
776
+ }
777
+ .share-btn:hover .share-btn-arrow { opacity: 1; transform: translateX(2px); }
778
+
779
+ @media (prefers-reduced-motion: reduce) {
780
+ .share-btn, .share-btn-arrow { transition: none; }
781
+ .share-btn:hover { transform: none; }
782
+ }
783
+
784
+ /* hide during html2canvas capture so the buttons don't render into the poster */
785
+ .archetype-frame.capturing .identity-share-grid { display: none; }
786
+
787
+ /* ───────────────────────── 02 STRENGTHS ───────────────────────── */
788
+
789
+ .strengths-grid {
790
+ display: grid; gap: 0;
791
+ border: 1px solid var(--line-2);
792
+ background: var(--bg-2);
793
+ }
794
+ .strength-row {
795
+ display: grid;
796
+ grid-template-columns: 56px 1fr auto;
797
+ align-items: start;
798
+ gap: 16px;
799
+ padding: 22px 24px;
800
+ border-bottom: 1px solid var(--line);
801
+ transition: background 120ms;
802
+ }
803
+ .strength-row:last-child { border-bottom: none; }
804
+ .strength-row:hover { background: rgba(102, 209, 181, 0.03); }
805
+ .strength-check {
806
+ width: 32px; height: 32px;
807
+ border: 1px solid var(--accent-green);
808
+ background: var(--accent-green-bg);
809
+ color: var(--accent-green);
810
+ display: grid; place-items: center;
811
+ font-family: var(--font-mono); font-weight: 600;
812
+ font-size: 14px;
813
+ }
814
+ .strength-body {
815
+ display: flex; flex-direction: column; gap: 6px;
816
+ }
817
+ .strength-headline {
818
+ font-family: var(--font-mono); font-size: 14px;
819
+ color: var(--ink); letter-spacing: 0.01em;
820
+ font-weight: 500;
821
+ }
822
+ .strength-detail {
823
+ font-family: var(--font-mono); font-size: 12px;
824
+ color: var(--ink-2); letter-spacing: 0.01em;
825
+ line-height: 1.55;
826
+ }
827
+ .strength-metric {
828
+ font-family: var(--font-display);
829
+ font-size: 26px; letter-spacing: 0.06em;
830
+ text-transform: lowercase;
831
+ color: var(--accent-green);
832
+ text-align: right;
833
+ line-height: 1;
834
+ white-space: nowrap;
835
+ }
836
+ .strength-metric .unit {
837
+ font-family: var(--font-mono); font-size: 10px;
838
+ letter-spacing: 0.18em;
839
+ text-transform: uppercase; color: var(--dim);
840
+ display: block; margin-top: 4px;
841
+ }
842
+ .strengths-footer {
843
+ font-family: var(--font-mono); font-size: 12px;
844
+ color: var(--ink-2); letter-spacing: 0.02em;
845
+ margin-top: 18px;
846
+ padding-left: 4px;
847
+ }
848
+
849
+ /* ───────────────────────── 03 SCORE CARD ───────────────────────── */
850
+
851
+ .score-share-card {
852
+ padding: 22px 24px 20px;
853
+ background:
854
+ repeating-linear-gradient(0deg, rgba(228,88,125,0.03) 0 1px, transparent 1px 16px),
855
+ repeating-linear-gradient(90deg, rgba(228,88,125,0.03) 0 1px, transparent 1px 16px),
856
+ var(--bg-2);
857
+ }
858
+
859
+ .score-card-header {
860
+ font-family: var(--font-mono); font-size: 10px;
861
+ letter-spacing: 0.18em; text-transform: uppercase;
862
+ color: var(--ink-2);
863
+ margin-bottom: 16px;
864
+ }
865
+
866
+ .ss-label {
867
+ font-family: var(--font-mono); font-size: 10px;
868
+ letter-spacing: 0.22em; text-transform: uppercase;
869
+ color: var(--accent-green);
870
+ margin-bottom: 14px;
871
+ }
872
+
873
+ /* — left column ------------------------------------------------------ */
874
+ .ss-score-row {
875
+ display: flex; align-items: baseline; gap: 10px;
876
+ margin: 0 0 10px;
877
+ }
878
+ .ss-score {
879
+ font-family: var(--font-display);
880
+ font-size: clamp(52px, 7vw, 76px);
881
+ line-height: 0.9;
882
+ letter-spacing: 0.04em;
883
+ color: var(--accent-pink);
884
+ text-shadow: 4px 4px 0 var(--accent-pink-shadow);
885
+ }
886
+ .ss-score.g-S, .ss-score.g-A { color: var(--accent-green); text-shadow: 4px 4px 0 var(--accent-green-shadow); }
887
+ .ss-score.g-B { color: #d3e1a8; text-shadow: 4px 4px 0 #6f7e45; }
888
+ .ss-score-of {
889
+ font-family: var(--font-mono); font-size: 18px;
890
+ color: var(--dim); letter-spacing: 0.08em;
891
+ }
892
+
893
+ .ss-tier-row {
894
+ display: flex; align-items: center; gap: 12px;
895
+ margin-bottom: 16px;
896
+ }
897
+ .ss-tier-badge {
898
+ font-family: var(--font-mono); font-size: 11px;
899
+ letter-spacing: 0.18em; text-transform: uppercase;
900
+ padding: 5px 10px;
901
+ border: 1px solid var(--accent-pink);
902
+ background: var(--accent-pink-bg);
903
+ color: var(--accent-pink);
904
+ }
905
+ .ss-tier-badge.g-S, .ss-tier-badge.g-A {
906
+ border-color: var(--accent-green);
907
+ background: var(--accent-green-bg);
908
+ color: var(--accent-green);
909
+ }
910
+ .ss-tier-badge.g-B {
911
+ border-color: #d3e1a8;
912
+ background: rgba(211, 225, 168, 0.10);
913
+ color: #d3e1a8;
914
+ }
915
+ .ss-arch {
916
+ font-family: var(--font-mono); font-size: 12px;
917
+ color: var(--ink-2); letter-spacing: 0.06em;
918
+ }
919
+
920
+ .ss-progress-label {
921
+ display: flex; justify-content: space-between;
922
+ font-family: var(--font-mono); font-size: 11px;
923
+ letter-spacing: 0.06em;
924
+ margin-bottom: 6px;
925
+ }
926
+ .ss-progress-track {
927
+ position: relative;
928
+ height: 10px; background: var(--bg);
929
+ border: 1px solid var(--line);
930
+ margin-bottom: 6px;
931
+ overflow: visible;
932
+ }
933
+ .ss-progress-fill {
934
+ height: 100%;
935
+ background: linear-gradient(90deg, var(--accent-pink) 0%, #f472b6 60%, #a78bfa 100%);
936
+ }
937
+ .ss-progress-tick {
938
+ position: absolute;
939
+ top: -4px; bottom: -4px;
940
+ width: 1px;
941
+ background: var(--line-2);
942
+ pointer-events: none;
943
+ }
944
+ .ss-grade-stops {
945
+ position: relative;
946
+ height: 16px;
947
+ margin-bottom: 16px;
948
+ }
949
+ .ss-grade-stop {
950
+ position: absolute;
951
+ transform: translateX(-50%);
952
+ font-family: var(--font-mono); font-size: 9px;
953
+ letter-spacing: 0.12em; text-transform: uppercase;
954
+ color: var(--dim);
955
+ top: 0;
956
+ }
957
+ .ss-grade-stop.active {
958
+ color: var(--accent-pink);
959
+ font-weight: 700;
960
+ }
961
+
962
+ .ss-stats {
963
+ display: grid;
964
+ grid-template-columns: repeat(3, 1fr);
965
+ gap: 8px;
966
+ margin-bottom: 16px;
967
+ }
968
+ .ss-stat {
969
+ border: 1px solid var(--line-2);
970
+ background: var(--bg);
971
+ padding: 10px 12px;
972
+ text-align: left;
973
+ }
974
+ .ss-stat-n {
975
+ font-family: var(--font-display);
976
+ font-size: 24px; line-height: 1;
977
+ letter-spacing: 0.04em;
978
+ margin-bottom: 6px;
979
+ }
980
+ .ss-stat-l {
981
+ font-family: var(--font-mono); font-size: 9px;
982
+ letter-spacing: 0.2em; text-transform: uppercase;
983
+ color: var(--dim);
984
+ line-height: 1.4;
985
+ }
986
+
987
+ .ss-policy-label {
988
+ font-family: var(--font-mono); font-size: 10px;
989
+ letter-spacing: 0.22em; text-transform: uppercase;
990
+ color: var(--ink-2);
991
+ margin-top: 14px;
992
+ padding-top: 14px;
993
+ border-top: 1px dashed var(--line);
994
+ margin-bottom: 10px;
995
+ }
996
+ .ss-policy-chips {
997
+ display: flex; flex-wrap: wrap; gap: 6px;
998
+ }
999
+ .ss-chip {
1000
+ display: inline-flex; align-items: center; gap: 6px;
1001
+ padding: 4px 10px;
1002
+ border-radius: 0;
1003
+ border: 1px solid var(--line-2);
1004
+ background: var(--bg);
1005
+ font-family: var(--font-mono); font-size: 11px;
1006
+ color: var(--ink-2);
1007
+ }
1008
+ .ss-chip .dot {
1009
+ width: 5px; height: 5px;
1010
+ border-radius: 0;
1011
+ background: var(--dim);
1012
+ }
1013
+ .ss-chip.missing {
1014
+ border-color: rgba(228, 88, 125, 0.6);
1015
+ color: var(--accent-pink);
1016
+ background: rgba(228, 88, 125, 0.06);
1017
+ }
1018
+ .ss-chip.missing .dot { background: var(--accent-pink); }
1019
+ .ss-chip.enabled {
1020
+ border-color: rgba(102, 209, 181, 0.5);
1021
+ color: var(--accent-green);
1022
+ background: rgba(102, 209, 181, 0.05);
1023
+ }
1024
+ .ss-chip.enabled .dot { background: var(--accent-green); }
1025
+
1026
+ /* — right column ----------------------------------------------------- */
1027
+ .ss-templates {
1028
+ display: flex; flex-direction: column; gap: 10px;
1029
+ margin-bottom: 16px;
1030
+ }
1031
+ .ss-template {
1032
+ border: 1px solid var(--line-2);
1033
+ background: var(--bg);
1034
+ padding: 14px 16px;
1035
+ }
1036
+ .ss-template-head {
1037
+ display: inline-flex; align-items: center; gap: 8px;
1038
+ font-family: var(--font-mono); font-size: 10px;
1039
+ letter-spacing: 0.2em; text-transform: uppercase;
1040
+ color: var(--ink-2);
1041
+ margin-bottom: 8px;
1042
+ }
1043
+ .ss-template-head .dot {
1044
+ width: 6px; height: 6px; border-radius: 50%;
1045
+ background: var(--accent-pink);
1046
+ }
1047
+ .ss-template-body {
1048
+ font-family: var(--font-mono); font-size: 12.5px;
1049
+ line-height: 1.55; color: var(--ink-2);
1050
+ margin: 0;
1051
+ }
1052
+
1053
+ .ss-actions {
1054
+ display: flex; flex-direction: column; gap: 8px;
1055
+ }
1056
+ .ss-action-btn {
1057
+ display: grid;
1058
+ grid-template-columns: 28px 1fr;
1059
+ align-items: center;
1060
+ gap: 12px;
1061
+ padding: 10px 14px;
1062
+ border: 1px solid var(--line-2);
1063
+ background: transparent;
1064
+ color: var(--ink);
1065
+ text-align: left;
1066
+ font-family: var(--font-mono); font-size: 12px;
1067
+ cursor: pointer;
1068
+ transition: all 120ms ease;
1069
+ text-decoration: none;
1070
+ }
1071
+ .ss-action-btn:hover {
1072
+ border-color: var(--accent-pink);
1073
+ background: var(--accent-pink-bg);
1074
+ color: var(--accent-pink);
1075
+ }
1076
+ .ss-action-btn:disabled {
1077
+ opacity: 0.55; cursor: wait;
1078
+ }
1079
+ .ss-action-glyph {
1080
+ display: grid; place-items: center;
1081
+ width: 24px; height: 24px;
1082
+ border: 1px solid var(--ink-2);
1083
+ font-family: var(--font-mono); font-size: 11px;
1084
+ text-transform: uppercase;
1085
+ color: var(--ink-2);
1086
+ }
1087
+ .ss-action-btn:hover .ss-action-glyph {
1088
+ border-color: var(--accent-pink);
1089
+ color: var(--accent-pink);
1090
+ }
1091
+ .ss-action-text {
1092
+ display: flex; flex-direction: column;
1093
+ }
1094
+ .ss-action-title {
1095
+ font-family: var(--font-mono); font-size: 13px;
1096
+ letter-spacing: 0.04em;
1097
+ color: var(--ink);
1098
+ }
1099
+ .ss-action-btn:hover .ss-action-title { color: var(--accent-pink); }
1100
+ .ss-action-sub {
1101
+ font-family: var(--font-mono); font-size: 10px;
1102
+ letter-spacing: 0.05em;
1103
+ color: var(--dim);
1104
+ margin-top: 2px;
1105
+ }
1106
+
1107
+ .ss-foot {
1108
+ display: flex; justify-content: space-between; gap: 16px;
1109
+ flex-wrap: wrap;
1110
+ padding-top: 18px; margin-top: 26px;
1111
+ border-top: 1px dashed var(--line);
1112
+ font-family: var(--font-mono); font-size: 11px;
1113
+ color: var(--ink-2);
1114
+ }
1115
+ .ss-foot-link {
1116
+ color: var(--accent-green);
1117
+ text-decoration: none;
1118
+ }
1119
+ .ss-foot-link:hover { text-decoration: underline; text-underline-offset: 3px; }
1120
+
1121
+ @media (max-width: 880px) {
1122
+ .score-share-card { padding: 16px 16px 16px; }
1123
+ }
1124
+
1125
+
1126
+ /* ───────────────────────── 04 FINDINGS ───────────────────────── */
1127
+
1128
+ .findings-list { display: flex; flex-direction: column; gap: 20px; }
1129
+ .finding {
1130
+ border: 1px solid var(--line-2);
1131
+ background: var(--bg-2);
1132
+ position: relative;
1133
+ }
1134
+ .finding::before {
1135
+ content: ""; position: absolute; top: -1px; left: -1px;
1136
+ width: 8px; height: 8px;
1137
+ border-top: 1px solid var(--accent-pink);
1138
+ border-left: 1px solid var(--accent-pink);
1139
+ }
1140
+ .finding-head {
1141
+ display: grid;
1142
+ grid-template-columns: auto 1fr auto;
1143
+ gap: 18px; align-items: center;
1144
+ padding: 20px 24px;
1145
+ border-bottom: 1px solid var(--line);
1146
+ }
1147
+ .finding-num {
1148
+ font-family: var(--font-mono); font-size: 13px;
1149
+ color: var(--accent-pink); letter-spacing: 0.12em;
1150
+ font-weight: 600;
1151
+ }
1152
+ .finding-title {
1153
+ font-family: var(--font-display); font-size: 22px;
1154
+ letter-spacing: 0.11em; color: var(--ink);
1155
+ text-transform: lowercase;
1156
+ }
1157
+ .finding-count {
1158
+ font-family: var(--font-display); font-size: 36px;
1159
+ letter-spacing: 0.04em; color: var(--accent-pink);
1160
+ text-transform: lowercase; line-height: 1;
1161
+ display: flex; align-items: baseline; gap: 6px;
1162
+ }
1163
+ .finding-count .label {
1164
+ font-family: var(--font-mono); font-size: 10px;
1165
+ letter-spacing: 0.22em; text-transform: uppercase;
1166
+ color: var(--dim);
1167
+ }
1168
+ .finding-meta {
1169
+ display: flex; gap: 16px; flex-wrap: wrap;
1170
+ padding: 12px 24px;
1171
+ font-family: var(--font-mono); font-size: 11px;
1172
+ letter-spacing: 0.05em;
1173
+ color: var(--ink-2);
1174
+ border-bottom: 1px solid var(--line);
1175
+ background: rgba(0,0,0,0.15);
1176
+ }
1177
+ .finding-meta .policy { color: var(--accent-green); }
1178
+ .finding-meta .sep { color: var(--dim); }
1179
+ .finding-body {
1180
+ display: grid;
1181
+ grid-template-columns: 1fr 1fr;
1182
+ gap: 0;
1183
+ }
1184
+ .finding-block {
1185
+ padding: 22px 24px;
1186
+ border-right: 1px solid var(--line);
1187
+ border-bottom: 1px solid var(--line);
1188
+ display: flex; flex-direction: column; gap: 10px;
1189
+ }
1190
+ .finding-block:nth-child(2n) { border-right: none; }
1191
+ .finding-block:nth-last-child(-n+2) { border-bottom: none; }
1192
+ .fb-label {
1193
+ font-family: var(--font-mono); font-size: 10px;
1194
+ letter-spacing: 0.22em; text-transform: uppercase;
1195
+ color: var(--accent-green);
1196
+ }
1197
+ .fb-label.cost { color: var(--amber); }
1198
+ .fb-label.fix { color: var(--accent-pink); }
1199
+ .fb-body {
1200
+ font-family: var(--font-mono); font-size: 13px;
1201
+ line-height: 1.65; color: var(--ink-2);
1202
+ }
1203
+ .fb-body .pk { color: var(--accent-pink); }
1204
+ .fb-body .g { color: var(--accent-green); }
1205
+ .fb-body .a { color: var(--amber); }
1206
+ .fb-body code {
1207
+ background: var(--bg); border: 1px solid var(--line);
1208
+ padding: 1px 6px; color: var(--accent-green); font-size: 12px;
1209
+ }
1210
+
1211
+ .fb-evidence {
1212
+ font-family: var(--font-mono); font-size: 12px;
1213
+ background: var(--bg); border: 1px solid var(--line);
1214
+ padding: 12px 14px;
1215
+ white-space: pre; overflow-x: auto;
1216
+ color: var(--ink); line-height: 1.65;
1217
+ }
1218
+ .fb-evidence .arrow { color: var(--accent-green); }
1219
+ .fb-evidence .err { color: var(--accent-pink); }
1220
+ .fb-evidence .comment { color: var(--dim); }
1221
+
1222
+ .fb-fix {
1223
+ background: var(--bg); border: 1px solid var(--line);
1224
+ padding: 14px;
1225
+ font-family: var(--font-mono); font-size: 12px;
1226
+ }
1227
+ .fb-fix .slug {
1228
+ display: inline-block; padding: 2px 8px;
1229
+ background: var(--accent-pink-bg); color: var(--accent-pink);
1230
+ border: 1px solid var(--accent-pink);
1231
+ font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase;
1232
+ margin-bottom: 10px;
1233
+ }
1234
+ .fb-fix .cmd {
1235
+ display: block; margin-top: 12px;
1236
+ color: var(--accent-green); font-size: 12px;
1237
+ border-top: 1px dashed var(--line); padding-top: 10px;
1238
+ }
1239
+ .fb-fix .cmd .prompt { color: var(--dim); margin-right: 6px; }
1240
+
1241
+ /* ───────────────────────── show-off CTA (after IDENTITY) ───────────────────────── */
1242
+
1243
+ .showoff {
1244
+ padding: 0 0 32px;
1245
+ border-bottom: 1px solid var(--line);
1246
+ margin-bottom: 0;
1247
+ /* Clear the sticky .app-header (≈52px tall) when scroll-anchored. */
1248
+ scroll-margin-top: 80px;
1249
+ }
1250
+ .showoff-cta {
1251
+ display: grid;
1252
+ grid-template-columns: auto 1fr auto;
1253
+ align-items: center;
1254
+ gap: 32px;
1255
+ padding: 28px 32px;
1256
+ border: 1px solid var(--line-2);
1257
+ background:
1258
+ repeating-linear-gradient(0deg, rgba(228,88,125,0.025) 0 1px, transparent 1px 16px),
1259
+ repeating-linear-gradient(90deg, rgba(228,88,125,0.025) 0 1px, transparent 1px 16px),
1260
+ var(--bg-2);
1261
+ color: var(--ink);
1262
+ text-decoration: none;
1263
+ position: relative;
1264
+ transition: border-color 120ms ease, background 120ms ease;
1265
+ }
1266
+ .showoff-cta:hover {
1267
+ border-color: var(--ink-2);
1268
+ background:
1269
+ repeating-linear-gradient(0deg, rgba(228,88,125,0.04) 0 1px, transparent 1px 16px),
1270
+ repeating-linear-gradient(90deg, rgba(228,88,125,0.04) 0 1px, transparent 1px 16px),
1271
+ var(--bg-3);
1272
+ }
1273
+ .showoff-cta::before {
1274
+ content: ""; position: absolute; top: -1px; left: -1px;
1275
+ width: 10px; height: 10px;
1276
+ border-top: 1px solid var(--accent-pink);
1277
+ border-left: 1px solid var(--accent-pink);
1278
+ }
1279
+ .showoff-cta::after {
1280
+ content: ""; position: absolute; bottom: -1px; right: -1px;
1281
+ width: 10px; height: 10px;
1282
+ border-bottom: 1px solid var(--accent-pink);
1283
+ border-right: 1px solid var(--accent-pink);
1284
+ }
1285
+ .showoff-glyph {
1286
+ display: block;
1287
+ transform: scale(0.55);
1288
+ transform-origin: center;
1289
+ margin: -40px -28px;
1290
+ /* shrink the embedded sigil without rebuilding it */
1291
+ }
1292
+ .showoff-glyph .sigil-wrap[data-bare="true"] .sigil {
1293
+ box-shadow: 4px 4px 0 0 var(--accent-pink-shadow);
1294
+ }
1295
+ /* legacy: pre-plate sigil rendered a .sigil-label sibling. The new plate
1296
+ renders strip rows inside the plate instead, but keep this null-rule so
1297
+ any cached HTML between deploys doesn't surface a stray label. */
1298
+ .showoff-glyph .sigil-label { display: none; }
1299
+ .showoff-copy {
1300
+ display: flex;
1301
+ flex-direction: column;
1302
+ gap: 6px;
1303
+ min-width: 0;
1304
+ }
1305
+ .showoff-label {
1306
+ font-family: var(--font-mono);
1307
+ font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
1308
+ color: var(--accent-green);
1309
+ }
1310
+ .showoff-headline {
1311
+ font-family: var(--font-display);
1312
+ font-size: clamp(28px, 3.4vw, 40px);
1313
+ letter-spacing: 0.11em;
1314
+ text-transform: lowercase;
1315
+ color: var(--ink);
1316
+ line-height: 1.05;
1317
+ text-shadow: 3px 3px 0 var(--accent-pink-shadow);
1318
+ }
1319
+ .showoff-sub {
1320
+ font-family: var(--font-mono);
1321
+ font-size: 13px; line-height: 1.55;
1322
+ color: var(--ink-2);
1323
+ max-width: 520px;
1324
+ }
1325
+ .showoff-action {
1326
+ display: inline-flex;
1327
+ flex-direction: column;
1328
+ align-items: center;
1329
+ gap: 8px;
1330
+ padding: 16px 24px;
1331
+ border: 1px solid var(--accent-pink);
1332
+ background: var(--accent-pink-bg);
1333
+ color: var(--accent-pink);
1334
+ font-family: var(--font-mono);
1335
+ font-size: 11px;
1336
+ letter-spacing: 0.22em;
1337
+ text-transform: uppercase;
1338
+ white-space: nowrap;
1339
+ }
1340
+ .showoff-arrow {
1341
+ font-family: var(--font-display);
1342
+ font-size: 36px;
1343
+ letter-spacing: 0;
1344
+ line-height: 1;
1345
+ color: var(--accent-pink);
1346
+ }
1347
+
1348
+ @media (max-width: 800px) {
1349
+ .showoff-cta { grid-template-columns: 1fr; padding: 24px 20px; gap: 18px; }
1350
+ .showoff-glyph { margin: 0; transform: scale(0.6); transform-origin: left top; }
1351
+ .showoff-action { width: 100%; flex-direction: row; justify-content: center; }
1352
+ }
1353
+
1354
+ /* ───────────────────────── 05 POLICIES ───────────────────────── */
1355
+
1356
+ .policy-callout {
1357
+ display: inline-flex; align-items: baseline; gap: 12px;
1358
+ padding: 12px 18px;
1359
+ border: 1px solid var(--accent-green);
1360
+ background: var(--accent-green-bg);
1361
+ margin-bottom: 28px;
1362
+ font-family: var(--font-mono); font-size: 13px;
1363
+ letter-spacing: 0.02em;
1364
+ color: var(--ink);
1365
+ box-shadow: 4px 4px 0 0 var(--accent-green-shadow);
1366
+ }
1367
+ .policy-callout .arrow { color: var(--accent-green); margin: 0 4px; }
1368
+ .policy-callout .new-score {
1369
+ font-family: var(--font-display); font-size: 22px;
1370
+ letter-spacing: 0.08em; color: var(--accent-green);
1371
+ }
1372
+ .policy-callout .new-tier { color: var(--accent-green); font-weight: 600; }
1373
+
1374
+ .policies-grid {
1375
+ display: grid;
1376
+ grid-template-columns: repeat(2, 1fr);
1377
+ gap: 16px;
1378
+ }
1379
+ .policy-card {
1380
+ border: 1px solid var(--line-2);
1381
+ background: var(--bg-2);
1382
+ padding: 20px 22px;
1383
+ display: flex; flex-direction: column; gap: 10px;
1384
+ transition: all 120ms;
1385
+ position: relative;
1386
+ }
1387
+ .policy-card::before {
1388
+ content: ""; position: absolute; left: 0; top: 0;
1389
+ width: 3px; height: 100%;
1390
+ background: var(--accent-pink); opacity: 0.7;
1391
+ }
1392
+ .policy-card:hover { background: var(--bg-3); }
1393
+ .policy-card .head {
1394
+ display: flex; justify-content: space-between; align-items: baseline;
1395
+ gap: 12px;
1396
+ padding-bottom: 10px;
1397
+ border-bottom: 1px dashed var(--line);
1398
+ margin-bottom: 4px;
1399
+ }
1400
+ .policy-name {
1401
+ font-family: var(--font-display); font-size: 18px;
1402
+ letter-spacing: 0.11em; color: var(--ink);
1403
+ text-transform: lowercase;
1404
+ }
1405
+ .policy-slug {
1406
+ font-family: var(--font-mono); font-size: 10px;
1407
+ letter-spacing: 0.12em; color: var(--dim);
1408
+ text-transform: uppercase;
1409
+ }
1410
+ .policy-desc {
1411
+ font-family: var(--font-mono); font-size: 12px;
1412
+ color: var(--ink-2); line-height: 1.6;
1413
+ }
1414
+ .policy-impact {
1415
+ font-family: var(--font-mono); font-size: 12px;
1416
+ color: var(--accent-green);
1417
+ letter-spacing: 0.01em;
1418
+ border-top: 1px dashed var(--line);
1419
+ padding-top: 10px;
1420
+ margin-top: auto;
1421
+ }
1422
+ .policy-impact .check { margin-right: 6px; }
1423
+ .policy-install {
1424
+ display: flex; align-items: center; gap: 8px;
1425
+ font-family: var(--font-mono); font-size: 11px;
1426
+ background: var(--bg); border: 1px solid var(--line);
1427
+ padding: 8px 10px;
1428
+ color: var(--accent-green);
1429
+ margin-top: 4px;
1430
+ }
1431
+ .policy-install .prompt { color: var(--dim); }
1432
+ .policy-install .copy {
1433
+ margin-left: auto; color: var(--dim); cursor: pointer;
1434
+ font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase;
1435
+ transition: color 120ms;
1436
+ }
1437
+ .policy-install .copy:hover { color: var(--accent-pink); }
1438
+
1439
+ /* ───────────────────────── 06 SHARE + RETURN ───────────────────────── */
1440
+
1441
+ .share-grid {
1442
+ display: grid;
1443
+ grid-template-columns: 1fr 1fr;
1444
+ gap: 32px;
1445
+ align-items: start;
1446
+ }
1447
+
1448
+ .share-card {
1449
+ border: 1px solid var(--accent-pink);
1450
+ background:
1451
+ repeating-linear-gradient(0deg, rgba(228,88,125,0.02) 0 1px, transparent 1px 16px),
1452
+ repeating-linear-gradient(90deg, rgba(228,88,125,0.02) 0 1px, transparent 1px 16px),
1453
+ var(--bg-2);
1454
+ padding: 32px;
1455
+ position: relative;
1456
+ box-shadow: 8px 8px 0 0 var(--accent-pink-shadow);
1457
+ }
1458
+ .share-card .stamp-tl, .share-card .stamp-br {
1459
+ position: absolute;
1460
+ font-family: var(--font-mono); font-size: 9px;
1461
+ letter-spacing: 0.2em; text-transform: uppercase;
1462
+ color: var(--accent-pink); opacity: 0.55;
1463
+ }
1464
+ .share-card .stamp-tl { top: 8px; left: 12px; }
1465
+ .share-card .stamp-br { bottom: 8px; right: 12px; }
1466
+
1467
+ .share-brand {
1468
+ display: flex; align-items: center; gap: 10px;
1469
+ margin-bottom: 28px;
1470
+ }
1471
+ .share-brand .glyph {
1472
+ color: var(--accent-pink); font-family: var(--font-mono);
1473
+ font-size: 14px; letter-spacing: -2px; font-weight: 700;
1474
+ }
1475
+ .share-brand .name {
1476
+ font-family: var(--font-display); font-size: 14px;
1477
+ letter-spacing: 0.11em; text-transform: lowercase; color: var(--ink);
1478
+ }
1479
+ .share-brand .sep { color: var(--dim); font-size: 11px; }
1480
+ .share-brand .meta {
1481
+ font-family: var(--font-mono); font-size: 10px;
1482
+ letter-spacing: 0.18em; text-transform: uppercase; color: var(--dim);
1483
+ }
1484
+ .share-project {
1485
+ font-family: var(--font-mono); font-size: 12px;
1486
+ letter-spacing: 0.05em; color: var(--ink-2);
1487
+ margin-bottom: 20px;
1488
+ }
1489
+ .share-archetype {
1490
+ font-family: var(--font-display);
1491
+ font-size: clamp(36px, 5vw, 56px);
1492
+ line-height: 1; letter-spacing: 0.08em;
1493
+ text-transform: lowercase;
1494
+ color: var(--ink);
1495
+ text-shadow: 3px 3px 0 var(--accent-pink-shadow);
1496
+ margin: 0 0 12px;
1497
+ text-wrap: balance;
1498
+ }
1499
+ .share-rule {
1500
+ width: 56px; height: 2px;
1501
+ background: var(--accent-pink);
1502
+ margin: 16px 0 20px;
1503
+ }
1504
+ .share-tagline {
1505
+ font-family: var(--font-mono); font-size: 14px;
1506
+ line-height: 1.45; color: var(--ink-2);
1507
+ margin-bottom: 32px;
1508
+ text-wrap: pretty;
1509
+ }
1510
+ .share-score-row {
1511
+ display: flex; gap: 14px; align-items: center;
1512
+ font-family: var(--font-mono); font-size: 14px;
1513
+ letter-spacing: 0.05em;
1514
+ padding-top: 22px;
1515
+ border-top: 1px dashed var(--line);
1516
+ }
1517
+ .share-score-row .tier {
1518
+ font-family: var(--font-display); font-size: 22px;
1519
+ letter-spacing: 0.08em; color: var(--accent-pink);
1520
+ text-transform: uppercase;
1521
+ }
1522
+ .share-score-row .sep { color: var(--dim); }
1523
+ .share-score-row .num { color: var(--ink); }
1524
+ .share-score-row .rank { color: var(--ink-2); }
1525
+ .share-url {
1526
+ margin-top: 22px;
1527
+ font-family: var(--font-mono); font-size: 11px;
1528
+ letter-spacing: 0.18em; text-transform: uppercase;
1529
+ color: var(--accent-green);
1530
+ }
1531
+
1532
+ .share-actions {
1533
+ display: flex; flex-direction: column; gap: 16px;
1534
+ }
1535
+ .tweet-tabs {
1536
+ display: flex; gap: 0;
1537
+ border: 1px solid var(--line-2);
1538
+ }
1539
+ .tweet-tab {
1540
+ flex: 1;
1541
+ padding: 10px 14px;
1542
+ font-family: var(--font-mono); font-size: 11px;
1543
+ letter-spacing: 0.15em; text-transform: uppercase;
1544
+ color: var(--ink-2);
1545
+ border-right: 1px solid var(--line);
1546
+ background: var(--bg-2);
1547
+ transition: all 120ms;
1548
+ }
1549
+ .tweet-tab:last-child { border-right: none; }
1550
+ .tweet-tab:hover { color: var(--ink); }
1551
+ .tweet-tab.is-active {
1552
+ color: var(--accent-pink);
1553
+ background: var(--accent-pink-bg);
1554
+ }
1555
+
1556
+ .tweet-preview {
1557
+ background: var(--bg-2);
1558
+ border: 1px solid var(--line-2);
1559
+ padding: 20px 22px;
1560
+ font-family: var(--font-mono); font-size: 13px;
1561
+ line-height: 1.65;
1562
+ color: var(--ink);
1563
+ white-space: pre-wrap;
1564
+ min-height: 200px;
1565
+ position: relative;
1566
+ }
1567
+ .tweet-preview .url { color: var(--accent-pink); }
1568
+ .tweet-preview .arch { color: var(--accent-pink); }
1569
+ .tweet-meta {
1570
+ display: flex; justify-content: space-between;
1571
+ font-family: var(--font-mono); font-size: 10px;
1572
+ letter-spacing: 0.18em; text-transform: uppercase;
1573
+ color: var(--dim);
1574
+ }
1575
+ .tweet-meta .count.over { color: var(--accent-pink); }
1576
+
1577
+ .share-buttons {
1578
+ display: flex; gap: 12px; flex-wrap: wrap;
1579
+ }
1580
+ .share-btn {
1581
+ display: inline-flex; align-items: center; gap: 10px;
1582
+ padding: 14px 20px;
1583
+ font-family: var(--font-mono); font-size: 13px;
1584
+ letter-spacing: 0.04em;
1585
+ border: 1px solid var(--accent-pink);
1586
+ color: var(--accent-pink);
1587
+ background: transparent;
1588
+ transition: all 120ms;
1589
+ box-shadow: 4px 4px 0 0 var(--accent-pink-shadow);
1590
+ }
1591
+ .share-btn:hover {
1592
+ background: var(--accent-pink);
1593
+ color: var(--bg);
1594
+ box-shadow: 2px 2px 0 0 var(--accent-pink-shadow);
1595
+ transform: translate(2px, 2px);
1596
+ }
1597
+ .share-btn.alt {
1598
+ border-color: var(--line-2); color: var(--ink);
1599
+ box-shadow: 4px 4px 0 0 #1a1a20;
1600
+ }
1601
+ .share-btn.alt:hover {
1602
+ border-color: var(--ink); background: rgba(255,255,255,0.04);
1603
+ color: var(--ink); box-shadow: 2px 2px 0 0 #1a1a20;
1604
+ }
1605
+ .share-btn .arrow { color: var(--accent-green); }
1606
+ .share-btn:hover .arrow { color: var(--bg); }
1607
+
1608
+ /* return hook */
1609
+ .return-hook {
1610
+ margin-top: 64px;
1611
+ padding: 40px 48px;
1612
+ border: 1px solid var(--line-2);
1613
+ background: var(--bg-2);
1614
+ position: relative;
1615
+ }
1616
+ .return-hook::before, .return-hook::after {
1617
+ content: ""; position: absolute; width: 8px; height: 8px;
1618
+ }
1619
+ .return-hook::before {
1620
+ top: -1px; left: -1px;
1621
+ border-top: 1px solid var(--accent-green);
1622
+ border-left: 1px solid var(--accent-green);
1623
+ }
1624
+ .return-hook::after {
1625
+ bottom: -1px; right: -1px;
1626
+ border-bottom: 1px solid var(--accent-green);
1627
+ border-right: 1px solid var(--accent-green);
1628
+ }
1629
+ .return-hook .label {
1630
+ font-family: var(--font-mono); font-size: 11px;
1631
+ letter-spacing: 0.22em; text-transform: uppercase;
1632
+ color: var(--accent-green); margin-bottom: 12px;
1633
+ }
1634
+ .return-hook h3 {
1635
+ font-family: var(--font-display); font-size: clamp(28px, 3.6vw, 40px);
1636
+ letter-spacing: 0.11em; line-height: 1.1;
1637
+ text-transform: lowercase; color: var(--ink);
1638
+ margin: 0 0 16px; font-weight: 400;
1639
+ }
1640
+ .return-hook p {
1641
+ font-family: var(--font-mono); font-size: 13px;
1642
+ color: var(--ink-2); line-height: 1.7;
1643
+ margin: 0 0 8px; max-width: 600px;
1644
+ }
1645
+ .return-actions { display: flex; gap: 12px; margin-top: 28px; flex-wrap: wrap; align-items: center; }
1646
+
1647
+ /* persistent reminder status (authed + reminder saved) */
1648
+ .return-status {
1649
+ margin-top: 24px;
1650
+ padding: 18px 20px;
1651
+ border: 1px solid var(--accent-pink);
1652
+ background:
1653
+ repeating-linear-gradient(0deg, rgba(228,88,125,0.03) 0 1px, transparent 1px 16px),
1654
+ repeating-linear-gradient(90deg, rgba(228,88,125,0.03) 0 1px, transparent 1px 16px),
1655
+ var(--bg-2);
1656
+ }
1657
+ .return-status .rs-row {
1658
+ display: flex; align-items: center; gap: 12px;
1659
+ font-family: var(--font-mono); font-size: 13px;
1660
+ color: var(--ink-2);
1661
+ margin: 6px 0;
1662
+ }
1663
+ .return-status .rs-row-primary {
1664
+ font-size: 15px;
1665
+ color: var(--ink);
1666
+ letter-spacing: 0.02em;
1667
+ }
1668
+ .return-status .rs-strong { color: var(--accent-pink); }
1669
+ .return-status .rs-email { color: var(--accent-green); }
1670
+ .rs-dot {
1671
+ width: 8px; height: 8px;
1672
+ display: inline-block;
1673
+ flex-shrink: 0;
1674
+ }
1675
+ .rs-dot-pink {
1676
+ background: var(--accent-pink);
1677
+ box-shadow: 0 0 8px rgba(228,88,125,0.55);
1678
+ animation: pulseDot 1.6s ease-in-out infinite;
1679
+ }
1680
+ .rs-dot-green {
1681
+ background: var(--accent-green);
1682
+ box-shadow: 0 0 6px rgba(102,209,181,0.55);
1683
+ }
1684
+ .rs-clear {
1685
+ background: transparent;
1686
+ border: none;
1687
+ padding: 4px 0;
1688
+ font-family: var(--font-mono); font-size: 11px;
1689
+ letter-spacing: 0.1em;
1690
+ color: var(--dim);
1691
+ cursor: pointer;
1692
+ text-decoration: underline;
1693
+ text-underline-offset: 3px;
1694
+ transition: color 120ms;
1695
+ }
1696
+ .rs-clear:hover:not(:disabled) { color: var(--accent-pink); }
1697
+ .rs-clear:disabled { opacity: 0.5; cursor: not-allowed; }
1698
+
1699
+ /* ───────────────────────── footer ───────────────────────── */
1700
+
1701
+ .report-footer {
1702
+ padding: 48px 32px 24px;
1703
+ border-top: 1px solid var(--line);
1704
+ background: var(--bg);
1705
+ text-align: center;
1706
+ font-family: var(--font-mono); font-size: 11px;
1707
+ letter-spacing: 0.15em; text-transform: uppercase;
1708
+ color: var(--dim);
1709
+ }
1710
+ /* Fixed variant — used on the empty/loading states where the page is
1711
+ short and a normal in-flow footer ends up floating mid-viewport. Pins
1712
+ it to the bottom of the viewport so it doesn't scroll with the page. */
1713
+ .report-footer--fixed {
1714
+ position: fixed;
1715
+ left: 0; right: 0; bottom: 0;
1716
+ padding: 16px 32px;
1717
+ z-index: 10;
1718
+ }
1719
+ .report-footer .brand-mark {
1720
+ color: var(--accent-pink); font-family: var(--font-mono);
1721
+ font-size: 14px; letter-spacing: -2px; font-weight: 700;
1722
+ margin-right: 6px;
1723
+ }
1724
+
1725
+ /* ───────────────────────── auth dialog (set-a-reminder gate) ───────────────────────── */
1726
+
1727
+ .auth-dialog-backdrop {
1728
+ position: fixed; inset: 0; z-index: 10000;
1729
+ display: grid; place-items: center;
1730
+ padding: 32px 16px;
1731
+ background:
1732
+ radial-gradient(ellipse 1000px 700px at 30% 20%, rgba(228,88,125,0.08) 0%, transparent 60%),
1733
+ rgba(8,8,10,0.78);
1734
+ backdrop-filter: blur(6px);
1735
+ -webkit-backdrop-filter: blur(6px);
1736
+ animation: authFadeIn 140ms ease-out;
1737
+ }
1738
+ @keyframes authFadeIn {
1739
+ from { opacity: 0; }
1740
+ to { opacity: 1; }
1741
+ }
1742
+
1743
+ .auth-dialog {
1744
+ position: relative;
1745
+ width: 100%;
1746
+ max-width: 460px;
1747
+ padding: 32px 32px 28px;
1748
+ border: 1px solid var(--accent-pink);
1749
+ background:
1750
+ repeating-linear-gradient(0deg, rgba(228,88,125,0.03) 0 1px, transparent 1px 16px),
1751
+ repeating-linear-gradient(90deg, rgba(228,88,125,0.03) 0 1px, transparent 1px 16px),
1752
+ var(--bg-2);
1753
+ box-shadow: 8px 8px 0 0 var(--accent-pink-shadow);
1754
+ font-family: var(--font-mono);
1755
+ color: var(--ink);
1756
+ animation: authPop 160ms ease-out;
1757
+ }
1758
+ @keyframes authPop {
1759
+ from { transform: translateY(8px) scale(0.985); opacity: 0; }
1760
+ to { transform: translateY(0) scale(1); opacity: 1; }
1761
+ }
1762
+
1763
+ .auth-dialog .corner {
1764
+ position: absolute;
1765
+ font-family: var(--font-mono);
1766
+ font-size: 14px; line-height: 1;
1767
+ color: var(--accent-pink); opacity: 0.85;
1768
+ }
1769
+ .auth-dialog .corner.tl { top: 6px; left: 8px; }
1770
+ .auth-dialog .corner.tr { top: 6px; right: 8px; }
1771
+ .auth-dialog .corner.bl { bottom: 6px; left: 8px; }
1772
+ .auth-dialog .corner.br { bottom: 6px; right: 8px; }
1773
+
1774
+ .auth-close {
1775
+ position: absolute; top: 12px; right: 14px;
1776
+ font-family: var(--font-mono); font-size: 11px;
1777
+ letter-spacing: 0.15em; text-transform: uppercase;
1778
+ color: var(--dim);
1779
+ background: transparent; border: none; padding: 4px 6px;
1780
+ cursor: pointer;
1781
+ transition: color 120ms;
1782
+ }
1783
+ .auth-close:hover { color: var(--accent-pink); }
1784
+ .auth-close:disabled { color: var(--line-2); cursor: not-allowed; }
1785
+
1786
+ .auth-label {
1787
+ font-family: var(--font-mono); font-size: 11px;
1788
+ letter-spacing: 0.22em; text-transform: uppercase;
1789
+ color: var(--accent-green);
1790
+ margin-bottom: 14px;
1791
+ }
1792
+
1793
+ .auth-headline {
1794
+ font-family: var(--font-display);
1795
+ font-size: clamp(26px, 3.6vw, 34px);
1796
+ letter-spacing: 0.09em; line-height: 1.1;
1797
+ text-transform: lowercase;
1798
+ color: var(--ink);
1799
+ margin: 0 0 12px;
1800
+ text-shadow: 3px 3px 0 var(--accent-pink-shadow);
1801
+ text-wrap: balance;
1802
+ }
1803
+
1804
+ .auth-sub {
1805
+ font-family: var(--font-mono); font-size: 13px;
1806
+ line-height: 1.65; color: var(--ink-2);
1807
+ margin: 0 0 22px;
1808
+ }
1809
+ .auth-sub .auth-email {
1810
+ color: var(--accent-pink);
1811
+ }
1812
+ .auth-sub .auth-ok {
1813
+ color: var(--accent-green);
1814
+ margin-right: 6px;
1815
+ }
1816
+
1817
+ .auth-form { display: flex; flex-direction: column; gap: 10px; }
1818
+
1819
+ .auth-field-label {
1820
+ font-family: var(--font-mono); font-size: 10px;
1821
+ letter-spacing: 0.22em; text-transform: uppercase;
1822
+ color: var(--accent-green);
1823
+ }
1824
+
1825
+ .auth-input {
1826
+ width: 100%;
1827
+ padding: 11px 14px;
1828
+ background: var(--bg);
1829
+ border: 1px solid var(--line-2);
1830
+ color: var(--ink);
1831
+ font-family: var(--font-mono); font-size: 14px;
1832
+ letter-spacing: 0.03em;
1833
+ outline: none;
1834
+ transition: border-color 120ms, box-shadow 120ms;
1835
+ }
1836
+ .auth-input:focus {
1837
+ border-color: var(--accent-pink);
1838
+ box-shadow: 0 0 0 1px var(--accent-pink-soft);
1839
+ }
1840
+ .auth-input:disabled {
1841
+ opacity: 0.55; cursor: not-allowed;
1842
+ }
1843
+ .auth-input-code {
1844
+ letter-spacing: 0.5em;
1845
+ text-align: center;
1846
+ font-size: 18px;
1847
+ font-variant-numeric: tabular-nums;
1848
+ }
1849
+ .auth-input::placeholder { color: var(--dim); }
1850
+
1851
+ .auth-error {
1852
+ font-family: var(--font-mono); font-size: 12px;
1853
+ color: var(--accent-pink);
1854
+ padding: 8px 12px;
1855
+ background: var(--accent-pink-bg);
1856
+ border: 1px solid var(--accent-pink);
1857
+ border-left-width: 3px;
1858
+ letter-spacing: 0.02em;
1859
+ margin-top: 4px;
1860
+ }
1861
+
1862
+ .auth-actions {
1863
+ display: flex; gap: 10px; flex-wrap: wrap;
1864
+ margin-top: 14px;
1865
+ }
1866
+
1867
+ .auth-btn {
1868
+ display: inline-flex; align-items: center; gap: 8px;
1869
+ padding: 10px 16px;
1870
+ font-family: var(--font-mono); font-size: 12px;
1871
+ letter-spacing: 0.06em;
1872
+ background: transparent;
1873
+ border: 1px solid var(--line-2);
1874
+ color: var(--ink);
1875
+ cursor: pointer;
1876
+ transition: all 120ms ease;
1877
+ }
1878
+ .auth-btn:hover:not(:disabled) {
1879
+ border-color: var(--ink); background: rgba(255,255,255,0.04);
1880
+ }
1881
+ .auth-btn:disabled { opacity: 0.45; cursor: not-allowed; }
1882
+ .auth-btn.primary {
1883
+ border-color: var(--accent-pink);
1884
+ color: var(--accent-pink);
1885
+ box-shadow: 4px 4px 0 0 var(--accent-pink-shadow);
1886
+ }
1887
+ .auth-btn.primary:hover:not(:disabled) {
1888
+ background: var(--accent-pink); color: var(--bg);
1889
+ box-shadow: 2px 2px 0 0 var(--accent-pink-shadow);
1890
+ transform: translate(2px, 2px);
1891
+ }
1892
+
1893
+ .auth-back {
1894
+ align-self: flex-start;
1895
+ margin-top: 4px;
1896
+ background: transparent; border: none; padding: 6px 0;
1897
+ font-family: var(--font-mono); font-size: 11px;
1898
+ letter-spacing: 0.1em; color: var(--dim);
1899
+ cursor: pointer;
1900
+ transition: color 120ms;
1901
+ }
1902
+ .auth-back:hover:not(:disabled) { color: var(--ink-2); }
1903
+ .auth-back:disabled { opacity: 0.45; cursor: not-allowed; }
1904
+
1905
+ @media (max-width: 520px) {
1906
+ .auth-dialog { padding: 26px 22px 22px; }
1907
+ .auth-actions { flex-direction: column; align-items: stretch; }
1908
+ .auth-btn { justify-content: center; }
1909
+ }
1910
+
1911
+ /* status pill in the return CTA: shows current logged-in email */
1912
+ .auth-status-pill {
1913
+ display: inline-flex; align-items: center; gap: 8px;
1914
+ margin-top: 16px;
1915
+ padding: 6px 10px;
1916
+ border: 1px dashed var(--line-2);
1917
+ font-family: var(--font-mono); font-size: 11px;
1918
+ letter-spacing: 0.1em;
1919
+ color: var(--ink-2);
1920
+ }
1921
+ .auth-status-pill .dot {
1922
+ width: 7px; height: 7px;
1923
+ background: var(--accent-green); display: inline-block;
1924
+ box-shadow: 0 0 6px rgba(102,209,181,0.55);
1925
+ }
1926
+ .auth-status-pill .email { color: var(--accent-green); }
1927
+
1928
+ /* responsive */
1929
+ @media (max-width: 960px) {
1930
+ .report { padding: 0 20px; }
1931
+ .archetype-frame { padding: 32px 24px; }
1932
+ .arch-body { grid-template-columns: 1fr; gap: 32px; }
1933
+ .arch-meta-grid { grid-template-columns: 1fr; gap: 16px; }
1934
+ .score-grid { grid-template-columns: 1fr; gap: 16px; }
1935
+ .finding-body { grid-template-columns: 1fr; }
1936
+ .finding-block { border-right: none !important; }
1937
+ .policies-grid { grid-template-columns: 1fr; }
1938
+ .share-grid { grid-template-columns: 1fr; }
1939
+ .strength-row { grid-template-columns: 40px 1fr; }
1940
+ .strength-metric { grid-column: 2; text-align: left; margin-top: 6px; }
1941
+ .return-hook { padding: 28px 24px; }
1942
+ }
1943
+
1944
+ /* reduced-motion: silence the ambient terminal motion (blinking cursor,
1945
+ spinner, marquee shine, status pulse) so vestibular-sensitive users get a
1946
+ still UI. Functional progress (.running-bar-fill width) still updates;
1947
+ only the decorative loops are stopped. */
1948
+ @media (prefers-reduced-motion: reduce) {
1949
+ .running-cursor,
1950
+ .running-stage-spin,
1951
+ .running-bar-fill::after,
1952
+ .auth-status-pill .dot {
1953
+ animation: none;
1954
+ }
1955
+ .running-bar-fill { transition: none; }
1956
+ }
1957
+
1958
+ /* ──────────────── floating share dock ────────────────
1959
+ Persistent share affordance pinned to the bottom-right of the audit
1960
+ page. Uses the same .share-btn styling as the inline strip in
1961
+ identity-section so the visual rhythm carries. The dock can be
1962
+ collapsed to a single pink FAB; preference persists in sessionStorage. */
1963
+
1964
+ .share-dock {
1965
+ position: fixed;
1966
+ right: clamp(16px, 2.5vw, 32px);
1967
+ bottom: clamp(16px, 2.5vw, 32px);
1968
+ z-index: 40;
1969
+ width: 300px;
1970
+ background: var(--bg-2);
1971
+ border: 1px solid var(--line-2);
1972
+ box-shadow:
1973
+ 8px 8px 0 0 var(--accent-pink-shadow),
1974
+ 16px 16px 0 0 rgba(0, 0, 0, 0.5);
1975
+ animation: share-dock-in 320ms cubic-bezier(0.22, 1, 0.36, 1);
1976
+ }
1977
+ .share-dock::before,
1978
+ .share-dock::after { content: ""; position: absolute; width: 10px; height: 10px; }
1979
+ .share-dock::before {
1980
+ top: -1px; left: -1px;
1981
+ border-top: 1px solid var(--accent-pink);
1982
+ border-left: 1px solid var(--accent-pink);
1983
+ }
1984
+ .share-dock::after {
1985
+ bottom: -1px; right: -1px;
1986
+ border-bottom: 1px solid var(--accent-pink);
1987
+ border-right: 1px solid var(--accent-pink);
1988
+ }
1989
+
1990
+ @keyframes share-dock-in {
1991
+ from { opacity: 0; transform: translate(8px, 8px); }
1992
+ to { opacity: 1; transform: translate(0, 0); }
1993
+ }
1994
+
1995
+ .share-dock-head {
1996
+ display: flex; align-items: center; justify-content: space-between;
1997
+ padding: 12px 16px;
1998
+ border-bottom: 1px dashed var(--line);
1999
+ }
2000
+ .share-dock-eyebrow {
2001
+ font-family: var(--font-mono); font-size: 10px;
2002
+ letter-spacing: 0.22em; text-transform: uppercase;
2003
+ color: var(--accent-green);
2004
+ }
2005
+ .share-dock-eyebrow > span { color: var(--accent-pink); margin-right: 8px; letter-spacing: -2px; }
2006
+ .share-dock-caret {
2007
+ display: grid; place-items: center;
2008
+ width: 24px; height: 24px;
2009
+ background: transparent;
2010
+ border: 1px solid var(--line-2);
2011
+ color: var(--ink-2);
2012
+ font-family: var(--font-mono); font-size: 11px;
2013
+ cursor: pointer;
2014
+ transition: color 140ms cubic-bezier(0.22, 1, 0.36, 1), border-color 140ms cubic-bezier(0.22, 1, 0.36, 1);
2015
+ }
2016
+ .share-dock-caret:hover { color: var(--accent-pink); border-color: var(--accent-pink); }
2017
+
2018
+ .share-dock-stack {
2019
+ display: flex; flex-direction: column;
2020
+ gap: 8px;
2021
+ padding: 14px 14px 10px;
2022
+ }
2023
+ /* Dock buttons fill the dock width — same `.share-btn` skin, just full-width. */
2024
+ .share-dock-stack .share-btn { width: 100%; }
2025
+
2026
+ .share-dock-foot {
2027
+ padding: 10px 16px 12px;
2028
+ border-top: 1px dashed var(--line);
2029
+ font-family: var(--font-mono); font-size: 10px;
2030
+ letter-spacing: 0.18em; text-transform: uppercase;
2031
+ color: var(--dim);
2032
+ text-align: center;
2033
+ }
2034
+ .share-dock-foot > span { color: var(--accent-pink); margin-right: 6px; }
2035
+
2036
+ /* Collapsed-state FAB — single pink-tile button that re-expands the dock. */
2037
+ .share-dock-fab {
2038
+ position: fixed;
2039
+ right: clamp(16px, 2.5vw, 32px);
2040
+ bottom: clamp(16px, 2.5vw, 32px);
2041
+ z-index: 40;
2042
+ width: 56px; height: 56px;
2043
+ display: grid; place-items: center;
2044
+ background: var(--accent-pink);
2045
+ color: var(--bg);
2046
+ border: 1px solid var(--accent-pink);
2047
+ box-shadow: 6px 6px 0 0 var(--accent-pink-shadow);
2048
+ font-family: var(--font-mono);
2049
+ font-size: 22px; font-weight: 700;
2050
+ cursor: pointer;
2051
+ transition: transform 160ms cubic-bezier(0.22, 1, 0.36, 1), box-shadow 160ms cubic-bezier(0.22, 1, 0.36, 1);
2052
+ animation: share-dock-in 320ms cubic-bezier(0.22, 1, 0.36, 1);
2053
+ }
2054
+ .share-dock-fab:hover { transform: translate(-2px, -2px); box-shadow: 9px 9px 0 0 var(--accent-pink-shadow); }
2055
+ .share-dock-fab:active { transform: translate(2px, 2px); box-shadow: 0 0 0 0 var(--accent-pink-shadow); }
2056
+
2057
+ /* hide on mobile — inline buttons cover the same affordance there */
2058
+ @media (max-width: 760px) {
2059
+ .share-dock, .share-dock-fab { display: none; }
2060
+ }
2061
+
2062
+ @media (prefers-reduced-motion: reduce) {
2063
+ .share-dock, .share-dock-fab { animation: none; }
2064
+ .share-dock-fab { transition: none; }
2065
+ .share-dock-caret { transition: none; }
2066
+ }