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.
- package/.next/standalone/.next/BUILD_ID +1 -1
- package/.next/standalone/.next/app-path-routes-manifest.json +8 -1
- package/.next/standalone/.next/build-manifest.json +10 -10
- package/.next/standalone/.next/prerender-manifest.json +3 -32
- package/.next/standalone/.next/required-server-files.json +2 -1
- package/.next/standalone/.next/routes-manifest.json +45 -3
- package/.next/standalone/.next/server/app/_global-error/page/build-manifest.json +7 -7
- package/.next/standalone/.next/server/app/_global-error/page/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/server/app/_global-error/page.js +6 -6
- package/.next/standalone/.next/server/app/_global-error/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/_global-error.html +1 -1
- package/.next/standalone/.next/server/app/_global-error.rsc +7 -7
- package/.next/standalone/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/_global-error.segments/_full.segment.rsc +7 -7
- package/.next/standalone/.next/server/app/_global-error.segments/_head.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/_global-error.segments/_index.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
- package/.next/standalone/.next/server/app/_not-found/page/build-manifest.json +7 -7
- package/.next/standalone/.next/server/app/_not-found/page/next-font-manifest.json +2 -6
- package/.next/standalone/.next/server/app/_not-found/page/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/server/app/_not-found/page.js +12 -13
- package/.next/standalone/.next/server/app/_not-found/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/_not-found.html +1 -1
- package/.next/standalone/.next/server/app/_not-found.rsc +16 -16
- package/.next/standalone/.next/server/app/_not-found.segments/_full.segment.rsc +16 -16
- package/.next/standalone/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/_not-found.segments/_index.segment.rsc +10 -10
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
- package/.next/standalone/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/api/audit/run/route/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/app/api/audit/run/route/server-reference-manifest.json +4 -0
- package/.next/standalone/.next/server/app/api/audit/run/route.js +8 -0
- package/.next/standalone/.next/server/app/api/audit/run/route.js.nft.json +1 -0
- package/.next/standalone/.next/server/app/api/audit/run/route_client-reference-manifest.js +3 -0
- package/.next/standalone/.next/server/app/api/audit/status/route/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/app/api/audit/status/route/build-manifest.json +9 -0
- package/.next/standalone/.next/server/app/api/audit/status/route/server-reference-manifest.json +4 -0
- package/.next/standalone/.next/server/app/api/audit/status/route.js +6 -0
- package/.next/standalone/.next/server/app/api/audit/status/route.js.map +5 -0
- package/.next/standalone/.next/server/app/api/audit/status/route.js.nft.json +1 -0
- package/.next/standalone/.next/server/app/api/audit/status/route_client-reference-manifest.js +3 -0
- package/.next/standalone/.next/server/app/api/auth/login-request/route/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/app/api/auth/login-request/route/build-manifest.json +9 -0
- package/.next/standalone/.next/server/app/api/auth/login-request/route/server-reference-manifest.json +4 -0
- package/.next/standalone/.next/server/app/api/auth/login-request/route.js +6 -0
- package/.next/standalone/.next/server/app/api/auth/login-request/route.js.map +5 -0
- package/.next/standalone/.next/server/app/api/auth/login-request/route.js.nft.json +1 -0
- package/.next/standalone/.next/server/app/api/auth/login-request/route_client-reference-manifest.js +3 -0
- package/.next/standalone/.next/server/app/api/auth/login-verify/route/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/app/api/auth/login-verify/route/build-manifest.json +9 -0
- package/.next/standalone/.next/server/app/api/auth/login-verify/route/server-reference-manifest.json +4 -0
- package/.next/standalone/.next/server/app/api/auth/login-verify/route.js +7 -0
- package/.next/standalone/.next/server/app/api/auth/login-verify/route.js.map +5 -0
- package/.next/standalone/.next/server/app/api/auth/login-verify/route.js.nft.json +1 -0
- package/.next/standalone/.next/server/app/api/auth/login-verify/route_client-reference-manifest.js +3 -0
- package/.next/standalone/.next/server/app/api/auth/logout/route/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/app/api/auth/logout/route/build-manifest.json +9 -0
- package/.next/standalone/.next/server/app/api/auth/logout/route/server-reference-manifest.json +4 -0
- package/.next/standalone/.next/server/app/api/auth/logout/route.js +7 -0
- package/.next/standalone/.next/server/app/api/auth/logout/route.js.map +5 -0
- package/.next/standalone/.next/server/app/api/auth/logout/route.js.nft.json +1 -0
- package/.next/standalone/.next/server/app/api/auth/logout/route_client-reference-manifest.js +3 -0
- package/.next/standalone/.next/server/app/api/auth/reminder/route/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/app/api/auth/reminder/route/build-manifest.json +9 -0
- package/.next/standalone/.next/server/app/api/auth/reminder/route/server-reference-manifest.json +4 -0
- package/.next/standalone/.next/server/app/api/auth/reminder/route.js +7 -0
- package/.next/standalone/.next/server/app/api/auth/reminder/route.js.map +5 -0
- package/.next/standalone/.next/server/app/api/auth/reminder/route.js.nft.json +1 -0
- package/.next/standalone/.next/server/app/api/auth/reminder/route_client-reference-manifest.js +3 -0
- package/.next/standalone/.next/server/app/api/auth/status/route/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/app/api/auth/status/route/build-manifest.json +9 -0
- package/.next/standalone/.next/server/app/api/auth/status/route/server-reference-manifest.json +4 -0
- package/.next/standalone/.next/server/app/api/auth/status/route.js +7 -0
- package/.next/standalone/.next/server/app/api/auth/status/route.js.map +5 -0
- package/.next/standalone/.next/server/app/api/auth/status/route.js.nft.json +1 -0
- package/.next/standalone/.next/server/app/api/auth/status/route_client-reference-manifest.js +3 -0
- package/.next/standalone/.next/server/app/api/download/[project]/[session]/route.js +3 -3
- package/.next/standalone/.next/server/app/api/download/[project]/[session]/route.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/audit/page/app-paths-manifest.json +3 -0
- package/.next/standalone/.next/server/app/audit/page/build-manifest.json +18 -0
- package/.next/standalone/.next/server/app/audit/page/next-font-manifest.json +6 -0
- package/.next/standalone/.next/server/app/audit/page/react-loadable-manifest.json +1 -0
- package/.next/standalone/.next/server/app/audit/page/server-reference-manifest.json +29 -0
- package/.next/standalone/.next/server/app/audit/page.js +17 -0
- package/.next/standalone/.next/server/app/audit/page.js.map +5 -0
- package/.next/standalone/.next/server/app/audit/page.js.nft.json +1 -0
- package/.next/standalone/.next/server/app/audit/page_client-reference-manifest.js +3 -0
- package/.next/standalone/.next/server/app/index.html +1 -1
- package/.next/standalone/.next/server/app/index.rsc +16 -17
- package/.next/standalone/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
- package/.next/standalone/.next/server/app/index.segments/_full.segment.rsc +16 -17
- package/.next/standalone/.next/server/app/index.segments/_head.segment.rsc +4 -4
- package/.next/standalone/.next/server/app/index.segments/_index.segment.rsc +10 -10
- package/.next/standalone/.next/server/app/index.segments/_tree.segment.rsc +2 -3
- package/.next/standalone/.next/server/app/page/build-manifest.json +7 -7
- package/.next/standalone/.next/server/app/page/next-font-manifest.json +2 -6
- package/.next/standalone/.next/server/app/page/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/server/app/page.js +14 -15
- package/.next/standalone/.next/server/app/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/policies/page/build-manifest.json +7 -7
- package/.next/standalone/.next/server/app/policies/page/next-font-manifest.json +2 -6
- package/.next/standalone/.next/server/app/policies/page/server-reference-manifest.json +8 -8
- package/.next/standalone/.next/server/app/policies/page.js +16 -16
- package/.next/standalone/.next/server/app/policies/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/policies/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/project/[name]/page/build-manifest.json +7 -7
- package/.next/standalone/.next/server/app/project/[name]/page/next-font-manifest.json +2 -6
- package/.next/standalone/.next/server/app/project/[name]/page/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/server/app/project/[name]/page.js +16 -17
- package/.next/standalone/.next/server/app/project/[name]/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/project/[name]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/build-manifest.json +7 -7
- package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/next-font-manifest.json +2 -6
- package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/react-loadable-manifest.json +2 -2
- package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page/server-reference-manifest.json +2 -2
- package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page.js +19 -20
- package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/project/[name]/session/[sessionId]/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app/projects/page/build-manifest.json +7 -7
- package/.next/standalone/.next/server/app/projects/page/next-font-manifest.json +2 -6
- package/.next/standalone/.next/server/app/projects/page/server-reference-manifest.json +1 -1
- package/.next/standalone/.next/server/app/projects/page.js +15 -16
- package/.next/standalone/.next/server/app/projects/page.js.nft.json +1 -1
- package/.next/standalone/.next/server/app/projects/page_client-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/app-paths-manifest.json +8 -1
- package/.next/standalone/.next/server/chunks/[externals]__14odj07._.js +3 -0
- package/.next/standalone/.next/server/chunks/{[externals]__0z0j--b._.js → [externals]__1nl3dvw._.js} +1 -1
- package/.next/standalone/.next/server/chunks/{[externals]__0-p9.k~._.js → [externals]__1s61mel._.js} +1 -1
- package/.next/standalone/.next/server/chunks/{[externals]_node_os_06ur78j._.js → [externals]_node_os_0by37l-._.js} +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__07tgnzi._.js +3 -0
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0kjo7d_._.js → [root-of-the-server]__0_0xu5z._.js} +2 -2
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0cag8qd._.js +3 -0
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0z-180.._.js → [root-of-the-server]__0cycwg6._.js} +2 -2
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__08px0ym._.js → [root-of-the-server]__0f7mikp._.js} +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0oeun7z._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0q-v9z2._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0rv7m0k._.js +3 -0
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0g48iv.._.js → [root-of-the-server]__0sb_5m8._.js} +3 -3
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0j8-xkl._.js → [root-of-the-server]__0xuaoik._.js} +2 -2
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__12pit4m._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__13h8pzr._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__13ra2jq._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__17g9wh7._.js +3 -0
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0d_ob4n._.js → [root-of-the-server]__1_mqemn._.js} +2 -2
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__1b9z5-i._.js +3 -0
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0vlhtkc._.js → [root-of-the-server]__1hgv_75._.js} +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__1ixjiy8._.js +3 -0
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0wu7fr7._.js → [root-of-the-server]__1jm9fw6._.js} +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__1legmza._.js +3 -0
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0fwb7ao._.js → [root-of-the-server]__1m2_4t0._.js} +2 -2
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0yfq1yr._.js → [root-of-the-server]__1mhmdzs._.js} +1 -1
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0zso~62._.js → [root-of-the-server]__1ou2ehh._.js} +1 -1
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__1qxztj-._.js +3 -0
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__1rhmvod._.js +3 -0
- package/.next/standalone/.next/server/chunks/{[root-of-the-server]__0.~nmr9._.js → [root-of-the-server]__1w9zl9-._.js} +1 -1
- package/.next/standalone/.next/server/chunks/{_0ebx_lc._.js → _0p53ge1._.js} +2 -2
- package/.next/standalone/.next/server/chunks/_1-1804f._.js +3 -0
- package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_audit_run_route_actions_1qgp9io.js +3 -0
- package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_audit_status_route_actions_1f7pjof.js +3 -0
- package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_auth_login-request_route_actions_1c49co0.js +3 -0
- package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_auth_login-verify_route_actions_1r3slzk.js +3 -0
- package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_auth_logout_route_actions_0regwyr.js +3 -0
- package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_auth_reminder_route_actions_1kjgxf8.js +3 -0
- package/.next/standalone/.next/server/chunks/_next-internal_server_app_api_auth_status_route_actions_1aho9zu.js +3 -0
- 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
- package/.next/standalone/.next/server/chunks/{lib_logger_ts_047tt9f._.js → lib_logger_ts_07e65t5._.js} +1 -1
- package/.next/standalone/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_17k9e3w.js +23 -0
- package/.next/standalone/.next/server/chunks/node_modules_posthog-node_dist_entrypoints_index_node_mjs_01r25oi._.js +3 -0
- package/.next/standalone/.next/server/chunks/node_modules_posthog-node_dist_entrypoints_index_node_mjs_09z9-p7._.js +3 -0
- package/.next/standalone/.next/server/chunks/{package_json_[json]_cjs_0z7w.hh._.js → package_json_[json]_cjs_1nxcc4v._.js} +2 -2
- package/.next/standalone/.next/server/chunks/ssr/{[externals]__12dv.x0._.js → [externals]__1_g_b3t._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{[externals]_node_async_hooks_0v0ln8c._.js → [externals]_node_async_hooks_1gjz99j._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0ts150~._.js → [root-of-the-server]__0-wdurj._.js} +2 -2
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__00jkjmt._.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__013du6r._.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__06f-yix._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0989_dx._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0e85wxv._.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0gfxvb1._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0h12me5._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0l13qf2._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1-scthx._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__11rtg6s._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__14dd6h8._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1cd25c7._.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0t5l7a5._.js → [root-of-the-server]__1d8omgc._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0tcyn68._.js → [root-of-the-server]__1dky4g0._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__098zro9._.js → [root-of-the-server]__1fax1sl._.js} +4 -4
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1hlrq6y._.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1ihxdo5._.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1mt35_w._.js +221 -0
- package/.next/standalone/.next/server/chunks/ssr/{[root-of-the-server]__0-wn51s._.js → [root-of-the-server]__1pcxxwg._.js} +3 -3
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1usf8v2._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__1vvfde2._.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__212nf49._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/{_03d7qyt._.js → _05whahf._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/_11_p9y8._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/{_0xb8ngh._.js → _1kje4fm._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{_0zx~s__._.js → _1p0-leb._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{app_04qfs8z._.js → app_087bt9w._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{app_0uosk1e._.js → app_1fvisnp._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{app_13f0ohr._.js → app_209u41o._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/app_audit__components_audit-dashboard_tsx_0p9ud47._.js +43 -0
- package/.next/standalone/.next/server/chunks/ssr/app_audit_loading_tsx_1j1kc6j._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/{app_error_tsx_11t4ysq._.js → app_error_tsx_1zds1ns._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{app_global-error_tsx_0m9qisk._.js → app_global-error_tsx_113y3za._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{app_global-error_tsx_0xerkr6._.js → app_global-error_tsx_1kp6l3x._.js} +2 -2
- package/.next/standalone/.next/server/chunks/ssr/app_policies_hooks-client_tsx_19dqvpc._.js +8 -0
- 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
- package/.next/standalone/.next/server/chunks/ssr/{app_project_[name]_loading_tsx_03g9xy0._.js → app_project_[name]_loading_tsx_05-l4uf._.js} +1 -1
- 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
- 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
- package/.next/standalone/.next/server/chunks/ssr/app_projects_loading_tsx_20-3u8b._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/{lib_codex-projects_ts_0eosib~._.js → lib_codex-projects_ts_0pqlw37._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{lib_copilot-projects_ts_0r8xkn8._.js → lib_copilot-projects_ts_19wl7tp._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{lib_cursor-projects_ts_0qt1scg._.js → lib_cursor-projects_ts_18-iwyk._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{lib_gemini-projects_ts_0sl~yqr._.js → lib_gemini-projects_ts_1c7bgx-._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{lib_opencode-projects_ts_0op9gyp._.js → lib_opencode-projects_ts_15bjxkm._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{lib_pi-projects_ts_103tsh1._.js → lib_pi-projects_ts_1wikofb._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{lib_utils_ts_068jk73._.js → lib_utils_ts_0az0sfq._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/node_modules_1ynf7el._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/node_modules_html2canvas_dist_html2canvas_esm_0hmsdod.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/node_modules_html2canvas_dist_html2canvas_esm_1n-0xws.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/{node_modules_next_0rd0oc-._.js → node_modules_next_1a1kch7._.js} +1 -1
- package/.next/standalone/.next/server/chunks/ssr/{node_modules_next_dist_0h9llsw._.js → node_modules_next_dist_0uboya6._.js} +2 -2
- package/.next/standalone/.next/server/chunks/ssr/{node_modules_next_dist_11dij6w._.js → node_modules_next_dist_1d_onnt._.js} +3 -3
- 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
- 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
- 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
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0-uvagv.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_03c7gi5.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_09p-8om.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0v-kfiu.js +4 -0
- 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
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_1806lsc.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_1j6dd-e.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_1sa65r-.js +4 -0
- package/.next/standalone/.next/server/chunks/ssr/node_modules_posthog-node_dist_entrypoints_index_node_mjs_11bnuzn._.js +3 -0
- package/.next/standalone/.next/server/chunks/ssr/src_hooks_1ezd2jf._.js +5 -0
- package/.next/standalone/.next/server/chunks/ssr/src_hooks_1tnuifj._.js +5 -0
- package/.next/standalone/.next/server/functions-config-manifest.json +3 -0
- package/.next/standalone/.next/server/instrumentation.js +1 -1
- package/.next/standalone/.next/server/middleware-build-manifest.js +10 -10
- package/.next/standalone/.next/server/middleware.js +2 -2
- package/.next/standalone/.next/server/next-font-manifest.js +1 -1
- package/.next/standalone/.next/server/next-font-manifest.json +2 -21
- package/.next/standalone/.next/server/pages/404.html +1 -1
- package/.next/standalone/.next/server/pages/500.html +1 -1
- package/.next/standalone/.next/server/server-reference-manifest.js +1 -1
- package/.next/standalone/.next/server/server-reference-manifest.json +27 -9
- package/.next/standalone/.next/static/chunks/{07uz2g0_38qia.js → 03fmihek9n986.js} +1 -1
- package/.next/standalone/.next/static/chunks/09ueq8s1as8xs.css +2 -0
- package/.next/standalone/.next/static/chunks/0fkntmojmibda.js +6 -0
- package/.next/standalone/.next/static/chunks/{11w14gnqzprir.js → 0nbmu4_n1j2-c.js} +1 -1
- package/.next/standalone/.next/static/chunks/0qassxjx1ef04.js +1 -0
- package/.next/standalone/.next/static/chunks/0zbxssxh53n-3.js +1 -0
- package/.next/standalone/.next/static/chunks/13f1kmjea-0md.js +2 -0
- package/.next/standalone/.next/static/chunks/1btx2c49fk9xt.css +1 -0
- package/.next/standalone/.next/static/chunks/1bxdpd036n3l9.js +41 -0
- package/.next/standalone/.next/static/chunks/{0bke.~atnsbeb.js → 1e0o-6kjfnwzh.js} +1 -1
- package/.next/standalone/.next/static/chunks/20b5bz43so-1k.js +1 -0
- package/.next/standalone/.next/static/chunks/2zjavpea8glet.js +1 -0
- package/.next/standalone/.next/static/chunks/{0d3shmwh5_nmn.js → 33u59vf_8xpd-.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0dvhi-prcsh3~.js → 36l507r2mbf5h.js} +1 -1
- package/.next/standalone/.next/static/chunks/3gti1qdk5epqn.js +1 -0
- package/.next/standalone/.next/static/chunks/{17mubwtqwijpu.js → 3w8d8k_dca5rp.js} +1 -1
- package/.next/standalone/.next/static/chunks/{0bv1oyxspkpkb.js → 3y3l184vijlfg.js} +1 -1
- package/.next/standalone/.next/static/chunks/41jjdgqqpl7em.js +1 -0
- package/.next/standalone/.next/static/chunks/{turbopack-0nh.aopesgj~5.js → turbopack-00qy7zfa7m--m.js} +1 -1
- package/.next/standalone/SECURITY.md +73 -0
- package/.next/standalone/app/actions/get-audit-result.ts +24 -0
- package/.next/standalone/app/api/audit/_state.ts +72 -0
- package/.next/standalone/app/api/audit/run/route.ts +89 -0
- package/.next/standalone/app/api/audit/status/route.ts +23 -0
- package/.next/standalone/app/api/auth/login-request/route.ts +91 -0
- package/.next/standalone/app/api/auth/login-verify/route.ts +98 -0
- package/.next/standalone/app/api/auth/logout/route.ts +48 -0
- package/.next/standalone/app/api/auth/reminder/route.ts +213 -0
- package/.next/standalone/app/api/auth/status/route.ts +42 -0
- package/.next/standalone/app/audit/_components/audit-dashboard.tsx +364 -0
- package/.next/standalone/app/audit/_components/auth-dialog.tsx +401 -0
- package/.next/standalone/app/audit/_components/empty-state.tsx +146 -0
- package/.next/standalone/app/audit/_components/findings-section.tsx +135 -0
- package/.next/standalone/app/audit/_components/identity-section.tsx +126 -0
- package/.next/standalone/app/audit/_components/policies-section.tsx +194 -0
- package/.next/standalone/app/audit/_components/report-footer.tsx +35 -0
- package/.next/standalone/app/audit/_components/rerun-button.tsx +81 -0
- package/.next/standalone/app/audit/_components/return-section.tsx +428 -0
- package/.next/standalone/app/audit/_components/run-progress.tsx +120 -0
- package/.next/standalone/app/audit/_components/score-section.tsx +179 -0
- package/.next/standalone/app/audit/_components/share-dock.tsx +265 -0
- package/.next/standalone/app/audit/_components/share-templates.ts +67 -0
- package/.next/standalone/app/audit/_components/show-off-cta.tsx +135 -0
- package/.next/standalone/app/audit/_components/sigil.tsx +93 -0
- package/.next/standalone/app/audit/_components/strengths-section.tsx +57 -0
- package/.next/standalone/app/audit/audit-styles.css +2066 -0
- package/.next/standalone/app/audit/loading.tsx +24 -0
- package/.next/standalone/app/audit/page.tsx +53 -0
- package/.next/standalone/app/globals.css +570 -137
- package/.next/standalone/app/layout.tsx +16 -9
- package/.next/standalone/app/policies/hooks-client.tsx +223 -129
- package/.next/standalone/app/project/[name]/page.tsx +89 -39
- package/.next/standalone/app/projects/loading.tsx +30 -8
- package/.next/standalone/app/projects/page.tsx +76 -18
- package/.next/standalone/assets/audit/Audit Report.html +22 -0
- package/.next/standalone/assets/audit/Show Off Your Agent.html +22 -0
- package/.next/standalone/assets/audit/archetypes.jsx +277 -0
- package/.next/standalone/assets/audit/assets/fonts/bitcount-prop-single.woff2 +0 -0
- package/.next/standalone/assets/audit/audit.jsx +825 -0
- package/.next/standalone/assets/audit/poster-styles.css +424 -0
- package/.next/standalone/assets/audit/poster.jsx +247 -0
- package/.next/standalone/assets/audit/screenshots/poster-optimist.png +0 -0
- package/.next/standalone/assets/audit/screenshots/poster-scrolled.png +0 -0
- package/.next/standalone/assets/audit/styles.css +1225 -0
- package/.next/standalone/assets/audit/tweaks-panel.jsx +425 -0
- package/.next/standalone/assets/logos/company/icon.svg +1 -0
- package/.next/standalone/assets/logos/company/logo.svg +1 -0
- package/.next/standalone/components/navbar.tsx +154 -65
- package/.next/standalone/components/reach-developers.tsx +37 -9
- package/.next/standalone/lib/atomic-write.ts +67 -0
- package/.next/standalone/lib/auth/api-server-client.ts +281 -0
- package/.next/standalone/lib/auth/auth-store.ts +250 -0
- package/.next/standalone/lib/client-telemetry.ts +2 -0
- package/.next/standalone/lib/fetch-with-timeout.ts +42 -0
- package/.next/standalone/lib/share-card.ts +144 -0
- package/.next/standalone/lib/telemetry.ts +12 -7
- package/.next/standalone/node_modules/@next/env/package.json +1 -1
- package/.next/standalone/node_modules/next/dist/build/swc/index.js +1 -1
- package/.next/standalone/node_modules/next/dist/client/dev/debug-channel.js +102 -2
- package/.next/standalone/node_modules/next/dist/compiled/next-server/app-page-turbo-experimental.runtime.prod.js +11 -11
- package/.next/standalone/node_modules/next/dist/compiled/next-server/app-page-turbo.runtime.prod.js +13 -13
- package/.next/standalone/node_modules/next/dist/compiled/next-server/app-route-turbo.runtime.prod.js +2 -2
- package/.next/standalone/node_modules/next/dist/compiled/next-server/pages-turbo.runtime.prod.js +1 -1
- package/.next/standalone/node_modules/next/dist/lib/patch-incorrect-lockfile.js +3 -3
- package/.next/standalone/node_modules/next/dist/server/app-render/action-handler.js +18 -8
- package/.next/standalone/node_modules/next/dist/server/config-schema.js +1 -0
- package/.next/standalone/node_modules/next/dist/server/config.js +1 -1
- package/.next/standalone/node_modules/next/dist/server/dev/hot-reloader-turbopack.js +2 -2
- package/.next/standalone/node_modules/next/dist/server/dev/hot-reloader-webpack.js +1 -1
- package/.next/standalone/node_modules/next/dist/server/lib/app-info-log.js +1 -1
- package/.next/standalone/node_modules/next/dist/server/lib/encode-cache-tag.js +45 -0
- package/.next/standalone/node_modules/next/dist/server/lib/implicit-tags.js +6 -3
- package/.next/standalone/node_modules/next/dist/server/lib/patch-fetch.js +5 -1
- package/.next/standalone/node_modules/next/dist/server/lib/start-server.js +1 -1
- package/.next/standalone/node_modules/next/dist/server/web/spec-extension/revalidate.js +4 -3
- package/.next/standalone/node_modules/next/dist/server/web/spec-extension/unstable-cache.js +6 -2
- package/.next/standalone/node_modules/next/dist/shared/lib/errors/canary-only-config-error.js +1 -1
- package/.next/standalone/node_modules/next/dist/telemetry/anonymous-meta.js +1 -1
- package/.next/standalone/node_modules/next/dist/telemetry/events/swc-load-failure.js +1 -1
- package/.next/standalone/node_modules/next/dist/telemetry/events/version.js +2 -2
- package/.next/standalone/node_modules/next/package.json +15 -15
- package/.next/standalone/node_modules/react/cjs/react.development.js +1 -1
- package/.next/standalone/node_modules/react/cjs/react.production.js +1 -1
- package/.next/standalone/node_modules/react/package.json +1 -1
- package/.next/standalone/node_modules/react-dom/cjs/react-dom-server-legacy.browser.production.js +1 -1
- package/.next/standalone/node_modules/react-dom/cjs/react-dom-server-legacy.node.production.js +1 -1
- package/.next/standalone/node_modules/react-dom/cjs/react-dom-server.browser.production.js +3 -3
- package/.next/standalone/node_modules/react-dom/cjs/react-dom-server.edge.production.js +3 -3
- package/.next/standalone/node_modules/react-dom/cjs/react-dom-server.node.production.js +3 -3
- package/.next/standalone/node_modules/react-dom/cjs/react-dom.production.js +1 -1
- package/.next/standalone/node_modules/react-dom/package.json +2 -2
- package/.next/standalone/osv-scanner.toml +17 -0
- package/.next/standalone/package.json +8 -3
- package/.next/standalone/public/audit/fonts/bitcount-prop-single.woff2 +0 -0
- package/.next/standalone/public/icon.svg +1 -0
- package/.next/standalone/public/logo.svg +1 -0
- package/.next/standalone/server.js +1 -1
- package/.next/standalone/templates/bitcount-font/README.md +42 -0
- package/.next/standalone/templates/bitcount-font/bitcount-prop-single.woff2 +0 -0
- package/.next/standalone/templates/bitcount-font/bitcount.css +49 -0
- package/.next/standalone/templates/bitcount-font/fonts.ts.example +23 -0
- package/README.md +2 -1
- package/bin/failproofai.mjs +165 -144
- package/dist/cli.mjs +607 -1858
- package/lib/atomic-write.ts +67 -0
- package/lib/auth/api-server-client.ts +281 -0
- package/lib/auth/auth-store.ts +250 -0
- package/lib/client-telemetry.ts +2 -0
- package/lib/fetch-with-timeout.ts +42 -0
- package/lib/share-card.ts +144 -0
- package/lib/telemetry.ts +12 -7
- package/package.json +8 -3
- package/scripts/install-telemetry.mjs +4 -0
- package/src/audit/archetypes.ts +924 -0
- package/src/audit/cache.ts +21 -2
- package/src/audit/dashboard-cache.ts +111 -0
- package/src/audit/features.ts +268 -0
- package/src/audit/findings.ts +298 -0
- package/src/audit/index.ts +39 -21
- package/src/audit/replay.ts +29 -3
- package/src/audit/scoring.ts +174 -0
- package/src/audit/strengths.ts +138 -0
- package/src/audit/types.ts +24 -1
- package/src/auth/cli.ts +359 -0
- package/src/hooks/builtin-policies.ts +2 -1
- package/src/hooks/hook-telemetry.ts +2 -2
- package/src/hooks/policy-registry.ts +20 -0
- package/src/posthog-key.ts +9 -0
- package/.next/standalone/.next/server/app/icon.png/route/app-paths-manifest.json +0 -3
- package/.next/standalone/.next/server/app/icon.png/route.js +0 -7
- package/.next/standalone/.next/server/app/icon.png/route.js.nft.json +0 -1
- package/.next/standalone/.next/server/app/icon.png.body +0 -0
- package/.next/standalone/.next/server/app/icon.png.meta +0 -1
- package/.next/standalone/.next/server/chunks/[externals]_next_dist_0sqmaqd._.js +0 -3
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__06.arfm._.js +0 -3
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0__i0h0._.js +0 -3
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0fe7_q_._.js +0 -3
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0fw.e.h._.js +0 -3
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0pxn0e1._.js +0 -3
- package/.next/standalone/.next/server/chunks/[root-of-the-server]__0xv0jh2._.js +0 -3
- package/.next/standalone/.next/server/chunks/_next-internal_server_app_icon_png_route_actions_12.gv.r.js +0 -3
- package/.next/standalone/.next/server/chunks/node_modules_next_dist_esm_build_templates_app-route_0bdfoky.js +0 -3
- package/.next/standalone/.next/server/chunks/node_modules_posthog-node_dist_entrypoints_index_node_mjs_05pz9._._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__01as125._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0370~qj._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__09v.ljl._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0agrcb8._.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0b7hkr~._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0ehh6vp._.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0g8l0tu._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0j4l6hl._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0k5n2kz._.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0lp08ll._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0n0yaqw._.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0o21f.o._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0t8juvy._.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0uylufv._.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0ymlddl._.js +0 -223
- package/.next/standalone/.next/server/chunks/ssr/[root-of-the-server]__0~03grs._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/app_0cdqd9w._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/app_policies_hooks-client_tsx_0q-m0y-._.js +0 -8
- package/.next/standalone/.next/server/chunks/ssr/app_projects_loading_tsx_13veom4._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/node_modules_0ttbz1~._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_06u0kr8._.js +0 -3
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0a_7sdg.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0ef3uwk.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0pbja1x.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_0r6o0i2.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_11y81~_.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/node_modules_next_dist_esm_build_templates_app-page_12or2kf.js +0 -4
- package/.next/standalone/.next/server/chunks/ssr/node_modules_posthog-node_dist_entrypoints_index_node_mjs_0mebn66._.js +0 -3
- package/.next/standalone/.next/static/chunks/07kpqoo7kuckx.js +0 -6
- package/.next/standalone/.next/static/chunks/0azb~vy9ds_uy.js +0 -1
- package/.next/standalone/.next/static/chunks/0f5p9plm.aqlp.css +0 -2
- package/.next/standalone/.next/static/chunks/0ffvlbgzgnlw7.js +0 -2
- package/.next/standalone/.next/static/chunks/0spktq7xqab9h.js +0 -1
- package/.next/standalone/.next/static/chunks/118q3uljozd5z.js +0 -4
- package/.next/standalone/.next/static/chunks/12pt~2f.c1sha.js +0 -1
- package/.next/standalone/.next/static/media/4fa387ec64143e14-s.0.qu-9752pffj.woff2 +0 -0
- package/.next/standalone/.next/static/media/5ce348bf30bf5439-s.0ee55_hj9qcer.woff2 +0 -0
- package/.next/standalone/.next/static/media/6306c77e7c8268e4-s.0mao5jbfbduzp.woff2 +0 -0
- package/.next/standalone/.next/static/media/797e433ab948586e-s.p.09zddjkbdep5a.woff2 +0 -0
- package/.next/standalone/.next/static/media/7d817b4c03b0c5f1-s.0uzt.a6d44yda.woff2 +0 -0
- package/.next/standalone/.next/static/media/bbc41e54d2fcbd21-s.0mvwgmnhv29no.woff2 +0 -0
- package/.next/standalone/.next/static/media/icon.0a.gigb3_x5pd.png +0 -0
- package/.next/standalone/app/icon.png +0 -0
- package/src/audit/telemetry.ts +0 -113
- /package/.next/standalone/.next/server/app/{icon.png → api/audit/run}/route/build-manifest.json +0 -0
- /package/.next/standalone/.next/server/app/{icon.png → api/audit/run}/route.js.map +0 -0
- /package/.next/standalone/.next/static/chunks/{03~yq9q893hmn.js → 0cz1d0mv5g_q7.js} +0 -0
- /package/.next/standalone/.next/static/chunks/{0a40sy4tk8ioe.js → 0wwt5o04i4zwh.js} +0 -0
- /package/.next/standalone/.next/static/chunks/{0n1n67imq.udf.js → 1__i9af9g78vd.js} +0 -0
- /package/.next/standalone/.next/static/chunks/{0w6fzf.07a24u.js → 2so39wg7mjbi7.js} +0 -0
- /package/.next/standalone/.next/static/chunks/{0xbo5nl6w4lka.js → 2wbuxnsvux4di.js} +0 -0
- /package/.next/standalone/.next/static/chunks/{0_s0luks5tay-.js → 35fgpd_feci6x.js} +0 -0
- /package/.next/standalone/.next/static/chunks/{15fklyav5py5m.js → 3xpjn3cdgm-7m.js} +0 -0
- /package/.next/standalone/.next/static/chunks/{17.b3suj8zjjj.js → 4448_qq7bd963.js} +0 -0
- /package/.next/standalone/.next/static/{tGVQM5SE3NvbVu0gbAJm7 → t4nu8RTRp3Z2srol-9pVb}/_buildManifest.js +0 -0
- /package/.next/standalone/.next/static/{tGVQM5SE3NvbVu0gbAJm7 → t4nu8RTRp3Z2srol-9pVb}/_clientMiddlewareManifest.js +0 -0
- /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
|
+
}
|