gitspace 0.2.0-rc.2 → 0.2.0-rc.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (316) hide show
  1. package/README.md +68 -38
  2. package/package.json +36 -25
  3. package/.claude/settings.local.json +0 -21
  4. package/.gitspace/bundle.json +0 -50
  5. package/.gitspace/select/01-status.sh +0 -40
  6. package/.gitspace/setup/01-install-deps.sh +0 -12
  7. package/.gitspace/setup/02-typecheck.sh +0 -16
  8. package/AGENTS.md +0 -439
  9. package/CLAUDE.md +0 -1
  10. package/bun.lock +0 -647
  11. package/docs/CONNECTION.md +0 -623
  12. package/docs/GATEWAY-WORKER.md +0 -319
  13. package/docs/GETTING-STARTED.md +0 -448
  14. package/docs/GITSPACE-PLATFORM.md +0 -1819
  15. package/docs/INFRASTRUCTURE.md +0 -1347
  16. package/docs/PROTOCOL.md +0 -619
  17. package/docs/QUICKSTART.md +0 -174
  18. package/docs/RELAY.md +0 -327
  19. package/docs/REMOTE-DESIGN.md +0 -549
  20. package/docs/ROADMAP.md +0 -564
  21. package/docs/SITE_DOCS_FIGMA_MAKE.md +0 -1167
  22. package/docs/STACK-DESIGN.md +0 -588
  23. package/docs/UNIFIED_ARCHITECTURE.md +0 -292
  24. package/experiments/pty-benchmark.ts +0 -148
  25. package/experiments/pty-latency.ts +0 -100
  26. package/experiments/router/client.ts +0 -199
  27. package/experiments/router/protocol.ts +0 -74
  28. package/experiments/router/router.ts +0 -217
  29. package/experiments/router/session.ts +0 -180
  30. package/experiments/router/test.ts +0 -133
  31. package/experiments/socket-bandwidth.ts +0 -77
  32. package/homebrew/gitspace.rb +0 -45
  33. package/landing-page/ATTRIBUTIONS.md +0 -3
  34. package/landing-page/README.md +0 -11
  35. package/landing-page/bun.lock +0 -801
  36. package/landing-page/guidelines/Guidelines.md +0 -61
  37. package/landing-page/index.html +0 -37
  38. package/landing-page/package.json +0 -90
  39. package/landing-page/postcss.config.mjs +0 -15
  40. package/landing-page/public/_redirects +0 -1
  41. package/landing-page/public/favicon.png +0 -0
  42. package/landing-page/src/app/App.tsx +0 -53
  43. package/landing-page/src/app/components/figma/ImageWithFallback.tsx +0 -27
  44. package/landing-page/src/app/components/ui/accordion.tsx +0 -66
  45. package/landing-page/src/app/components/ui/alert-dialog.tsx +0 -157
  46. package/landing-page/src/app/components/ui/alert.tsx +0 -66
  47. package/landing-page/src/app/components/ui/aspect-ratio.tsx +0 -11
  48. package/landing-page/src/app/components/ui/avatar.tsx +0 -53
  49. package/landing-page/src/app/components/ui/badge.tsx +0 -46
  50. package/landing-page/src/app/components/ui/breadcrumb.tsx +0 -109
  51. package/landing-page/src/app/components/ui/button.tsx +0 -57
  52. package/landing-page/src/app/components/ui/calendar.tsx +0 -75
  53. package/landing-page/src/app/components/ui/card.tsx +0 -92
  54. package/landing-page/src/app/components/ui/carousel.tsx +0 -241
  55. package/landing-page/src/app/components/ui/chart.tsx +0 -353
  56. package/landing-page/src/app/components/ui/checkbox.tsx +0 -32
  57. package/landing-page/src/app/components/ui/collapsible.tsx +0 -33
  58. package/landing-page/src/app/components/ui/command.tsx +0 -177
  59. package/landing-page/src/app/components/ui/context-menu.tsx +0 -252
  60. package/landing-page/src/app/components/ui/dialog.tsx +0 -135
  61. package/landing-page/src/app/components/ui/drawer.tsx +0 -132
  62. package/landing-page/src/app/components/ui/dropdown-menu.tsx +0 -257
  63. package/landing-page/src/app/components/ui/form.tsx +0 -168
  64. package/landing-page/src/app/components/ui/hover-card.tsx +0 -44
  65. package/landing-page/src/app/components/ui/input-otp.tsx +0 -77
  66. package/landing-page/src/app/components/ui/input.tsx +0 -21
  67. package/landing-page/src/app/components/ui/label.tsx +0 -24
  68. package/landing-page/src/app/components/ui/menubar.tsx +0 -276
  69. package/landing-page/src/app/components/ui/navigation-menu.tsx +0 -168
  70. package/landing-page/src/app/components/ui/pagination.tsx +0 -127
  71. package/landing-page/src/app/components/ui/popover.tsx +0 -48
  72. package/landing-page/src/app/components/ui/progress.tsx +0 -31
  73. package/landing-page/src/app/components/ui/radio-group.tsx +0 -45
  74. package/landing-page/src/app/components/ui/resizable.tsx +0 -56
  75. package/landing-page/src/app/components/ui/scroll-area.tsx +0 -58
  76. package/landing-page/src/app/components/ui/select.tsx +0 -189
  77. package/landing-page/src/app/components/ui/separator.tsx +0 -28
  78. package/landing-page/src/app/components/ui/sheet.tsx +0 -139
  79. package/landing-page/src/app/components/ui/sidebar.tsx +0 -726
  80. package/landing-page/src/app/components/ui/skeleton.tsx +0 -13
  81. package/landing-page/src/app/components/ui/slider.tsx +0 -63
  82. package/landing-page/src/app/components/ui/sonner.tsx +0 -25
  83. package/landing-page/src/app/components/ui/switch.tsx +0 -31
  84. package/landing-page/src/app/components/ui/table.tsx +0 -116
  85. package/landing-page/src/app/components/ui/tabs.tsx +0 -66
  86. package/landing-page/src/app/components/ui/textarea.tsx +0 -18
  87. package/landing-page/src/app/components/ui/toggle-group.tsx +0 -73
  88. package/landing-page/src/app/components/ui/toggle.tsx +0 -47
  89. package/landing-page/src/app/components/ui/tooltip.tsx +0 -61
  90. package/landing-page/src/app/components/ui/use-mobile.ts +0 -21
  91. package/landing-page/src/app/components/ui/utils.ts +0 -6
  92. package/landing-page/src/components/docs/DocsContent.tsx +0 -718
  93. package/landing-page/src/components/docs/DocsSidebar.tsx +0 -84
  94. package/landing-page/src/components/landing/CTA.tsx +0 -59
  95. package/landing-page/src/components/landing/Comparison.tsx +0 -84
  96. package/landing-page/src/components/landing/FaultyTerminal.tsx +0 -424
  97. package/landing-page/src/components/landing/Features.tsx +0 -201
  98. package/landing-page/src/components/landing/Hero.tsx +0 -142
  99. package/landing-page/src/components/landing/Pricing.tsx +0 -140
  100. package/landing-page/src/components/landing/Roadmap.tsx +0 -86
  101. package/landing-page/src/components/landing/Security.tsx +0 -81
  102. package/landing-page/src/components/landing/TerminalWindow.tsx +0 -27
  103. package/landing-page/src/components/landing/UseCases.tsx +0 -55
  104. package/landing-page/src/components/landing/Workflow.tsx +0 -101
  105. package/landing-page/src/components/layout/DashboardNavbar.tsx +0 -37
  106. package/landing-page/src/components/layout/Footer.tsx +0 -55
  107. package/landing-page/src/components/layout/LandingNavbar.tsx +0 -82
  108. package/landing-page/src/components/ui/badge.tsx +0 -39
  109. package/landing-page/src/components/ui/breadcrumb.tsx +0 -115
  110. package/landing-page/src/components/ui/button.tsx +0 -57
  111. package/landing-page/src/components/ui/card.tsx +0 -79
  112. package/landing-page/src/components/ui/mock-terminal.tsx +0 -68
  113. package/landing-page/src/components/ui/separator.tsx +0 -28
  114. package/landing-page/src/lib/utils.ts +0 -6
  115. package/landing-page/src/main.tsx +0 -10
  116. package/landing-page/src/pages/Dashboard.tsx +0 -133
  117. package/landing-page/src/pages/DocsPage.tsx +0 -79
  118. package/landing-page/src/pages/LandingPage.tsx +0 -31
  119. package/landing-page/src/pages/TerminalView.tsx +0 -106
  120. package/landing-page/src/styles/fonts.css +0 -0
  121. package/landing-page/src/styles/index.css +0 -3
  122. package/landing-page/src/styles/tailwind.css +0 -4
  123. package/landing-page/src/styles/theme.css +0 -181
  124. package/landing-page/vite.config.ts +0 -19
  125. package/npm/darwin-arm64/bin/gssh +0 -0
  126. package/npm/darwin-arm64/package.json +0 -20
  127. package/scripts/build.ts +0 -298
  128. package/scripts/release.ts +0 -140
  129. package/src/__tests__/test-utils.ts +0 -298
  130. package/src/commands/__tests__/serve-messages.test.ts +0 -190
  131. package/src/commands/access.ts +0 -298
  132. package/src/commands/add.ts +0 -452
  133. package/src/commands/auth.ts +0 -364
  134. package/src/commands/connect.ts +0 -287
  135. package/src/commands/directory.ts +0 -16
  136. package/src/commands/host.ts +0 -396
  137. package/src/commands/identity.ts +0 -184
  138. package/src/commands/list.ts +0 -200
  139. package/src/commands/relay.ts +0 -315
  140. package/src/commands/remove.ts +0 -241
  141. package/src/commands/serve.ts +0 -1493
  142. package/src/commands/share.ts +0 -456
  143. package/src/commands/status.ts +0 -125
  144. package/src/commands/switch.ts +0 -353
  145. package/src/commands/tmux.ts +0 -317
  146. package/src/core/__tests__/access.test.ts +0 -240
  147. package/src/core/access.ts +0 -277
  148. package/src/core/bundle.ts +0 -342
  149. package/src/core/config.ts +0 -510
  150. package/src/core/git.ts +0 -317
  151. package/src/core/github.ts +0 -151
  152. package/src/core/identity.ts +0 -631
  153. package/src/core/linear.ts +0 -225
  154. package/src/core/shell.ts +0 -161
  155. package/src/core/trusted-relays.ts +0 -315
  156. package/src/index.ts +0 -810
  157. package/src/lib/remote-session/index.ts +0 -7
  158. package/src/lib/remote-session/protocol.ts +0 -267
  159. package/src/lib/remote-session/session-handler.ts +0 -581
  160. package/src/lib/remote-session/workspace-scanner.ts +0 -167
  161. package/src/lib/tmux-lite/README.md +0 -81
  162. package/src/lib/tmux-lite/cli.ts +0 -796
  163. package/src/lib/tmux-lite/crypto/__tests__/helpers/handshake-runner.ts +0 -349
  164. package/src/lib/tmux-lite/crypto/__tests__/helpers/mock-relay.ts +0 -291
  165. package/src/lib/tmux-lite/crypto/__tests__/helpers/test-identities.ts +0 -142
  166. package/src/lib/tmux-lite/crypto/__tests__/integration/authorization.integration.test.ts +0 -339
  167. package/src/lib/tmux-lite/crypto/__tests__/integration/e2e-communication.integration.test.ts +0 -477
  168. package/src/lib/tmux-lite/crypto/__tests__/integration/error-handling.integration.test.ts +0 -499
  169. package/src/lib/tmux-lite/crypto/__tests__/integration/handshake.integration.test.ts +0 -371
  170. package/src/lib/tmux-lite/crypto/__tests__/integration/security.integration.test.ts +0 -573
  171. package/src/lib/tmux-lite/crypto/access-control.test.ts +0 -512
  172. package/src/lib/tmux-lite/crypto/access-control.ts +0 -320
  173. package/src/lib/tmux-lite/crypto/frames.test.ts +0 -262
  174. package/src/lib/tmux-lite/crypto/frames.ts +0 -141
  175. package/src/lib/tmux-lite/crypto/handshake.ts +0 -894
  176. package/src/lib/tmux-lite/crypto/identity.test.ts +0 -220
  177. package/src/lib/tmux-lite/crypto/identity.ts +0 -286
  178. package/src/lib/tmux-lite/crypto/index.ts +0 -51
  179. package/src/lib/tmux-lite/crypto/invites.test.ts +0 -381
  180. package/src/lib/tmux-lite/crypto/invites.ts +0 -215
  181. package/src/lib/tmux-lite/crypto/keyexchange.ts +0 -435
  182. package/src/lib/tmux-lite/crypto/keys.test.ts +0 -58
  183. package/src/lib/tmux-lite/crypto/keys.ts +0 -47
  184. package/src/lib/tmux-lite/crypto/secretbox.test.ts +0 -169
  185. package/src/lib/tmux-lite/crypto/secretbox.ts +0 -124
  186. package/src/lib/tmux-lite/handshake-handler.ts +0 -451
  187. package/src/lib/tmux-lite/protocol.test.ts +0 -307
  188. package/src/lib/tmux-lite/protocol.ts +0 -266
  189. package/src/lib/tmux-lite/relay-client.ts +0 -506
  190. package/src/lib/tmux-lite/server.ts +0 -1250
  191. package/src/lib/tmux-lite/shell-integration.sh +0 -37
  192. package/src/lib/tmux-lite/terminal-queries.test.ts +0 -54
  193. package/src/lib/tmux-lite/terminal-queries.ts +0 -49
  194. package/src/relay/__tests__/e2e-flow.test.ts +0 -1284
  195. package/src/relay/__tests__/helpers/auth.ts +0 -354
  196. package/src/relay/__tests__/helpers/ports.ts +0 -51
  197. package/src/relay/__tests__/protocol-validation.test.ts +0 -265
  198. package/src/relay/authorization.ts +0 -303
  199. package/src/relay/embedded-assets.generated.d.ts +0 -15
  200. package/src/relay/identity.ts +0 -352
  201. package/src/relay/index.ts +0 -57
  202. package/src/relay/pipes.test.ts +0 -427
  203. package/src/relay/pipes.ts +0 -195
  204. package/src/relay/protocol.ts +0 -804
  205. package/src/relay/registries.test.ts +0 -437
  206. package/src/relay/registries.ts +0 -593
  207. package/src/relay/server.test.ts +0 -1323
  208. package/src/relay/server.ts +0 -1092
  209. package/src/relay/signing.ts +0 -238
  210. package/src/relay/types.ts +0 -69
  211. package/src/serve/client-session-manager.ts +0 -622
  212. package/src/serve/daemon.ts +0 -497
  213. package/src/serve/pty-session.ts +0 -236
  214. package/src/serve/types.ts +0 -169
  215. package/src/shared/components/Flow.tsx +0 -453
  216. package/src/shared/components/Flow.tui.tsx +0 -343
  217. package/src/shared/components/Flow.web.tsx +0 -442
  218. package/src/shared/components/Inbox.tsx +0 -446
  219. package/src/shared/components/Inbox.tui.tsx +0 -262
  220. package/src/shared/components/Inbox.web.tsx +0 -329
  221. package/src/shared/components/MachineList.tsx +0 -187
  222. package/src/shared/components/MachineList.tui.tsx +0 -161
  223. package/src/shared/components/MachineList.web.tsx +0 -210
  224. package/src/shared/components/ProjectList.tsx +0 -176
  225. package/src/shared/components/ProjectList.tui.tsx +0 -109
  226. package/src/shared/components/ProjectList.web.tsx +0 -143
  227. package/src/shared/components/SpacesBrowser.tsx +0 -332
  228. package/src/shared/components/SpacesBrowser.tui.tsx +0 -163
  229. package/src/shared/components/SpacesBrowser.web.tsx +0 -221
  230. package/src/shared/components/index.ts +0 -103
  231. package/src/shared/hooks/index.ts +0 -16
  232. package/src/shared/hooks/useNavigation.ts +0 -226
  233. package/src/shared/index.ts +0 -122
  234. package/src/shared/providers/LocalMachineProvider.ts +0 -425
  235. package/src/shared/providers/MachineProvider.ts +0 -165
  236. package/src/shared/providers/RemoteMachineProvider.ts +0 -444
  237. package/src/shared/providers/index.ts +0 -26
  238. package/src/shared/types.ts +0 -145
  239. package/src/tui/adapters.ts +0 -120
  240. package/src/tui/app.tsx +0 -1816
  241. package/src/tui/components/Terminal.tsx +0 -580
  242. package/src/tui/hooks/index.ts +0 -35
  243. package/src/tui/hooks/useAppState.ts +0 -314
  244. package/src/tui/hooks/useDaemonStatus.ts +0 -174
  245. package/src/tui/hooks/useInboxTUI.ts +0 -113
  246. package/src/tui/hooks/useRemoteMachines.ts +0 -209
  247. package/src/tui/index.ts +0 -24
  248. package/src/tui/state.ts +0 -299
  249. package/src/tui/terminal-bracketed-paste.test.ts +0 -45
  250. package/src/tui/terminal-bracketed-paste.ts +0 -47
  251. package/src/types/bundle.ts +0 -112
  252. package/src/types/config.ts +0 -89
  253. package/src/types/errors.ts +0 -206
  254. package/src/types/identity.ts +0 -284
  255. package/src/types/workspace-fuzzy.ts +0 -49
  256. package/src/types/workspace.ts +0 -151
  257. package/src/utils/bun-socket-writer.ts +0 -80
  258. package/src/utils/deps.ts +0 -127
  259. package/src/utils/fuzzy-match.ts +0 -125
  260. package/src/utils/logger.ts +0 -127
  261. package/src/utils/markdown.ts +0 -254
  262. package/src/utils/onboarding.ts +0 -229
  263. package/src/utils/prompts.ts +0 -114
  264. package/src/utils/run-commands.ts +0 -112
  265. package/src/utils/run-scripts.ts +0 -142
  266. package/src/utils/sanitize.ts +0 -98
  267. package/src/utils/secrets.ts +0 -122
  268. package/src/utils/shell-escape.ts +0 -40
  269. package/src/utils/utf8.ts +0 -79
  270. package/src/utils/workspace-state.ts +0 -47
  271. package/src/web/README.md +0 -73
  272. package/src/web/bun.lock +0 -575
  273. package/src/web/eslint.config.js +0 -23
  274. package/src/web/index.html +0 -16
  275. package/src/web/package.json +0 -37
  276. package/src/web/public/vite.svg +0 -1
  277. package/src/web/src/App.tsx +0 -604
  278. package/src/web/src/assets/react.svg +0 -1
  279. package/src/web/src/components/Terminal.tsx +0 -207
  280. package/src/web/src/hooks/useRelayConnection.ts +0 -224
  281. package/src/web/src/hooks/useTerminal.ts +0 -699
  282. package/src/web/src/index.css +0 -55
  283. package/src/web/src/lib/crypto/__tests__/web-terminal.test.ts +0 -1158
  284. package/src/web/src/lib/crypto/frames.ts +0 -205
  285. package/src/web/src/lib/crypto/handshake.ts +0 -396
  286. package/src/web/src/lib/crypto/identity.ts +0 -128
  287. package/src/web/src/lib/crypto/keyexchange.ts +0 -246
  288. package/src/web/src/lib/crypto/relay-signing.ts +0 -53
  289. package/src/web/src/lib/invite.ts +0 -58
  290. package/src/web/src/lib/storage/identity-store.ts +0 -94
  291. package/src/web/src/main.tsx +0 -10
  292. package/src/web/src/types/identity.ts +0 -45
  293. package/src/web/tsconfig.app.json +0 -28
  294. package/src/web/tsconfig.json +0 -7
  295. package/src/web/tsconfig.node.json +0 -26
  296. package/src/web/vite.config.ts +0 -31
  297. package/todo-security.md +0 -92
  298. package/tsconfig.json +0 -23
  299. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/12b7107e435bf1b9a8713a7f320472a63e543104d633d89a26f8d21f4e4ef182.sqlite +0 -0
  300. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/12b7107e435bf1b9a8713a7f320472a63e543104d633d89a26f8d21f4e4ef182.sqlite-shm +0 -0
  301. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/12b7107e435bf1b9a8713a7f320472a63e543104d633d89a26f8d21f4e4ef182.sqlite-wal +0 -0
  302. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/1a1ac3db1ab86ecf712f90322868a9aabc2c7dc9fe2dfbe94f9b075096276b0f.sqlite +0 -0
  303. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/1a1ac3db1ab86ecf712f90322868a9aabc2c7dc9fe2dfbe94f9b075096276b0f.sqlite-shm +0 -0
  304. package/worker/.wrangler/state/v3/d1/miniflare-D1DatabaseObject/1a1ac3db1ab86ecf712f90322868a9aabc2c7dc9fe2dfbe94f9b075096276b0f.sqlite-wal +0 -0
  305. package/worker/bun.lock +0 -237
  306. package/worker/package.json +0 -22
  307. package/worker/schema.sql +0 -96
  308. package/worker/src/handlers/auth.ts +0 -451
  309. package/worker/src/handlers/subdomains.ts +0 -376
  310. package/worker/src/handlers/user.ts +0 -98
  311. package/worker/src/index.ts +0 -70
  312. package/worker/src/middleware/auth.ts +0 -152
  313. package/worker/src/services/cloudflare.ts +0 -609
  314. package/worker/src/types.ts +0 -96
  315. package/worker/tsconfig.json +0 -15
  316. package/worker/wrangler.toml +0 -26
@@ -1,201 +0,0 @@
1
- import { TerminalWindow } from "./TerminalWindow";
2
- import { GitBranch, Globe, Layers, ArrowRight, Shield, Smartphone, Laptop } from "lucide-react";
3
- import { Badge } from "../../app/components/ui/badge";
4
-
5
- export function Features() {
6
- return (
7
- <section id="features" className="py-24 bg-black relative">
8
- <div className="container px-4 mx-auto">
9
- <div className="text-center mb-20">
10
- <h2 className="text-3xl md:text-5xl font-bold mb-4">One tool. Three superpowers.</h2>
11
- <div className="h-1 w-20 bg-green-500 mx-auto rounded-full" />
12
- </div>
13
-
14
- <div className="space-y-32">
15
-
16
- {/* SPACES */}
17
- <div className="grid lg:grid-cols-2 gap-12 items-center">
18
- <div>
19
- <div className="inline-flex items-center gap-2 text-green-400 font-mono text-sm mb-4">
20
- <GitBranch className="w-5 h-5" />
21
- <span>SPACES</span>
22
- </div>
23
- <h3 className="text-3xl md:text-4xl font-bold mb-6">Work on everything at once.</h3>
24
- <p className="text-lg text-zinc-400 leading-relaxed mb-8">
25
- Git worktrees let you have multiple branches checked out simultaneously. No more stashing. No more "let me finish this first." Jump between features instantly.
26
- </p>
27
- <ul className="space-y-3 text-zinc-300">
28
- <li className="flex items-start">
29
- <ArrowRight className="w-5 h-5 text-green-500 mr-3 shrink-0 mt-0.5" />
30
- <span>Each workspace is a full git worktree</span>
31
- </li>
32
- <li className="flex items-start">
33
- <ArrowRight className="w-5 h-5 text-green-500 mr-3 shrink-0 mt-0.5" />
34
- <span>Run different branches simultaneously</span>
35
- </li>
36
- <li className="flex items-start">
37
- <ArrowRight className="w-5 h-5 text-green-500 mr-3 shrink-0 mt-0.5" />
38
- <span>Custom setup scripts per project</span>
39
- </li>
40
- <li className="flex items-start">
41
- <ArrowRight className="w-5 h-5 text-green-500 mr-3 shrink-0 mt-0.5" />
42
- <span>Integrates with Linear issues</span>
43
- </li>
44
- </ul>
45
- </div>
46
- <div>
47
- <TerminalWindow title="bash">
48
- <div className="space-y-2 font-mono text-sm">
49
- <div className="text-zinc-500"># Install</div>
50
- <div className="text-zinc-400">$ bun install -g https://github.com/inkibra/gitspace.sh</div>
51
- <br />
52
- <div className="text-zinc-500"># Launch the TUI</div>
53
- <div className="text-zinc-400">$ gssh</div>
54
- <br />
55
- <div className="text-zinc-500"># Or use commands</div>
56
- <div className="text-zinc-400">$ gssh add project</div>
57
- <div className="text-green-400">✓ Added project: my-api</div>
58
- <div className="text-zinc-400">$ gssh add feature-auth</div>
59
- <div className="text-green-400">✓ Created workspace: feature-auth</div>
60
- </div>
61
- </TerminalWindow>
62
- </div>
63
- </div>
64
-
65
- {/* REMOTE */}
66
- <div className="grid lg:grid-cols-2 gap-12 items-center lg:flex-row-reverse">
67
- <div className="lg:order-2">
68
- <div className="inline-flex items-center gap-2 text-blue-400 font-mono text-sm mb-4">
69
- <Globe className="w-5 h-5" />
70
- <span>REMOTE</span>
71
- </div>
72
- <h3 className="text-3xl md:text-4xl font-bold mb-6">Your terminal, from anywhere.</h3>
73
- <p className="text-lg text-zinc-400 leading-relaxed mb-8">
74
- Start an AI agent on a big task. Close your laptop. Check in from your phone.
75
- Get notified when it's done. End-to-end encrypted - we can't see your terminal.
76
- </p>
77
- <ul className="space-y-3 text-zinc-300">
78
- <li className="flex items-start">
79
- <ArrowRight className="w-5 h-5 text-blue-500 mr-3 shrink-0 mt-0.5" />
80
- <span>Encrypted access from your phone or any device</span>
81
- </li>
82
- <li className="flex items-start">
83
- <ArrowRight className="w-5 h-5 text-blue-500 mr-3 shrink-0 mt-0.5" />
84
- <div className="flex flex-col">
85
- <span className="text-zinc-300">Public subdomains & port forwarding</span>
86
- <span className="text-xs font-semibold text-blue-500 mt-1 uppercase tracking-wider">Coming Soon</span>
87
- </div>
88
- </li>
89
- <li className="flex items-start">
90
- <ArrowRight className="w-5 h-5 text-blue-500 mr-3 shrink-0 mt-0.5" />
91
- <span>End-to-end encrypted relay — we can't see your data</span>
92
- </li>
93
- <li className="flex items-start">
94
- <ArrowRight className="w-5 h-5 text-blue-500 mr-3 shrink-0 mt-0.5" />
95
- <span>Share sessions (view-only or full access)</span>
96
- </li>
97
- <li className="flex items-start">
98
- <ArrowRight className="w-5 h-5 text-blue-500 mr-3 shrink-0 mt-0.5" />
99
- <span>Inbox tracks what happened while you were away</span>
100
- </li>
101
- </ul>
102
- </div>
103
- <div className="lg:order-1">
104
- <TerminalWindow title="Connection Architecture">
105
- <div className="flex justify-between items-center text-center text-xs md:text-sm p-4">
106
- <div className="flex flex-col items-center gap-2">
107
- <Laptop className="w-8 h-8 text-zinc-300" />
108
- <span className="font-bold">Your Mac</span>
109
- <span className="text-green-500 text-[10px] border border-green-500/30 px-1 rounded bg-green-500/10">Has Keys</span>
110
- </div>
111
-
112
- <div className="flex-1 px-4 relative">
113
- <div className="h-px bg-zinc-700 absolute top-1/2 left-0 right-0 -z-10" />
114
- <div className="bg-black px-2 relative z-10 inline-block">
115
- <Shield className="w-5 h-5 text-green-500 mx-auto mb-1" />
116
- <span className="text-[10px] text-zinc-500 uppercase tracking-wider block bg-zinc-900 px-2 py-0.5 rounded border border-zinc-800">End-to-End Encrypted</span>
117
- </div>
118
- </div>
119
-
120
- <div className="flex flex-col items-center gap-2">
121
- <Smartphone className="w-8 h-8 text-zinc-300" />
122
- <span className="font-bold">Your Phone</span>
123
- <span className="text-green-500 text-[10px] border border-green-500/30 px-1 rounded bg-green-500/10">Has Keys</span>
124
- </div>
125
- </div>
126
- <div className="text-center mt-4 pt-4 border-t border-zinc-800">
127
- <div className="text-zinc-500 text-xs mb-1">gitspace.sh Relay</div>
128
- <div className="text-zinc-600 text-[10px] italic">Blind relay - cannot read data</div>
129
- </div>
130
- </TerminalWindow>
131
- </div>
132
- </div>
133
-
134
- {/* GIT STACK */}
135
- <div className="grid lg:grid-cols-2 gap-12 items-center">
136
- <div>
137
- <div className="inline-flex items-center gap-2 text-purple-400 font-mono text-sm mb-4">
138
- <Layers className="w-5 h-5" />
139
- <span>GIT STACK</span>
140
- <Badge variant="outline" className="ml-2 border-purple-500/30 text-purple-400 bg-purple-500/10 text-[10px] h-5">COMING SOON</Badge>
141
- </div>
142
- <h3 className="text-3xl md:text-4xl font-bold mb-6">AI turns your mess into clean PRs.</h3>
143
- <p className="text-lg text-zinc-400 leading-relaxed mb-8">
144
- You've been hacking for hours. Your branch has 47 commits touching 30 files.
145
- Git Stack analyzes your changes and splits them into logical, reviewable PRs - automatically.
146
- </p>
147
- <ul className="space-y-3 text-zinc-300">
148
- <li className="flex items-start">
149
- <ArrowRight className="w-5 h-5 text-purple-500 mr-3 shrink-0 mt-0.5" />
150
- <span>AI understands code dependencies</span>
151
- </li>
152
- <li className="flex items-start">
153
- <ArrowRight className="w-5 h-5 text-purple-500 mr-3 shrink-0 mt-0.5" />
154
- <span>Splits by logical units, not just files</span>
155
- </li>
156
- <li className="flex items-start">
157
- <ArrowRight className="w-5 h-5 text-purple-500 mr-3 shrink-0 mt-0.5" />
158
- <span>Creates dependent PR chains</span>
159
- </li>
160
- <li className="flex items-start">
161
- <ArrowRight className="w-5 h-5 text-purple-500 mr-3 shrink-0 mt-0.5" />
162
- <span>Explains its reasoning</span>
163
- </li>
164
- </ul>
165
- </div>
166
- <div>
167
- <TerminalWindow title="bash">
168
- <div className="space-y-2 font-mono text-sm">
169
- <div className="text-zinc-400">$ gitspace stack</div>
170
- <div className="text-blue-400 animate-pulse">Analyzing 47 commits across 30 files...</div>
171
- <br />
172
- <div className="text-zinc-300">Suggested stack:</div>
173
-
174
- <div className="pl-4 border-l-2 border-purple-500/30 space-y-3 mt-2">
175
- <div>
176
- <div className="text-green-400 font-bold">PR #1: Add user authentication types</div>
177
- <div className="text-zinc-500 text-xs">└─ src/types/auth.ts, src/types/user.ts</div>
178
- </div>
179
- <div>
180
- <div className="text-green-400 font-bold">PR #2: Implement auth middleware</div>
181
- <div className="text-zinc-500 text-xs">└─ src/middleware/auth.ts (depends on #1)</div>
182
- </div>
183
- <div>
184
- <div className="text-green-400 font-bold">PR #3: Add login/logout endpoints</div>
185
- <div className="text-zinc-500 text-xs">└─ src/routes/auth.ts (depends on #2)</div>
186
- </div>
187
- </div>
188
-
189
- <div className="mt-4 pt-2 border-t border-zinc-800 text-zinc-500 text-xs">
190
- [c] create stack [e] edit [?] explain reasoning
191
- </div>
192
- </div>
193
- </TerminalWindow>
194
- </div>
195
- </div>
196
-
197
- </div>
198
- </div>
199
- </section>
200
- );
201
- }
@@ -1,142 +0,0 @@
1
- import { Button } from "../../app/components/ui/button";
2
- import { Link } from "react-router-dom";
3
- import { ArrowRight, Play, Check, Activity, Clock, Laptop, Smartphone, Github } from "lucide-react";
4
- import { TerminalWindow } from "./TerminalWindow";
5
- import FaultyTerminal from "./FaultyTerminal";
6
- import { Badge } from "../../app/components/ui/badge";
7
-
8
- export function Hero() {
9
- return (
10
- <section className="relative pt-32 pb-32 overflow-hidden px-4">
11
-
12
- <div className="absolute inset-0 w-full h-full z-0 opacity-15">
13
- <FaultyTerminal
14
- scale={2}
15
- gridMul={[2, 1]}
16
- digitSize={1.2}
17
- timeScale={0.5}
18
- pause={false}
19
- scanlineIntensity={0.35}
20
- glitchAmount={1}
21
- flickerAmount={1}
22
- noiseAmp={1}
23
- chromaticAberration={0}
24
- dither={1}
25
- curvature={0}
26
- tint="#22c55e"
27
- mouseReact={true}
28
- mouseStrength={0.5}
29
- pageLoadAnimation={false}
30
- brightness={0.4}
31
- />
32
- </div>
33
-
34
- <div className="container px-4 mx-auto text-center relative z-10">
35
-
36
- <h1 className="text-4xl md:text-6xl lg:text-7xl font-bold tracking-tight mb-6 bg-clip-text text-transparent bg-gradient-to-b from-white to-white/60">
37
- The developer environment<br />for the AI age.
38
- </h1>
39
-
40
- <p className="text-xl md:text-2xl text-muted-foreground max-w-2xl mx-auto mb-10 leading-relaxed">
41
- Parallel workspaces. Remote access. AI-assisted shipping.
42
- </p>
43
-
44
- <div className="flex flex-col sm:flex-row items-center justify-center gap-4 mb-20">
45
- <a href="https://github.com/inkibra/gitspace.sh" target="_blank" rel="noopener noreferrer">
46
- <Button size="lg" className="bg-white text-black hover:bg-gray-200 h-12 px-8 text-base">
47
- <Github className="w-5 h-5 mr-2" />
48
- Star on GitHub
49
- </Button>
50
- </a>
51
- <Link to="/docs">
52
- <Button variant="outline" size="lg" className="h-12 px-8 text-base border-white/10 hover:bg-white/5">
53
- Read the Docs <ArrowRight className="ml-2 w-4 h-4" />
54
- </Button>
55
- </Link>
56
- </div>
57
-
58
- <div className="max-w-4xl mx-auto text-left relative group">
59
- <div className="absolute -inset-1 bg-gradient-to-b from-green-500/20 to-transparent blur-2xl opacity-50 rounded-[2rem] group-hover:opacity-75 transition duration-500" />
60
-
61
- <TerminalWindow title="gitspace" className="relative bg-black/90 backdrop-blur-xl">
62
- <div className="flex flex-col md:flex-row gap-8 p-2 font-mono text-sm md:text-base">
63
-
64
- {/* Left Column: Projects */}
65
- <div className="w-full md:w-1/3 border-r border-zinc-800 md:pr-4">
66
- <div className="text-zinc-500 mb-2 uppercase text-xs tracking-wider">Projects</div>
67
- <div className="h-px bg-zinc-800 mb-4" />
68
- <ul className="space-y-2">
69
- <li className="flex items-center text-green-400 font-bold bg-zinc-900/50 -mx-2 px-2 py-1 rounded">
70
- <span className="mr-2">&gt;</span> gitspace
71
- </li>
72
- <li className="text-zinc-400 px-2">website</li>
73
- <li className="text-zinc-400 px-2">relay-server</li>
74
- </ul>
75
- </div>
76
-
77
- {/* Right Column: Workspaces */}
78
- <div className="w-full md:w-2/3">
79
- <div className="text-zinc-500 mb-2 uppercase text-xs tracking-wider">Workspaces (gitspace)</div>
80
- <div className="h-px bg-zinc-800 mb-4" />
81
-
82
- <ul className="space-y-3">
83
- <li className="flex items-center justify-between group/item p-1 hover:bg-zinc-900/50 rounded cursor-pointer transition-colors">
84
- <div className="flex items-center text-white">
85
- <span className="text-green-500 mr-2">&gt;</span> feat-remote-acl
86
- </div>
87
- <div className="flex items-center text-xs text-zinc-500">
88
- [main] *
89
- </div>
90
- </li>
91
-
92
- <li className="flex items-center justify-between group/item p-1 hover:bg-zinc-900/50 rounded cursor-pointer transition-colors">
93
- <div className="flex items-center text-zinc-400">
94
- <span className="w-3 mr-2"></span> fix-worktree-cleanup
95
- </div>
96
- <div className="flex items-center text-xs text-zinc-600">
97
- [main]
98
- </div>
99
- </li>
100
-
101
- <li className="flex items-center justify-between group/item p-1 hover:bg-zinc-900/50 rounded cursor-pointer transition-colors">
102
- <div className="flex items-center text-zinc-400">
103
- <span className="w-3 mr-2"></span> refactor-crypto
104
- </div>
105
- <div className="flex items-center text-xs text-zinc-600">
106
- [dev-v2]
107
- </div>
108
- </li>
109
- </ul>
110
- </div>
111
-
112
- </div>
113
-
114
- {/* Status Bar */}
115
- <div className="mt-8 pt-3 border-t border-zinc-800 text-xs text-zinc-500 flex flex-wrap gap-4">
116
- <span><span className="text-zinc-300">[a]</span> add</span>
117
- <span><span className="text-zinc-300">[s]</span> switch</span>
118
- <span><span className="text-zinc-300">[r]</span> remove</span>
119
- <span><span className="text-zinc-300">[i]</span> identity</span>
120
- </div>
121
- </TerminalWindow>
122
-
123
- {/* Device Labels */}
124
- <div className="flex justify-between mt-4 text-xs md:text-sm font-medium text-zinc-500 px-4">
125
- <div className="flex items-center gap-2">
126
- <Laptop className="w-4 h-4" />
127
- <span>On your Mac</span>
128
- </div>
129
- <div className="flex items-center gap-2 text-green-500/80 animate-pulse">
130
- <Smartphone className="w-4 h-4" />
131
- <span>Watching from phone</span>
132
- </div>
133
- </div>
134
-
135
- </div>
136
- </div>
137
-
138
- {/* Background Gradient */}
139
- <div className="absolute top-0 left-1/2 -translate-x-1/2 w-full h-[600px] bg-[radial-gradient(ellipse_at_top,_var(--tw-gradient-stops))] from-green-950/10 via-black/0 to-black/0 pointer-events-none" />
140
- </section>
141
- );
142
- }
@@ -1,140 +0,0 @@
1
- import { Check, X, Github } from "lucide-react";
2
- import { Button } from "../../app/components/ui/button";
3
- import { Card, CardContent, CardHeader, CardTitle, CardFooter, CardDescription } from "../../app/components/ui/card";
4
- import { Badge } from "../../app/components/ui/badge";
5
-
6
- export function Pricing() {
7
- const plans = [
8
- {
9
- name: "Local",
10
- price: "Free",
11
- period: "forever",
12
- description: "For individual developers working locally.",
13
- features: [
14
- "Unlimited workspaces",
15
- "TUI & CLI",
16
- "Setup scripts",
17
- "Linear integration",
18
- "Git Stack (when released)"
19
- ],
20
- notIncluded: [
21
- "Remote access"
22
- ],
23
- cta: "Star on GitHub",
24
- variant: "outline",
25
- link: "https://github.com/inkibra/gitspace.sh"
26
- },
27
- {
28
- name: "Pro",
29
- price: "$4.99",
30
- period: "/month",
31
- description: "Remote access and AI workflow superpowers.",
32
- features: [
33
- "Everything in Local",
34
- "Remote access",
35
- "Unlimited machines",
36
- "Session sharing",
37
- "90-day inbox history",
38
- "Priority support"
39
- ],
40
- cta: "Coming Soon",
41
- variant: "default",
42
- popular: true,
43
- disabled: true
44
- },
45
- {
46
- name: "Enterprise",
47
- price: "Contact Us",
48
- period: "",
49
- description: "For organizations with custom security and scale needs.",
50
- features: [
51
- "Everything in Pro",
52
- "Team sharing",
53
- "Shared inbox",
54
- "Audit logs",
55
- "SSO & SAML",
56
- "Dedicated support"
57
- ],
58
- cta: "Coming Soon",
59
- variant: "outline",
60
- disabled: true
61
- }
62
- ];
63
-
64
- return (
65
- <section id="pricing" className="py-24 bg-zinc-950">
66
- <div className="container px-4 mx-auto">
67
- <div className="text-center mb-16">
68
- <h2 className="text-3xl md:text-5xl font-bold mb-4">Simple Pricing</h2>
69
- <p className="text-zinc-400">Local-only is always free. Pay for remote access.</p>
70
- </div>
71
-
72
- <div className="grid md:grid-cols-3 gap-8 max-w-6xl mx-auto">
73
- {plans.map((plan, i) => (
74
- <Card key={i} className={`relative bg-zinc-900/50 border-zinc-800 hover:border-zinc-700 transition-all ${plan.popular ? 'border-green-500/50 shadow-green-900/20 shadow-2xl' : ''}`}>
75
- {plan.popular && (
76
- <div className="absolute -top-3 left-1/2 -translate-x-1/2">
77
- <Badge className="bg-green-500 text-black hover:bg-green-600">Most Popular</Badge>
78
- </div>
79
- )}
80
-
81
- <CardHeader>
82
- <CardTitle className="text-xl text-zinc-300">{plan.name}</CardTitle>
83
- <div className="flex items-baseline mt-4">
84
- <span className="text-4xl font-bold text-white">{plan.price}</span>
85
- <span className="text-zinc-500 ml-2">{plan.period}</span>
86
- </div>
87
- <CardDescription className="mt-2 text-zinc-400">
88
- {plan.description}
89
- </CardDescription>
90
- </CardHeader>
91
-
92
- <CardContent>
93
- <ul className="space-y-4">
94
- {plan.features.map((feature, j) => (
95
- <li key={j} className="flex items-start">
96
- <Check className="w-5 h-5 text-green-500 mr-3 shrink-0" />
97
- <span className="text-sm text-zinc-300">{feature}</span>
98
- </li>
99
- ))}
100
- {plan.notIncluded?.map((feature, j) => (
101
- <li key={j} className="flex items-start opacity-50">
102
- <X className="w-5 h-5 text-zinc-600 mr-3 shrink-0" />
103
- <span className="text-sm text-zinc-500">{feature}</span>
104
- </li>
105
- ))}
106
- </ul>
107
- </CardContent>
108
-
109
- <CardFooter className="flex flex-col gap-4">
110
- {plan.link ? (
111
- <a href={plan.link} target="_blank" rel="noopener noreferrer" className="w-full">
112
- <Button
113
- variant={plan.variant as "default" | "outline"}
114
- className={`w-full ${plan.variant === 'default' ? 'bg-white text-black hover:bg-gray-200' : 'border-zinc-700 text-white hover:bg-zinc-800'}`}
115
- >
116
- {plan.name === "Local" && <Github className="w-4 h-4 mr-2" />}
117
- {plan.cta}
118
- </Button>
119
- </a>
120
- ) : (
121
- <Button
122
- variant={plan.variant as "default" | "outline"}
123
- className={`w-full ${plan.variant === 'default' ? 'bg-white text-black hover:bg-gray-200' : 'border-zinc-700 text-white hover:bg-zinc-800'}`}
124
- disabled={plan.disabled}
125
- >
126
- {plan.cta}
127
- </Button>
128
- )}
129
- </CardFooter>
130
- </Card>
131
- ))}
132
- </div>
133
-
134
- <div className="text-center mt-12 text-zinc-500 text-sm">
135
- Self-host the relay? It's open source. Run it on your infra.
136
- </div>
137
- </div>
138
- </section>
139
- );
140
- }
@@ -1,86 +0,0 @@
1
- import { Badge } from "../../app/components/ui/badge";
2
- import { Terminal, Zap, Bug, PlayCircle } from "lucide-react";
3
-
4
- export function Roadmap() {
5
- const plannedFeatures = [
6
- {
7
- title: "CI/CD via GitSpace",
8
- description: "Use a remote GitSpace as your CI/CD runner. If a build fails, you don't just get a log—you get a machine. SSH into the runner instantly to see exactly what happened and fix it in real-time.",
9
- icon: <Terminal className="w-5 h-5 text-green-500" />,
10
- tag: "Planned",
11
- status: "In Concept"
12
- },
13
- {
14
- title: "Dev & Preview Deploys",
15
- description: "Push a branch and see it running instantly as a GitSpace in a Firecracker VM. Only pay for what you use with sub-second startup times. Remote into the preview environment via GitSpace to debug live code.",
16
- icon: <Zap className="w-5 h-5 text-blue-500" />,
17
- tag: "Coming Soon",
18
- status: "In Development"
19
- }
20
- ];
21
-
22
- return (
23
- <section className="py-24 bg-zinc-950 border-y border-zinc-900">
24
- <div className="container px-4 mx-auto">
25
- <div className="max-w-4xl">
26
- <div className="inline-flex items-center gap-2 px-3 py-1 rounded-full bg-green-500/10 border border-green-500/20 text-green-400 text-xs font-mono mb-6">
27
- <span className="relative flex h-2 w-2">
28
- <span className="animate-ping absolute inline-flex h-full w-full rounded-full bg-green-400 opacity-75"></span>
29
- <span className="relative inline-flex rounded-full h-2 w-2 bg-green-500"></span>
30
- </span>
31
- ROADMAP
32
- </div>
33
-
34
- <h2 className="text-3xl md:text-5xl font-bold mb-6">Building the future of dev-ops.</h2>
35
- <p className="text-xl text-zinc-400 mb-16 max-w-2xl leading-relaxed">
36
- GitSpace isn't just about local development. We're rethinking the entire lifecycle from commit to production.
37
- </p>
38
-
39
- <div className="grid md:grid-cols-2 gap-8">
40
- {plannedFeatures.map((feature, i) => (
41
- <div key={i} className="group p-8 rounded-2xl bg-black border border-zinc-800 hover:border-zinc-700 transition-all duration-300">
42
- <div className="flex items-start justify-between mb-6">
43
- <div className="p-3 rounded-xl bg-zinc-900 border border-zinc-800 group-hover:bg-zinc-800 transition-colors">
44
- {feature.icon}
45
- </div>
46
- <Badge variant="outline" className="border-zinc-800 text-zinc-500 text-[10px] uppercase tracking-wider">
47
- {feature.tag}
48
- </Badge>
49
- </div>
50
-
51
- <h3 className="text-xl font-bold mb-3 group-hover:text-white transition-colors">
52
- {feature.title}
53
- </h3>
54
-
55
- <p className="text-zinc-400 text-sm leading-relaxed mb-6">
56
- {feature.description}
57
- </p>
58
-
59
- <div className="flex items-center gap-4 pt-4 border-t border-zinc-900">
60
- <div className="flex items-center gap-1.5 text-[10px] font-mono text-zinc-500">
61
- <div className="w-1.5 h-1.5 rounded-full bg-zinc-700" />
62
- STATUS: {feature.status}
63
- </div>
64
- </div>
65
- </div>
66
- ))}
67
- </div>
68
-
69
- <div className="mt-16 p-8 rounded-2xl bg-gradient-to-br from-green-500/5 to-transparent border border-green-500/10">
70
- <div className="flex flex-col md:flex-row items-center justify-between gap-8">
71
- <div>
72
- <h4 className="text-lg font-bold mb-2">Want to shape our roadmap?</h4>
73
- <p className="text-sm text-zinc-400">Join our Discord to suggest features and test new builds.</p>
74
- </div>
75
- <a href="https://discord.gg/kHRWYPnR" target="_blank" rel="noopener noreferrer">
76
- <button className="px-6 py-2.5 rounded-full bg-white text-black font-medium hover:bg-zinc-200 transition-colors shrink-0">
77
- Join Discord
78
- </button>
79
- </a>
80
- </div>
81
- </div>
82
- </div>
83
- </div>
84
- </section>
85
- );
86
- }
@@ -1,81 +0,0 @@
1
- import { Lock, Github, Server, FileCode, ShieldCheck, Eye, ArrowRight } from "lucide-react";
2
- import { Button } from "../../app/components/ui/button";
3
- import { Link } from "react-router-dom";
4
-
5
- export function Security() {
6
- return (
7
- <section id="security" className="py-24 bg-black relative">
8
- <div className="container px-4 mx-auto">
9
- <div className="text-center mb-16">
10
- <h2 className="text-3xl md:text-5xl font-bold mb-6">Open source. Self-hostable. <span className="text-green-500">Actually secure.</span></h2>
11
- </div>
12
-
13
- <div className="grid md:grid-cols-2 gap-8 max-w-5xl mx-auto">
14
-
15
- {/* Open Source Card */}
16
- <div className="bg-zinc-900/30 border border-zinc-800 rounded-2xl p-8 hover:border-zinc-700 transition-colors">
17
- <div className="w-12 h-12 rounded-lg bg-blue-500/10 flex items-center justify-center border border-blue-500/20 mb-6">
18
- <Github className="w-6 h-6 text-blue-400" />
19
- </div>
20
- <h3 className="text-2xl font-bold mb-4">Fully Open Source</h3>
21
- <p className="text-zinc-400 mb-8 leading-relaxed">
22
- The CLI, the relay, the protocol. All MIT licensed.
23
- Run it yourself or use our managed service. We have nothing to hide.
24
- </p>
25
-
26
- <div className="space-y-4">
27
- <div className="flex items-start gap-3">
28
- <Server className="w-5 h-5 text-zinc-500 mt-1" />
29
- <div>
30
- <h4 className="font-bold text-white">Self-Host Everything</h4>
31
- <p className="text-sm text-zinc-500">Don't trust us? Don't have to. Run your own relay. Same security. Your infrastructure.</p>
32
- </div>
33
- </div>
34
- </div>
35
-
36
- <div className="mt-8 pt-8 border-t border-zinc-800">
37
- <a href="https://github.com/inkibra/gitspace.sh" target="_blank" rel="noopener noreferrer">
38
- <Button variant="outline" className="text-blue-400 border-blue-500/20 hover:bg-blue-500/10 hover:text-blue-300 w-full justify-between group">
39
- View on GitHub
40
- <ArrowRight className="w-4 h-4 ml-2 group-hover:translate-x-1 transition-transform" />
41
- </Button>
42
- </a>
43
- </div>
44
- </div>
45
-
46
- {/* Security Card */}
47
- <div className="bg-zinc-900/30 border border-zinc-800 rounded-2xl p-8 hover:border-zinc-700 transition-colors">
48
- <div className="w-12 h-12 rounded-lg bg-green-500/10 flex items-center justify-center border border-green-500/20 mb-6">
49
- <Lock className="w-6 h-6 text-green-400" />
50
- </div>
51
- <h3 className="text-2xl font-bold mb-4">End-to-End Encrypted</h3>
52
- <p className="text-zinc-400 mb-8 leading-relaxed">
53
- Your encryption keys never leave your devices. We route bytes but can't read them.
54
- Even if our servers are compromised, your data is safe.
55
- </p>
56
-
57
- <div className="space-y-4">
58
- <div className="flex items-start gap-3">
59
- <Eye className="w-5 h-5 text-zinc-500 mt-1" />
60
- <div>
61
- <h4 className="font-bold text-white">Auditable Protocol</h4>
62
- <p className="text-sm text-zinc-500">The crypto is standard. The protocol is documented. Third party audits coming.</p>
63
- </div>
64
- </div>
65
- </div>
66
-
67
- <div className="mt-8 pt-8 border-t border-zinc-800">
68
- <Link to="/docs?section=security-notes">
69
- <Button variant="outline" className="text-green-400 border-green-500/20 hover:bg-green-500/10 hover:text-green-300 w-full justify-between group">
70
- Read Security Docs
71
- <ArrowRight className="w-4 h-4 ml-2 group-hover:translate-x-1 transition-transform" />
72
- </Button>
73
- </Link>
74
- </div>
75
- </div>
76
-
77
- </div>
78
- </div>
79
- </section>
80
- );
81
- }