@agent-relay/dashboard 2.0.81 → 2.0.82

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 (244) hide show
  1. package/out/404.html +1 -1
  2. package/out/_next/static/chunks/{118-4c8241b0218335de.js → 118-ae2b650136a5a5fc.js} +1 -1
  3. package/out/_next/static/chunks/407-0c82986cf79c8ecb.js +1 -0
  4. package/out/_next/static/chunks/app/app/[[...slug]]/{page-1e81c047cff17212.js → page-f7eca1b66fb4249b.js} +1 -1
  5. package/out/_next/static/chunks/app/{page-6892fe2dd07fb48b.js → page-0ee604f7070d14c0.js} +1 -1
  6. package/out/_next/static/css/8968d98ed4c4d33f.css +1 -0
  7. package/out/about.html +2 -2
  8. package/out/about.txt +1 -1
  9. package/out/app/onboarding.html +1 -1
  10. package/out/app/onboarding.txt +1 -1
  11. package/out/app.html +1 -1
  12. package/out/app.txt +2 -2
  13. package/out/blog/go-to-bed-wake-up-to-a-finished-product.html +2 -2
  14. package/out/blog/go-to-bed-wake-up-to-a-finished-product.txt +1 -1
  15. package/out/blog/let-them-cook-multi-agent-orchestration.html +2 -2
  16. package/out/blog/let-them-cook-multi-agent-orchestration.txt +2 -2
  17. package/out/blog.html +2 -2
  18. package/out/blog.txt +1 -1
  19. package/out/careers.html +2 -2
  20. package/out/careers.txt +1 -1
  21. package/out/changelog.html +2 -2
  22. package/out/changelog.txt +1 -1
  23. package/out/cloud/link.html +1 -1
  24. package/out/cloud/link.txt +2 -2
  25. package/out/complete-profile.html +2 -2
  26. package/out/complete-profile.txt +1 -1
  27. package/out/connect-repos.html +1 -1
  28. package/out/connect-repos.txt +1 -1
  29. package/out/contact.html +2 -2
  30. package/out/contact.txt +1 -1
  31. package/out/docs.html +2 -2
  32. package/out/docs.txt +1 -1
  33. package/out/history.html +1 -1
  34. package/out/history.txt +2 -2
  35. package/out/index.html +1 -1
  36. package/out/index.txt +2 -2
  37. package/out/login.html +2 -2
  38. package/out/login.txt +1 -1
  39. package/out/metrics.html +1 -1
  40. package/out/metrics.txt +2 -2
  41. package/out/pricing.html +2 -2
  42. package/out/pricing.txt +1 -1
  43. package/out/privacy.html +2 -2
  44. package/out/privacy.txt +1 -1
  45. package/out/providers/setup/claude.html +1 -1
  46. package/out/providers/setup/claude.txt +1 -1
  47. package/out/providers/setup/codex.html +1 -1
  48. package/out/providers/setup/codex.txt +1 -1
  49. package/out/providers/setup/cursor.html +1 -1
  50. package/out/providers/setup/cursor.txt +1 -1
  51. package/out/providers.html +1 -1
  52. package/out/providers.txt +1 -1
  53. package/out/security.html +2 -2
  54. package/out/security.txt +1 -1
  55. package/out/signup.html +2 -2
  56. package/out/signup.txt +1 -1
  57. package/out/terms.html +2 -2
  58. package/out/terms.txt +1 -1
  59. package/package.json +7 -1
  60. package/src/app/about/page.tsx +7 -0
  61. package/src/app/app/[[...slug]]/DashboardPageClient.tsx +853 -0
  62. package/src/app/app/[[...slug]]/page.tsx +23 -0
  63. package/src/app/app/onboarding/page.tsx +394 -0
  64. package/src/app/apple-icon.png +0 -0
  65. package/src/app/blog/go-to-bed-wake-up-to-a-finished-product/page.tsx +88 -0
  66. package/src/app/blog/let-them-cook-multi-agent-orchestration/page.tsx +93 -0
  67. package/src/app/blog/page.tsx +15 -0
  68. package/src/app/careers/page.tsx +7 -0
  69. package/src/app/changelog/page.tsx +7 -0
  70. package/src/app/cloud/link/page.tsx +464 -0
  71. package/src/app/complete-profile/page.tsx +204 -0
  72. package/src/app/connect-repos/page.tsx +410 -0
  73. package/src/app/contact/page.tsx +7 -0
  74. package/src/app/docs/page.tsx +7 -0
  75. package/src/app/favicon.png +0 -0
  76. package/src/app/globals.css +200 -0
  77. package/src/app/history/page.tsx +658 -0
  78. package/src/app/layout.tsx +25 -0
  79. package/src/app/login/page.tsx +424 -0
  80. package/src/app/metrics/page.tsx +781 -0
  81. package/src/app/page.tsx +59 -0
  82. package/src/app/pricing/page.tsx +7 -0
  83. package/src/app/privacy/page.tsx +7 -0
  84. package/src/app/providers/page.tsx +193 -0
  85. package/src/app/providers/setup/[provider]/ProviderSetupClient.tsx +197 -0
  86. package/src/app/providers/setup/[provider]/constants.ts +35 -0
  87. package/src/app/providers/setup/[provider]/page.tsx +42 -0
  88. package/src/app/security/page.tsx +7 -0
  89. package/src/app/signup/page.tsx +533 -0
  90. package/src/app/terms/page.tsx +7 -0
  91. package/src/components/ActivityFeed.tsx +216 -0
  92. package/src/components/AddWorkspaceModal.tsx +170 -0
  93. package/src/components/AgentCard.test.tsx +134 -0
  94. package/src/components/AgentCard.tsx +585 -0
  95. package/src/components/AgentList.test.tsx +147 -0
  96. package/src/components/AgentList.tsx +419 -0
  97. package/src/components/AgentLogPreview.tsx +173 -0
  98. package/src/components/AgentProfilePanel.tsx +569 -0
  99. package/src/components/App.tsx +3424 -0
  100. package/src/components/BillingPanel.tsx +922 -0
  101. package/src/components/BillingResult.tsx +447 -0
  102. package/src/components/BroadcastComposer.tsx +690 -0
  103. package/src/components/ChannelAdminPanel.tsx +773 -0
  104. package/src/components/ChannelBrowser.tsx +385 -0
  105. package/src/components/ChannelChat.tsx +261 -0
  106. package/src/components/ChannelSidebar.tsx +399 -0
  107. package/src/components/CloudSessionProvider.tsx +130 -0
  108. package/src/components/CommandPalette.tsx +815 -0
  109. package/src/components/ConfirmationDialog.tsx +133 -0
  110. package/src/components/ConversationHistory.tsx +518 -0
  111. package/src/components/CoordinatorPanel.tsx +956 -0
  112. package/src/components/DecisionQueue.tsx +717 -0
  113. package/src/components/DirectMessageView.tsx +164 -0
  114. package/src/components/FileAutocomplete.tsx +368 -0
  115. package/src/components/FleetOverview.tsx +278 -0
  116. package/src/components/LogViewer.tsx +310 -0
  117. package/src/components/LogViewerPanel.tsx +482 -0
  118. package/src/components/Logo.tsx +284 -0
  119. package/src/components/MentionAutocomplete.tsx +384 -0
  120. package/src/components/MessageComposer.tsx +473 -0
  121. package/src/components/MessageList.tsx +725 -0
  122. package/src/components/MessageSenderName.tsx +91 -0
  123. package/src/components/MessageStatusIndicator.tsx +142 -0
  124. package/src/components/NewConversationModal.tsx +400 -0
  125. package/src/components/NotificationToast.tsx +488 -0
  126. package/src/components/OnlineUsersIndicator.tsx +164 -0
  127. package/src/components/Pagination.tsx +124 -0
  128. package/src/components/PricingPlans.tsx +386 -0
  129. package/src/components/ProjectList.tsx +711 -0
  130. package/src/components/ProviderAuthFlow.tsx +343 -0
  131. package/src/components/ProviderConnectionList.tsx +375 -0
  132. package/src/components/ProvisioningProgress.tsx +730 -0
  133. package/src/components/ReactionChips.tsx +70 -0
  134. package/src/components/ReactionPicker.tsx +121 -0
  135. package/src/components/RepoAccessPanel.tsx +787 -0
  136. package/src/components/RepositoriesPanel.tsx +901 -0
  137. package/src/components/ServerCard.tsx +202 -0
  138. package/src/components/SessionExpiredModal.tsx +128 -0
  139. package/src/components/SpawnModal.test.tsx +190 -0
  140. package/src/components/SpawnModal.tsx +1001 -0
  141. package/src/components/TaskAssignmentUI.tsx +375 -0
  142. package/src/components/TerminalProviderSetup.tsx +517 -0
  143. package/src/components/ThemeProvider.tsx +159 -0
  144. package/src/components/ThinkingIndicator.tsx +231 -0
  145. package/src/components/ThreadList.tsx +198 -0
  146. package/src/components/ThreadPanel.tsx +405 -0
  147. package/src/components/TrajectoryViewer.tsx +698 -0
  148. package/src/components/TypingIndicator.tsx +69 -0
  149. package/src/components/UsageBanner.tsx +231 -0
  150. package/src/components/UserProfilePanel.tsx +233 -0
  151. package/src/components/WorkspaceContext.tsx +95 -0
  152. package/src/components/WorkspaceSelector.tsx +234 -0
  153. package/src/components/WorkspaceStatusIndicator.tsx +396 -0
  154. package/src/components/XTermInteractive.tsx +516 -0
  155. package/src/components/XTermLogViewer.tsx +719 -0
  156. package/src/components/channels/ChannelDialogs.tsx +1411 -0
  157. package/src/components/channels/ChannelHeader.tsx +317 -0
  158. package/src/components/channels/ChannelMessageList.tsx +463 -0
  159. package/src/components/channels/ChannelViewV1.tsx +146 -0
  160. package/src/components/channels/MessageInput.tsx +302 -0
  161. package/src/components/channels/SearchInput.tsx +172 -0
  162. package/src/components/channels/SearchResults.tsx +336 -0
  163. package/src/components/channels/api.test.ts +1527 -0
  164. package/src/components/channels/api.ts +703 -0
  165. package/src/components/channels/index.ts +76 -0
  166. package/src/components/channels/mockApi.ts +344 -0
  167. package/src/components/channels/types.ts +566 -0
  168. package/src/components/hooks/index.ts +58 -0
  169. package/src/components/hooks/useAgentLogs.ts +504 -0
  170. package/src/components/hooks/useAgents.ts +127 -0
  171. package/src/components/hooks/useBroadcastDedup.test.ts +371 -0
  172. package/src/components/hooks/useBroadcastDedup.ts +86 -0
  173. package/src/components/hooks/useChannelAdmin.ts +329 -0
  174. package/src/components/hooks/useChannelBrowser.ts +239 -0
  175. package/src/components/hooks/useChannelCommands.ts +138 -0
  176. package/src/components/hooks/useChannels.ts +367 -0
  177. package/src/components/hooks/useDebounce.ts +29 -0
  178. package/src/components/hooks/useDirectMessage.test.ts +952 -0
  179. package/src/components/hooks/useDirectMessage.ts +141 -0
  180. package/src/components/hooks/useMessages.ts +310 -0
  181. package/src/components/hooks/useOrchestrator.test.ts +165 -0
  182. package/src/components/hooks/useOrchestrator.ts +424 -0
  183. package/src/components/hooks/usePinnedAgents.test.ts +356 -0
  184. package/src/components/hooks/usePinnedAgents.ts +140 -0
  185. package/src/components/hooks/usePresence.test.ts +245 -0
  186. package/src/components/hooks/usePresence.ts +377 -0
  187. package/src/components/hooks/useRecentRepos.ts +130 -0
  188. package/src/components/hooks/useSession.ts +209 -0
  189. package/src/components/hooks/useThread.ts +138 -0
  190. package/src/components/hooks/useTrajectory.ts +265 -0
  191. package/src/components/hooks/useWebSocket.ts +290 -0
  192. package/src/components/hooks/useWorkspaceMembers.ts +132 -0
  193. package/src/components/hooks/useWorkspaceRepos.ts +73 -0
  194. package/src/components/hooks/useWorkspaceStatus.ts +237 -0
  195. package/src/components/index.ts +81 -0
  196. package/src/components/layout/Header.tsx +311 -0
  197. package/src/components/layout/RepoContextHeader.tsx +361 -0
  198. package/src/components/layout/Sidebar.archive.test.tsx +126 -0
  199. package/src/components/layout/Sidebar.test.tsx +691 -0
  200. package/src/components/layout/Sidebar.tsx +900 -0
  201. package/src/components/layout/index.ts +7 -0
  202. package/src/components/settings/BillingSettingsPanel.tsx +564 -0
  203. package/src/components/settings/SettingsPage.tsx +683 -0
  204. package/src/components/settings/TeamSettingsPanel.tsx +560 -0
  205. package/src/components/settings/WorkspaceSettingsPanel.tsx +1368 -0
  206. package/src/components/settings/index.ts +11 -0
  207. package/src/components/settings/types.ts +79 -0
  208. package/src/components/utils/messageFormatting.test.tsx +331 -0
  209. package/src/components/utils/messageFormatting.tsx +597 -0
  210. package/src/index.ts +63 -0
  211. package/src/landing/AboutPage.tsx +77 -0
  212. package/src/landing/BlogContent.tsx +187 -0
  213. package/src/landing/BlogPage.tsx +47 -0
  214. package/src/landing/CareersPage.tsx +53 -0
  215. package/src/landing/ChangelogPage.tsx +33 -0
  216. package/src/landing/ContactPage.tsx +41 -0
  217. package/src/landing/DocsPage.tsx +43 -0
  218. package/src/landing/LandingPage.tsx +702 -0
  219. package/src/landing/PricingPage.tsx +549 -0
  220. package/src/landing/PrivacyPage.tsx +117 -0
  221. package/src/landing/SecurityPage.tsx +42 -0
  222. package/src/landing/StaticPage.tsx +165 -0
  223. package/src/landing/TermsPage.tsx +125 -0
  224. package/src/landing/blogData.ts +312 -0
  225. package/src/landing/index.ts +18 -0
  226. package/src/landing/styles.css +3673 -0
  227. package/src/lib/agent-merge.test.ts +43 -0
  228. package/src/lib/agent-merge.ts +35 -0
  229. package/src/lib/api.ts +1294 -0
  230. package/src/lib/cloudApi.ts +893 -0
  231. package/src/lib/colors.test.ts +175 -0
  232. package/src/lib/colors.ts +218 -0
  233. package/src/lib/config.ts +109 -0
  234. package/src/lib/hierarchy.ts +242 -0
  235. package/src/lib/stuckDetection.ts +142 -0
  236. package/src/lib/useUrlRouting.ts +190 -0
  237. package/src/types/index.ts +317 -0
  238. package/src/types/threading.ts +7 -0
  239. package/out/_next/static/chunks/285-dc644487a8d6500d.js +0 -1
  240. package/out/_next/static/css/4c58d9cf493aa626.css +0 -1
  241. /package/out/_next/static/{dYlczDQI12PIQ3tqq3N4Y → IxfA6RZu4trcsEMYlkQra}/_buildManifest.js +0 -0
  242. /package/out/_next/static/{dYlczDQI12PIQ3tqq3N4Y → IxfA6RZu4trcsEMYlkQra}/_ssgManifest.js +0 -0
  243. /package/out/_next/static/chunks/{528-d375bc8b46912d2c.js → 528-f5f676996d613c25.js} +0 -0
  244. /package/out/_next/static/chunks/app/blog/let-them-cook-multi-agent-orchestration/{page-a58308f43557b908.js → page-b194f207fbd91862.js} +0 -0
@@ -0,0 +1,3673 @@
1
+ /**
2
+ * Agent Relay Cloud - Landing Page Styles
3
+ *
4
+ * Aesthetic: Mission Control / Command Center
5
+ * Dark, atmospheric, with glowing agent connections
6
+ */
7
+
8
+ /* ============================================
9
+ FONTS
10
+ ============================================ */
11
+ @import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=IBM+Plex+Mono:wght@400;500;600&family=Inter:wght@400;500;600&display=swap');
12
+
13
+ /* ============================================
14
+ CSS VARIABLES
15
+ ============================================ */
16
+ :root {
17
+ /* Colors */
18
+ --bg-deep: #0a0a0f;
19
+ --bg-primary: #0d0d14;
20
+ --bg-secondary: #12121c;
21
+ --bg-tertiary: #181824;
22
+ --bg-card: #1a1a28;
23
+ --bg-elevated: #202030;
24
+
25
+ --text-primary: #f0f0f5;
26
+ --text-secondary: #a0a0b0;
27
+ --text-muted: #606070;
28
+ --text-dim: #404050;
29
+
30
+ --accent-cyan: #00d9ff;
31
+ --accent-orange: #ff6b35;
32
+ --accent-teal: #00ffc8;
33
+ --accent-blue: #0891b2;
34
+ --accent-green: #00ffc8;
35
+
36
+ --border-subtle: rgba(255, 255, 255, 0.06);
37
+ --border-light: rgba(255, 255, 255, 0.1);
38
+ --border-medium: rgba(255, 255, 255, 0.15);
39
+
40
+ --glow-cyan: 0 0 30px rgba(0, 217, 255, 0.3);
41
+ --glow-orange: 0 0 30px rgba(255, 107, 53, 0.3);
42
+ --glow-teal: 0 0 30px rgba(0, 255, 200, 0.3);
43
+ --glow-blue: 0 0 30px rgba(8, 145, 178, 0.3);
44
+
45
+ /* Typography */
46
+ --font-display: 'Outfit', sans-serif;
47
+ --font-mono: 'IBM Plex Mono', monospace;
48
+ --font-body: 'Inter', sans-serif;
49
+
50
+ /* Spacing */
51
+ --section-padding: 120px;
52
+ --container-max: 1280px;
53
+
54
+ /* Transitions */
55
+ --transition-fast: 0.15s ease;
56
+ --transition-medium: 0.3s ease;
57
+ --transition-slow: 0.5s ease;
58
+ }
59
+
60
+ /* ============================================
61
+ RESET & BASE (scoped to landing pages only)
62
+ ============================================ */
63
+ .landing-page *,
64
+ .landing-page *::before,
65
+ .landing-page *::after,
66
+ .pricing-page *,
67
+ .pricing-page *::before,
68
+ .pricing-page *::after {
69
+ margin: 0;
70
+ padding: 0;
71
+ box-sizing: border-box;
72
+ }
73
+
74
+ .landing-page,
75
+ .pricing-page {
76
+ font-family: var(--font-body);
77
+ font-size: 16px;
78
+ line-height: 1.6;
79
+ color: var(--text-primary);
80
+ background: var(--bg-deep);
81
+ -webkit-font-smoothing: antialiased;
82
+ -moz-osx-font-smoothing: grayscale;
83
+ }
84
+
85
+ .landing-page a,
86
+ .pricing-page a {
87
+ color: inherit;
88
+ text-decoration: none;
89
+ }
90
+
91
+ .landing-page button,
92
+ .pricing-page button {
93
+ font-family: inherit;
94
+ cursor: pointer;
95
+ border: none;
96
+ background: none;
97
+ }
98
+
99
+ /* ============================================
100
+ LANDING PAGE CONTAINER
101
+ ============================================ */
102
+ .landing-page {
103
+ position: relative;
104
+ min-height: 100vh;
105
+ overflow-x: hidden;
106
+ }
107
+
108
+ .landing-bg {
109
+ position: fixed;
110
+ inset: 0;
111
+ pointer-events: none;
112
+ z-index: 0;
113
+ }
114
+
115
+ /* ============================================
116
+ GRID BACKGROUND
117
+ ============================================ */
118
+ .grid-bg {
119
+ position: absolute;
120
+ inset: 0;
121
+ overflow: hidden;
122
+ }
123
+
124
+ .grid-lines {
125
+ position: absolute;
126
+ inset: 0;
127
+ background-image:
128
+ linear-gradient(rgba(255, 255, 255, 0.02) 1px, transparent 1px),
129
+ linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
130
+ background-size: 60px 60px;
131
+ mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, black 30%, transparent 70%);
132
+ }
133
+
134
+ .grid-glow {
135
+ position: absolute;
136
+ top: 0;
137
+ left: 50%;
138
+ transform: translateX(-50%);
139
+ width: 100%;
140
+ height: 600px;
141
+ background: radial-gradient(ellipse 60% 40% at 50% 0%, rgba(0, 217, 255, 0.08) 0%, transparent 70%);
142
+ }
143
+
144
+ /* ============================================
145
+ GLOW ORBS
146
+ ============================================ */
147
+ .glow-orbs {
148
+ position: absolute;
149
+ inset: 0;
150
+ }
151
+
152
+ .orb {
153
+ position: absolute;
154
+ border-radius: 50%;
155
+ filter: blur(100px);
156
+ opacity: 0.4;
157
+ animation: float 20s ease-in-out infinite;
158
+ }
159
+
160
+ .orb-1 {
161
+ width: 600px;
162
+ height: 600px;
163
+ background: var(--accent-cyan);
164
+ top: -200px;
165
+ left: -200px;
166
+ animation-delay: 0s;
167
+ }
168
+
169
+ .orb-2 {
170
+ width: 500px;
171
+ height: 500px;
172
+ background: var(--accent-teal);
173
+ top: 40%;
174
+ right: -150px;
175
+ animation-delay: -7s;
176
+ }
177
+
178
+ .orb-3 {
179
+ width: 400px;
180
+ height: 400px;
181
+ background: var(--accent-orange);
182
+ bottom: 10%;
183
+ left: 20%;
184
+ animation-delay: -14s;
185
+ }
186
+
187
+ @keyframes float {
188
+ 0%, 100% { transform: translate(0, 0) scale(1); }
189
+ 25% { transform: translate(30px, -30px) scale(1.05); }
190
+ 50% { transform: translate(-20px, 20px) scale(0.95); }
191
+ 75% { transform: translate(20px, 10px) scale(1.02); }
192
+ }
193
+
194
+ /* ============================================
195
+ NAVIGATION
196
+ ============================================ */
197
+ .nav {
198
+ position: fixed;
199
+ top: 0;
200
+ left: 0;
201
+ right: 0;
202
+ z-index: 100;
203
+ padding: 20px 40px;
204
+ transition: var(--transition-medium);
205
+ }
206
+
207
+ .nav.scrolled {
208
+ background: rgba(10, 10, 15, 0.9);
209
+ backdrop-filter: blur(20px);
210
+ border-bottom: 1px solid var(--border-subtle);
211
+ padding: 16px 40px;
212
+ }
213
+
214
+ .nav-inner {
215
+ max-width: var(--container-max);
216
+ margin: 0 auto;
217
+ display: flex;
218
+ align-items: center;
219
+ justify-content: space-between;
220
+ }
221
+
222
+ .nav-logo {
223
+ display: flex;
224
+ align-items: center;
225
+ gap: 10px;
226
+ font-family: var(--font-display);
227
+ font-weight: 700;
228
+ font-size: 20px;
229
+ }
230
+
231
+ .logo-icon {
232
+ font-size: 24px;
233
+ color: var(--accent-cyan);
234
+ filter: drop-shadow(var(--glow-cyan));
235
+ }
236
+
237
+ .nav-links {
238
+ display: flex;
239
+ align-items: center;
240
+ gap: 40px;
241
+ }
242
+
243
+ .nav-links a {
244
+ font-size: 14px;
245
+ font-weight: 500;
246
+ color: var(--text-secondary);
247
+ transition: var(--transition-fast);
248
+ }
249
+
250
+ .nav-links a:hover {
251
+ color: var(--text-primary);
252
+ }
253
+
254
+ .nav-docs {
255
+ padding: 6px 14px;
256
+ background: var(--bg-elevated);
257
+ border-radius: 6px;
258
+ border: 1px solid var(--border-light);
259
+ }
260
+
261
+ .nav-actions {
262
+ display: flex;
263
+ align-items: center;
264
+ gap: 12px;
265
+ }
266
+
267
+ /* Hide mobile elements on desktop */
268
+ .mobile-menu-toggle,
269
+ .mobile-menu-overlay,
270
+ .mobile-menu {
271
+ display: none;
272
+ }
273
+
274
+ /* ============================================
275
+ BUTTONS
276
+ ============================================ */
277
+ .btn-primary {
278
+ display: inline-flex;
279
+ align-items: center;
280
+ gap: 8px;
281
+ padding: 12px 24px;
282
+ background: linear-gradient(135deg, var(--accent-cyan) 0%, #00b8d9 100%);
283
+ color: var(--bg-deep);
284
+ font-weight: 600;
285
+ font-size: 14px;
286
+ border-radius: 8px;
287
+ transition: var(--transition-fast);
288
+ box-shadow: 0 4px 20px rgba(0, 217, 255, 0.3);
289
+ }
290
+
291
+ .btn-primary:hover {
292
+ transform: translateY(-2px);
293
+ box-shadow: 0 6px 30px rgba(0, 217, 255, 0.4);
294
+ }
295
+
296
+ .btn-ghost {
297
+ display: inline-flex;
298
+ align-items: center;
299
+ gap: 8px;
300
+ padding: 12px 24px;
301
+ background: transparent;
302
+ color: var(--text-primary);
303
+ font-weight: 500;
304
+ font-size: 14px;
305
+ border-radius: 8px;
306
+ border: 1px solid var(--border-light);
307
+ transition: var(--transition-fast);
308
+ }
309
+
310
+ .btn-ghost:hover {
311
+ background: rgba(255, 255, 255, 0.05);
312
+ border-color: var(--border-medium);
313
+ }
314
+
315
+ .btn-large {
316
+ padding: 16px 32px;
317
+ font-size: 16px;
318
+ }
319
+
320
+ .btn-full {
321
+ width: 100%;
322
+ justify-content: center;
323
+ }
324
+
325
+ .btn-arrow {
326
+ transition: transform var(--transition-fast);
327
+ }
328
+
329
+ .btn-primary:hover .btn-arrow {
330
+ transform: translateX(4px);
331
+ }
332
+
333
+ .play-icon {
334
+ font-size: 10px;
335
+ }
336
+
337
+ /* ============================================
338
+ HERO SECTION
339
+ ============================================ */
340
+ .hero {
341
+ position: relative;
342
+ z-index: 1;
343
+ min-height: 100vh;
344
+ display: grid;
345
+ grid-template-columns: 1fr 1fr;
346
+ gap: 80px;
347
+ align-items: center;
348
+ max-width: var(--container-max);
349
+ margin: 0 auto;
350
+ padding: 140px 40px 100px;
351
+ }
352
+
353
+ .hero-badge {
354
+ display: inline-flex;
355
+ align-items: center;
356
+ gap: 8px;
357
+ padding: 8px 16px;
358
+ background: rgba(0, 217, 255, 0.1);
359
+ border: 1px solid rgba(0, 217, 255, 0.2);
360
+ border-radius: 100px;
361
+ font-size: 13px;
362
+ font-weight: 500;
363
+ color: var(--accent-cyan);
364
+ margin-bottom: 24px;
365
+ animation: fadeInUp 0.6s ease forwards;
366
+ }
367
+
368
+ .badge-dot {
369
+ width: 6px;
370
+ height: 6px;
371
+ background: var(--accent-cyan);
372
+ border-radius: 50%;
373
+ animation: pulse 2s ease-in-out infinite;
374
+ }
375
+
376
+ @keyframes pulse {
377
+ 0%, 100% { opacity: 1; transform: scale(1); }
378
+ 50% { opacity: 0.5; transform: scale(1.2); }
379
+ }
380
+
381
+ .hero-title {
382
+ font-family: var(--font-display);
383
+ font-size: clamp(48px, 6vw, 72px);
384
+ font-weight: 800;
385
+ line-height: 1.1;
386
+ letter-spacing: -0.02em;
387
+ margin-bottom: 24px;
388
+ }
389
+
390
+ .title-line {
391
+ display: block;
392
+ animation: fadeInUp 0.6s ease forwards;
393
+ animation-delay: 0.1s;
394
+ opacity: 0;
395
+ }
396
+
397
+ .title-line:nth-child(2) {
398
+ animation-delay: 0.2s;
399
+ }
400
+
401
+ .title-line.gradient {
402
+ background: linear-gradient(135deg, var(--accent-cyan) 0%, var(--accent-teal) 50%, var(--accent-blue) 100%);
403
+ -webkit-background-clip: text;
404
+ -webkit-text-fill-color: transparent;
405
+ background-clip: text;
406
+ }
407
+
408
+ @keyframes fadeInUp {
409
+ from {
410
+ opacity: 0;
411
+ transform: translateY(20px);
412
+ }
413
+ to {
414
+ opacity: 1;
415
+ transform: translateY(0);
416
+ }
417
+ }
418
+
419
+ .hero-subtitle {
420
+ font-size: 18px;
421
+ line-height: 1.7;
422
+ color: var(--text-secondary);
423
+ max-width: 500px;
424
+ margin-bottom: 40px;
425
+ animation: fadeInUp 0.6s ease forwards;
426
+ animation-delay: 0.3s;
427
+ opacity: 0;
428
+ }
429
+
430
+ .hero-cta {
431
+ display: flex;
432
+ gap: 16px;
433
+ margin-bottom: 60px;
434
+ animation: fadeInUp 0.6s ease forwards;
435
+ animation-delay: 0.4s;
436
+ opacity: 0;
437
+ }
438
+
439
+ .hero-stats {
440
+ display: flex;
441
+ align-items: center;
442
+ gap: 32px;
443
+ animation: fadeInUp 0.6s ease forwards;
444
+ animation-delay: 0.5s;
445
+ opacity: 0;
446
+ }
447
+
448
+ .stat {
449
+ display: flex;
450
+ flex-direction: column;
451
+ gap: 4px;
452
+ }
453
+
454
+ .stat-value {
455
+ font-family: var(--font-display);
456
+ font-size: 28px;
457
+ font-weight: 700;
458
+ color: var(--text-primary);
459
+ }
460
+
461
+ .stat-label {
462
+ font-size: 13px;
463
+ color: var(--text-muted);
464
+ }
465
+
466
+ .stat-divider {
467
+ width: 1px;
468
+ height: 40px;
469
+ background: var(--border-light);
470
+ }
471
+
472
+ /* ============================================
473
+ AGENT NETWORK VISUALIZATION
474
+ ============================================ */
475
+ .hero-visual {
476
+ position: relative;
477
+ animation: fadeIn 1s ease forwards;
478
+ animation-delay: 0.6s;
479
+ opacity: 0;
480
+ overflow: hidden;
481
+ }
482
+
483
+ @keyframes fadeIn {
484
+ to { opacity: 1; }
485
+ }
486
+
487
+ .agent-network {
488
+ position: relative;
489
+ width: 100%;
490
+ aspect-ratio: 1;
491
+ max-width: 500px;
492
+ margin: 0 auto;
493
+ overflow: hidden;
494
+ }
495
+
496
+ .network-lines {
497
+ position: absolute;
498
+ inset: 0;
499
+ width: 100%;
500
+ height: 100%;
501
+ }
502
+
503
+ .network-line {
504
+ stroke: rgba(255, 255, 255, 0.1);
505
+ stroke-width: 0.5;
506
+ }
507
+
508
+ .network-line-glow {
509
+ stroke: var(--accent-cyan);
510
+ stroke-width: 1;
511
+ stroke-dasharray: 100;
512
+ stroke-dashoffset: 100;
513
+ animation: lineFlow 3s ease-in-out infinite;
514
+ filter: drop-shadow(0 0 4px var(--accent-cyan));
515
+ }
516
+
517
+ @keyframes lineFlow {
518
+ 0% { stroke-dashoffset: 100; opacity: 0; }
519
+ 50% { opacity: 1; }
520
+ 100% { stroke-dashoffset: -100; opacity: 0; }
521
+ }
522
+
523
+ .network-agent {
524
+ position: absolute;
525
+ transform: translate(-50%, -50%);
526
+ display: flex;
527
+ flex-direction: column;
528
+ align-items: center;
529
+ gap: 8px;
530
+ }
531
+
532
+ .agent-glow {
533
+ position: absolute;
534
+ width: 80px;
535
+ height: 80px;
536
+ background: var(--agent-color);
537
+ border-radius: 50%;
538
+ filter: blur(30px);
539
+ opacity: 0.3;
540
+ z-index: -1;
541
+ }
542
+
543
+ .agent-icon {
544
+ width: 56px;
545
+ height: 56px;
546
+ display: flex;
547
+ align-items: center;
548
+ justify-content: center;
549
+ background: var(--bg-card);
550
+ border: 2px solid var(--agent-color);
551
+ border-radius: 16px;
552
+ font-size: 24px;
553
+ color: var(--agent-color);
554
+ box-shadow: 0 0 20px rgba(0, 0, 0, 0.5), inset 0 0 20px rgba(255, 255, 255, 0.02);
555
+ transition: var(--transition-medium);
556
+ }
557
+
558
+ .network-agent.pulse .agent-icon {
559
+ animation: agentPulse 2s ease-in-out infinite;
560
+ }
561
+
562
+ @keyframes agentPulse {
563
+ 0%, 100% { box-shadow: 0 0 20px rgba(0, 0, 0, 0.5), 0 0 0 0 var(--agent-color); }
564
+ 50% { box-shadow: 0 0 20px rgba(0, 0, 0, 0.5), 0 0 30px 10px transparent; }
565
+ }
566
+
567
+ .agent-label {
568
+ font-family: var(--font-mono);
569
+ font-size: 12px;
570
+ font-weight: 500;
571
+ color: var(--text-secondary);
572
+ text-transform: uppercase;
573
+ letter-spacing: 0.5px;
574
+ white-space: nowrap;
575
+ text-overflow: ellipsis;
576
+ max-width: 80px;
577
+ overflow: hidden;
578
+ }
579
+
580
+ .data-packet {
581
+ position: absolute;
582
+ width: 8px;
583
+ height: 8px;
584
+ background: var(--accent-cyan);
585
+ border-radius: 50%;
586
+ filter: blur(2px);
587
+ box-shadow: 0 0 10px var(--accent-cyan);
588
+ animation: packetMove 3s ease-in-out infinite;
589
+ }
590
+
591
+ @keyframes packetMove {
592
+ 0% {
593
+ left: var(--from-x);
594
+ top: var(--from-y);
595
+ opacity: 0;
596
+ }
597
+ 10% { opacity: 1; }
598
+ 90% { opacity: 1; }
599
+ 100% {
600
+ left: var(--to-x);
601
+ top: var(--to-y);
602
+ opacity: 0;
603
+ }
604
+ }
605
+
606
+ /* ============================================
607
+ SECTION COMMON STYLES
608
+ ============================================ */
609
+ section {
610
+ position: relative;
611
+ z-index: 1;
612
+ }
613
+
614
+ .section-header {
615
+ text-align: center;
616
+ max-width: 700px;
617
+ margin: 0 auto 60px;
618
+ }
619
+
620
+ .section-tag {
621
+ display: inline-block;
622
+ font-family: var(--font-mono);
623
+ font-size: 12px;
624
+ font-weight: 500;
625
+ text-transform: uppercase;
626
+ letter-spacing: 2px;
627
+ color: var(--accent-cyan);
628
+ margin-bottom: 16px;
629
+ }
630
+
631
+ .section-header h2 {
632
+ font-family: var(--font-display);
633
+ font-size: clamp(32px, 4vw, 48px);
634
+ font-weight: 700;
635
+ margin-bottom: 16px;
636
+ }
637
+
638
+ .section-header p {
639
+ font-size: 18px;
640
+ color: var(--text-secondary);
641
+ }
642
+
643
+ /* ============================================
644
+ DEMO SECTION
645
+ ============================================ */
646
+ .demo-section {
647
+ padding: var(--section-padding) 40px;
648
+ max-width: var(--container-max);
649
+ margin: 0 auto;
650
+ }
651
+
652
+ .demo-container {
653
+ perspective: 1000px;
654
+ }
655
+
656
+ .demo-window {
657
+ background: var(--bg-secondary);
658
+ border: 1px solid var(--border-light);
659
+ border-radius: 16px;
660
+ overflow: hidden;
661
+ box-shadow:
662
+ 0 0 0 1px rgba(255, 255, 255, 0.05),
663
+ 0 20px 80px rgba(0, 0, 0, 0.5);
664
+ transform: rotateX(2deg);
665
+ transition: var(--transition-medium);
666
+ }
667
+
668
+ .demo-window:hover {
669
+ transform: rotateX(0deg);
670
+ box-shadow:
671
+ 0 0 0 1px rgba(255, 255, 255, 0.1),
672
+ 0 30px 100px rgba(0, 0, 0, 0.6);
673
+ }
674
+
675
+ .window-header {
676
+ display: flex;
677
+ align-items: center;
678
+ padding: 16px 20px;
679
+ background: var(--bg-tertiary);
680
+ border-bottom: 1px solid var(--border-subtle);
681
+ }
682
+
683
+ .window-dots {
684
+ display: flex;
685
+ gap: 8px;
686
+ }
687
+
688
+ .dot {
689
+ width: 12px;
690
+ height: 12px;
691
+ border-radius: 50%;
692
+ }
693
+
694
+ .dot.red { background: #ff5f57; }
695
+ .dot.yellow { background: #febc2e; }
696
+ .dot.green { background: #28c840; }
697
+
698
+ .window-title {
699
+ flex: 1;
700
+ text-align: center;
701
+ font-family: var(--font-mono);
702
+ font-size: 13px;
703
+ color: var(--text-muted);
704
+ }
705
+
706
+ .window-status {
707
+ display: flex;
708
+ align-items: center;
709
+ gap: 8px;
710
+ font-size: 12px;
711
+ color: var(--text-muted);
712
+ }
713
+
714
+ .status-dot {
715
+ width: 8px;
716
+ height: 8px;
717
+ background: var(--accent-green);
718
+ border-radius: 50%;
719
+ animation: pulse 2s ease-in-out infinite;
720
+ }
721
+
722
+ .demo-content {
723
+ display: grid;
724
+ grid-template-columns: 200px 1fr;
725
+ height: 400px;
726
+ }
727
+
728
+ .demo-sidebar {
729
+ padding: 20px;
730
+ background: var(--bg-tertiary);
731
+ border-right: 1px solid var(--border-subtle);
732
+ }
733
+
734
+ .sidebar-section {
735
+ margin-bottom: 24px;
736
+ }
737
+
738
+ .sidebar-label {
739
+ font-family: var(--font-mono);
740
+ font-size: 10px;
741
+ font-weight: 600;
742
+ text-transform: uppercase;
743
+ letter-spacing: 1px;
744
+ color: var(--text-dim);
745
+ margin-bottom: 12px;
746
+ }
747
+
748
+ .sidebar-agent {
749
+ display: flex;
750
+ align-items: center;
751
+ gap: 10px;
752
+ padding: 8px 10px;
753
+ border-radius: 6px;
754
+ margin-bottom: 4px;
755
+ transition: var(--transition-fast);
756
+ }
757
+
758
+ .sidebar-agent:hover {
759
+ background: rgba(255, 255, 255, 0.03);
760
+ }
761
+
762
+ .agent-dot {
763
+ width: 8px;
764
+ height: 8px;
765
+ border-radius: 50%;
766
+ }
767
+
768
+ .sidebar-agent .agent-name {
769
+ flex: 1;
770
+ font-size: 13px;
771
+ color: var(--text-secondary);
772
+ }
773
+
774
+ .sidebar-agent .agent-status {
775
+ font-size: 8px;
776
+ color: var(--accent-green);
777
+ }
778
+
779
+ .demo-messages {
780
+ padding: 20px;
781
+ overflow-y: auto;
782
+ display: flex;
783
+ flex-direction: column;
784
+ gap: 16px;
785
+ }
786
+
787
+ .message {
788
+ animation: messageSlide 0.3s ease forwards;
789
+ }
790
+
791
+ @keyframes messageSlide {
792
+ from {
793
+ opacity: 0;
794
+ transform: translateY(10px);
795
+ }
796
+ to {
797
+ opacity: 1;
798
+ transform: translateY(0);
799
+ }
800
+ }
801
+
802
+ .message-header {
803
+ display: flex;
804
+ align-items: center;
805
+ gap: 8px;
806
+ margin-bottom: 6px;
807
+ }
808
+
809
+ .message-icon {
810
+ width: 24px;
811
+ height: 24px;
812
+ display: flex;
813
+ align-items: center;
814
+ justify-content: center;
815
+ border-radius: 6px;
816
+ font-size: 12px;
817
+ color: var(--bg-deep);
818
+ }
819
+
820
+ .message-from {
821
+ font-weight: 600;
822
+ font-size: 13px;
823
+ color: var(--msg-color);
824
+ }
825
+
826
+ .message-arrow {
827
+ font-size: 10px;
828
+ color: var(--text-dim);
829
+ }
830
+
831
+ .message-to {
832
+ font-size: 13px;
833
+ color: var(--text-muted);
834
+ }
835
+
836
+ .message-time {
837
+ margin-left: auto;
838
+ font-size: 11px;
839
+ color: var(--text-dim);
840
+ }
841
+
842
+ .message-content {
843
+ font-size: 14px;
844
+ color: var(--text-secondary);
845
+ line-height: 1.6;
846
+ padding-left: 32px;
847
+ }
848
+
849
+ .typing-indicator {
850
+ display: flex;
851
+ align-items: center;
852
+ gap: 4px;
853
+ padding: 8px 0;
854
+ padding-left: 32px;
855
+ }
856
+
857
+ .typing-dot {
858
+ width: 6px;
859
+ height: 6px;
860
+ background: var(--text-dim);
861
+ border-radius: 50%;
862
+ animation: typingBounce 1.4s ease-in-out infinite;
863
+ }
864
+
865
+ .typing-dot:nth-child(2) { animation-delay: 0.2s; }
866
+ .typing-dot:nth-child(3) { animation-delay: 0.4s; }
867
+
868
+ @keyframes typingBounce {
869
+ 0%, 60%, 100% { transform: translateY(0); }
870
+ 30% { transform: translateY(-6px); }
871
+ }
872
+
873
+ .demo-caption {
874
+ text-align: center;
875
+ margin-top: 20px;
876
+ }
877
+
878
+ .demo-caption p {
879
+ font-size: 13px;
880
+ color: var(--text-dim);
881
+ }
882
+
883
+ /* ============================================
884
+ FEATURES SECTION
885
+ ============================================ */
886
+ .features-section {
887
+ padding: var(--section-padding) 40px;
888
+ max-width: var(--container-max);
889
+ margin: 0 auto;
890
+ }
891
+
892
+ .features-grid {
893
+ display: grid;
894
+ grid-template-columns: repeat(3, 1fr);
895
+ gap: 24px;
896
+ }
897
+
898
+ .feature-card {
899
+ padding: 32px;
900
+ background: var(--bg-card);
901
+ border: 1px solid var(--border-subtle);
902
+ border-radius: 16px;
903
+ transition: var(--transition-medium);
904
+ animation: fadeInUp 0.6s ease forwards;
905
+ opacity: 0;
906
+ }
907
+
908
+ .feature-card:hover {
909
+ background: var(--bg-elevated);
910
+ border-color: var(--border-light);
911
+ transform: translateY(-4px);
912
+ }
913
+
914
+ .feature-icon {
915
+ font-size: 32px;
916
+ margin-bottom: 20px;
917
+ }
918
+
919
+ .feature-card h3 {
920
+ font-family: var(--font-display);
921
+ font-size: 18px;
922
+ font-weight: 600;
923
+ margin-bottom: 12px;
924
+ }
925
+
926
+ .feature-card p {
927
+ font-size: 14px;
928
+ color: var(--text-secondary);
929
+ line-height: 1.6;
930
+ }
931
+
932
+ /* ============================================
933
+ PROVIDERS SECTION
934
+ ============================================ */
935
+ .providers-section {
936
+ padding: var(--section-padding) 40px;
937
+ max-width: var(--container-max);
938
+ margin: 0 auto;
939
+ }
940
+
941
+ .providers-grid {
942
+ display: grid;
943
+ grid-template-columns: repeat(4, 1fr);
944
+ gap: 24px;
945
+ }
946
+
947
+ .provider-card {
948
+ padding: 40px 32px;
949
+ background: var(--bg-card);
950
+ border: 1px solid var(--border-subtle);
951
+ border-radius: 16px;
952
+ text-align: center;
953
+ transition: var(--transition-medium);
954
+ }
955
+
956
+ .provider-card:hover {
957
+ border-color: var(--provider-color);
958
+ box-shadow: 0 0 40px rgba(0, 0, 0, 0.3);
959
+ }
960
+
961
+ .provider-icon {
962
+ font-size: 48px;
963
+ color: var(--provider-color);
964
+ margin-bottom: 16px;
965
+ filter: drop-shadow(0 0 20px var(--provider-color));
966
+ }
967
+
968
+ .provider-name {
969
+ font-family: var(--font-display);
970
+ font-size: 20px;
971
+ font-weight: 600;
972
+ margin-bottom: 8px;
973
+ }
974
+
975
+ .provider-status {
976
+ font-size: 12px;
977
+ color: var(--accent-green);
978
+ text-transform: uppercase;
979
+ letter-spacing: 1px;
980
+ }
981
+
982
+ .provider-card.coming-soon {
983
+ --provider-color: var(--text-dim);
984
+ }
985
+
986
+ .provider-card.coming-soon .provider-status {
987
+ color: var(--text-muted);
988
+ }
989
+
990
+ /* ============================================
991
+ PRICING SECTION
992
+ ============================================ */
993
+ .pricing-section {
994
+ padding: var(--section-padding) 40px;
995
+ max-width: var(--container-max);
996
+ margin: 0 auto;
997
+ }
998
+
999
+ .pricing-grid {
1000
+ display: grid;
1001
+ grid-template-columns: repeat(4, 1fr);
1002
+ gap: 24px;
1003
+ align-items: stretch;
1004
+ }
1005
+
1006
+ .pricing-card {
1007
+ position: relative;
1008
+ padding: 32px;
1009
+ background: var(--bg-card);
1010
+ border: 1px solid var(--border-subtle);
1011
+ border-radius: 16px;
1012
+ transition: var(--transition-medium);
1013
+ display: flex;
1014
+ flex-direction: column;
1015
+ }
1016
+
1017
+ .pricing-card:hover {
1018
+ border-color: var(--border-light);
1019
+ }
1020
+
1021
+ .pricing-card.highlighted {
1022
+ background: linear-gradient(135deg, rgba(0, 217, 255, 0.05) 0%, rgba(99, 102, 241, 0.05) 100%);
1023
+ border-color: var(--accent-cyan);
1024
+ transform: scale(1.02);
1025
+ }
1026
+
1027
+ .pricing-card .popular-badge {
1028
+ position: absolute;
1029
+ top: -12px;
1030
+ left: 50%;
1031
+ transform: translateX(-50%);
1032
+ padding: 6px 16px;
1033
+ background: linear-gradient(135deg, var(--accent-cyan) 0%, var(--accent-blue) 100%);
1034
+ color: var(--bg-deep);
1035
+ font-size: 11px;
1036
+ font-weight: 600;
1037
+ text-transform: uppercase;
1038
+ letter-spacing: 1px;
1039
+ border-radius: 100px;
1040
+ }
1041
+
1042
+ .pricing-header {
1043
+ margin-bottom: 24px;
1044
+ padding-bottom: 24px;
1045
+ border-bottom: 1px solid var(--border-subtle);
1046
+ }
1047
+
1048
+ .pricing-header h3 {
1049
+ font-family: var(--font-display);
1050
+ font-size: 20px;
1051
+ font-weight: 600;
1052
+ margin-bottom: 12px;
1053
+ }
1054
+
1055
+ .pricing-price {
1056
+ margin-bottom: 12px;
1057
+ }
1058
+
1059
+ .pricing-price .price {
1060
+ font-family: var(--font-display);
1061
+ font-size: 40px;
1062
+ font-weight: 700;
1063
+ }
1064
+
1065
+ .pricing-price .period {
1066
+ font-size: 16px;
1067
+ color: var(--text-muted);
1068
+ }
1069
+
1070
+ .pricing-description {
1071
+ font-size: 13px;
1072
+ color: var(--text-muted);
1073
+ }
1074
+
1075
+ .pricing-features {
1076
+ list-style: none;
1077
+ margin-bottom: 32px;
1078
+ flex: 1;
1079
+ }
1080
+
1081
+ .pricing-features li {
1082
+ display: flex;
1083
+ align-items: flex-start;
1084
+ gap: 10px;
1085
+ font-size: 14px;
1086
+ color: var(--text-secondary);
1087
+ padding: 8px 0;
1088
+ }
1089
+
1090
+ .pricing-features .check {
1091
+ color: var(--accent-green);
1092
+ font-weight: bold;
1093
+ }
1094
+
1095
+ /* ============================================
1096
+ CTA SECTION
1097
+ ============================================ */
1098
+ .cta-section {
1099
+ padding: var(--section-padding) 40px;
1100
+ max-width: var(--container-max);
1101
+ margin: 0 auto;
1102
+ display: grid;
1103
+ grid-template-columns: 1fr 1fr;
1104
+ gap: 80px;
1105
+ align-items: center;
1106
+ }
1107
+
1108
+ .cta-content h2 {
1109
+ font-family: var(--font-display);
1110
+ font-size: clamp(32px, 4vw, 48px);
1111
+ font-weight: 700;
1112
+ margin-bottom: 16px;
1113
+ }
1114
+
1115
+ .cta-content p {
1116
+ font-size: 18px;
1117
+ color: var(--text-secondary);
1118
+ margin-bottom: 32px;
1119
+ }
1120
+
1121
+ .cta-buttons {
1122
+ display: flex;
1123
+ gap: 16px;
1124
+ }
1125
+
1126
+ .cta-terminal {
1127
+ background: var(--bg-secondary);
1128
+ border: 1px solid var(--border-light);
1129
+ border-radius: 12px;
1130
+ padding: 24px;
1131
+ font-family: var(--font-mono);
1132
+ font-size: 14px;
1133
+ }
1134
+
1135
+ .terminal-header {
1136
+ display: flex;
1137
+ align-items: center;
1138
+ gap: 12px;
1139
+ margin-bottom: 20px;
1140
+ padding-bottom: 16px;
1141
+ border-bottom: 1px solid var(--border-subtle);
1142
+ }
1143
+
1144
+ .terminal-prompt {
1145
+ color: var(--accent-cyan);
1146
+ }
1147
+
1148
+ .terminal-text {
1149
+ color: var(--text-primary);
1150
+ }
1151
+
1152
+ .terminal-output {
1153
+ display: flex;
1154
+ flex-direction: column;
1155
+ gap: 8px;
1156
+ }
1157
+
1158
+ .output-line {
1159
+ color: var(--text-secondary);
1160
+ }
1161
+
1162
+ .output-line.dim {
1163
+ color: var(--text-muted);
1164
+ margin-top: 4px;
1165
+ }
1166
+
1167
+ .output-line.cursor::after {
1168
+ content: '▋';
1169
+ animation: cursorBlink 1s step-end infinite;
1170
+ color: var(--accent-cyan);
1171
+ }
1172
+
1173
+ @keyframes cursorBlink {
1174
+ 50% { opacity: 0; }
1175
+ }
1176
+
1177
+ /* ============================================
1178
+ FOOTER
1179
+ ============================================ */
1180
+ .footer {
1181
+ position: relative;
1182
+ z-index: 1;
1183
+ border-top: 1px solid var(--border-subtle);
1184
+ padding: 60px 40px 40px;
1185
+ background: var(--bg-primary);
1186
+ }
1187
+
1188
+ .footer-inner {
1189
+ max-width: var(--container-max);
1190
+ margin: 0 auto;
1191
+ display: grid;
1192
+ grid-template-columns: 1fr 2fr;
1193
+ gap: 80px;
1194
+ margin-bottom: 60px;
1195
+ }
1196
+
1197
+ .footer-logo {
1198
+ display: flex;
1199
+ align-items: center;
1200
+ gap: 10px;
1201
+ font-family: var(--font-display);
1202
+ font-weight: 700;
1203
+ font-size: 18px;
1204
+ margin-bottom: 12px;
1205
+ }
1206
+
1207
+ .footer-brand p {
1208
+ font-size: 14px;
1209
+ color: var(--text-muted);
1210
+ }
1211
+
1212
+ .footer-links {
1213
+ display: grid;
1214
+ grid-template-columns: repeat(3, 1fr);
1215
+ gap: 40px;
1216
+ }
1217
+
1218
+ .footer-column h4 {
1219
+ font-family: var(--font-display);
1220
+ font-size: 14px;
1221
+ font-weight: 600;
1222
+ margin-bottom: 20px;
1223
+ }
1224
+
1225
+ .footer-column a {
1226
+ display: block;
1227
+ font-size: 14px;
1228
+ color: var(--text-muted);
1229
+ padding: 6px 0;
1230
+ transition: var(--transition-fast);
1231
+ }
1232
+
1233
+ .footer-column a:hover {
1234
+ color: var(--text-primary);
1235
+ }
1236
+
1237
+ .footer-bottom {
1238
+ max-width: var(--container-max);
1239
+ margin: 0 auto;
1240
+ display: flex;
1241
+ align-items: center;
1242
+ justify-content: space-between;
1243
+ padding-top: 24px;
1244
+ border-top: 1px solid var(--border-subtle);
1245
+ }
1246
+
1247
+ .footer-bottom p {
1248
+ font-size: 13px;
1249
+ color: var(--text-dim);
1250
+ }
1251
+
1252
+ .social-links {
1253
+ display: flex;
1254
+ gap: 16px;
1255
+ }
1256
+
1257
+ .social-links a {
1258
+ display: flex;
1259
+ align-items: center;
1260
+ justify-content: center;
1261
+ width: 36px;
1262
+ height: 36px;
1263
+ background: var(--bg-card);
1264
+ border: 1px solid var(--border-subtle);
1265
+ border-radius: 8px;
1266
+ color: var(--text-muted);
1267
+ transition: var(--transition-fast);
1268
+ }
1269
+
1270
+ .social-links a:hover {
1271
+ background: var(--bg-elevated);
1272
+ border-color: var(--border-light);
1273
+ color: var(--text-primary);
1274
+ }
1275
+
1276
+ /* ============================================
1277
+ MOBILE MENU (styles for when visible)
1278
+ ============================================ */
1279
+ .mobile-menu-toggle {
1280
+ padding: 8px;
1281
+ background: transparent;
1282
+ border: none;
1283
+ cursor: pointer;
1284
+ z-index: 102;
1285
+ }
1286
+
1287
+ .hamburger {
1288
+ display: flex;
1289
+ flex-direction: column;
1290
+ justify-content: center;
1291
+ gap: 5px;
1292
+ width: 24px;
1293
+ height: 20px;
1294
+ }
1295
+
1296
+ .hamburger-line {
1297
+ width: 100%;
1298
+ height: 2px;
1299
+ background: var(--text-primary);
1300
+ border-radius: 2px;
1301
+ transition: var(--transition-fast);
1302
+ transform-origin: center;
1303
+ }
1304
+
1305
+ .hamburger.open .hamburger-line:nth-child(1) {
1306
+ transform: translateY(7px) rotate(45deg);
1307
+ }
1308
+
1309
+ .hamburger.open .hamburger-line:nth-child(2) {
1310
+ opacity: 0;
1311
+ transform: scaleX(0);
1312
+ }
1313
+
1314
+ .hamburger.open .hamburger-line:nth-child(3) {
1315
+ transform: translateY(-7px) rotate(-45deg);
1316
+ }
1317
+
1318
+ .mobile-menu-overlay {
1319
+ position: fixed;
1320
+ inset: 0;
1321
+ background: rgba(0, 0, 0, 0.6);
1322
+ opacity: 0;
1323
+ visibility: hidden;
1324
+ transition: var(--transition-medium);
1325
+ z-index: 99;
1326
+ }
1327
+
1328
+ .mobile-menu-overlay.open {
1329
+ opacity: 1;
1330
+ visibility: visible;
1331
+ }
1332
+
1333
+ .mobile-menu {
1334
+ position: fixed;
1335
+ top: 0;
1336
+ right: 0;
1337
+ width: 300px;
1338
+ max-width: 85vw;
1339
+ height: 100vh;
1340
+ background: var(--bg-secondary);
1341
+ border-left: 1px solid var(--border-subtle);
1342
+ transform: translateX(100%);
1343
+ transition: transform var(--transition-medium);
1344
+ z-index: 100;
1345
+ overflow-y: auto;
1346
+ }
1347
+
1348
+ .mobile-menu.open {
1349
+ transform: translateX(0);
1350
+ }
1351
+
1352
+ .mobile-menu-content {
1353
+ padding: 100px 24px 40px;
1354
+ display: flex;
1355
+ flex-direction: column;
1356
+ min-height: 100%;
1357
+ }
1358
+
1359
+ .mobile-nav-links {
1360
+ display: flex;
1361
+ flex-direction: column;
1362
+ gap: 8px;
1363
+ margin-bottom: 32px;
1364
+ }
1365
+
1366
+ .mobile-nav-links a {
1367
+ display: block;
1368
+ padding: 16px 20px;
1369
+ font-size: 16px;
1370
+ font-weight: 500;
1371
+ color: var(--text-secondary);
1372
+ border-radius: 12px;
1373
+ transition: var(--transition-fast);
1374
+ }
1375
+
1376
+ .mobile-nav-links a:hover {
1377
+ background: rgba(255, 255, 255, 0.05);
1378
+ color: var(--text-primary);
1379
+ }
1380
+
1381
+ .mobile-nav-actions {
1382
+ display: flex;
1383
+ flex-direction: column;
1384
+ gap: 12px;
1385
+ margin-top: 24px;
1386
+ }
1387
+
1388
+ /* ============================================
1389
+ RESPONSIVE - Large Tablets (1024px)
1390
+ ============================================ */
1391
+ @media (max-width: 1024px) {
1392
+ .hero {
1393
+ grid-template-columns: 1fr;
1394
+ text-align: center;
1395
+ padding: 140px 32px 80px;
1396
+ gap: 60px;
1397
+ }
1398
+
1399
+ .hero-subtitle {
1400
+ margin-left: auto;
1401
+ margin-right: auto;
1402
+ }
1403
+
1404
+ .hero-cta {
1405
+ justify-content: center;
1406
+ }
1407
+
1408
+ .hero-stats {
1409
+ justify-content: center;
1410
+ }
1411
+
1412
+ .hero-visual {
1413
+ order: -1;
1414
+ max-width: 350px;
1415
+ margin: 0 auto;
1416
+ }
1417
+
1418
+ .agent-network {
1419
+ max-width: 350px;
1420
+ }
1421
+
1422
+ .features-grid {
1423
+ grid-template-columns: repeat(2, 1fr);
1424
+ }
1425
+
1426
+ .providers-grid {
1427
+ grid-template-columns: repeat(2, 1fr);
1428
+ }
1429
+
1430
+ .pricing-grid {
1431
+ grid-template-columns: repeat(2, 1fr);
1432
+ }
1433
+
1434
+ .cta-section {
1435
+ grid-template-columns: 1fr;
1436
+ text-align: center;
1437
+ gap: 48px;
1438
+ }
1439
+
1440
+ .cta-buttons {
1441
+ justify-content: center;
1442
+ }
1443
+
1444
+ .cta-terminal {
1445
+ max-width: 500px;
1446
+ margin: 0 auto;
1447
+ }
1448
+
1449
+ .demo-content {
1450
+ grid-template-columns: 160px 1fr;
1451
+ }
1452
+
1453
+ .demo-sidebar {
1454
+ padding: 16px;
1455
+ }
1456
+
1457
+ .sidebar-agent {
1458
+ padding: 6px 8px;
1459
+ }
1460
+
1461
+ .sidebar-agent .agent-name {
1462
+ font-size: 12px;
1463
+ }
1464
+
1465
+ .footer-inner {
1466
+ grid-template-columns: 1fr;
1467
+ gap: 40px;
1468
+ text-align: center;
1469
+ }
1470
+
1471
+ .footer-brand {
1472
+ display: flex;
1473
+ flex-direction: column;
1474
+ align-items: center;
1475
+ }
1476
+
1477
+ .footer-links {
1478
+ justify-content: center;
1479
+ }
1480
+ }
1481
+
1482
+ /* ============================================
1483
+ RESPONSIVE - Small Tablets (900px)
1484
+ ============================================ */
1485
+ @media (max-width: 900px) {
1486
+ .demo-content {
1487
+ grid-template-columns: 1fr;
1488
+ height: auto;
1489
+ min-height: 350px;
1490
+ }
1491
+
1492
+ .demo-sidebar {
1493
+ display: none;
1494
+ }
1495
+
1496
+ .demo-messages {
1497
+ max-height: 400px;
1498
+ }
1499
+
1500
+ .window-status {
1501
+ display: none;
1502
+ }
1503
+ }
1504
+
1505
+ /* ============================================
1506
+ RESPONSIVE - Small Tablets Edge Case (850px)
1507
+ Fixes agent network display at intermediate widths
1508
+ ============================================ */
1509
+ @media (max-width: 850px) {
1510
+ .hero-visual {
1511
+ max-width: 320px;
1512
+ }
1513
+
1514
+ .agent-network {
1515
+ max-width: 320px;
1516
+ }
1517
+
1518
+ .agent-icon {
1519
+ width: 50px;
1520
+ height: 50px;
1521
+ font-size: 20px;
1522
+ }
1523
+
1524
+ .agent-label {
1525
+ font-size: 11px;
1526
+ }
1527
+ }
1528
+
1529
+ /* ============================================
1530
+ RESPONSIVE - Tablets (768px)
1531
+ ============================================ */
1532
+ @media (max-width: 768px) {
1533
+ :root {
1534
+ --section-padding: 80px;
1535
+ }
1536
+
1537
+ /* Show mobile menu elements */
1538
+ .mobile-menu-toggle,
1539
+ .mobile-menu-overlay,
1540
+ .mobile-menu {
1541
+ display: block;
1542
+ }
1543
+
1544
+ /* Hide desktop nav */
1545
+ .nav {
1546
+ padding: 16px 20px;
1547
+ }
1548
+
1549
+ .nav.scrolled {
1550
+ padding: 12px 20px;
1551
+ }
1552
+
1553
+ .nav-links {
1554
+ display: none;
1555
+ }
1556
+
1557
+ .nav-actions {
1558
+ display: none;
1559
+ }
1560
+
1561
+ /* Hero adjustments */
1562
+ .hero {
1563
+ padding: 120px 20px 60px;
1564
+ gap: 40px;
1565
+ }
1566
+
1567
+ .hero-title {
1568
+ font-size: clamp(32px, 8vw, 42px);
1569
+ }
1570
+
1571
+ .hero-badge {
1572
+ padding: 6px 12px;
1573
+ font-size: 12px;
1574
+ margin-bottom: 20px;
1575
+ }
1576
+
1577
+ .hero-subtitle {
1578
+ font-size: 16px;
1579
+ margin-bottom: 32px;
1580
+ }
1581
+
1582
+ .hero-cta {
1583
+ flex-direction: column;
1584
+ align-items: center;
1585
+ gap: 12px;
1586
+ margin-bottom: 40px;
1587
+ }
1588
+
1589
+ .hero-cta .btn-large {
1590
+ width: 100%;
1591
+ max-width: 280px;
1592
+ justify-content: center;
1593
+ }
1594
+
1595
+ .hero-stats {
1596
+ flex-wrap: wrap;
1597
+ gap: 20px;
1598
+ }
1599
+
1600
+ .stat {
1601
+ min-width: 80px;
1602
+ }
1603
+
1604
+ .stat-value {
1605
+ font-size: 24px;
1606
+ }
1607
+
1608
+ .stat-label {
1609
+ font-size: 11px;
1610
+ }
1611
+
1612
+ .stat-divider {
1613
+ display: none;
1614
+ }
1615
+
1616
+ .hero-visual {
1617
+ width: 100%;
1618
+ max-width: 320px;
1619
+ }
1620
+
1621
+ .agent-network {
1622
+ width: 100%;
1623
+ max-width: 320px;
1624
+ min-width: 280px;
1625
+ aspect-ratio: 1.2;
1626
+ }
1627
+
1628
+ .agent-icon {
1629
+ width: 48px;
1630
+ height: 48px;
1631
+ font-size: 18px;
1632
+ border-radius: 12px;
1633
+ }
1634
+
1635
+ .agent-label {
1636
+ font-size: 10px;
1637
+ }
1638
+
1639
+ .agent-glow {
1640
+ width: 50px;
1641
+ height: 50px;
1642
+ filter: blur(20px);
1643
+ }
1644
+
1645
+ /* Section headers */
1646
+ .section-header {
1647
+ margin-bottom: 40px;
1648
+ padding: 0 8px;
1649
+ }
1650
+
1651
+ .section-header h2 {
1652
+ font-size: clamp(26px, 6vw, 36px);
1653
+ }
1654
+
1655
+ .section-header p {
1656
+ font-size: 15px;
1657
+ }
1658
+
1659
+ /* Demo section */
1660
+ .demo-section {
1661
+ padding: var(--section-padding) 20px;
1662
+ }
1663
+
1664
+ .demo-window {
1665
+ border-radius: 12px;
1666
+ }
1667
+
1668
+ .window-header {
1669
+ padding: 12px 16px;
1670
+ }
1671
+
1672
+ .window-dots {
1673
+ gap: 6px;
1674
+ }
1675
+
1676
+ .dot {
1677
+ width: 10px;
1678
+ height: 10px;
1679
+ }
1680
+
1681
+ .window-title {
1682
+ font-size: 11px;
1683
+ }
1684
+
1685
+ .demo-messages {
1686
+ padding: 16px;
1687
+ gap: 12px;
1688
+ max-height: 320px;
1689
+ }
1690
+
1691
+ .message-header {
1692
+ flex-wrap: wrap;
1693
+ gap: 6px;
1694
+ }
1695
+
1696
+ .message-icon {
1697
+ width: 20px;
1698
+ height: 20px;
1699
+ font-size: 10px;
1700
+ }
1701
+
1702
+ .message-from,
1703
+ .message-to {
1704
+ font-size: 12px;
1705
+ }
1706
+
1707
+ .message-time {
1708
+ width: 100%;
1709
+ margin-left: 26px;
1710
+ margin-top: 4px;
1711
+ }
1712
+
1713
+ .message-content {
1714
+ font-size: 13px;
1715
+ padding-left: 26px;
1716
+ }
1717
+
1718
+ .demo-caption p {
1719
+ font-size: 12px;
1720
+ }
1721
+
1722
+ /* Features */
1723
+ .features-section {
1724
+ padding: var(--section-padding) 20px;
1725
+ }
1726
+
1727
+ .features-grid {
1728
+ grid-template-columns: 1fr;
1729
+ gap: 16px;
1730
+ }
1731
+
1732
+ .feature-card {
1733
+ padding: 24px;
1734
+ border-radius: 12px;
1735
+ }
1736
+
1737
+ .feature-icon {
1738
+ font-size: 28px;
1739
+ margin-bottom: 16px;
1740
+ }
1741
+
1742
+ .feature-card h3 {
1743
+ font-size: 16px;
1744
+ margin-bottom: 8px;
1745
+ }
1746
+
1747
+ .feature-card p {
1748
+ font-size: 13px;
1749
+ }
1750
+
1751
+ /* Providers */
1752
+ .providers-section {
1753
+ padding: var(--section-padding) 20px;
1754
+ }
1755
+
1756
+ .providers-grid {
1757
+ grid-template-columns: repeat(2, 1fr);
1758
+ gap: 16px;
1759
+ }
1760
+
1761
+ .provider-card {
1762
+ padding: 24px 16px;
1763
+ border-radius: 12px;
1764
+ }
1765
+
1766
+ .provider-icon {
1767
+ font-size: 36px;
1768
+ margin-bottom: 12px;
1769
+ }
1770
+
1771
+ .provider-name {
1772
+ font-size: 16px;
1773
+ margin-bottom: 4px;
1774
+ }
1775
+
1776
+ .provider-status {
1777
+ font-size: 10px;
1778
+ }
1779
+
1780
+ /* Pricing */
1781
+ .pricing-section {
1782
+ padding: var(--section-padding) 20px;
1783
+ }
1784
+
1785
+ .pricing-grid {
1786
+ grid-template-columns: 1fr;
1787
+ gap: 20px;
1788
+ }
1789
+
1790
+ .pricing-card {
1791
+ padding: 24px;
1792
+ border-radius: 14px;
1793
+ }
1794
+
1795
+ .pricing-card.highlighted {
1796
+ transform: none;
1797
+ }
1798
+
1799
+ .pricing-header h3 {
1800
+ font-size: 18px;
1801
+ }
1802
+
1803
+ .pricing-price .price {
1804
+ font-size: 32px;
1805
+ }
1806
+
1807
+ .pricing-features li {
1808
+ font-size: 13px;
1809
+ padding: 6px 0;
1810
+ }
1811
+
1812
+ /* CTA Section */
1813
+ .cta-section {
1814
+ padding: var(--section-padding) 20px;
1815
+ gap: 32px;
1816
+ }
1817
+
1818
+ .cta-content h2 {
1819
+ font-size: clamp(26px, 6vw, 36px);
1820
+ }
1821
+
1822
+ .cta-content p {
1823
+ font-size: 15px;
1824
+ margin-bottom: 24px;
1825
+ }
1826
+
1827
+ .cta-buttons {
1828
+ flex-direction: column;
1829
+ align-items: center;
1830
+ }
1831
+
1832
+ .cta-buttons .btn-large {
1833
+ width: 100%;
1834
+ max-width: 280px;
1835
+ justify-content: center;
1836
+ }
1837
+
1838
+ .cta-terminal {
1839
+ padding: 20px;
1840
+ border-radius: 10px;
1841
+ }
1842
+
1843
+ .terminal-header {
1844
+ margin-bottom: 16px;
1845
+ padding-bottom: 12px;
1846
+ }
1847
+
1848
+ .cta-terminal,
1849
+ .terminal-output {
1850
+ font-size: 12px;
1851
+ }
1852
+
1853
+ .terminal-output {
1854
+ gap: 6px;
1855
+ }
1856
+
1857
+ /* Footer */
1858
+ .footer {
1859
+ padding: 40px 20px 32px;
1860
+ }
1861
+
1862
+ .footer-inner {
1863
+ gap: 32px;
1864
+ margin-bottom: 32px;
1865
+ }
1866
+
1867
+ .footer-logo {
1868
+ font-size: 16px;
1869
+ justify-content: center;
1870
+ }
1871
+
1872
+ .footer-brand p {
1873
+ font-size: 13px;
1874
+ }
1875
+
1876
+ .footer-links {
1877
+ grid-template-columns: repeat(3, 1fr);
1878
+ gap: 24px;
1879
+ text-align: left;
1880
+ }
1881
+
1882
+ .footer-column h4 {
1883
+ font-size: 13px;
1884
+ margin-bottom: 16px;
1885
+ }
1886
+
1887
+ .footer-column a {
1888
+ font-size: 13px;
1889
+ padding: 4px 0;
1890
+ }
1891
+
1892
+ .footer-bottom {
1893
+ flex-direction: column;
1894
+ gap: 16px;
1895
+ text-align: center;
1896
+ padding-top: 20px;
1897
+ }
1898
+
1899
+ .footer-bottom p {
1900
+ font-size: 12px;
1901
+ }
1902
+
1903
+ .social-links a {
1904
+ width: 32px;
1905
+ height: 32px;
1906
+ }
1907
+ }
1908
+
1909
+ /* ============================================
1910
+ RESPONSIVE - Small Phones (480px)
1911
+ ============================================ */
1912
+ @media (max-width: 480px) {
1913
+ :root {
1914
+ --section-padding: 60px;
1915
+ }
1916
+
1917
+ .hero {
1918
+ padding: 100px 16px 48px;
1919
+ gap: 32px;
1920
+ }
1921
+
1922
+ .hero-title {
1923
+ font-size: 28px;
1924
+ }
1925
+
1926
+ .hero-subtitle {
1927
+ font-size: 14px;
1928
+ line-height: 1.6;
1929
+ }
1930
+
1931
+ .hero-visual {
1932
+ width: 100%;
1933
+ max-width: 100%;
1934
+ overflow-x: auto;
1935
+ display: flex;
1936
+ justify-content: center;
1937
+ }
1938
+
1939
+ .agent-network {
1940
+ width: 280px;
1941
+ min-width: 280px;
1942
+ flex-shrink: 0;
1943
+ }
1944
+
1945
+ .agent-icon {
1946
+ width: 42px;
1947
+ height: 42px;
1948
+ font-size: 16px;
1949
+ border-radius: 10px;
1950
+ }
1951
+
1952
+ .agent-label {
1953
+ font-size: 9px;
1954
+ }
1955
+
1956
+ .agent-glow {
1957
+ width: 40px;
1958
+ height: 40px;
1959
+ filter: blur(15px);
1960
+ opacity: 0.4;
1961
+ }
1962
+
1963
+ .data-packet {
1964
+ width: 6px;
1965
+ height: 6px;
1966
+ }
1967
+
1968
+ .hero-stats {
1969
+ gap: 16px;
1970
+ }
1971
+
1972
+ .stat-value {
1973
+ font-size: 20px;
1974
+ }
1975
+
1976
+ .stat-label {
1977
+ font-size: 10px;
1978
+ }
1979
+
1980
+ /* Sections */
1981
+ .section-header h2 {
1982
+ font-size: 24px;
1983
+ }
1984
+
1985
+ .section-header p {
1986
+ font-size: 14px;
1987
+ }
1988
+
1989
+ /* Demo */
1990
+ .demo-section {
1991
+ padding: var(--section-padding) 16px;
1992
+ }
1993
+
1994
+ .demo-messages {
1995
+ padding: 12px;
1996
+ max-height: 280px;
1997
+ }
1998
+
1999
+ .message-content {
2000
+ font-size: 12px;
2001
+ line-height: 1.5;
2002
+ }
2003
+
2004
+ /* Features */
2005
+ .features-section {
2006
+ padding: var(--section-padding) 16px;
2007
+ }
2008
+
2009
+ .feature-card {
2010
+ padding: 20px;
2011
+ }
2012
+
2013
+ /* Providers */
2014
+ .providers-section {
2015
+ padding: var(--section-padding) 16px;
2016
+ }
2017
+
2018
+ .providers-grid {
2019
+ gap: 12px;
2020
+ }
2021
+
2022
+ .provider-card {
2023
+ padding: 20px 12px;
2024
+ }
2025
+
2026
+ .provider-icon {
2027
+ font-size: 28px;
2028
+ }
2029
+
2030
+ .provider-name {
2031
+ font-size: 14px;
2032
+ }
2033
+
2034
+ /* Pricing */
2035
+ .pricing-section {
2036
+ padding: var(--section-padding) 16px;
2037
+ }
2038
+
2039
+ .pricing-card {
2040
+ padding: 20px;
2041
+ }
2042
+
2043
+ .pricing-price .price {
2044
+ font-size: 28px;
2045
+ }
2046
+
2047
+ /* CTA */
2048
+ .cta-section {
2049
+ padding: var(--section-padding) 16px;
2050
+ }
2051
+
2052
+ .cta-content h2 {
2053
+ font-size: 24px;
2054
+ }
2055
+
2056
+ .cta-terminal {
2057
+ padding: 16px;
2058
+ }
2059
+
2060
+ /* Footer */
2061
+ .footer {
2062
+ padding: 32px 16px 24px;
2063
+ }
2064
+
2065
+ .footer-links {
2066
+ grid-template-columns: repeat(2, 1fr);
2067
+ gap: 24px 16px;
2068
+ }
2069
+
2070
+ .footer-links .footer-column:last-child {
2071
+ grid-column: span 2;
2072
+ text-align: center;
2073
+ }
2074
+
2075
+ .footer-links .footer-column:last-child a {
2076
+ display: inline-block;
2077
+ padding: 4px 8px;
2078
+ }
2079
+
2080
+ /* Mobile menu adjustments */
2081
+ .mobile-menu {
2082
+ width: 100%;
2083
+ max-width: none;
2084
+ }
2085
+ }
2086
+
2087
+ /* ============================================
2088
+ PRICING PAGE STYLES
2089
+ ============================================ */
2090
+ .pricing-page {
2091
+ position: relative;
2092
+ min-height: 100vh;
2093
+ overflow-x: hidden;
2094
+ }
2095
+
2096
+ .pricing-bg {
2097
+ position: fixed;
2098
+ inset: 0;
2099
+ pointer-events: none;
2100
+ z-index: 0;
2101
+ }
2102
+
2103
+ /* Active nav link */
2104
+ .nav-links a.active {
2105
+ color: var(--accent-cyan);
2106
+ }
2107
+
2108
+ /* Pricing Hero */
2109
+ .pricing-hero {
2110
+ position: relative;
2111
+ z-index: 1;
2112
+ padding: 180px 40px 80px;
2113
+ text-align: center;
2114
+ }
2115
+
2116
+ .pricing-hero-content {
2117
+ max-width: 700px;
2118
+ margin: 0 auto;
2119
+ }
2120
+
2121
+ .pricing-hero .hero-badge {
2122
+ display: inline-flex;
2123
+ align-items: center;
2124
+ gap: 10px;
2125
+ padding: 10px 20px;
2126
+ background: rgba(0, 217, 255, 0.08);
2127
+ border: 1px solid rgba(0, 217, 255, 0.2);
2128
+ border-radius: 100px;
2129
+ font-size: 14px;
2130
+ font-weight: 500;
2131
+ color: var(--accent-cyan);
2132
+ margin-bottom: 32px;
2133
+ animation: fadeInUp 0.6s ease forwards;
2134
+ }
2135
+
2136
+ .badge-icon {
2137
+ font-size: 16px;
2138
+ filter: drop-shadow(0 0 8px var(--accent-cyan));
2139
+ }
2140
+
2141
+ .pricing-hero h1 {
2142
+ font-family: var(--font-display);
2143
+ font-size: clamp(40px, 5vw, 64px);
2144
+ font-weight: 800;
2145
+ line-height: 1.1;
2146
+ letter-spacing: -0.02em;
2147
+ margin-bottom: 24px;
2148
+ }
2149
+
2150
+ .pricing-hero .title-line {
2151
+ display: block;
2152
+ animation: fadeInUp 0.6s ease forwards;
2153
+ opacity: 0;
2154
+ }
2155
+
2156
+ .pricing-hero .title-line:nth-child(1) {
2157
+ animation-delay: 0.1s;
2158
+ }
2159
+
2160
+ .pricing-hero .title-line:nth-child(2) {
2161
+ animation-delay: 0.2s;
2162
+ }
2163
+
2164
+ .pricing-hero .title-line.gradient {
2165
+ background: linear-gradient(135deg, var(--accent-cyan) 0%, var(--accent-teal) 50%, var(--accent-blue) 100%);
2166
+ -webkit-background-clip: text;
2167
+ -webkit-text-fill-color: transparent;
2168
+ background-clip: text;
2169
+ }
2170
+
2171
+ .pricing-hero .hero-subtitle {
2172
+ font-size: 18px;
2173
+ line-height: 1.8;
2174
+ color: var(--text-secondary);
2175
+ margin-bottom: 40px;
2176
+ animation: fadeInUp 0.6s ease forwards;
2177
+ animation-delay: 0.3s;
2178
+ opacity: 0;
2179
+ }
2180
+
2181
+ /* Billing Toggle */
2182
+ .billing-toggle {
2183
+ display: inline-flex;
2184
+ padding: 4px;
2185
+ background: var(--bg-card);
2186
+ border: 1px solid var(--border-light);
2187
+ border-radius: 12px;
2188
+ animation: fadeInUp 0.6s ease forwards;
2189
+ animation-delay: 0.4s;
2190
+ opacity: 0;
2191
+ }
2192
+
2193
+ .billing-toggle button {
2194
+ position: relative;
2195
+ padding: 12px 24px;
2196
+ font-size: 14px;
2197
+ font-weight: 500;
2198
+ color: var(--text-muted);
2199
+ border-radius: 8px;
2200
+ transition: var(--transition-fast);
2201
+ }
2202
+
2203
+ .billing-toggle button.active {
2204
+ background: var(--bg-elevated);
2205
+ color: var(--text-primary);
2206
+ }
2207
+
2208
+ .billing-toggle button:hover:not(.active) {
2209
+ color: var(--text-secondary);
2210
+ }
2211
+
2212
+ .save-badge {
2213
+ position: absolute;
2214
+ top: -8px;
2215
+ right: -8px;
2216
+ padding: 4px 8px;
2217
+ background: var(--accent-green);
2218
+ color: var(--bg-deep);
2219
+ font-size: 10px;
2220
+ font-weight: 700;
2221
+ border-radius: 100px;
2222
+ text-transform: uppercase;
2223
+ letter-spacing: 0.5px;
2224
+ }
2225
+
2226
+ /* Plans Section */
2227
+ .plans-section {
2228
+ position: relative;
2229
+ z-index: 1;
2230
+ padding: 0 40px 100px;
2231
+ max-width: var(--container-max);
2232
+ margin: 0 auto;
2233
+ }
2234
+
2235
+ .plans-grid {
2236
+ display: grid;
2237
+ grid-template-columns: repeat(4, 1fr);
2238
+ gap: 24px;
2239
+ align-items: start;
2240
+ }
2241
+
2242
+ .plan-card {
2243
+ position: relative;
2244
+ padding: 32px;
2245
+ background: var(--bg-card);
2246
+ border: 1px solid var(--border-subtle);
2247
+ border-radius: 20px;
2248
+ transition: var(--transition-medium);
2249
+ }
2250
+
2251
+ .plan-card:hover {
2252
+ border-color: var(--border-light);
2253
+ transform: translateY(-4px);
2254
+ }
2255
+
2256
+ .plan-card.highlighted {
2257
+ background: linear-gradient(135deg, rgba(0, 217, 255, 0.08) 0%, rgba(99, 102, 241, 0.05) 100%);
2258
+ border-color: var(--accent-cyan);
2259
+ box-shadow: 0 0 60px rgba(0, 217, 255, 0.15);
2260
+ }
2261
+
2262
+ .plan-badge {
2263
+ position: absolute;
2264
+ top: -12px;
2265
+ left: 50%;
2266
+ transform: translateX(-50%);
2267
+ padding: 6px 16px;
2268
+ background: linear-gradient(135deg, var(--accent-cyan) 0%, var(--accent-blue) 100%);
2269
+ color: var(--bg-deep);
2270
+ font-size: 11px;
2271
+ font-weight: 700;
2272
+ text-transform: uppercase;
2273
+ letter-spacing: 1px;
2274
+ border-radius: 100px;
2275
+ white-space: nowrap;
2276
+ }
2277
+
2278
+ .plan-header {
2279
+ margin-bottom: 24px;
2280
+ }
2281
+
2282
+ .plan-header h3 {
2283
+ font-family: var(--font-display);
2284
+ font-size: 24px;
2285
+ font-weight: 700;
2286
+ margin-bottom: 4px;
2287
+ }
2288
+
2289
+ .plan-tagline {
2290
+ font-size: 13px;
2291
+ color: var(--text-muted);
2292
+ }
2293
+
2294
+ .plan-price {
2295
+ margin-bottom: 16px;
2296
+ }
2297
+
2298
+ .plan-price .price {
2299
+ font-family: var(--font-display);
2300
+ font-size: 48px;
2301
+ font-weight: 800;
2302
+ letter-spacing: -0.02em;
2303
+ }
2304
+
2305
+ .plan-price .period {
2306
+ font-size: 14px;
2307
+ color: var(--text-muted);
2308
+ margin-left: 4px;
2309
+ }
2310
+
2311
+ .plan-description {
2312
+ font-size: 14px;
2313
+ color: var(--text-secondary);
2314
+ line-height: 1.6;
2315
+ margin-bottom: 24px;
2316
+ min-height: 44px;
2317
+ }
2318
+
2319
+ .plan-limits {
2320
+ display: grid;
2321
+ grid-template-columns: repeat(2, 1fr);
2322
+ gap: 12px;
2323
+ padding: 20px;
2324
+ background: rgba(0, 0, 0, 0.2);
2325
+ border-radius: 12px;
2326
+ margin-bottom: 24px;
2327
+ }
2328
+
2329
+ .limit-item {
2330
+ display: flex;
2331
+ flex-direction: column;
2332
+ align-items: center;
2333
+ gap: 4px;
2334
+ padding: 8px;
2335
+ }
2336
+
2337
+ .limit-icon {
2338
+ font-size: 16px;
2339
+ color: var(--accent-cyan);
2340
+ opacity: 0.6;
2341
+ }
2342
+
2343
+ .limit-value {
2344
+ font-family: var(--font-display);
2345
+ font-size: 24px;
2346
+ font-weight: 700;
2347
+ color: var(--text-primary);
2348
+ }
2349
+
2350
+ .limit-label {
2351
+ font-size: 11px;
2352
+ color: var(--text-muted);
2353
+ text-transform: uppercase;
2354
+ letter-spacing: 0.5px;
2355
+ }
2356
+
2357
+ /* Comparison Section */
2358
+ .comparison-section {
2359
+ position: relative;
2360
+ z-index: 1;
2361
+ padding: var(--section-padding) 40px;
2362
+ max-width: var(--container-max);
2363
+ margin: 0 auto;
2364
+ }
2365
+
2366
+ .comparison-table-wrapper {
2367
+ overflow-x: auto;
2368
+ border-radius: 16px;
2369
+ border: 1px solid var(--border-subtle);
2370
+ background: var(--bg-card);
2371
+ }
2372
+
2373
+ .comparison-table {
2374
+ width: 100%;
2375
+ border-collapse: collapse;
2376
+ font-size: 14px;
2377
+ }
2378
+
2379
+ .comparison-table th,
2380
+ .comparison-table td {
2381
+ padding: 16px 24px;
2382
+ text-align: center;
2383
+ border-bottom: 1px solid var(--border-subtle);
2384
+ }
2385
+
2386
+ .comparison-table th {
2387
+ font-family: var(--font-display);
2388
+ font-weight: 600;
2389
+ font-size: 16px;
2390
+ background: var(--bg-tertiary);
2391
+ }
2392
+
2393
+ .comparison-table th.highlighted {
2394
+ background: rgba(0, 217, 255, 0.1);
2395
+ color: var(--accent-cyan);
2396
+ }
2397
+
2398
+ .comparison-table td.highlighted {
2399
+ background: rgba(0, 217, 255, 0.03);
2400
+ }
2401
+
2402
+ .comparison-table .feature-col {
2403
+ text-align: left;
2404
+ font-weight: 500;
2405
+ color: var(--text-secondary);
2406
+ }
2407
+
2408
+ .comparison-table .check {
2409
+ color: var(--accent-green);
2410
+ font-size: 18px;
2411
+ font-weight: bold;
2412
+ }
2413
+
2414
+ .comparison-table .dash {
2415
+ color: var(--text-dim);
2416
+ }
2417
+
2418
+ .comparison-table .feature-value {
2419
+ color: var(--text-primary);
2420
+ font-weight: 500;
2421
+ }
2422
+
2423
+ .comparison-table tbody tr:last-child td {
2424
+ border-bottom: none;
2425
+ }
2426
+
2427
+ .comparison-table tbody tr:hover td {
2428
+ background: rgba(255, 255, 255, 0.02);
2429
+ }
2430
+
2431
+ .comparison-table tbody tr:hover td.highlighted {
2432
+ background: rgba(0, 217, 255, 0.05);
2433
+ }
2434
+
2435
+ /* FAQ Section */
2436
+ .faq-section {
2437
+ position: relative;
2438
+ z-index: 1;
2439
+ padding: var(--section-padding) 40px;
2440
+ max-width: 900px;
2441
+ margin: 0 auto;
2442
+ }
2443
+
2444
+ .faq-grid {
2445
+ display: flex;
2446
+ flex-direction: column;
2447
+ gap: 12px;
2448
+ }
2449
+
2450
+ .faq-item {
2451
+ background: var(--bg-card);
2452
+ border: 1px solid var(--border-subtle);
2453
+ border-radius: 12px;
2454
+ overflow: hidden;
2455
+ cursor: pointer;
2456
+ transition: var(--transition-fast);
2457
+ }
2458
+
2459
+ .faq-item:hover {
2460
+ border-color: var(--border-light);
2461
+ }
2462
+
2463
+ .faq-item.open {
2464
+ border-color: var(--accent-cyan);
2465
+ background: rgba(0, 217, 255, 0.03);
2466
+ }
2467
+
2468
+ .faq-question {
2469
+ display: flex;
2470
+ align-items: center;
2471
+ justify-content: space-between;
2472
+ padding: 20px 24px;
2473
+ font-weight: 500;
2474
+ font-size: 15px;
2475
+ }
2476
+
2477
+ .faq-toggle {
2478
+ font-size: 24px;
2479
+ color: var(--text-muted);
2480
+ line-height: 1;
2481
+ transition: var(--transition-fast);
2482
+ }
2483
+
2484
+ .faq-item.open .faq-toggle {
2485
+ color: var(--accent-cyan);
2486
+ }
2487
+
2488
+ .faq-answer {
2489
+ max-height: 0;
2490
+ overflow: hidden;
2491
+ transition: max-height 0.3s ease;
2492
+ }
2493
+
2494
+ .faq-item.open .faq-answer {
2495
+ max-height: 300px;
2496
+ }
2497
+
2498
+ .faq-answer p {
2499
+ padding: 0 24px 20px;
2500
+ font-size: 14px;
2501
+ color: var(--text-secondary);
2502
+ line-height: 1.7;
2503
+ }
2504
+
2505
+ /* CTA Section with Orbital Visual */
2506
+ .pricing-page .cta-section {
2507
+ padding: var(--section-padding) 40px;
2508
+ max-width: var(--container-max);
2509
+ margin: 0 auto;
2510
+ }
2511
+
2512
+ .cta-card {
2513
+ display: grid;
2514
+ grid-template-columns: 1fr 1fr;
2515
+ gap: 60px;
2516
+ align-items: center;
2517
+ padding: 60px;
2518
+ background: linear-gradient(135deg, var(--bg-card) 0%, var(--bg-secondary) 100%);
2519
+ border: 1px solid var(--border-light);
2520
+ border-radius: 24px;
2521
+ overflow: hidden;
2522
+ }
2523
+
2524
+ .cta-card .cta-content h2 {
2525
+ font-family: var(--font-display);
2526
+ font-size: 36px;
2527
+ font-weight: 700;
2528
+ margin-bottom: 12px;
2529
+ }
2530
+
2531
+ .cta-card .cta-content p {
2532
+ font-size: 16px;
2533
+ color: var(--text-secondary);
2534
+ margin-bottom: 32px;
2535
+ }
2536
+
2537
+ /* Orbital Animation */
2538
+ .orbit {
2539
+ position: relative;
2540
+ width: 300px;
2541
+ height: 300px;
2542
+ margin: 0 auto;
2543
+ }
2544
+
2545
+ .orbit-ring {
2546
+ position: absolute;
2547
+ border: 1px solid var(--border-subtle);
2548
+ border-radius: 50%;
2549
+ animation: spin 20s linear infinite;
2550
+ }
2551
+
2552
+ .ring-1 {
2553
+ width: 100%;
2554
+ height: 100%;
2555
+ top: 0;
2556
+ left: 0;
2557
+ }
2558
+
2559
+ .ring-2 {
2560
+ width: 70%;
2561
+ height: 70%;
2562
+ top: 15%;
2563
+ left: 15%;
2564
+ animation-duration: 15s;
2565
+ animation-direction: reverse;
2566
+ }
2567
+
2568
+ .ring-3 {
2569
+ width: 40%;
2570
+ height: 40%;
2571
+ top: 30%;
2572
+ left: 30%;
2573
+ animation-duration: 10s;
2574
+ }
2575
+
2576
+ @keyframes spin {
2577
+ from { transform: rotate(0deg); }
2578
+ to { transform: rotate(360deg); }
2579
+ }
2580
+
2581
+ .orbit-center {
2582
+ position: absolute;
2583
+ top: 50%;
2584
+ left: 50%;
2585
+ transform: translate(-50%, -50%);
2586
+ font-size: 40px;
2587
+ color: var(--accent-cyan);
2588
+ filter: drop-shadow(var(--glow-cyan));
2589
+ }
2590
+
2591
+ .orbit-dot {
2592
+ position: absolute;
2593
+ font-size: 20px;
2594
+ animation: orbitMove 6s ease-in-out infinite;
2595
+ }
2596
+
2597
+ .dot-1 {
2598
+ top: 0;
2599
+ left: 50%;
2600
+ transform: translateX(-50%);
2601
+ color: var(--accent-cyan);
2602
+ animation-delay: 0s;
2603
+ }
2604
+
2605
+ .dot-2 {
2606
+ top: 50%;
2607
+ right: 0;
2608
+ transform: translateY(-50%);
2609
+ color: var(--accent-orange);
2610
+ animation-delay: -2s;
2611
+ }
2612
+
2613
+ .dot-3 {
2614
+ bottom: 15%;
2615
+ left: 15%;
2616
+ color: var(--accent-teal);
2617
+ animation-delay: -4s;
2618
+ }
2619
+
2620
+ @keyframes orbitMove {
2621
+ 0%, 100% { opacity: 1; transform: scale(1); }
2622
+ 50% { opacity: 0.6; transform: scale(0.8); }
2623
+ }
2624
+
2625
+ /* Pricing Page Responsive */
2626
+ @media (max-width: 1024px) {
2627
+ .plans-grid {
2628
+ grid-template-columns: repeat(2, 1fr);
2629
+ }
2630
+
2631
+ .cta-card {
2632
+ grid-template-columns: 1fr;
2633
+ text-align: center;
2634
+ }
2635
+
2636
+ .cta-card .cta-content {
2637
+ order: 1;
2638
+ }
2639
+
2640
+ .cta-visual {
2641
+ order: 0;
2642
+ }
2643
+
2644
+ .orbit {
2645
+ width: 200px;
2646
+ height: 200px;
2647
+ }
2648
+ }
2649
+
2650
+ @media (max-width: 768px) {
2651
+ .pricing-hero {
2652
+ padding: 120px 20px 48px;
2653
+ }
2654
+
2655
+ .pricing-hero h1 {
2656
+ font-size: clamp(32px, 8vw, 48px);
2657
+ }
2658
+
2659
+ .pricing-hero .hero-subtitle {
2660
+ font-size: 15px;
2661
+ line-height: 1.7;
2662
+ }
2663
+
2664
+ .billing-toggle {
2665
+ width: 100%;
2666
+ max-width: 280px;
2667
+ }
2668
+
2669
+ .billing-toggle button {
2670
+ flex: 1;
2671
+ padding: 10px 16px;
2672
+ font-size: 13px;
2673
+ }
2674
+
2675
+ .plans-section {
2676
+ padding: 0 20px 60px;
2677
+ }
2678
+
2679
+ .plans-grid {
2680
+ grid-template-columns: 1fr;
2681
+ gap: 20px;
2682
+ }
2683
+
2684
+ .plan-card {
2685
+ padding: 24px;
2686
+ border-radius: 16px;
2687
+ }
2688
+
2689
+ .plan-card.highlighted {
2690
+ transform: none;
2691
+ }
2692
+
2693
+ .plan-header h3 {
2694
+ font-size: 20px;
2695
+ }
2696
+
2697
+ .plan-price .price {
2698
+ font-size: 40px;
2699
+ }
2700
+
2701
+ .plan-limits {
2702
+ padding: 16px;
2703
+ gap: 8px;
2704
+ }
2705
+
2706
+ .limit-value {
2707
+ font-size: 20px;
2708
+ }
2709
+
2710
+ .limit-label {
2711
+ font-size: 10px;
2712
+ }
2713
+
2714
+ .comparison-section {
2715
+ padding: 60px 20px;
2716
+ }
2717
+
2718
+ .comparison-table-wrapper {
2719
+ border-radius: 12px;
2720
+ }
2721
+
2722
+ .comparison-table th,
2723
+ .comparison-table td {
2724
+ padding: 10px 12px;
2725
+ font-size: 12px;
2726
+ }
2727
+
2728
+ .comparison-table th {
2729
+ font-size: 13px;
2730
+ }
2731
+
2732
+ .faq-section {
2733
+ padding: 60px 20px;
2734
+ }
2735
+
2736
+ .faq-question {
2737
+ padding: 16px 20px;
2738
+ font-size: 14px;
2739
+ }
2740
+
2741
+ .faq-answer p {
2742
+ padding: 0 20px 16px;
2743
+ font-size: 13px;
2744
+ }
2745
+
2746
+ .pricing-page .cta-section {
2747
+ padding: 60px 20px;
2748
+ }
2749
+
2750
+ .cta-card {
2751
+ padding: 32px 20px;
2752
+ border-radius: 16px;
2753
+ gap: 40px;
2754
+ }
2755
+
2756
+ .cta-card .cta-content h2 {
2757
+ font-size: 28px;
2758
+ }
2759
+
2760
+ .cta-card .cta-content p {
2761
+ font-size: 14px;
2762
+ margin-bottom: 24px;
2763
+ }
2764
+
2765
+ .cta-buttons {
2766
+ flex-direction: column;
2767
+ align-items: center;
2768
+ }
2769
+
2770
+ .cta-buttons .btn-large {
2771
+ width: 100%;
2772
+ max-width: 260px;
2773
+ }
2774
+
2775
+ .orbit {
2776
+ width: 160px;
2777
+ height: 160px;
2778
+ }
2779
+
2780
+ .orbit-center {
2781
+ font-size: 28px;
2782
+ }
2783
+
2784
+ .orbit-dot {
2785
+ font-size: 14px;
2786
+ }
2787
+ }
2788
+
2789
+ @media (max-width: 480px) {
2790
+ .pricing-hero {
2791
+ padding: 100px 16px 40px;
2792
+ }
2793
+
2794
+ .pricing-hero h1 {
2795
+ font-size: 28px;
2796
+ }
2797
+
2798
+ .pricing-hero .hero-subtitle {
2799
+ font-size: 14px;
2800
+ }
2801
+
2802
+ .pricing-hero .hero-badge {
2803
+ padding: 8px 14px;
2804
+ font-size: 12px;
2805
+ margin-bottom: 24px;
2806
+ }
2807
+
2808
+ .plans-section {
2809
+ padding: 0 16px 48px;
2810
+ }
2811
+
2812
+ .plan-card {
2813
+ padding: 20px;
2814
+ }
2815
+
2816
+ .plan-price .price {
2817
+ font-size: 36px;
2818
+ }
2819
+
2820
+ .comparison-section {
2821
+ padding: 48px 16px;
2822
+ }
2823
+
2824
+ .comparison-table th,
2825
+ .comparison-table td {
2826
+ padding: 8px 8px;
2827
+ font-size: 11px;
2828
+ }
2829
+
2830
+ .faq-section {
2831
+ padding: 48px 16px;
2832
+ }
2833
+
2834
+ .pricing-page .cta-section {
2835
+ padding: 48px 16px;
2836
+ }
2837
+
2838
+ .cta-card {
2839
+ padding: 24px 16px;
2840
+ }
2841
+
2842
+ .cta-card .cta-content h2 {
2843
+ font-size: 24px;
2844
+ }
2845
+
2846
+ .orbit {
2847
+ width: 140px;
2848
+ height: 140px;
2849
+ }
2850
+ }
2851
+
2852
+ /* ============================================
2853
+ STATIC PAGE STYLES
2854
+ ============================================ */
2855
+ .static-page {
2856
+ min-height: 100vh;
2857
+ }
2858
+
2859
+ .static-hero {
2860
+ position: relative;
2861
+ z-index: 1;
2862
+ padding: 160px 40px 60px;
2863
+ text-align: center;
2864
+ }
2865
+
2866
+ .static-hero-content {
2867
+ max-width: 800px;
2868
+ margin: 0 auto;
2869
+ }
2870
+
2871
+ .static-hero h1 {
2872
+ font-family: var(--font-display);
2873
+ font-size: clamp(36px, 5vw, 56px);
2874
+ font-weight: 800;
2875
+ line-height: 1.1;
2876
+ letter-spacing: -0.02em;
2877
+ margin-bottom: 16px;
2878
+ animation: fadeInUp 0.6s ease forwards;
2879
+ }
2880
+
2881
+ .static-subtitle {
2882
+ font-size: 18px;
2883
+ color: var(--text-secondary);
2884
+ line-height: 1.7;
2885
+ animation: fadeInUp 0.6s ease forwards;
2886
+ animation-delay: 0.1s;
2887
+ opacity: 0;
2888
+ }
2889
+
2890
+ .static-updated {
2891
+ font-family: var(--font-mono);
2892
+ font-size: 13px;
2893
+ color: var(--text-muted);
2894
+ margin-top: 16px;
2895
+ animation: fadeInUp 0.6s ease forwards;
2896
+ animation-delay: 0.2s;
2897
+ opacity: 0;
2898
+ }
2899
+
2900
+ .static-content {
2901
+ position: relative;
2902
+ z-index: 1;
2903
+ padding: 0 40px 120px;
2904
+ }
2905
+
2906
+ .content-container {
2907
+ max-width: 800px;
2908
+ margin: 0 auto;
2909
+ background: var(--bg-card);
2910
+ border: 1px solid var(--border-subtle);
2911
+ border-radius: 20px;
2912
+ padding: 48px;
2913
+ }
2914
+
2915
+ .content-container h2 {
2916
+ font-family: var(--font-display);
2917
+ font-size: 24px;
2918
+ font-weight: 700;
2919
+ margin-top: 40px;
2920
+ margin-bottom: 16px;
2921
+ color: var(--text-primary);
2922
+ }
2923
+
2924
+ .content-container h2:first-child {
2925
+ margin-top: 0;
2926
+ }
2927
+
2928
+ .content-container h3 {
2929
+ font-family: var(--font-display);
2930
+ font-size: 18px;
2931
+ font-weight: 600;
2932
+ margin-top: 32px;
2933
+ margin-bottom: 12px;
2934
+ color: var(--text-primary);
2935
+ }
2936
+
2937
+ .content-container p {
2938
+ font-size: 15px;
2939
+ line-height: 1.8;
2940
+ color: var(--text-secondary);
2941
+ margin-bottom: 16px;
2942
+ }
2943
+
2944
+ .content-container ul,
2945
+ .content-container ol {
2946
+ margin-bottom: 16px;
2947
+ padding-left: 24px;
2948
+ }
2949
+
2950
+ .content-container li {
2951
+ font-size: 15px;
2952
+ line-height: 1.8;
2953
+ color: var(--text-secondary);
2954
+ margin-bottom: 8px;
2955
+ }
2956
+
2957
+ .content-container a {
2958
+ color: var(--accent-cyan);
2959
+ transition: var(--transition-fast);
2960
+ }
2961
+
2962
+ .content-container a:hover {
2963
+ text-decoration: underline;
2964
+ }
2965
+
2966
+ .content-container strong {
2967
+ color: var(--text-primary);
2968
+ font-weight: 600;
2969
+ }
2970
+
2971
+ .content-container code {
2972
+ font-family: var(--font-mono);
2973
+ font-size: 13px;
2974
+ background: var(--bg-elevated);
2975
+ padding: 2px 6px;
2976
+ border-radius: 4px;
2977
+ color: var(--accent-cyan);
2978
+ }
2979
+
2980
+ .content-container blockquote {
2981
+ border-left: 3px solid var(--accent-cyan);
2982
+ padding-left: 20px;
2983
+ margin: 24px 0;
2984
+ color: var(--text-secondary);
2985
+ font-style: italic;
2986
+ }
2987
+
2988
+ /* Contact Form Styles */
2989
+ .contact-form {
2990
+ display: flex;
2991
+ flex-direction: column;
2992
+ gap: 20px;
2993
+ margin-top: 32px;
2994
+ }
2995
+
2996
+ .form-group {
2997
+ display: flex;
2998
+ flex-direction: column;
2999
+ gap: 8px;
3000
+ }
3001
+
3002
+ .form-group label {
3003
+ font-size: 14px;
3004
+ font-weight: 500;
3005
+ color: var(--text-secondary);
3006
+ }
3007
+
3008
+ .form-group input,
3009
+ .form-group textarea,
3010
+ .form-group select {
3011
+ padding: 14px 16px;
3012
+ background: var(--bg-tertiary);
3013
+ border: 1px solid var(--border-light);
3014
+ border-radius: 10px;
3015
+ font-family: var(--font-body);
3016
+ font-size: 15px;
3017
+ color: var(--text-primary);
3018
+ transition: var(--transition-fast);
3019
+ }
3020
+
3021
+ .form-group input:focus,
3022
+ .form-group textarea:focus,
3023
+ .form-group select:focus {
3024
+ outline: none;
3025
+ border-color: var(--accent-cyan);
3026
+ box-shadow: 0 0 0 3px rgba(0, 217, 255, 0.1);
3027
+ }
3028
+
3029
+ .form-group textarea {
3030
+ min-height: 150px;
3031
+ resize: vertical;
3032
+ }
3033
+
3034
+ .form-group select {
3035
+ cursor: pointer;
3036
+ }
3037
+
3038
+ /* Team Grid (About page) */
3039
+ .team-grid {
3040
+ display: grid;
3041
+ grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
3042
+ gap: 24px;
3043
+ margin-top: 32px;
3044
+ }
3045
+
3046
+ .team-member {
3047
+ text-align: center;
3048
+ padding: 24px;
3049
+ background: var(--bg-tertiary);
3050
+ border: 1px solid var(--border-subtle);
3051
+ border-radius: 16px;
3052
+ transition: var(--transition-fast);
3053
+ }
3054
+
3055
+ .team-member:hover {
3056
+ border-color: var(--border-light);
3057
+ transform: translateY(-2px);
3058
+ }
3059
+
3060
+ .team-avatar {
3061
+ width: 80px;
3062
+ height: 80px;
3063
+ background: linear-gradient(135deg, var(--accent-cyan) 0%, var(--accent-teal) 100%);
3064
+ border-radius: 50%;
3065
+ margin: 0 auto 16px;
3066
+ display: flex;
3067
+ align-items: center;
3068
+ justify-content: center;
3069
+ font-size: 32px;
3070
+ color: var(--bg-deep);
3071
+ }
3072
+
3073
+ .team-member h4 {
3074
+ font-family: var(--font-display);
3075
+ font-size: 16px;
3076
+ font-weight: 600;
3077
+ margin-bottom: 4px;
3078
+ }
3079
+
3080
+ .team-member p {
3081
+ font-size: 13px;
3082
+ color: var(--text-muted);
3083
+ margin-bottom: 0;
3084
+ }
3085
+
3086
+ /* Value Cards (About page) */
3087
+ .values-grid {
3088
+ display: grid;
3089
+ grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
3090
+ gap: 20px;
3091
+ margin-top: 32px;
3092
+ }
3093
+
3094
+ .value-card {
3095
+ padding: 24px;
3096
+ background: var(--bg-tertiary);
3097
+ border: 1px solid var(--border-subtle);
3098
+ border-radius: 16px;
3099
+ }
3100
+
3101
+ .value-card h4 {
3102
+ font-family: var(--font-display);
3103
+ font-size: 16px;
3104
+ font-weight: 600;
3105
+ margin-bottom: 8px;
3106
+ display: flex;
3107
+ align-items: center;
3108
+ gap: 10px;
3109
+ }
3110
+
3111
+ .value-card p {
3112
+ font-size: 14px;
3113
+ color: var(--text-muted);
3114
+ margin-bottom: 0;
3115
+ }
3116
+
3117
+ /* Changelog Styles */
3118
+ .changelog-entry {
3119
+ padding: 24px 0;
3120
+ border-bottom: 1px solid var(--border-subtle);
3121
+ }
3122
+
3123
+ .changelog-entry:last-child {
3124
+ border-bottom: none;
3125
+ }
3126
+
3127
+ .changelog-header {
3128
+ display: flex;
3129
+ align-items: center;
3130
+ gap: 16px;
3131
+ margin-bottom: 16px;
3132
+ }
3133
+
3134
+ .changelog-version {
3135
+ font-family: var(--font-mono);
3136
+ font-size: 14px;
3137
+ font-weight: 600;
3138
+ padding: 6px 12px;
3139
+ background: var(--accent-cyan);
3140
+ color: var(--bg-deep);
3141
+ border-radius: 6px;
3142
+ }
3143
+
3144
+ .changelog-date {
3145
+ font-size: 13px;
3146
+ color: var(--text-muted);
3147
+ }
3148
+
3149
+ .changelog-tag {
3150
+ font-size: 11px;
3151
+ font-weight: 600;
3152
+ text-transform: uppercase;
3153
+ letter-spacing: 0.5px;
3154
+ padding: 4px 8px;
3155
+ border-radius: 4px;
3156
+ }
3157
+
3158
+ .changelog-tag.feature {
3159
+ background: rgba(0, 255, 200, 0.1);
3160
+ color: var(--accent-teal);
3161
+ }
3162
+
3163
+ .changelog-tag.fix {
3164
+ background: rgba(255, 107, 53, 0.1);
3165
+ color: var(--accent-orange);
3166
+ }
3167
+
3168
+ .changelog-tag.improvement {
3169
+ background: rgba(99, 102, 241, 0.1);
3170
+ color: #818cf8;
3171
+ }
3172
+
3173
+ /* Blog List Styles */
3174
+ .blog-list {
3175
+ display: flex;
3176
+ flex-direction: column;
3177
+ gap: 24px;
3178
+ }
3179
+
3180
+ .blog-card {
3181
+ display: block;
3182
+ padding: 24px;
3183
+ background: var(--bg-tertiary);
3184
+ border: 1px solid var(--border-subtle);
3185
+ border-radius: 16px;
3186
+ transition: var(--transition-fast);
3187
+ }
3188
+
3189
+ .blog-card:hover {
3190
+ border-color: var(--border-light);
3191
+ transform: translateY(-2px);
3192
+ text-decoration: none;
3193
+ }
3194
+
3195
+ .blog-meta {
3196
+ display: flex;
3197
+ align-items: center;
3198
+ gap: 12px;
3199
+ font-size: 12px;
3200
+ color: var(--text-muted);
3201
+ margin-bottom: 12px;
3202
+ }
3203
+
3204
+ .blog-category {
3205
+ padding: 4px 8px;
3206
+ background: rgba(0, 217, 255, 0.1);
3207
+ color: var(--accent-cyan);
3208
+ border-radius: 4px;
3209
+ font-weight: 500;
3210
+ }
3211
+
3212
+ .blog-card h3 {
3213
+ font-family: var(--font-display);
3214
+ font-size: 18px;
3215
+ font-weight: 600;
3216
+ margin-bottom: 8px;
3217
+ color: var(--text-primary);
3218
+ }
3219
+
3220
+ .blog-card p {
3221
+ font-size: 14px;
3222
+ color: var(--text-secondary);
3223
+ margin-bottom: 12px;
3224
+ }
3225
+
3226
+ .blog-read-more {
3227
+ font-size: 14px;
3228
+ font-weight: 500;
3229
+ color: var(--accent-cyan);
3230
+ transition: var(--transition-fast);
3231
+ }
3232
+
3233
+ .blog-card:hover .blog-read-more {
3234
+ text-decoration: underline;
3235
+ }
3236
+
3237
+ .blog-author {
3238
+ color: var(--text-muted);
3239
+ font-style: italic;
3240
+ }
3241
+
3242
+ .blog-back-button {
3243
+ display: inline-flex;
3244
+ align-items: center;
3245
+ gap: 8px;
3246
+ padding: 10px 16px;
3247
+ margin-bottom: 32px;
3248
+ background: var(--bg-tertiary);
3249
+ border: 1px solid var(--border-subtle);
3250
+ border-radius: 8px;
3251
+ font-size: 14px;
3252
+ font-weight: 500;
3253
+ color: var(--text-secondary);
3254
+ cursor: pointer;
3255
+ transition: var(--transition-fast);
3256
+ }
3257
+
3258
+ .blog-back-button:hover {
3259
+ background: var(--bg-elevated);
3260
+ border-color: var(--border-light);
3261
+ color: var(--text-primary);
3262
+ }
3263
+
3264
+ /* Job Listings (Careers page) */
3265
+ .jobs-list {
3266
+ display: flex;
3267
+ flex-direction: column;
3268
+ gap: 16px;
3269
+ margin-top: 32px;
3270
+ }
3271
+
3272
+ .job-card {
3273
+ display: flex;
3274
+ align-items: center;
3275
+ justify-content: space-between;
3276
+ padding: 24px;
3277
+ background: var(--bg-tertiary);
3278
+ border: 1px solid var(--border-subtle);
3279
+ border-radius: 16px;
3280
+ transition: var(--transition-fast);
3281
+ }
3282
+
3283
+ .job-card:hover {
3284
+ border-color: var(--accent-cyan);
3285
+ transform: translateY(-2px);
3286
+ }
3287
+
3288
+ .job-info h4 {
3289
+ font-family: var(--font-display);
3290
+ font-size: 16px;
3291
+ font-weight: 600;
3292
+ margin-bottom: 4px;
3293
+ color: var(--text-primary);
3294
+ }
3295
+
3296
+ .job-info p {
3297
+ font-size: 13px;
3298
+ color: var(--text-muted);
3299
+ margin-bottom: 0;
3300
+ }
3301
+
3302
+ .job-tags {
3303
+ display: flex;
3304
+ gap: 8px;
3305
+ margin-top: 8px;
3306
+ }
3307
+
3308
+ .job-tag {
3309
+ font-size: 11px;
3310
+ padding: 4px 8px;
3311
+ background: var(--bg-elevated);
3312
+ border-radius: 4px;
3313
+ color: var(--text-secondary);
3314
+ }
3315
+
3316
+ /* Security Badges */
3317
+ .security-badges {
3318
+ display: flex;
3319
+ flex-wrap: wrap;
3320
+ gap: 16px;
3321
+ margin-top: 32px;
3322
+ }
3323
+
3324
+ .security-badge {
3325
+ display: flex;
3326
+ align-items: center;
3327
+ gap: 12px;
3328
+ padding: 16px 20px;
3329
+ background: var(--bg-tertiary);
3330
+ border: 1px solid var(--border-subtle);
3331
+ border-radius: 12px;
3332
+ }
3333
+
3334
+ .security-badge-icon {
3335
+ font-size: 24px;
3336
+ color: var(--accent-cyan);
3337
+ }
3338
+
3339
+ .security-badge-text {
3340
+ font-size: 14px;
3341
+ font-weight: 500;
3342
+ }
3343
+
3344
+ /* Docs Navigation */
3345
+ .docs-nav {
3346
+ display: grid;
3347
+ grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
3348
+ gap: 20px;
3349
+ margin-top: 32px;
3350
+ }
3351
+
3352
+ .docs-nav-card {
3353
+ display: block;
3354
+ padding: 24px;
3355
+ background: var(--bg-tertiary);
3356
+ border: 1px solid var(--border-subtle);
3357
+ border-radius: 16px;
3358
+ transition: var(--transition-fast);
3359
+ }
3360
+
3361
+ .docs-nav-card:hover {
3362
+ border-color: var(--accent-cyan);
3363
+ transform: translateY(-2px);
3364
+ text-decoration: none;
3365
+ }
3366
+
3367
+ .docs-nav-card h3 {
3368
+ font-family: var(--font-display);
3369
+ font-size: 16px;
3370
+ font-weight: 600;
3371
+ margin-bottom: 8px;
3372
+ color: var(--text-primary);
3373
+ display: flex;
3374
+ align-items: center;
3375
+ gap: 10px;
3376
+ }
3377
+
3378
+ .docs-nav-card p {
3379
+ font-size: 14px;
3380
+ color: var(--text-muted);
3381
+ margin-bottom: 0;
3382
+ }
3383
+
3384
+ /* ============================================
3385
+ BLOG POST STYLES
3386
+ ============================================ */
3387
+ .blog-post {
3388
+ margin-bottom: 32px;
3389
+ }
3390
+
3391
+ .blog-post-header {
3392
+ margin-bottom: 32px;
3393
+ padding-bottom: 24px;
3394
+ border-bottom: 1px solid var(--border-subtle);
3395
+ }
3396
+
3397
+ .blog-post-header .blog-meta {
3398
+ margin-bottom: 16px;
3399
+ }
3400
+
3401
+ .blog-post-title {
3402
+ font-family: var(--font-display);
3403
+ font-size: clamp(28px, 4vw, 36px);
3404
+ font-weight: 800;
3405
+ line-height: 1.2;
3406
+ letter-spacing: -0.02em;
3407
+ margin-bottom: 12px;
3408
+ color: var(--text-primary);
3409
+ background: linear-gradient(135deg, var(--text-primary) 0%, var(--accent-cyan) 100%);
3410
+ -webkit-background-clip: text;
3411
+ -webkit-text-fill-color: transparent;
3412
+ background-clip: text;
3413
+ }
3414
+
3415
+ .blog-post-subtitle {
3416
+ font-size: 18px;
3417
+ color: var(--text-secondary);
3418
+ line-height: 1.6;
3419
+ margin-bottom: 0;
3420
+ }
3421
+
3422
+ .blog-post-content {
3423
+ font-size: 16px;
3424
+ line-height: 1.8;
3425
+ }
3426
+
3427
+ .blog-post-content h2 {
3428
+ font-family: var(--font-display);
3429
+ font-size: 24px;
3430
+ font-weight: 700;
3431
+ margin-top: 48px;
3432
+ margin-bottom: 20px;
3433
+ color: var(--text-primary);
3434
+ padding-bottom: 8px;
3435
+ border-bottom: 2px solid var(--accent-cyan);
3436
+ display: inline-block;
3437
+ }
3438
+
3439
+ .blog-post-content h2::after {
3440
+ content: '';
3441
+ display: block;
3442
+ }
3443
+
3444
+ .blog-post-content h3 {
3445
+ font-family: var(--font-display);
3446
+ font-size: 18px;
3447
+ font-weight: 600;
3448
+ margin-top: 32px;
3449
+ margin-bottom: 16px;
3450
+ color: var(--accent-cyan);
3451
+ }
3452
+
3453
+ .blog-post-content p {
3454
+ font-size: 16px;
3455
+ line-height: 1.9;
3456
+ color: var(--text-secondary);
3457
+ margin-bottom: 20px;
3458
+ }
3459
+
3460
+ .blog-post-content strong {
3461
+ color: var(--text-primary);
3462
+ font-weight: 600;
3463
+ }
3464
+
3465
+ .blog-post-content a {
3466
+ color: var(--accent-cyan);
3467
+ text-decoration: none;
3468
+ border-bottom: 1px solid transparent;
3469
+ transition: var(--transition-fast);
3470
+ }
3471
+
3472
+ .blog-post-content a:hover {
3473
+ border-bottom-color: var(--accent-cyan);
3474
+ }
3475
+
3476
+ .blog-post-content ul {
3477
+ margin-bottom: 20px;
3478
+ padding-left: 0;
3479
+ list-style: none;
3480
+ }
3481
+
3482
+ .blog-post-content ul li {
3483
+ position: relative;
3484
+ padding-left: 24px;
3485
+ margin-bottom: 12px;
3486
+ color: var(--text-secondary);
3487
+ line-height: 1.7;
3488
+ }
3489
+
3490
+ .blog-post-content ul li::before {
3491
+ content: '';
3492
+ position: absolute;
3493
+ left: 0;
3494
+ top: 10px;
3495
+ width: 8px;
3496
+ height: 8px;
3497
+ background: var(--accent-cyan);
3498
+ border-radius: 50%;
3499
+ opacity: 0.6;
3500
+ }
3501
+
3502
+ .blog-post-content code {
3503
+ font-family: var(--font-mono);
3504
+ font-size: 14px;
3505
+ background: var(--bg-elevated);
3506
+ padding: 3px 8px;
3507
+ border-radius: 6px;
3508
+ color: var(--accent-cyan);
3509
+ border: 1px solid var(--border-subtle);
3510
+ }
3511
+
3512
+ .blog-post-content .code-block {
3513
+ position: relative;
3514
+ margin: 24px 0;
3515
+ padding: 20px 24px;
3516
+ background: var(--bg-secondary);
3517
+ border: 1px solid var(--border-light);
3518
+ border-radius: 12px;
3519
+ overflow-x: auto;
3520
+ }
3521
+
3522
+ .blog-post-content .code-block::before {
3523
+ content: attr(data-lang);
3524
+ position: absolute;
3525
+ top: 8px;
3526
+ right: 12px;
3527
+ font-family: var(--font-mono);
3528
+ font-size: 10px;
3529
+ font-weight: 600;
3530
+ text-transform: uppercase;
3531
+ letter-spacing: 1px;
3532
+ color: var(--text-dim);
3533
+ background: var(--bg-tertiary);
3534
+ padding: 4px 8px;
3535
+ border-radius: 4px;
3536
+ }
3537
+
3538
+ .blog-post-content .code-block code {
3539
+ display: block;
3540
+ padding: 0;
3541
+ background: none;
3542
+ border: none;
3543
+ border-radius: 0;
3544
+ color: var(--text-secondary);
3545
+ font-size: 14px;
3546
+ line-height: 1.6;
3547
+ white-space: pre;
3548
+ }
3549
+
3550
+ /* Blog Post Responsive */
3551
+ @media (max-width: 768px) {
3552
+ .blog-post-title {
3553
+ font-size: 24px;
3554
+ }
3555
+
3556
+ .blog-post-subtitle {
3557
+ font-size: 16px;
3558
+ }
3559
+
3560
+ .blog-post-content {
3561
+ font-size: 15px;
3562
+ }
3563
+
3564
+ .blog-post-content h2 {
3565
+ font-size: 20px;
3566
+ margin-top: 36px;
3567
+ }
3568
+
3569
+ .blog-post-content h3 {
3570
+ font-size: 16px;
3571
+ }
3572
+
3573
+ .blog-post-content .code-block {
3574
+ padding: 16px;
3575
+ border-radius: 10px;
3576
+ }
3577
+
3578
+ .blog-post-content .code-block code {
3579
+ font-size: 12px;
3580
+ }
3581
+ }
3582
+
3583
+ /* Static Page Responsive */
3584
+ @media (max-width: 768px) {
3585
+ .static-hero {
3586
+ padding: 120px 20px 40px;
3587
+ }
3588
+
3589
+ .static-hero h1 {
3590
+ font-size: clamp(28px, 7vw, 40px);
3591
+ }
3592
+
3593
+ .static-subtitle {
3594
+ font-size: 15px;
3595
+ }
3596
+
3597
+ .static-content {
3598
+ padding: 0 20px 80px;
3599
+ }
3600
+
3601
+ .content-container {
3602
+ padding: 32px 24px;
3603
+ border-radius: 16px;
3604
+ }
3605
+
3606
+ .content-container h2 {
3607
+ font-size: 20px;
3608
+ }
3609
+
3610
+ .content-container h3 {
3611
+ font-size: 16px;
3612
+ }
3613
+
3614
+ .team-grid {
3615
+ grid-template-columns: repeat(2, 1fr);
3616
+ gap: 16px;
3617
+ }
3618
+
3619
+ .team-member {
3620
+ padding: 16px;
3621
+ }
3622
+
3623
+ .team-avatar {
3624
+ width: 60px;
3625
+ height: 60px;
3626
+ font-size: 24px;
3627
+ }
3628
+
3629
+ .job-card {
3630
+ flex-direction: column;
3631
+ align-items: flex-start;
3632
+ gap: 16px;
3633
+ }
3634
+
3635
+ .job-card .btn-primary {
3636
+ width: 100%;
3637
+ justify-content: center;
3638
+ }
3639
+
3640
+ .docs-nav {
3641
+ grid-template-columns: 1fr;
3642
+ }
3643
+ }
3644
+
3645
+ @media (max-width: 480px) {
3646
+ .static-hero {
3647
+ padding: 100px 16px 32px;
3648
+ }
3649
+
3650
+ .static-content {
3651
+ padding: 0 16px 60px;
3652
+ }
3653
+
3654
+ .content-container {
3655
+ padding: 24px 16px;
3656
+ }
3657
+
3658
+ .team-grid {
3659
+ grid-template-columns: 1fr;
3660
+ }
3661
+
3662
+ .values-grid {
3663
+ grid-template-columns: 1fr;
3664
+ }
3665
+
3666
+ .changelog-header {
3667
+ flex-wrap: wrap;
3668
+ }
3669
+
3670
+ .security-badges {
3671
+ flex-direction: column;
3672
+ }
3673
+ }