thumbgate 0.9.10 → 0.9.12

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 (115) hide show
  1. package/.claude-plugin/README.md +2 -2
  2. package/.claude-plugin/marketplace.json +4 -2
  3. package/.claude-plugin/plugin.json +1 -1
  4. package/.well-known/mcp/server-card.json +1 -1
  5. package/README.md +115 -312
  6. package/adapters/README.md +1 -1
  7. package/adapters/claude/.mcp.json +2 -2
  8. package/adapters/codex/config.toml +4 -4
  9. package/adapters/mcp/server-stdio.js +61 -1
  10. package/adapters/opencode/opencode.json +4 -2
  11. package/bin/cli.js +156 -8
  12. package/bin/memory.sh +3 -3
  13. package/config/e2e-critical-flows.json +4 -0
  14. package/config/gates/default.json +74 -2
  15. package/config/github-about.json +1 -1
  16. package/config/mcp-allowlists.json +27 -0
  17. package/package.json +22 -5
  18. package/plugins/amp-skill/INSTALL.md +1 -0
  19. package/plugins/amp-skill/SKILL.md +1 -0
  20. package/plugins/claude-codex-bridge/.claude-plugin/plugin.json +1 -1
  21. package/plugins/claude-codex-bridge/.mcp.json +4 -2
  22. package/plugins/claude-skill/INSTALL.md +1 -0
  23. package/plugins/codex-profile/.codex-plugin/plugin.json +1 -1
  24. package/plugins/codex-profile/.mcp.json +4 -2
  25. package/plugins/codex-profile/INSTALL.md +1 -1
  26. package/plugins/codex-profile/README.md +1 -1
  27. package/plugins/cursor-marketplace/.cursor-plugin/plugin.json +1 -1
  28. package/plugins/cursor-marketplace/README.md +3 -3
  29. package/plugins/cursor-marketplace/mcp.json +3 -1
  30. package/plugins/cursor-marketplace/scripts/gate-check.sh +15 -5
  31. package/plugins/gemini-extension/INSTALL.md +3 -3
  32. package/plugins/opencode-profile/INSTALL.md +1 -1
  33. package/public/dashboard.html +15 -8
  34. package/public/index.html +125 -185
  35. package/public/js/buyer-intent.js +252 -0
  36. package/public/pro.html +1085 -0
  37. package/scripts/__pycache__/train_from_feedback.cpython-312.pyc +0 -0
  38. package/scripts/adk-consolidator.js +14 -2
  39. package/scripts/agent-readiness.js +3 -1
  40. package/scripts/agent-security-hardening.js +4 -4
  41. package/scripts/auto-promote-gates.js +2 -0
  42. package/scripts/auto-wire-hooks.js +105 -17
  43. package/scripts/behavioral-extraction.js +2 -6
  44. package/scripts/billing.js +107 -3
  45. package/scripts/budget-guard.js +2 -2
  46. package/scripts/build-metadata.js +14 -0
  47. package/scripts/context-engine.js +1 -0
  48. package/scripts/deploy-policy.js +3 -17
  49. package/scripts/dpo-optimizer.js +3 -6
  50. package/scripts/ensure-repo-bootstrap.js +129 -0
  51. package/scripts/export-dpo-pairs.js +2 -3
  52. package/scripts/export-kto-pairs.js +3 -4
  53. package/scripts/export-training.js +8 -6
  54. package/scripts/feedback-attribution.js +23 -11
  55. package/scripts/feedback-loop.js +40 -2
  56. package/scripts/feedback-to-rules.js +2 -1
  57. package/scripts/filesystem-search.js +3 -2
  58. package/scripts/gates-engine.js +760 -29
  59. package/scripts/generate-pretool-hook.sh +0 -0
  60. package/scripts/gtm-revenue-loop.js +20 -1
  61. package/scripts/hook-auto-capture.sh +8 -3
  62. package/scripts/hook-runtime.js +81 -0
  63. package/scripts/hook-stop-self-score.sh +3 -3
  64. package/scripts/hook-thumbgate-cache-updater.js +99 -38
  65. package/scripts/hosted-config.js +4 -16
  66. package/scripts/hybrid-feedback-context.js +54 -14
  67. package/scripts/install-mcp.js +13 -3
  68. package/scripts/intent-router.js +2 -2
  69. package/scripts/license.js +52 -14
  70. package/scripts/local-model-profile.js +3 -2
  71. package/scripts/mcp-config.js +62 -7
  72. package/scripts/meta-policy.js +4 -8
  73. package/scripts/money-watcher.js +166 -16
  74. package/scripts/obsidian-export.js +1 -0
  75. package/scripts/operational-integrity.js +480 -0
  76. package/scripts/post-everywhere.js +35 -12
  77. package/scripts/pr-manager.js +14 -11
  78. package/scripts/profile-router.js +2 -0
  79. package/scripts/prompt-dlp.js +1 -0
  80. package/scripts/publish-decision.js +10 -0
  81. package/scripts/published-cli.js +61 -0
  82. package/scripts/risk-scorer.js +3 -2
  83. package/scripts/rlhf_session_start.sh +32 -0
  84. package/scripts/skill-quality-tracker.js +3 -5
  85. package/scripts/social-analytics/db/social-analytics.db-shm +0 -0
  86. package/scripts/social-analytics/db/social-analytics.db-wal +0 -0
  87. package/scripts/social-analytics/engagement-audit.js +202 -0
  88. package/scripts/social-analytics/instagram-thumbgate-post.js +45 -7
  89. package/scripts/social-analytics/install-growth-automation.js +114 -0
  90. package/scripts/social-analytics/load-env.js +46 -0
  91. package/scripts/social-analytics/poll-all.js +23 -23
  92. package/scripts/social-analytics/pollers/plausible.js +2 -4
  93. package/scripts/social-analytics/pollers/zernio.js +3 -0
  94. package/scripts/social-analytics/publish-instagram-thumbgate.js +22 -3
  95. package/scripts/social-analytics/publish-thumbgate-launch.js +322 -0
  96. package/scripts/social-analytics/publishers/reddit.js +7 -12
  97. package/scripts/social-analytics/publishers/zernio.js +301 -22
  98. package/scripts/social-analytics/reconcile-thumbgate-campaign.js +165 -0
  99. package/scripts/social-analytics/schedule-thumbgate-campaign.js +275 -0
  100. package/scripts/social-analytics/sync-launch-assets.js +185 -0
  101. package/scripts/social-post-hourly.js +185 -0
  102. package/scripts/social-quality-gate.js +119 -3
  103. package/scripts/social-reply-monitor.js +184 -37
  104. package/scripts/statusline-cache-path.js +27 -0
  105. package/scripts/statusline-local-stats.js +16 -0
  106. package/scripts/statusline-meta.js +22 -0
  107. package/scripts/statusline.sh +40 -33
  108. package/scripts/sync-version.js +24 -3
  109. package/scripts/test-coverage.js +21 -13
  110. package/scripts/tool-registry.js +97 -0
  111. package/scripts/train_from_feedback.py +32 -9
  112. package/scripts/validate-feedback.js +3 -2
  113. package/scripts/vector-store.js +2 -3
  114. package/scripts/verify-obsidian-setup.sh +3 -3
  115. package/src/api/server.js +281 -33
@@ -0,0 +1,1085 @@
1
+ <!DOCTYPE html>
2
+ <html lang="en">
3
+ <head>
4
+ <meta charset="UTF-8">
5
+ <meta name="viewport" content="width=device-width, initial-scale=1.0">
6
+ __GOOGLE_SITE_VERIFICATION_META__
7
+ <title>ThumbGate Pro | Personal local dashboard and proof for AI agent reliability</title>
8
+ <meta name="description" content="ThumbGate Pro is the paid lane for individual operators who want a personal local dashboard, DPO export, review-ready evidence, and founder support for risky AI coding workflows.">
9
+ <meta property="og:title" content="ThumbGate Pro | Personal local dashboard and proof for AI agent reliability">
10
+ <meta property="og:description" content="Move from free local gates to a paid operator workflow with a personal local dashboard, DPO export, and review-ready evidence for repeated AI coding failures.">
11
+ <meta property="og:type" content="website">
12
+ <meta property="og:url" content="__APP_ORIGIN__/pro">
13
+ <link rel="canonical" href="__APP_ORIGIN__/pro">
14
+ <meta name="keywords" content="ThumbGate Pro, AI agent reliability, pre-action gates, DPO export, local dashboard, review-ready evidence, Claude Code reliability, Codex reliability, Cursor reliability">
15
+
16
+ <script defer data-domain="thumbgate-production.up.railway.app" data-api="/api/event" src="/js/analytics.js"></script>
17
+ __GA_BOOTSTRAP__
18
+
19
+ <script>
20
+ const gaMeasurementId = '__GA_MEASUREMENT_ID__';
21
+ const serverVisitorId = '__SERVER_VISITOR_ID__';
22
+ const serverSessionId = '__SERVER_SESSION_ID__';
23
+ const serverAcquisitionId = '__SERVER_ACQUISITION_ID__';
24
+ const serverTelemetryCaptured = '__SERVER_TELEMETRY_CAPTURED__' === 'true';
25
+ </script>
26
+
27
+ <script type="application/ld+json">
28
+ {
29
+ "@context": "https://schema.org",
30
+ "@type": "SoftwareApplication",
31
+ "name": "ThumbGate Pro",
32
+ "alternateName": "thumbgate pro",
33
+ "applicationCategory": "DeveloperApplication",
34
+ "operatingSystem": "Cross-platform, Node.js >=18.18.0",
35
+ "description": "Paid ThumbGate lane for individual operators who want a personal local dashboard, DPO export, review-ready evidence, and founder support for risky AI coding workflows.",
36
+ "url": "__APP_ORIGIN__/pro",
37
+ "downloadUrl": "https://www.npmjs.com/package/thumbgate",
38
+ "creator": {
39
+ "@type": "Person",
40
+ "name": "Igor Ganapolsky",
41
+ "url": "https://github.com/IgorGanapolsky"
42
+ },
43
+ "featureList": [
44
+ "Personal local dashboard",
45
+ "Visual gate debugger",
46
+ "DPO export from real thumbs-down corrections",
47
+ "Auto-connect running agents after activation",
48
+ "Founder support on risky workflows",
49
+ "Model Hardening Advisor"
50
+ ],
51
+ "offers": [
52
+ {
53
+ "@type": "Offer",
54
+ "name": "ThumbGate Pro Monthly",
55
+ "price": "__PRO_PRICE_DOLLARS__",
56
+ "priceCurrency": "USD",
57
+ "url": "__APP_ORIGIN__/checkout/pro?plan_id=pro&billing_cycle=monthly&landing_path=%2Fpro",
58
+ "description": "Monthly Pro for individual operators who want a personal local dashboard and proof-ready exports."
59
+ },
60
+ {
61
+ "@type": "Offer",
62
+ "name": "ThumbGate Pro Annual",
63
+ "price": "149",
64
+ "priceCurrency": "USD",
65
+ "url": "__APP_ORIGIN__/checkout/pro?plan_id=pro&billing_cycle=annual&landing_path=%2Fpro",
66
+ "description": "Annual Pro for operators who want the dashboard, DPO export, and founder support at a lower effective monthly price."
67
+ }
68
+ ]
69
+ }
70
+ </script>
71
+
72
+ <script type="application/ld+json">
73
+ {
74
+ "@context": "https://schema.org",
75
+ "@type": "FAQPage",
76
+ "mainEntity": [
77
+ {
78
+ "@type": "Question",
79
+ "name": "How is Pro different from the free install?",
80
+ "acceptedAnswer": {
81
+ "@type": "Answer",
82
+ "text": "Free keeps the local recall, gates, and MCP workflow. Pro adds a personal local dashboard, DPO export, auto-connect for running agents, and founder support for risky workflows."
83
+ }
84
+ },
85
+ {
86
+ "@type": "Question",
87
+ "name": "Does Pro require a cloud account?",
88
+ "acceptedAnswer": {
89
+ "@type": "Answer",
90
+ "text": "No. ThumbGate Pro is still local-first for the individual operator lane. Team is the hosted rollout lane when you need shared lessons, org visibility, and rollout review views."
91
+ }
92
+ },
93
+ {
94
+ "@type": "Question",
95
+ "name": "What happens after checkout?",
96
+ "acceptedAnswer": {
97
+ "@type": "Answer",
98
+ "text": "You activate Pro, connect your personal local dashboard, and your running agents can appear automatically so you can inspect blocked actions, lessons, and exports without adding a cloud dashboard dependency."
99
+ }
100
+ },
101
+ {
102
+ "@type": "Question",
103
+ "name": "When should I choose Team instead of Pro?",
104
+ "acceptedAnswer": {
105
+ "@type": "Answer",
106
+ "text": "Choose Team when one correction needs to protect multiple developers or agents, when you need a shared hosted lesson database, org dashboard visibility, or a workflow hardening pilot across shared repositories."
107
+ }
108
+ }
109
+ ]
110
+ }
111
+ </script>
112
+
113
+ <style>
114
+ *, *::before, *::after { box-sizing: border-box; }
115
+
116
+ :root {
117
+ --bg: #0a0a0b;
118
+ --bg-raised: #111113;
119
+ --bg-card: #161618;
120
+ --border: #232327;
121
+ --text: #ececf1;
122
+ --text-muted: #9a9aa6;
123
+ --cyan: #22d3ee;
124
+ --cyan-dim: rgba(34, 211, 238, 0.12);
125
+ --cyan-glow: rgba(34, 211, 238, 0.22);
126
+ --green: #4ade80;
127
+ --green-dim: rgba(74, 222, 128, 0.12);
128
+ --amber: #fbbf24;
129
+ --amber-dim: rgba(251, 191, 36, 0.12);
130
+ --red: #f87171;
131
+ --font: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Inter', Roboto, sans-serif;
132
+ --mono: 'SF Mono', 'Cascadia Code', 'JetBrains Mono', 'Fira Code', Consolas, monospace;
133
+ }
134
+
135
+ html { scroll-behavior: smooth; }
136
+ body {
137
+ margin: 0;
138
+ font-family: var(--font);
139
+ background:
140
+ radial-gradient(circle at top, rgba(34, 211, 238, 0.16) 0%, rgba(34, 211, 238, 0) 28%),
141
+ linear-gradient(180deg, #0a0a0b 0%, #0d1016 48%, #0a0a0b 100%);
142
+ color: var(--text);
143
+ line-height: 1.6;
144
+ -webkit-font-smoothing: antialiased;
145
+ }
146
+
147
+ a { color: inherit; }
148
+ .container { max-width: 1040px; margin: 0 auto; padding: 0 24px; }
149
+
150
+ nav {
151
+ position: sticky;
152
+ top: 0;
153
+ z-index: 50;
154
+ backdrop-filter: blur(12px);
155
+ background: rgba(10, 10, 11, 0.86);
156
+ border-bottom: 1px solid rgba(35, 35, 39, 0.92);
157
+ }
158
+
159
+ nav .container {
160
+ min-height: 68px;
161
+ display: flex;
162
+ align-items: center;
163
+ justify-content: space-between;
164
+ gap: 20px;
165
+ }
166
+
167
+ .nav-logo {
168
+ font-size: 15px;
169
+ font-weight: 700;
170
+ letter-spacing: -0.02em;
171
+ text-decoration: none;
172
+ }
173
+
174
+ .nav-logo span { color: var(--cyan); }
175
+
176
+ .nav-links {
177
+ display: flex;
178
+ align-items: center;
179
+ gap: 18px;
180
+ flex-wrap: wrap;
181
+ }
182
+
183
+ .nav-links a {
184
+ color: var(--text-muted);
185
+ text-decoration: none;
186
+ font-size: 13px;
187
+ }
188
+
189
+ .nav-links a:hover { color: var(--text); }
190
+
191
+ .nav-cta,
192
+ .btn-primary,
193
+ .btn-secondary,
194
+ .btn-ghost {
195
+ border-radius: 999px;
196
+ text-decoration: none;
197
+ font-weight: 700;
198
+ transition: transform 0.15s, opacity 0.15s, border-color 0.15s;
199
+ }
200
+
201
+ .nav-cta,
202
+ .btn-primary {
203
+ display: inline-flex;
204
+ align-items: center;
205
+ justify-content: center;
206
+ gap: 8px;
207
+ background: var(--cyan);
208
+ color: #041016;
209
+ padding: 11px 18px;
210
+ box-shadow: 0 0 0 1px rgba(34, 211, 238, 0.28), 0 12px 32px rgba(34, 211, 238, 0.18);
211
+ }
212
+
213
+ .btn-secondary,
214
+ .btn-ghost {
215
+ display: inline-flex;
216
+ align-items: center;
217
+ justify-content: center;
218
+ gap: 8px;
219
+ padding: 11px 18px;
220
+ border: 1px solid var(--border);
221
+ color: var(--text);
222
+ background: rgba(17, 17, 19, 0.75);
223
+ }
224
+
225
+ .nav-cta:hover,
226
+ .btn-primary:hover,
227
+ .btn-secondary:hover,
228
+ .btn-ghost:hover {
229
+ transform: translateY(-1px);
230
+ opacity: 0.94;
231
+ }
232
+
233
+ .hero {
234
+ padding: 90px 0 72px;
235
+ }
236
+
237
+ .hero-grid {
238
+ display: grid;
239
+ grid-template-columns: minmax(0, 1.15fr) minmax(280px, 0.85fr);
240
+ gap: 28px;
241
+ align-items: stretch;
242
+ }
243
+
244
+ .panel {
245
+ background: linear-gradient(180deg, rgba(17, 17, 19, 0.94) 0%, rgba(22, 22, 24, 0.94) 100%);
246
+ border: 1px solid var(--border);
247
+ border-radius: 22px;
248
+ box-shadow: 0 24px 64px rgba(0, 0, 0, 0.28);
249
+ }
250
+
251
+ .hero-copy {
252
+ padding: 40px;
253
+ }
254
+
255
+ .eyebrow {
256
+ display: inline-flex;
257
+ align-items: center;
258
+ gap: 8px;
259
+ padding: 7px 12px;
260
+ border-radius: 999px;
261
+ border: 1px solid rgba(34, 211, 238, 0.2);
262
+ background: var(--cyan-dim);
263
+ color: var(--cyan);
264
+ font-size: 12px;
265
+ font-weight: 700;
266
+ letter-spacing: 0.08em;
267
+ text-transform: uppercase;
268
+ }
269
+
270
+ h1 {
271
+ margin: 18px 0 14px;
272
+ font-size: clamp(34px, 6vw, 58px);
273
+ line-height: 1.02;
274
+ letter-spacing: -0.05em;
275
+ }
276
+
277
+ .hero-copy p {
278
+ margin: 0 0 18px;
279
+ color: var(--text-muted);
280
+ font-size: 17px;
281
+ max-width: 700px;
282
+ }
283
+
284
+ .hero-proof {
285
+ display: flex;
286
+ flex-wrap: wrap;
287
+ gap: 10px;
288
+ margin: 20px 0 24px;
289
+ }
290
+
291
+ .proof-pill {
292
+ display: inline-flex;
293
+ align-items: center;
294
+ gap: 8px;
295
+ padding: 9px 12px;
296
+ border-radius: 999px;
297
+ background: rgba(255, 255, 255, 0.02);
298
+ border: 1px solid var(--border);
299
+ color: var(--text-muted);
300
+ font-size: 13px;
301
+ font-weight: 600;
302
+ }
303
+
304
+ .hero-actions {
305
+ display: flex;
306
+ flex-wrap: wrap;
307
+ gap: 12px;
308
+ margin: 26px 0 14px;
309
+ }
310
+
311
+ .hero-note {
312
+ font-size: 14px;
313
+ color: var(--text-muted);
314
+ margin-top: 8px;
315
+ }
316
+
317
+ .hero-note strong { color: var(--text); }
318
+
319
+ .hero-aside {
320
+ padding: 28px;
321
+ display: flex;
322
+ flex-direction: column;
323
+ gap: 18px;
324
+ }
325
+
326
+ .aside-card {
327
+ background: rgba(255, 255, 255, 0.02);
328
+ border: 1px solid var(--border);
329
+ border-radius: 18px;
330
+ padding: 20px;
331
+ }
332
+
333
+ .aside-kicker {
334
+ font-size: 11px;
335
+ text-transform: uppercase;
336
+ letter-spacing: 0.1em;
337
+ color: var(--cyan);
338
+ font-weight: 700;
339
+ margin-bottom: 10px;
340
+ }
341
+
342
+ .aside-card h2,
343
+ .aside-card h3 {
344
+ margin: 0 0 8px;
345
+ font-size: 20px;
346
+ letter-spacing: -0.03em;
347
+ }
348
+
349
+ .aside-card p {
350
+ margin: 0;
351
+ color: var(--text-muted);
352
+ font-size: 14px;
353
+ }
354
+
355
+ .price-stack {
356
+ display: grid;
357
+ gap: 10px;
358
+ margin-top: 14px;
359
+ }
360
+
361
+ .price-line {
362
+ display: flex;
363
+ align-items: baseline;
364
+ justify-content: space-between;
365
+ gap: 16px;
366
+ padding: 14px 16px;
367
+ border-radius: 16px;
368
+ border: 1px solid var(--border);
369
+ background: rgba(255, 255, 255, 0.02);
370
+ }
371
+
372
+ .price-line strong {
373
+ font-size: 20px;
374
+ letter-spacing: -0.03em;
375
+ }
376
+
377
+ .price-line span {
378
+ color: var(--text-muted);
379
+ font-size: 13px;
380
+ }
381
+
382
+ .buyer-form {
383
+ display: grid;
384
+ gap: 12px;
385
+ margin-top: 16px;
386
+ }
387
+
388
+ .buyer-form input[type="email"] {
389
+ width: 100%;
390
+ padding: 12px 14px;
391
+ border-radius: 12px;
392
+ border: 1px solid var(--border);
393
+ background: rgba(10, 10, 11, 0.72);
394
+ color: var(--text);
395
+ font: inherit;
396
+ }
397
+
398
+ .buyer-form-actions {
399
+ display: grid;
400
+ grid-template-columns: repeat(2, minmax(0, 1fr));
401
+ gap: 10px;
402
+ }
403
+
404
+ .buyer-form-note,
405
+ .buyer-form-status {
406
+ margin: 0;
407
+ font-size: 12px;
408
+ color: var(--text-muted);
409
+ }
410
+
411
+ .proof-strip {
412
+ padding: 0 0 72px;
413
+ }
414
+
415
+ .proof-links {
416
+ display: grid;
417
+ grid-template-columns: repeat(4, minmax(0, 1fr));
418
+ gap: 16px;
419
+ }
420
+
421
+ .proof-links a {
422
+ display: block;
423
+ padding: 18px;
424
+ border-radius: 18px;
425
+ border: 1px solid var(--border);
426
+ background: rgba(255, 255, 255, 0.02);
427
+ text-decoration: none;
428
+ }
429
+
430
+ .proof-links a:hover { border-color: rgba(34, 211, 238, 0.28); }
431
+
432
+ .proof-links strong {
433
+ display: block;
434
+ margin-bottom: 6px;
435
+ font-size: 15px;
436
+ letter-spacing: -0.02em;
437
+ }
438
+
439
+ .proof-links span {
440
+ color: var(--text-muted);
441
+ font-size: 13px;
442
+ }
443
+
444
+ .section {
445
+ padding: 0 0 80px;
446
+ }
447
+
448
+ .section-label {
449
+ font-size: 12px;
450
+ text-transform: uppercase;
451
+ letter-spacing: 0.1em;
452
+ color: var(--cyan);
453
+ font-weight: 700;
454
+ margin-bottom: 12px;
455
+ text-align: center;
456
+ }
457
+
458
+ .section-title {
459
+ margin: 0 auto 16px;
460
+ max-width: 760px;
461
+ text-align: center;
462
+ font-size: clamp(28px, 4vw, 40px);
463
+ letter-spacing: -0.04em;
464
+ line-height: 1.08;
465
+ }
466
+
467
+ .section-intro {
468
+ max-width: 720px;
469
+ margin: 0 auto 34px;
470
+ text-align: center;
471
+ color: var(--text-muted);
472
+ font-size: 16px;
473
+ }
474
+
475
+ .grid-3 {
476
+ display: grid;
477
+ grid-template-columns: repeat(3, minmax(0, 1fr));
478
+ gap: 18px;
479
+ }
480
+
481
+ .feature-card,
482
+ .split-card,
483
+ .team-card {
484
+ background: linear-gradient(180deg, rgba(17, 17, 19, 0.98) 0%, rgba(22, 22, 24, 0.96) 100%);
485
+ border: 1px solid var(--border);
486
+ border-radius: 20px;
487
+ padding: 24px;
488
+ }
489
+
490
+ .feature-card h3,
491
+ .split-card h3,
492
+ .team-card h3 {
493
+ margin: 0 0 10px;
494
+ font-size: 19px;
495
+ letter-spacing: -0.03em;
496
+ }
497
+
498
+ .feature-card p,
499
+ .split-card p,
500
+ .team-card p,
501
+ .comparison-note,
502
+ .pricing-note {
503
+ margin: 0;
504
+ color: var(--text-muted);
505
+ font-size: 14px;
506
+ }
507
+
508
+ .feature-card ul,
509
+ .split-card ul,
510
+ .pricing-card ul {
511
+ list-style: none;
512
+ padding: 0;
513
+ margin: 16px 0 0;
514
+ display: grid;
515
+ gap: 10px;
516
+ }
517
+
518
+ .feature-card li,
519
+ .split-card li,
520
+ .pricing-card li {
521
+ position: relative;
522
+ padding-left: 18px;
523
+ color: var(--text-muted);
524
+ font-size: 14px;
525
+ }
526
+
527
+ .feature-card li::before,
528
+ .split-card li::before,
529
+ .pricing-card li::before {
530
+ content: '';
531
+ position: absolute;
532
+ top: 9px;
533
+ left: 0;
534
+ width: 7px;
535
+ height: 7px;
536
+ border-radius: 50%;
537
+ background: var(--cyan);
538
+ box-shadow: 0 0 0 4px rgba(34, 211, 238, 0.12);
539
+ }
540
+
541
+ .split-grid {
542
+ display: grid;
543
+ grid-template-columns: repeat(2, minmax(0, 1fr));
544
+ gap: 18px;
545
+ margin-top: 30px;
546
+ }
547
+
548
+ .split-card.free { border-color: rgba(74, 222, 128, 0.28); }
549
+ .split-card.pro { border-color: rgba(34, 211, 238, 0.28); box-shadow: 0 0 40px rgba(34, 211, 238, 0.08); }
550
+
551
+ .split-kicker {
552
+ display: inline-flex;
553
+ align-items: center;
554
+ gap: 8px;
555
+ padding: 6px 10px;
556
+ border-radius: 999px;
557
+ font-size: 11px;
558
+ font-weight: 700;
559
+ letter-spacing: 0.08em;
560
+ text-transform: uppercase;
561
+ margin-bottom: 12px;
562
+ }
563
+
564
+ .split-card.free .split-kicker {
565
+ color: var(--green);
566
+ background: var(--green-dim);
567
+ }
568
+
569
+ .split-card.pro .split-kicker {
570
+ color: var(--cyan);
571
+ background: var(--cyan-dim);
572
+ }
573
+
574
+ .pricing-shell {
575
+ display: grid;
576
+ grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
577
+ gap: 18px;
578
+ align-items: start;
579
+ }
580
+
581
+ .pricing-card {
582
+ background: linear-gradient(180deg, rgba(17, 17, 19, 0.98) 0%, rgba(22, 22, 24, 0.96) 100%);
583
+ border: 1px solid rgba(34, 211, 238, 0.34);
584
+ border-radius: 24px;
585
+ padding: 28px;
586
+ box-shadow: 0 0 48px rgba(34, 211, 238, 0.08);
587
+ }
588
+
589
+ .pricing-card h3 {
590
+ margin: 0 0 10px;
591
+ font-size: 24px;
592
+ letter-spacing: -0.03em;
593
+ }
594
+
595
+ .pricing-card .price {
596
+ margin: 8px 0 6px;
597
+ font-size: 44px;
598
+ font-weight: 800;
599
+ letter-spacing: -0.05em;
600
+ }
601
+
602
+ .pricing-card .price span {
603
+ color: var(--text-muted);
604
+ font-size: 18px;
605
+ font-weight: 600;
606
+ }
607
+
608
+ .pricing-card .annual {
609
+ color: var(--cyan);
610
+ font-size: 14px;
611
+ margin-bottom: 16px;
612
+ }
613
+
614
+ .pricing-actions {
615
+ display: flex;
616
+ flex-wrap: wrap;
617
+ gap: 12px;
618
+ margin: 22px 0 10px;
619
+ }
620
+
621
+ .pricing-meta {
622
+ font-size: 12px;
623
+ color: var(--text-muted);
624
+ margin-top: 10px;
625
+ }
626
+
627
+ .pricing-sidebar {
628
+ display: grid;
629
+ gap: 18px;
630
+ }
631
+
632
+ .team-card {
633
+ border-color: rgba(74, 222, 128, 0.28);
634
+ }
635
+
636
+ .faq-list {
637
+ max-width: 760px;
638
+ margin: 0 auto;
639
+ border-top: 1px solid var(--border);
640
+ }
641
+
642
+ .faq-item { border-bottom: 1px solid var(--border); }
643
+
644
+ .faq-q {
645
+ width: 100%;
646
+ background: transparent;
647
+ border: 0;
648
+ color: var(--text);
649
+ cursor: pointer;
650
+ text-align: left;
651
+ font: inherit;
652
+ padding: 22px 0;
653
+ display: flex;
654
+ align-items: center;
655
+ justify-content: space-between;
656
+ gap: 16px;
657
+ font-size: 16px;
658
+ font-weight: 600;
659
+ }
660
+
661
+ .faq-q::after {
662
+ content: '+';
663
+ color: var(--text-muted);
664
+ font-size: 20px;
665
+ transition: transform 0.2s ease;
666
+ }
667
+
668
+ .faq-item.open .faq-q::after { transform: rotate(45deg); }
669
+
670
+ .faq-a {
671
+ display: none;
672
+ padding: 0 0 22px;
673
+ color: var(--text-muted);
674
+ font-size: 14px;
675
+ }
676
+
677
+ .faq-item.open .faq-a { display: block; }
678
+
679
+ .final-cta {
680
+ padding: 0 0 88px;
681
+ }
682
+
683
+ .final-shell {
684
+ padding: 34px;
685
+ border-radius: 24px;
686
+ border: 1px solid var(--border);
687
+ background: linear-gradient(180deg, rgba(17, 17, 19, 0.98) 0%, rgba(22, 22, 24, 0.96) 100%);
688
+ text-align: center;
689
+ }
690
+
691
+ .final-shell h2 {
692
+ margin: 0 0 12px;
693
+ font-size: clamp(28px, 4vw, 40px);
694
+ letter-spacing: -0.04em;
695
+ }
696
+
697
+ .final-shell p {
698
+ margin: 0 auto 22px;
699
+ max-width: 680px;
700
+ color: var(--text-muted);
701
+ font-size: 16px;
702
+ }
703
+
704
+ .footer {
705
+ padding: 26px 0 40px;
706
+ border-top: 1px solid var(--border);
707
+ }
708
+
709
+ .footer .container {
710
+ display: flex;
711
+ justify-content: space-between;
712
+ gap: 18px;
713
+ flex-wrap: wrap;
714
+ align-items: center;
715
+ }
716
+
717
+ .footer-links {
718
+ display: flex;
719
+ flex-wrap: wrap;
720
+ gap: 18px;
721
+ }
722
+
723
+ .footer-links a {
724
+ color: var(--text-muted);
725
+ text-decoration: none;
726
+ font-size: 13px;
727
+ }
728
+
729
+ .footer-links a:hover { color: var(--text); }
730
+
731
+ .footer-copy {
732
+ color: var(--text-muted);
733
+ font-size: 12px;
734
+ }
735
+
736
+ @media (max-width: 920px) {
737
+ .hero-grid,
738
+ .pricing-shell,
739
+ .proof-links,
740
+ .grid-3,
741
+ .split-grid {
742
+ grid-template-columns: 1fr;
743
+ }
744
+ }
745
+
746
+ @media (max-width: 700px) {
747
+ .hero { padding-top: 72px; }
748
+ .hero-copy,
749
+ .hero-aside,
750
+ .pricing-card,
751
+ .final-shell,
752
+ .feature-card,
753
+ .split-card,
754
+ .team-card {
755
+ padding: 22px;
756
+ }
757
+
758
+ .nav-links a:not(.nav-cta) { display: none; }
759
+ .hero-actions,
760
+ .pricing-actions {
761
+ flex-direction: column;
762
+ }
763
+
764
+ .buyer-form-actions {
765
+ grid-template-columns: 1fr;
766
+ }
767
+
768
+ .btn-primary,
769
+ .btn-secondary,
770
+ .btn-ghost,
771
+ .nav-cta {
772
+ width: 100%;
773
+ }
774
+ }
775
+ </style>
776
+ </head>
777
+ <body>
778
+ <nav>
779
+ <div class="container">
780
+ <a href="/" class="nav-logo"><span>👍👎</span> ThumbGate Pro</a>
781
+ <div class="nav-links">
782
+ <a href="#why-pay">Why Pro</a>
783
+ <a href="#proof">Proof</a>
784
+ <a href="#pricing">Pricing</a>
785
+ <a href="#faq">FAQ</a>
786
+ <a href="/dashboard">Demo</a>
787
+ <a class="nav-cta btn-pro-checkout" href="/checkout/pro?utm_source=website&utm_medium=pro_page_nav&utm_campaign=pro_pack&cta_id=pro_page_nav&cta_placement=nav&plan_id=pro&landing_path=%2Fpro">Start 7-Day Free Trial</a>
788
+ </div>
789
+ </div>
790
+ </nav>
791
+
792
+ <section class="hero">
793
+ <div class="container hero-grid">
794
+ <div class="panel hero-copy">
795
+ <div class="eyebrow">Paid lane for individual operators</div>
796
+ <h1>Stop paying review time for the same AI mistake twice.</h1>
797
+ <p>ThumbGate Pro is for the operator who already likes the free local install, but now needs a personal local dashboard, DPO export, review-ready evidence, and founder support on the workflows that keep hurting: deploys, migrations, force-pushes, and CI.</p>
798
+ <p>Free remains the honest default if all you need is local recall, Pre-Action Gates, and MCP wiring. Pro is the paid lane when you need faster debugging, exportable proof, and a tighter Reliability Gateway around one operator's real workflow.</p>
799
+ <div class="hero-proof">
800
+ <div class="proof-pill">Personal local dashboard</div>
801
+ <div class="proof-pill">DPO export from real corrections</div>
802
+ <div class="proof-pill">Review-ready evidence</div>
803
+ <div class="proof-pill">Founder support on risky flows</div>
804
+ </div>
805
+ <div class="hero-actions">
806
+ <a class="btn-primary btn-pro-checkout" href="/checkout/pro?utm_source=website&utm_medium=pro_page_hero&utm_campaign=pro_pack&cta_id=pro_page_primary&cta_placement=hero&plan_id=pro&landing_path=%2Fpro">Start 7-Day Free Trial</a>
807
+ <a class="btn-secondary btn-demo" href="/dashboard?utm_source=website&utm_medium=pro_page&utm_campaign=pro_pack">Open dashboard demo</a>
808
+ <a class="btn-ghost btn-free-path" href="/guide?utm_source=website&utm_medium=pro_page&utm_campaign=free_install">Stay on Free and install locally</a>
809
+ </div>
810
+ <p class="hero-note"><strong>Honest split:</strong> if local recall and gates are enough, stay on Free. Go Pro when you want your own dashboard, DPO training data export, and proof you can show on the next risky workflow review.</p>
811
+ </div>
812
+
813
+ <div class="panel hero-aside">
814
+ <div class="aside-card">
815
+ <div class="aside-kicker">What you are buying</div>
816
+ <h2>A faster operator loop</h2>
817
+ <p>See every blocked action, the gate that fired, the lesson behind it, and the export path that turns real thumbs-downs into reusable DPO pairs.</p>
818
+ <div class="price-stack">
819
+ <div class="price-line">
820
+ <div>
821
+ <strong>$19/mo</strong>
822
+ <span>Monthly Pro</span>
823
+ </div>
824
+ <a class="btn-primary btn-pro-checkout" href="/checkout/pro?utm_source=website&utm_medium=pro_page_monthly&utm_campaign=pro_pack&cta_id=pro_page_monthly&cta_placement=sidebar&plan_id=pro&landing_path=%2Fpro">Choose monthly</a>
825
+ </div>
826
+ <div class="price-line">
827
+ <div>
828
+ <strong>$149/yr</strong>
829
+ <span>Save 35% annually</span>
830
+ </div>
831
+ <a class="btn-secondary btn-pro-checkout" href="/checkout/pro?utm_source=website&utm_medium=pro_page_annual&utm_campaign=pro_pack&cta_id=pro_page_annual&cta_placement=sidebar&plan_id=pro&billing_cycle=annual&landing_path=%2Fpro">Choose annual</a>
832
+ </div>
833
+ </div>
834
+ </div>
835
+
836
+ <div class="aside-card">
837
+ <div class="aside-kicker">Proof-backed, not vibes</div>
838
+ <h3>Specific paid outcomes</h3>
839
+ <p>Visual gate debugger, DPO export, auto-connect after activation, Model Hardening Advisor, and founder support for the risky flow you need to harden first.</p>
840
+ </div>
841
+
842
+ <div class="aside-card">
843
+ <div class="aside-kicker">Keep the buyer path warm</div>
844
+ <h3>Save your work email before you decide</h3>
845
+ <p>We will keep the Pro checkout prefilled on this device and send the demo path plus product updates, so you can come back without retyping or losing the thread.</p>
846
+ <form class="buyer-form" action="/api/newsletter" method="POST" data-newsletter-form data-page="pro" data-intent="buyer_follow_up">
847
+ <input type="email" name="email" data-buyer-email placeholder="you@company.com" required>
848
+ <div class="buyer-form-actions">
849
+ <button type="submit" class="btn-secondary">Email me the demo</button>
850
+ <button type="button" class="btn-primary btn-email-checkout">Start trial with this email</button>
851
+ </div>
852
+ <p class="buyer-form-note">No sales deck. Just the Pro demo path, launch updates, and a prefilled checkout when you are ready.</p>
853
+ <p class="buyer-form-status" data-newsletter-status aria-live="polite"></p>
854
+ </form>
855
+ </div>
856
+ </div>
857
+ </div>
858
+ </section>
859
+
860
+ <section class="proof-strip section" id="proof">
861
+ <div class="container">
862
+ <div class="proof-links">
863
+ <a href="__VERIFICATION_URL__" target="_blank" rel="noopener">
864
+ <strong>Verification evidence</strong>
865
+ <span>Read the human proof pack and the buyer-facing evidence trail.</span>
866
+ </a>
867
+ <a href="__COMPATIBILITY_REPORT_URL__" target="_blank" rel="noopener">
868
+ <strong>Compatibility report</strong>
869
+ <span>Machine-readable proof for Claude Code, Cursor, Codex, Gemini, Amp, and OpenCode.</span>
870
+ </a>
871
+ <a href="__AUTOMATION_REPORT_URL__" target="_blank" rel="noopener">
872
+ <strong>Automation report</strong>
873
+ <span>Proof that the automation and enforcement path stays verifiable.</span>
874
+ </a>
875
+ <a href="/dashboard?utm_source=website&utm_medium=pro_page_proof&utm_campaign=pro_pack">
876
+ <strong>Live dashboard demo</strong>
877
+ <span>Inspect lessons, gates, and blocked actions before you buy.</span>
878
+ </a>
879
+ </div>
880
+ </div>
881
+ </section>
882
+
883
+ <section class="section" id="why-pay">
884
+ <div class="container">
885
+ <div class="section-label">Why operators pay</div>
886
+ <h2 class="section-title">Pro is not "more memory." It is a tighter operating loop around one operator's real failures.</h2>
887
+ <p class="section-intro">The paid story is simple: free helps you install and block repeated mistakes locally. Pro helps you debug those blocks faster, export the learning, and show proof when a workflow owner asks what changed.</p>
888
+ <div class="grid-3">
889
+ <div class="feature-card">
890
+ <h3>Debug the exact block in minutes</h3>
891
+ <p>The visual gate debugger shows every blocked action and the gate that fired, so you stop guessing whether the Reliability Gateway is actually working.</p>
892
+ <ul>
893
+ <li>See the gate, evidence, and lesson behind each deny.</li>
894
+ <li>Trust the system faster on deploys, migrations, and CI.</li>
895
+ </ul>
896
+ </div>
897
+ <div class="feature-card">
898
+ <h3>Turn corrections into DPO export</h3>
899
+ <p>Pro turns real thumbs-down corrections into ready-to-use preference pairs for model hardening, instead of leaving the learning trapped in one operator's head.</p>
900
+ <ul>
901
+ <li>DPO export built from actual accepted vs rejected behavior.</li>
902
+ <li>Model Hardening Advisor helps decide when fine-tuning is worth it.</li>
903
+ </ul>
904
+ </div>
905
+ <div class="feature-card">
906
+ <h3>Ship proof, not just confidence</h3>
907
+ <p>When the next risky workflow review happens, you have evidence links, reports, and a founder-supported path to harden the exact failure domain that keeps returning.</p>
908
+ <ul>
909
+ <li>Review-ready evidence for one operator's high-risk workflows.</li>
910
+ <li>Founder support on force-pushes, deploys, migrations, and CI.</li>
911
+ </ul>
912
+ </div>
913
+ </div>
914
+ </div>
915
+ </section>
916
+
917
+ <section class="section">
918
+ <div class="container">
919
+ <div class="section-label">Honest packaging</div>
920
+ <h2 class="section-title">Stay on Free when recall and gates are enough. Go Pro when you need proof and operator speed.</h2>
921
+ <div class="split-grid">
922
+ <div class="split-card free">
923
+ <div class="split-kicker">Stay on Free</div>
924
+ <h3>The local install is still the right first step</h3>
925
+ <p>If you only need local recall, Pre-Action Gates, MCP setup, and a way to stop repeated mistakes on one machine, keep the free install and move fast.</p>
926
+ <ul>
927
+ <li>Local-first recall, lessons, and enforcement.</li>
928
+ <li>No cloud account required.</li>
929
+ <li>Best when you do not yet need a personal dashboard or export path.</li>
930
+ </ul>
931
+ </div>
932
+ <div class="split-card pro">
933
+ <div class="split-kicker">Go Pro</div>
934
+ <h3>Buy Pro when the workflow owner asks for proof</h3>
935
+ <p>Pro is for the individual operator who now needs a personal local dashboard, DPO export, auto-connect, and a buyer-ready reason to pay instead of re-explaining the same failure pattern.</p>
936
+ <ul>
937
+ <li>Review-ready evidence and a dashboard of exactly what got blocked.</li>
938
+ <li>DPO export from real corrections, not synthetic examples.</li>
939
+ <li>Founder support for the first risky workflow you need to harden.</li>
940
+ </ul>
941
+ </div>
942
+ </div>
943
+ </div>
944
+ </section>
945
+
946
+ <section class="section" id="pricing">
947
+ <div class="container pricing-shell">
948
+ <div class="pricing-card">
949
+ <div class="section-label" style="text-align:left;margin-bottom:8px;">Pricing</div>
950
+ <h3>ThumbGate Pro for one operator</h3>
951
+ <div class="price">$19<span>/mo</span></div>
952
+ <div class="annual">or $149/yr when you already know this workflow needs to stay hardened</div>
953
+ <p class="pricing-note">Pro keeps the local-first posture and adds the paid operator surface: personal local dashboard, DPO export, auto-connect after activation, Model Hardening Advisor, and founder support.</p>
954
+ <ul>
955
+ <li>Visual gate debugger to inspect every blocked action and the gate that fired.</li>
956
+ <li>DPO training data export from real thumbs-down corrections.</li>
957
+ <li>Auto-connect running agents to your personal local dashboard after activation.</li>
958
+ <li>Founder support on risky workflows: migrations, deploys, force-pushes, and CI.</li>
959
+ </ul>
960
+ <div class="pricing-actions">
961
+ <a class="btn-primary btn-pro-checkout" href="/checkout/pro?utm_source=website&utm_medium=pro_page_pricing&utm_campaign=pro_pack&cta_id=pro_page_pricing_monthly&cta_placement=pricing&plan_id=pro&landing_path=%2Fpro">Start 7-Day Free Trial</a>
962
+ <a class="btn-secondary btn-pro-checkout" href="/checkout/pro?utm_source=website&utm_medium=pro_page_pricing&utm_campaign=pro_pack&cta_id=pro_page_pricing_annual&cta_placement=pricing&plan_id=pro&billing_cycle=annual&landing_path=%2Fpro">Choose annual</a>
963
+ </div>
964
+ <div class="pricing-meta">If the personal local dashboard and export path do not matter yet, stay on Free. This page exists so paid buyers do not have to infer the value from the general homepage.</div>
965
+ </div>
966
+
967
+ <div class="pricing-sidebar">
968
+ <div class="team-card">
969
+ <div class="section-label" style="text-align:left;margin-bottom:8px;">When Team is better</div>
970
+ <h3>Multiple agents, shared repos, one correction that should protect everyone</h3>
971
+ <p>Choose Team when you need a shared hosted lesson DB, org dashboard visibility, hosted review views, and a workflow hardening pilot instead of one operator's personal local dashboard.</p>
972
+ <div class="hero-actions" style="margin-top:18px;">
973
+ <a class="btn-secondary" href="/?utm_source=website&utm_medium=pro_page&utm_campaign=team_rollout#workflow-sprint-intake">Start team pilot intake</a>
974
+ </div>
975
+ </div>
976
+ <div class="team-card">
977
+ <div class="section-label" style="text-align:left;margin-bottom:8px;">Free path</div>
978
+ <h3>Prefer the local install first?</h3>
979
+ <p class="comparison-note">Install with <code style="font-family:var(--mono);color:var(--cyan);">npx thumbgate init</code>, keep the free local gates, and come back to Pro once the workflow owner asks for your own dashboard, exports, or review-ready proof.</p>
980
+ </div>
981
+ </div>
982
+ </div>
983
+ </section>
984
+
985
+ <section class="section" id="faq">
986
+ <div class="container">
987
+ <div class="section-label">FAQ</div>
988
+ <h2 class="section-title">Questions paid buyers ask before checkout</h2>
989
+ <div class="faq-list">
990
+ <div class="faq-item open">
991
+ <button class="faq-q" type="button" onclick="toggleFaq(this)" onkeydown="handleFaqKeydown(event)" aria-expanded="true">How is Pro different from the free install?</button>
992
+ <div class="faq-a">Free keeps the local recall, Pre-Action Gates, and MCP setup. Pro adds the personal local dashboard, DPO export, auto-connect after activation, and founder support when one risky workflow keeps repeating the same failure mode.</div>
993
+ </div>
994
+ <div class="faq-item">
995
+ <button class="faq-q" type="button" onclick="toggleFaq(this)" onkeydown="handleFaqKeydown(event)" aria-expanded="false">Does Pro require a cloud account?</button>
996
+ <div class="faq-a">No. Pro is still local-first for the individual operator lane. Team is the hosted rollout lane for shared lessons, org visibility, and hosted review views.</div>
997
+ </div>
998
+ <div class="faq-item">
999
+ <button class="faq-q" type="button" onclick="toggleFaq(this)" onkeydown="handleFaqKeydown(event)" aria-expanded="false">What happens after checkout?</button>
1000
+ <div class="faq-a">You activate Pro, connect the personal local dashboard, and your running agents can appear automatically so you can inspect blocked actions, active lessons, and exportable DPO pairs without adding a separate cloud dashboard dependency.</div>
1001
+ </div>
1002
+ <div class="faq-item">
1003
+ <button class="faq-q" type="button" onclick="toggleFaq(this)" onkeydown="handleFaqKeydown(event)" aria-expanded="false">When should I choose Team instead of Pro?</button>
1004
+ <div class="faq-a">Choose Team when one thumbs-down should protect multiple people or agents across shared repositories, or when you need shared hosted lessons, org dashboard visibility, and a workflow hardening pilot with rollout review views.</div>
1005
+ </div>
1006
+ </div>
1007
+ </div>
1008
+ </section>
1009
+
1010
+ <section class="final-cta">
1011
+ <div class="container">
1012
+ <div class="final-shell">
1013
+ <h2>Make the paid path obvious before you ask for the card.</h2>
1014
+ <p>ThumbGate Pro exists for the operator who wants the local dashboard, DPO export, and proof-ready story. The free install stays honest. The paid lane now has its own page.</p>
1015
+ <div class="hero-actions" style="justify-content:center;">
1016
+ <a class="btn-primary btn-pro-checkout" href="/checkout/pro?utm_source=website&utm_medium=pro_page_final&utm_campaign=pro_pack&cta_id=pro_page_final&cta_placement=final&plan_id=pro&landing_path=%2Fpro">Start 7-Day Free Trial</a>
1017
+ <a class="btn-secondary btn-demo" href="/dashboard?utm_source=website&utm_medium=pro_page_final&utm_campaign=pro_pack">Open dashboard demo</a>
1018
+ </div>
1019
+ </div>
1020
+ </div>
1021
+ </section>
1022
+
1023
+ <footer class="footer">
1024
+ <div class="container">
1025
+ <div class="footer-links">
1026
+ <a href="/">Home</a>
1027
+ <a href="/guide">Setup Guide</a>
1028
+ <a href="/dashboard">Dashboard Demo</a>
1029
+ <a href="__VERIFICATION_URL__" target="_blank" rel="noopener">Verification Evidence</a>
1030
+ <a href="https://github.com/IgorGanapolsky/ThumbGate" target="_blank" rel="noopener">GitHub</a>
1031
+ </div>
1032
+ <div class="footer-copy">ThumbGate Pro for individual operators. Team stays intake-first.</div>
1033
+ </div>
1034
+ </footer>
1035
+
1036
+ <script src="/js/buyer-intent.js"></script>
1037
+ <script>
1038
+ function initializeBuyerIntent() {
1039
+ globalThis.ThumbGateBuyerIntent.initializeBuyerIntent({
1040
+ page: 'pro',
1041
+ duplicateMessage: 'Already saved. All Pro checkout buttons on this device are now prefilled.',
1042
+ successMessage: 'Saved. We will keep checkout prefilled on this device.',
1043
+ });
1044
+ globalThis.ThumbGateBuyerIntent.initializeEmailCheckoutButtons({
1045
+ eventName: 'pro_checkout_email_start',
1046
+ eventProps: { page: 'pro', intent: 'checkout' },
1047
+ });
1048
+ }
1049
+
1050
+ function trackClick(selector, eventName, props) {
1051
+ document.querySelectorAll(selector).forEach(function(el) {
1052
+ el.addEventListener('click', function() {
1053
+ if (typeof plausible === 'function') plausible(eventName, { props: props || {} });
1054
+ });
1055
+ });
1056
+ }
1057
+
1058
+ function toggleFaq(el) {
1059
+ var item = el.parentElement;
1060
+ var open = item.classList.toggle('open');
1061
+ el.setAttribute('aria-expanded', open ? 'true' : 'false');
1062
+ }
1063
+
1064
+ function handleFaqKeydown(event) {
1065
+ if (event.key !== 'Enter' && event.key !== ' ') return;
1066
+ event.preventDefault();
1067
+ toggleFaq(event.currentTarget);
1068
+ }
1069
+
1070
+ trackClick('.btn-pro-checkout', 'pro_checkout_start', { tier: 'pro', page: 'pro' });
1071
+ trackClick('.btn-demo', 'pro_demo_click', { page: 'pro' });
1072
+ trackClick('.btn-free-path', 'pro_free_path_click', { page: 'pro' });
1073
+ trackClick('.proof-links a', 'pro_proof_click', { page: 'pro' });
1074
+ initializeBuyerIntent();
1075
+
1076
+ document.querySelectorAll('.faq-q').forEach(function(el) {
1077
+ el.addEventListener('click', function() {
1078
+ if (typeof plausible === 'function') {
1079
+ plausible('pro_faq_open', { props: { question: (el.textContent || '').trim().substring(0, 80) } });
1080
+ }
1081
+ });
1082
+ });
1083
+ </script>
1084
+ </body>
1085
+ </html>