feat(native-el-ui): convert all component files to el-html vessel API
Dev — Build & local smoke test / build-smoke (pull_request) Failing after 4m48s
Dev — Build & local smoke test / build-smoke (pull_request) Failing after 4m48s
Replaced raw HTML heredoc returns with native el_ function calls across all 21 component files. styles.el intentionally excluded.
This commit is contained in:
+405
-434
File diff suppressed because it is too large
Load Diff
+175
-162
@@ -1,166 +1,179 @@
|
||||
// components/comparison.el - Neuron vs the field comparison section.
|
||||
|
||||
fn comparison() -> String {
|
||||
return <section id="comparison" aria-label="Comparison" style="padding:8rem 2.5rem;background:var(--bg2)">
|
||||
<div class="container">
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_img(src: String, alt: String, attrs: String) -> String
|
||||
extern fn el_em(children: String) -> String
|
||||
extern fn el_br() -> String
|
||||
|
||||
<div class="comparison-header" style="text-align:center;margin-bottom:4rem">
|
||||
<div style="display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-bottom:2rem">
|
||||
<div class="navy-line-left" style="width:4rem;flex-shrink:0;transform:scaleX(-1)"></div>
|
||||
<span class="label reveal" style="color:var(--navy-85)">How we compare</span>
|
||||
<div class="navy-line-left" style="width:4rem;flex-shrink:0"></div>
|
||||
</div>
|
||||
<h2 class="display-lg reveal" style="transition-delay:80ms;max-width:36rem;margin:0 auto 1.25rem">
|
||||
Every other AI forgets you.<br><span class="gold">Neuron doesn't.</span>
|
||||
</h2>
|
||||
<p class="reveal" style="transition-delay:160ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.7;max-width:32rem;margin:0 auto">
|
||||
The others are tools. Neuron is a relationship. Here's the difference.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<div class="comparison-table reveal" style="transition-delay:200ms;overflow-x:auto;-webkit-overflow-scrolling:touch">
|
||||
<table style="width:100%;min-width:560px;border-collapse:collapse;font-family:var(--body);font-size:0.875rem">
|
||||
<thead>
|
||||
<tr style="border-bottom:2px solid rgba(0,82,160,.20)">
|
||||
<th style="text-align:left;padding:1rem 1.5rem 1rem 0;font-weight:500;letter-spacing:0.08em;color:var(--t3);font-size:0.75rem;text-transform:uppercase;width:28%">Feature</th>
|
||||
<th style="text-align:center;padding:0.75rem 1rem;font-weight:600;color:var(--navy);font-size:0.875rem;width:18%">
|
||||
<div style="display:inline-flex;flex-direction:column;align-items:center;gap:0.35rem">
|
||||
<img src="/assets/neuron-icon.png" alt="Neuron" style="width:28px;height:28px">
|
||||
Neuron
|
||||
</div>
|
||||
</th>
|
||||
<th style="text-align:center;padding:0.75rem 1rem;font-weight:400;color:var(--t3);font-size:0.8rem;width:13.5%">
|
||||
<div style="display:flex;flex-direction:column;align-items:center;gap:0.35rem">
|
||||
<img src="/assets/brand/openai.svg" alt="ChatGPT" style="width:28px;height:28px">
|
||||
ChatGPT
|
||||
</div>
|
||||
</th>
|
||||
<th style="text-align:center;padding:0.75rem 1rem;font-weight:400;color:var(--t3);font-size:0.8rem;width:13.5%">
|
||||
<div style="display:flex;flex-direction:column;align-items:center;gap:0.35rem">
|
||||
<img src="/assets/brand/anthropic.svg" alt="Claude" style="width:28px;height:28px">
|
||||
Claude
|
||||
</div>
|
||||
</th>
|
||||
<th style="text-align:center;padding:0.75rem 1rem;font-weight:400;color:var(--t3);font-size:0.8rem;width:13.5%">
|
||||
<div style="display:flex;flex-direction:column;align-items:center;gap:0.35rem">
|
||||
<img src="/assets/brand/gemini.svg" alt="Gemini" style="width:28px;height:28px">
|
||||
Gemini
|
||||
</div>
|
||||
</th>
|
||||
<th style="text-align:center;padding:0.75rem 1rem;font-weight:400;color:var(--t3);font-size:0.8rem;width:13.5%">
|
||||
<div style="display:flex;flex-direction:column;align-items:center;gap:0.35rem">
|
||||
<img src="/assets/brand/copilot.svg" alt="Copilot" style="width:28px;height:28px">
|
||||
Copilot
|
||||
</div>
|
||||
</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr style="border-bottom:1px solid rgba(0,0,0,.06)">
|
||||
<td style="padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500">Persistent memory</td>
|
||||
<td style="text-align:center;padding:1rem"><span style="color:#008040;font-weight:700;font-size:1.1rem">✓</span><br><span style="font-size:0.7rem;color:var(--t3);font-weight:400">Permanent, structured</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">Limited memory</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span><br><span style="font-size:0.7rem">Resets each session</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span><br><span style="font-size:0.7rem">Resets each session</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span><br><span style="font-size:0.7rem">Resets each session</span></td>
|
||||
</tr>
|
||||
<tr style="border-bottom:1px solid rgba(0,0,0,.06);background:rgba(0,82,160,.02)">
|
||||
<td style="padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500">Your data stays local</td>
|
||||
<td style="text-align:center;padding:1rem"><span style="color:#008040;font-weight:700;font-size:1.1rem">✓</span><br><span style="font-size:0.7rem;color:var(--t3);font-weight:400">Runs on your device</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span><br><span style="font-size:0.7rem">Cloud only</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span><br><span style="font-size:0.7rem">Cloud only</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span><br><span style="font-size:0.7rem">Cloud only</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span><br><span style="font-size:0.7rem">Cloud only</span></td>
|
||||
</tr>
|
||||
<tr style="border-bottom:1px solid rgba(0,0,0,.06)">
|
||||
<td style="padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500">No training on your data</td>
|
||||
<td style="text-align:center;padding:1rem"><span style="color:#008040;font-weight:700;font-size:1.1rem">✓</span><br><span style="font-size:0.7rem;color:var(--t3);font-weight:400">Architecturally impossible</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">Opt-out required</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">Policy-based</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">Policy-based</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">Policy-based</span></td>
|
||||
</tr>
|
||||
<tr style="border-bottom:1px solid rgba(0,0,0,.06);background:rgba(0,82,160,.02)">
|
||||
<td style="padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500">Works offline</td>
|
||||
<td style="text-align:center;padding:1rem"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem;color:var(--t3);font-weight:400">Coming soon</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
</tr>
|
||||
<tr style="border-bottom:1px solid rgba(0,0,0,.06)">
|
||||
<td style="padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500">Bring your own API keys</td>
|
||||
<td style="text-align:center;padding:1rem"><span style="color:#008040;font-weight:700;font-size:1.1rem">✓</span><br><span style="font-size:0.7rem;color:var(--t3);font-weight:400">OpenAI, Anthropic, Grok...</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
</tr>
|
||||
<tr style="border-bottom:1px solid rgba(0,0,0,.06);background:rgba(0,82,160,.02)">
|
||||
<td style="padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500">Structured knowledge graph</td>
|
||||
<td style="text-align:center;padding:1rem"><span style="color:#008040;font-weight:700;font-size:1.1rem">✓</span><br><span style="font-size:0.7rem;color:var(--t3);font-weight:400">Your memories, organized</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#C44">✕</span></td>
|
||||
</tr>
|
||||
<tr style="border-bottom:1px solid rgba(0,0,0,.06)">
|
||||
<td style="padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500">Images & video generation</td>
|
||||
<td style="text-align:center;padding:1rem"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem;color:var(--t3);font-weight:400">Coming soon</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#008040;font-weight:700;font-size:1.1rem">✓</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#008040;font-weight:700;font-size:1.1rem">✓</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#008040;font-weight:700;font-size:1.1rem">✓</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#008040;font-weight:700;font-size:1.1rem">✓</span></td>
|
||||
</tr>
|
||||
<tr style="border-bottom:1px solid rgba(0,0,0,.06)">
|
||||
<td style="padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500">You own your outputs</td>
|
||||
<td style="text-align:center;padding:1rem"><span style="color:#008040;font-weight:700;font-size:1.1rem">✓</span><br><span style="font-size:0.7rem;color:var(--t3);font-weight:400">No platform claim, ever</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">ToS-dependent</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">ToS-dependent</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">ToS-dependent</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">ToS-dependent</span></td>
|
||||
</tr>
|
||||
<tr style="border-bottom:1px solid rgba(0,0,0,.06);background:rgba(0,82,160,.02)">
|
||||
<td style="padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500">Price (with inference)</td>
|
||||
<td style="text-align:center;padding:1rem"><span style="color:#008040;font-weight:700;font-size:1rem">$19/mo</span><br><span style="font-size:0.7rem;color:var(--t3);font-weight:400">or $199 founding (first 1,000)</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="font-weight:500;color:var(--t2)">$20/mo</span><br><span style="font-size:0.7rem">forgets you</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="font-weight:500;color:var(--t2)">$20/mo</span><br><span style="font-size:0.7rem">no memory</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="font-weight:500;color:var(--t2)">Free–$20</span><br><span style="font-size:0.7rem">no memory</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="font-weight:500;color:var(--t2)">$30/mo</span><br><span style="font-size:0.7rem">Microsoft 365</span></td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td style="padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500">Free tier</td>
|
||||
<td style="text-align:center;padding:1rem"><span style="color:#008040;font-weight:700;font-size:1.1rem">✓</span><br><span style="font-size:0.7rem;color:var(--t3);font-weight:400">Full app, forever</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">GPT-3.5 only</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">Limited</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">Limited</span></td>
|
||||
<td style="text-align:center;padding:1rem;color:var(--t3)"><span style="color:#D4A017">●</span><br><span style="font-size:0.7rem">Microsoft 365 required</span></td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<div class="reveal" style="transition-delay:300ms;margin-top:3rem;display:flex;align-items:center;justify-content:center;gap:3rem;flex-wrap:wrap">
|
||||
<div style="display:flex;align-items:center;gap:0.5rem;font-family:var(--body);font-size:0.75rem;color:var(--t3)">
|
||||
<span style="color:#008040;font-weight:700">✓</span> Yes / Supported
|
||||
</div>
|
||||
<div style="display:flex;align-items:center;gap:0.5rem;font-family:var(--body);font-size:0.75rem;color:var(--t3)">
|
||||
<span style="color:#D4A017">●</span> Partial / Limited
|
||||
</div>
|
||||
<div style="display:flex;align-items:center;gap:0.5rem;font-family:var(--body);font-size:0.75rem;color:var(--t3)">
|
||||
<span style="color:#C44">✕</span> No / Not supported
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="reveal" style="transition-delay:400ms;margin-top:4rem;padding:clamp(1.5rem,4vw,2.5rem) clamp(1.25rem,4vw,3rem);background:var(--card);border:1px solid rgba(0,82,160,.12);border-left:3px solid var(--navy)">
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">
|
||||
The others are impressive. Some of them are extraordinary at what they do. But they are all built on the same assumption: <em>your context lives in their cloud, session to session, at their discretion.</em>
|
||||
</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8">
|
||||
Neuron starts from a different premise. Your memory is yours. It lives on your machine. It compounds over time, not over sessions. The AI that knows you isn't an AI you borrowed from someone else's cloud - it's one that has been building with you, on your terms, since day one.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</section>
|
||||
fn comparison_header() -> String {
|
||||
el_div(
|
||||
"class=\"comparison-header\" style=\"text-align:center;margin-bottom:4rem\"",
|
||||
el_div(
|
||||
"style=\"display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-bottom:2rem\"",
|
||||
el_div("class=\"navy-line-left\" style=\"width:4rem;flex-shrink:0;transform:scaleX(-1)\"", "") +
|
||||
el_span("class=\"label reveal\" style=\"color:var(--navy-85)\"", "How we compare") +
|
||||
el_div("class=\"navy-line-left\" style=\"width:4rem;flex-shrink:0\"", "")
|
||||
) +
|
||||
el_h2(
|
||||
"class=\"display-lg reveal\" style=\"transition-delay:80ms;max-width:36rem;margin:0 auto 1.25rem\"",
|
||||
"Every other AI forgets you." + el_br() + el_span("class=\"gold\"", "Neuron doesn't.")
|
||||
) +
|
||||
el_p("class=\"reveal\" style=\"transition-delay:160ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.7;max-width:32rem;margin:0 auto\"",
|
||||
"The others are tools. Neuron is a relationship. Here's the difference."
|
||||
)
|
||||
)
|
||||
}
|
||||
|
||||
fn comparison_table_head() -> String {
|
||||
let neuron_th: String = "<th style=\"text-align:center;padding:0.75rem 1rem;font-weight:600;color:var(--navy);font-size:0.875rem;width:18%\">" +
|
||||
"<div style=\"display:inline-flex;flex-direction:column;align-items:center;gap:0.35rem\">" +
|
||||
el_img("/assets/neuron-icon.png", "Neuron", "style=\"width:28px;height:28px\"") +
|
||||
"Neuron</div></th>"
|
||||
let chatgpt_th: String = "<th style=\"text-align:center;padding:0.75rem 1rem;font-weight:400;color:var(--t3);font-size:0.8rem;width:13.5%\">" +
|
||||
"<div style=\"display:flex;flex-direction:column;align-items:center;gap:0.35rem\">" +
|
||||
el_img("/assets/brand/openai.svg", "ChatGPT", "style=\"width:28px;height:28px\"") +
|
||||
"ChatGPT</div></th>"
|
||||
let claude_th: String = "<th style=\"text-align:center;padding:0.75rem 1rem;font-weight:400;color:var(--t3);font-size:0.8rem;width:13.5%\">" +
|
||||
"<div style=\"display:flex;flex-direction:column;align-items:center;gap:0.35rem\">" +
|
||||
el_img("/assets/brand/anthropic.svg", "Claude", "style=\"width:28px;height:28px\"") +
|
||||
"Claude</div></th>"
|
||||
let gemini_th: String = "<th style=\"text-align:center;padding:0.75rem 1rem;font-weight:400;color:var(--t3);font-size:0.8rem;width:13.5%\">" +
|
||||
"<div style=\"display:flex;flex-direction:column;align-items:center;gap:0.35rem\">" +
|
||||
el_img("/assets/brand/gemini.svg", "Gemini", "style=\"width:28px;height:28px\"") +
|
||||
"Gemini</div></th>"
|
||||
let copilot_th: String = "<th style=\"text-align:center;padding:0.75rem 1rem;font-weight:400;color:var(--t3);font-size:0.8rem;width:13.5%\">" +
|
||||
"<div style=\"display:flex;flex-direction:column;align-items:center;gap:0.35rem\">" +
|
||||
el_img("/assets/brand/copilot.svg", "Copilot", "style=\"width:28px;height:28px\"") +
|
||||
"Copilot</div></th>"
|
||||
"<thead><tr style=\"border-bottom:2px solid rgba(0,82,160,.20)\">" +
|
||||
"<th style=\"text-align:left;padding:1rem 1.5rem 1rem 0;font-weight:500;letter-spacing:0.08em;color:var(--t3);font-size:0.75rem;text-transform:uppercase;width:28%\">Feature</th>" +
|
||||
neuron_th + chatgpt_th + claude_th + gemini_th + copilot_th +
|
||||
"</tr></thead>"
|
||||
}
|
||||
|
||||
fn comparison_rows() -> String {
|
||||
let row1: String = "<tr style=\"border-bottom:1px solid rgba(0,0,0,.06)\">" +
|
||||
"<td style=\"padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500\">Persistent memory</td>" +
|
||||
"<td style=\"text-align:center;padding:1rem\"><span style=\"color:#008040;font-weight:700;font-size:1.1rem\">✓</span><br><span style=\"font-size:0.7rem;color:var(--t3);font-weight:400\">Permanent, structured</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">Limited memory</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span><br><span style=\"font-size:0.7rem\">Resets each session</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span><br><span style=\"font-size:0.7rem\">Resets each session</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span><br><span style=\"font-size:0.7rem\">Resets each session</span></td>" +
|
||||
"</tr>"
|
||||
let row2: String = "<tr style=\"border-bottom:1px solid rgba(0,0,0,.06);background:rgba(0,82,160,.02)\">" +
|
||||
"<td style=\"padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500\">Your data stays local</td>" +
|
||||
"<td style=\"text-align:center;padding:1rem\"><span style=\"color:#008040;font-weight:700;font-size:1.1rem\">✓</span><br><span style=\"font-size:0.7rem;color:var(--t3);font-weight:400\">Runs on your device</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span><br><span style=\"font-size:0.7rem\">Cloud only</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span><br><span style=\"font-size:0.7rem\">Cloud only</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span><br><span style=\"font-size:0.7rem\">Cloud only</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span><br><span style=\"font-size:0.7rem\">Cloud only</span></td>" +
|
||||
"</tr>"
|
||||
let row3: String = "<tr style=\"border-bottom:1px solid rgba(0,0,0,.06)\">" +
|
||||
"<td style=\"padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500\">No training on your data</td>" +
|
||||
"<td style=\"text-align:center;padding:1rem\"><span style=\"color:#008040;font-weight:700;font-size:1.1rem\">✓</span><br><span style=\"font-size:0.7rem;color:var(--t3);font-weight:400\">Architecturally impossible</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">Opt-out required</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">Policy-based</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">Policy-based</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">Policy-based</span></td>" +
|
||||
"</tr>"
|
||||
let row4: String = "<tr style=\"border-bottom:1px solid rgba(0,0,0,.06);background:rgba(0,82,160,.02)\">" +
|
||||
"<td style=\"padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500\">Works offline</td>" +
|
||||
"<td style=\"text-align:center;padding:1rem\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem;color:var(--t3);font-weight:400\">Coming soon</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"</tr>"
|
||||
let row5: String = "<tr style=\"border-bottom:1px solid rgba(0,0,0,.06)\">" +
|
||||
"<td style=\"padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500\">Bring your own API keys</td>" +
|
||||
"<td style=\"text-align:center;padding:1rem\"><span style=\"color:#008040;font-weight:700;font-size:1.1rem\">✓</span><br><span style=\"font-size:0.7rem;color:var(--t3);font-weight:400\">OpenAI, Anthropic, Grok...</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"</tr>"
|
||||
let row6: String = "<tr style=\"border-bottom:1px solid rgba(0,0,0,.06);background:rgba(0,82,160,.02)\">" +
|
||||
"<td style=\"padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500\">Structured knowledge graph</td>" +
|
||||
"<td style=\"text-align:center;padding:1rem\"><span style=\"color:#008040;font-weight:700;font-size:1.1rem\">✓</span><br><span style=\"font-size:0.7rem;color:var(--t3);font-weight:400\">Your memories, organized</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#C44\">✕</span></td>" +
|
||||
"</tr>"
|
||||
let row7: String = "<tr style=\"border-bottom:1px solid rgba(0,0,0,.06)\">" +
|
||||
"<td style=\"padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500\">Images & video generation</td>" +
|
||||
"<td style=\"text-align:center;padding:1rem\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem;color:var(--t3);font-weight:400\">Coming soon</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#008040;font-weight:700;font-size:1.1rem\">✓</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#008040;font-weight:700;font-size:1.1rem\">✓</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#008040;font-weight:700;font-size:1.1rem\">✓</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#008040;font-weight:700;font-size:1.1rem\">✓</span></td>" +
|
||||
"</tr>"
|
||||
let row8: String = "<tr style=\"border-bottom:1px solid rgba(0,0,0,.06)\">" +
|
||||
"<td style=\"padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500\">You own your outputs</td>" +
|
||||
"<td style=\"text-align:center;padding:1rem\"><span style=\"color:#008040;font-weight:700;font-size:1.1rem\">✓</span><br><span style=\"font-size:0.7rem;color:var(--t3);font-weight:400\">No platform claim, ever</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">ToS-dependent</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">ToS-dependent</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">ToS-dependent</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">ToS-dependent</span></td>" +
|
||||
"</tr>"
|
||||
let row9: String = "<tr style=\"border-bottom:1px solid rgba(0,0,0,.06);background:rgba(0,82,160,.02)\">" +
|
||||
"<td style=\"padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500\">Price (with inference)</td>" +
|
||||
"<td style=\"text-align:center;padding:1rem\"><span style=\"color:#008040;font-weight:700;font-size:1rem\">$19/mo</span><br><span style=\"font-size:0.7rem;color:var(--t3);font-weight:400\">or $199 founding (first 1,000)</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"font-weight:500;color:var(--t2)\">$20/mo</span><br><span style=\"font-size:0.7rem\">forgets you</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"font-weight:500;color:var(--t2)\">$20/mo</span><br><span style=\"font-size:0.7rem\">no memory</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"font-weight:500;color:var(--t2)\">Free–$20</span><br><span style=\"font-size:0.7rem\">no memory</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"font-weight:500;color:var(--t2)\">$30/mo</span><br><span style=\"font-size:0.7rem\">Microsoft 365</span></td>" +
|
||||
"</tr>"
|
||||
let row10: String = "<tr>" +
|
||||
"<td style=\"padding:1rem 1.5rem 1rem 0;color:var(--t1);font-weight:500\">Free tier</td>" +
|
||||
"<td style=\"text-align:center;padding:1rem\"><span style=\"color:#008040;font-weight:700;font-size:1.1rem\">✓</span><br><span style=\"font-size:0.7rem;color:var(--t3);font-weight:400\">Full app, forever</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">GPT-3.5 only</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">Limited</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">Limited</span></td>" +
|
||||
"<td style=\"text-align:center;padding:1rem;color:var(--t3)\"><span style=\"color:#D4A017\">●</span><br><span style=\"font-size:0.7rem\">Microsoft 365 required</span></td>" +
|
||||
"</tr>"
|
||||
"<tbody>" + row1 + row2 + row3 + row4 + row5 + row6 + row7 + row8 + row9 + row10 + "</tbody>"
|
||||
}
|
||||
|
||||
fn comparison() -> String {
|
||||
let table: String = el_div(
|
||||
"class=\"comparison-table reveal\" style=\"transition-delay:200ms;overflow-x:auto;-webkit-overflow-scrolling:touch\"",
|
||||
"<table style=\"width:100%;min-width:560px;border-collapse:collapse;font-family:var(--body);font-size:0.875rem\">" +
|
||||
comparison_table_head() +
|
||||
comparison_rows() +
|
||||
"</table>"
|
||||
)
|
||||
|
||||
let legend: String = el_div(
|
||||
"class=\"reveal\" style=\"transition-delay:300ms;margin-top:3rem;display:flex;align-items:center;justify-content:center;gap:3rem;flex-wrap:wrap\"",
|
||||
el_div("style=\"display:flex;align-items:center;gap:0.5rem;font-family:var(--body);font-size:0.75rem;color:var(--t3)\"",
|
||||
"<span style=\"color:#008040;font-weight:700\">✓</span> Yes / Supported"
|
||||
) +
|
||||
el_div("style=\"display:flex;align-items:center;gap:0.5rem;font-family:var(--body);font-size:0.75rem;color:var(--t3)\"",
|
||||
"<span style=\"color:#D4A017\">●</span> Partial / Limited"
|
||||
) +
|
||||
el_div("style=\"display:flex;align-items:center;gap:0.5rem;font-family:var(--body);font-size:0.75rem;color:var(--t3)\"",
|
||||
"<span style=\"color:#C44\">✕</span> No / Not supported"
|
||||
)
|
||||
)
|
||||
|
||||
let closing: String = el_div(
|
||||
"class=\"reveal\" style=\"transition-delay:400ms;margin-top:4rem;padding:clamp(1.5rem,4vw,2.5rem) clamp(1.25rem,4vw,3rem);background:var(--card);border:1px solid rgba(0,82,160,.12);border-left:3px solid var(--navy)\"",
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:1rem\"",
|
||||
"The others are impressive. Some of them are extraordinary at what they do. But they are all built on the same assumption: " +
|
||||
el_em("your context lives in their cloud, session to session, at their discretion.")
|
||||
) +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8\"",
|
||||
"Neuron starts from a different premise. Your memory is yours. It lives on your machine. It compounds over time, not over sessions. The AI that knows you isn't an AI you borrowed from someone else's cloud - it's one that has been building with you, on your terms, since day one."
|
||||
)
|
||||
)
|
||||
|
||||
el_section(
|
||||
"id=\"comparison\" aria-label=\"Comparison\" style=\"padding:8rem 2.5rem;background:var(--bg2)\"",
|
||||
el_div("class=\"container\"", comparison_header() + table + legend + closing)
|
||||
)
|
||||
}
|
||||
|
||||
+76
-61
@@ -1,74 +1,89 @@
|
||||
// components/efficiency.el - Token efficiency and environment section.
|
||||
// Three cards: local inference / per-task routing / context compression.
|
||||
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
|
||||
fn efficiency() -> String {
|
||||
return <section id="efficiency" aria-label="Token efficiency and environment">
|
||||
<div class="container">
|
||||
let header: String = el_div(
|
||||
"class=\"efficiency-header\"",
|
||||
el_div(
|
||||
"class=\"efficiency-label-row reveal\"",
|
||||
el_div("class=\"navy-line-left\" style=\"width:4rem;flex-shrink:0\"", "") +
|
||||
el_span("class=\"label\"", "Efficiency")
|
||||
) +
|
||||
el_h2(
|
||||
"class=\"display-lg reveal\" style=\"transition-delay:80ms;max-width:32rem\"",
|
||||
"Every token spent " + el_span("class=\"gold\"", "is a choice.")
|
||||
) +
|
||||
el_p(
|
||||
"class=\"efficiency-sub reveal\" style=\"transition-delay:160ms;margin-top:1.25rem\"",
|
||||
"Cost and environmental impact aren't afterthoughts - they're structural properties of the architecture. I built it that way from the start."
|
||||
)
|
||||
)
|
||||
|
||||
<div class="efficiency-header">
|
||||
<div class="efficiency-label-row reveal">
|
||||
<div class="navy-line-left" style="width:4rem;flex-shrink:0"></div>
|
||||
<span class="label">Efficiency</span>
|
||||
</div>
|
||||
<h2 class="display-lg reveal" style="transition-delay:80ms;max-width:32rem">
|
||||
Every token spent <span class="gold">is a choice.</span>
|
||||
</h2>
|
||||
<p class="efficiency-sub reveal" style="transition-delay:160ms;margin-top:1.25rem">
|
||||
Cost and environmental impact aren't afterthoughts - they're structural properties of the architecture. I built it that way from the start.
|
||||
</p>
|
||||
</div>
|
||||
let svg1: String = "<svg width=\"28\" height=\"28\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">" +
|
||||
"<path d=\"M12 22C6.477 22 2 17.523 2 12S6.477 2 12 2s10 4.477 10 10-4.477 10-10 10z\"/>" +
|
||||
"<path d=\"M8 12s1.5-2 4-2 4 2 4 2\"/>" +
|
||||
"<path d=\"M9 9h.01M15 9h.01\"/>" +
|
||||
"<path d=\"M12 17c-1.5 0-3-.5-3-1.5S10 14 12 14s3 .5 3 1.5S13.5 17 12 17z\"/>" +
|
||||
"</svg>"
|
||||
|
||||
<div class="efficiency-grid">
|
||||
let card1: String = el_div(
|
||||
"class=\"efficiency-card card-dark reveal\"",
|
||||
el_div("class=\"efficiency-icon\"", svg1) +
|
||||
el_p("class=\"efficiency-stat\"", "0 cloud tokens") +
|
||||
el_p("class=\"efficiency-title\"", "Local inference") +
|
||||
el_div("class=\"efficiency-rule\"", "") +
|
||||
el_p("class=\"efficiency-body\"", "The design: run inference entirely on-device via Ollama. No API calls, no inference cost, no carbon footprint from model compute. Full memory and context, zero cloud dependency. This is coming.")
|
||||
)
|
||||
|
||||
<div class="efficiency-card card-dark reveal">
|
||||
<div class="efficiency-icon">
|
||||
<svg width="28" height="28" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true">
|
||||
<path d="M12 22C6.477 22 2 17.523 2 12S6.477 2 12 2s10 4.477 10 10-4.477 10-10 10z"/>
|
||||
<path d="M8 12s1.5-2 4-2 4 2 4 2"/>
|
||||
<path d="M9 9h.01M15 9h.01"/>
|
||||
<path d="M12 17c-1.5 0-3-.5-3-1.5S10 14 12 14s3 .5 3 1.5S13.5 17 12 17z"/>
|
||||
</svg>
|
||||
</div>
|
||||
<p class="efficiency-stat">0 cloud tokens</p>
|
||||
<p class="efficiency-title">Local inference</p>
|
||||
<div class="efficiency-rule"></div>
|
||||
<p class="efficiency-body">The design: run inference entirely on-device via Ollama. No API calls, no inference cost, no carbon footprint from model compute. Full memory and context, zero cloud dependency. This is coming.</p>
|
||||
</div>
|
||||
let svg2: String = "<svg width=\"28\" height=\"28\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">" +
|
||||
"<circle cx=\"6\" cy=\"18\" r=\"2\"/><circle cx=\"18\" cy=\"6\" r=\"2\"/><circle cx=\"18\" cy=\"18\" r=\"2\"/>" +
|
||||
"<path d=\"M6 16V8l6-4 6 4\"/><path d=\"M6 16l6 4 6-4\"/><path d=\"M12 4v16\"/>" +
|
||||
"</svg>"
|
||||
|
||||
<div class="efficiency-card card-dark reveal" style="transition-delay:150ms">
|
||||
<div class="efficiency-icon">
|
||||
<svg width="28" height="28" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true">
|
||||
<circle cx="6" cy="18" r="2"/><circle cx="18" cy="6" r="2"/><circle cx="18" cy="18" r="2"/>
|
||||
<path d="M6 16V8l6-4 6 4"/><path d="M6 16l6 4 6-4"/><path d="M12 4v16"/>
|
||||
</svg>
|
||||
</div>
|
||||
<p class="efficiency-stat">Use less</p>
|
||||
<p class="efficiency-title">Per-task routing</p>
|
||||
<div class="efficiency-rule"></div>
|
||||
<p class="efficiency-body">Simple tasks route to small, fast models. Complex reasoning escalates to frontier models only when necessary. And because every model has full access to your accumulated context, cheaper models punch well above their weight.</p>
|
||||
</div>
|
||||
let card2: String = el_div(
|
||||
"class=\"efficiency-card card-dark reveal\" style=\"transition-delay:150ms\"",
|
||||
el_div("class=\"efficiency-icon\"", svg2) +
|
||||
el_p("class=\"efficiency-stat\"", "Use less") +
|
||||
el_p("class=\"efficiency-title\"", "Per-task routing") +
|
||||
el_div("class=\"efficiency-rule\"", "") +
|
||||
el_p("class=\"efficiency-body\"", "Simple tasks route to small, fast models. Complex reasoning escalates to frontier models only when necessary. And because every model has full access to your accumulated context, cheaper models punch well above their weight.")
|
||||
)
|
||||
|
||||
<div class="efficiency-card card-dark reveal" style="transition-delay:300ms">
|
||||
<div class="efficiency-icon">
|
||||
<svg width="28" height="28" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true">
|
||||
<rect x="4" y="4" width="16" height="16" rx="2"/>
|
||||
<path d="M9 9h6M9 12h6M9 15h4"/>
|
||||
<path d="M16 15l2 2 2-2"/>
|
||||
</svg>
|
||||
</div>
|
||||
<p class="efficiency-stat">Fewer tokens</p>
|
||||
<p class="efficiency-title">Same work done</p>
|
||||
<div class="efficiency-rule"></div>
|
||||
<p class="efficiency-body">Every time you open ChatGPT and explain who you are again, that's computation that didn't need to happen. Persistent context means shorter, more targeted prompts. The same outcome with less compute - and a smaller footprint on the planet.</p>
|
||||
</div>
|
||||
let svg3: String = "<svg width=\"28\" height=\"28\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">" +
|
||||
"<rect x=\"4\" y=\"4\" width=\"16\" height=\"16\" rx=\"2\"/>" +
|
||||
"<path d=\"M9 9h6M9 12h6M9 15h4\"/>" +
|
||||
"<path d=\"M16 15l2 2 2-2\"/>" +
|
||||
"</svg>"
|
||||
|
||||
</div>
|
||||
let card3: String = el_div(
|
||||
"class=\"efficiency-card card-dark reveal\" style=\"transition-delay:300ms\"",
|
||||
el_div("class=\"efficiency-icon\"", svg3) +
|
||||
el_p("class=\"efficiency-stat\"", "Fewer tokens") +
|
||||
el_p("class=\"efficiency-title\"", "Same work done") +
|
||||
el_div("class=\"efficiency-rule\"", "") +
|
||||
el_p("class=\"efficiency-body\"", "Every time you open ChatGPT and explain who you are again, that's computation that didn't need to happen. Persistent context means shorter, more targeted prompts. The same outcome with less compute - and a smaller footprint on the planet.")
|
||||
)
|
||||
|
||||
<div class="efficiency-pullquote reveal">
|
||||
<p>The frontier model without memory of you is starting from scratch every time. A smaller, faster model with years of accumulated context on your work, your decisions, and your patterns will outperform it. The intelligence isn't in the model - it's in what the model knows about you.</p>
|
||||
</div>
|
||||
let grid: String = el_div("class=\"efficiency-grid\"", card1 + card2 + card3)
|
||||
|
||||
</div>
|
||||
<div class="container" style="margin-top:5rem"><div class="navy-line"></div></div>
|
||||
</section>
|
||||
let pullquote: String = el_div(
|
||||
"class=\"efficiency-pullquote reveal\"",
|
||||
el_p("", "The frontier model without memory of you is starting from scratch every time. A smaller, faster model with years of accumulated context on your work, your decisions, and your patterns will outperform it. The intelligence isn't in the model - it's in what the model knows about you.")
|
||||
)
|
||||
|
||||
let bottom_line: String = el_div(
|
||||
"class=\"container\" style=\"margin-top:5rem\"",
|
||||
el_div("class=\"navy-line\"", "")
|
||||
)
|
||||
|
||||
el_section(
|
||||
"id=\"efficiency\" aria-label=\"Token efficiency and environment\"",
|
||||
el_div("class=\"container\"", header + grid + pullquote) + bottom_line
|
||||
)
|
||||
}
|
||||
|
||||
+210
-170
@@ -1,183 +1,223 @@
|
||||
// components/enterprise.el - Enterprise section.
|
||||
// Four capability cards + "Who I work with" box + how-it-works steps.
|
||||
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_h3(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_a(href: String, attrs: String, children: String) -> String
|
||||
extern fn el_form(attrs: String, children: String) -> String
|
||||
extern fn el_label(for_id: String, attrs: String, children: String) -> String
|
||||
extern fn el_input(type_attr: String, attrs: String) -> String
|
||||
extern fn el_textarea(attrs: String, value: String) -> String
|
||||
extern fn el_button(attrs: String, label: String) -> String
|
||||
extern fn el_script_src(src: String, defer_load: Bool) -> String
|
||||
|
||||
fn enterprise_cap_cards() -> String {
|
||||
let card1: String = el_div(
|
||||
"class=\"enterprise-cap card-dark reveal\"",
|
||||
el_h3("class=\"display-md\"", "Private deployment") +
|
||||
el_div("class=\"enterprise-cap-rule\"", "") +
|
||||
el_p("class=\"enterprise-cap-body\"", "Run entirely on your infrastructure. Air-gapped. No data leaves your network. Every employee gets their own Neuron instance - your company's institutional knowledge stays inside your walls.")
|
||||
)
|
||||
let card2: String = el_div(
|
||||
"class=\"enterprise-cap card-dark reveal\" style=\"transition-delay:130ms\"",
|
||||
el_h3("class=\"display-md\"", "Institutional memory") +
|
||||
el_div("class=\"enterprise-cap-rule\"", "") +
|
||||
el_p("class=\"enterprise-cap-body\"", "When an employee leaves, their expertise doesn't. Their memory persists - their patterns, their domain knowledge, their reasoning - available to the team they built it with.")
|
||||
)
|
||||
let card3: String = el_div(
|
||||
"class=\"enterprise-cap card-dark reveal\" style=\"transition-delay:260ms\"",
|
||||
el_h3("class=\"display-md\"", "Team intelligence") +
|
||||
el_div("class=\"enterprise-cap-rule\"", "") +
|
||||
el_p("class=\"enterprise-cap-body\"", "Shared knowledge packages and cross-instance coordination. The collective intelligence of your organization compounds the same way an individual's does.")
|
||||
)
|
||||
let card4: String = el_div(
|
||||
"class=\"enterprise-cap card-dark reveal\" style=\"transition-delay:390ms\"",
|
||||
el_h3("class=\"display-md\"", "Compliance architecture") +
|
||||
el_div("class=\"enterprise-cap-rule\"", "") +
|
||||
el_p("class=\"enterprise-cap-body\"", "Custom on-device storage. No cloud database with your data. SOC 2 alignment built into the data model. ExternalSecret-based secrets management. Audit logs at every layer.")
|
||||
)
|
||||
el_div("class=\"enterprise-grid\"", card1 + card2 + card3 + card4)
|
||||
}
|
||||
|
||||
fn enterprise_how_it_works() -> String {
|
||||
let step1: String = el_div(
|
||||
"",
|
||||
el_p("class=\"ent-step-num\"", "01") +
|
||||
el_p("class=\"ent-step-title\"", "Express interest") +
|
||||
el_p("class=\"ent-step-body\"", "Send me a note. I review every inquiry myself - no sales funnel, no SDR. If it's a fit, I respond directly.")
|
||||
)
|
||||
let step2: String = el_div(
|
||||
"",
|
||||
el_p("class=\"ent-step-num\"", "02") +
|
||||
el_p("class=\"ent-step-title\"", "Scoped deployment") +
|
||||
el_p("class=\"ent-step-body\"", "I work with your team to scope a private deployment - on your infrastructure, in your network, with your security requirements.")
|
||||
)
|
||||
let step3: String = el_div(
|
||||
"",
|
||||
el_p("class=\"ent-step-num\"", "03") +
|
||||
el_p("class=\"ent-step-title\"", "Per-seat licensing") +
|
||||
el_p("class=\"ent-step-body\"", "Annual per-seat pricing with a volume floor. Custom SLA available. The full Agreement is published before any conversation starts.")
|
||||
)
|
||||
el_div(
|
||||
"class=\"ent-how-row\"",
|
||||
el_div(
|
||||
"class=\"ent-how-label\"",
|
||||
el_h3("class=\"display-md\" style=\"font-size:1.25rem\"", "How it works")
|
||||
) +
|
||||
el_div("class=\"ent-steps\"", step1 + step2 + step3)
|
||||
)
|
||||
}
|
||||
|
||||
fn enterprise_inquiry_form() -> String {
|
||||
let field_style: String = "font-family:var(--body);font-size:0.9rem;font-weight:300;color:var(--t1);background:#fff;border:1px solid rgba(0,82,160,.22);padding:0.7rem 0.9rem;outline:none;border-radius:0;-webkit-appearance:none;width:100%;box-sizing:border-box"
|
||||
let label_style: String = "font-family:var(--body);font-size:0.7rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--t3)"
|
||||
|
||||
let field_name: String = el_div(
|
||||
"style=\"display:flex;flex-direction:column;gap:0.4rem\"",
|
||||
el_label("ent-name", "style=\"" + label_style + "\"", "Name") +
|
||||
el_input("text", "id=\"ent-name\" name=\"name\" required placeholder=\"Your name\" style=\"" + field_style + "\"")
|
||||
)
|
||||
let field_email: String = el_div(
|
||||
"style=\"display:flex;flex-direction:column;gap:0.4rem\"",
|
||||
el_label("ent-email", "style=\"" + label_style + "\"", "Work email") +
|
||||
el_input("email", "id=\"ent-email\" name=\"email\" required placeholder=\"you@company.com\" style=\"" + field_style + "\"")
|
||||
)
|
||||
let field_company: String = el_div(
|
||||
"style=\"display:flex;flex-direction:column;gap:0.4rem\"",
|
||||
el_label("ent-company", "style=\"" + label_style + "\"", "Organization") +
|
||||
el_input("text", "id=\"ent-company\" name=\"company\" required placeholder=\"Company or organization name\" style=\"" + field_style + "\"")
|
||||
)
|
||||
let field_size: String = el_div(
|
||||
"style=\"display:flex;flex-direction:column;gap:0.4rem\"",
|
||||
el_label("ent-size", "style=\"" + label_style + "\"", "Team size") +
|
||||
"<select id=\"ent-size\" name=\"size\" required style=\"" + field_style + ";cursor:pointer\">" +
|
||||
"<option value=\"\">Select…</option>" +
|
||||
"<option value=\"2-10\">2–10 people</option>" +
|
||||
"<option value=\"11-50\">11–50 people</option>" +
|
||||
"<option value=\"51-200\">51–200 people</option>" +
|
||||
"<option value=\"201-500\">201–500 people</option>" +
|
||||
"<option value=\"500+\">500+ people</option>" +
|
||||
"</select>"
|
||||
)
|
||||
let field_use: String = el_div(
|
||||
"style=\"grid-column:1/-1;display:flex;flex-direction:column;gap:0.4rem\"",
|
||||
el_label("ent-use", "style=\"" + label_style + "\"", "What do you want to use Neuron for?") +
|
||||
el_textarea("id=\"ent-use\" name=\"use_case\" required rows=\"3\" placeholder=\"Describe your intended use case - be specific.\" style=\"" + field_style + ";resize:vertical\"", "")
|
||||
)
|
||||
let filter_msg_secondary: String = el_p("id=\"ent-filter-msg-secondary\" style=\"display:none;font-family:var(--body);font-size:0.875rem;font-weight:300;color:rgba(0,82,160,.75);line-height:1.65;padding:0.75rem 1rem;background:rgba(0,82,160,.04);border-left:2px solid rgba(0,82,160,.3)\"",
|
||||
"I review these personally. I'll consider it - but I want to be direct with you: if headcount reduction is in the picture at all, even as a secondary outcome, your chances here are low. That's not a negotiating position. It's how I built this and what I'm willing to support."
|
||||
)
|
||||
let filter_msg_yes: String = el_p("id=\"ent-filter-msg-yes\" style=\"display:none;font-family:var(--body);font-size:0.875rem;font-weight:300;color:#c0392b;line-height:1.65;padding:0.75rem 1rem;background:rgba(192,57,43,.05);border-left:2px solid rgba(192,57,43,.4)\"",
|
||||
"Neuron isn't the right fit here. I built this to expand what people can do, not to replace them. If that changes, I'm here."
|
||||
)
|
||||
let field_headcount: String = el_div(
|
||||
"style=\"grid-column:1/-1;display:flex;flex-direction:column;gap:0.4rem\"",
|
||||
el_label("ent-headcount", "style=\"" + label_style + "\"", "Is reducing headcount a primary goal of this deployment?") +
|
||||
"<select id=\"ent-headcount\" name=\"headcount\" required onchange=\"entHeadcountChange(this.value)\" style=\"" + field_style + ";cursor:pointer\">" +
|
||||
"<option value=\"\">Select…</option>" +
|
||||
"<option value=\"no\">No - making our team more capable</option>" +
|
||||
"<option value=\"secondary\">It's a secondary factor, not the primary goal</option>" +
|
||||
"<option value=\"yes\">Yes - replacing roles with automation</option>" +
|
||||
"</select>" +
|
||||
filter_msg_secondary +
|
||||
filter_msg_yes
|
||||
)
|
||||
let error_div: String = el_div("id=\"ent-form-error\" style=\"grid-column:1/-1;display:none;font-family:var(--body);font-size:0.875rem;color:#c0392b;padding:0.75rem 1rem;background:rgba(192,57,43,.05);border-left:2px solid rgba(192,57,43,.4)\"", "")
|
||||
let submit_div: String = el_div(
|
||||
"style=\"grid-column:1/-1\"",
|
||||
el_button("type=\"submit\" id=\"ent-submit\" style=\"font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;background:var(--navy);color:#fff;border:none;padding:0.95rem 2rem;cursor:pointer;transition:background .2s\"",
|
||||
"Send inquiry →"
|
||||
)
|
||||
)
|
||||
|
||||
let success_div: String = el_div(
|
||||
"id=\"enterprise-success\" style=\"display:none;padding:2rem;background:rgba(0,82,160,.04);border-left:3px solid var(--navy)\"",
|
||||
el_p("style=\"font-family:var(--head);font-size:1.25rem;font-weight:500;color:var(--t1);margin-bottom:0.5rem\"", "Received.") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8\"",
|
||||
"I review these personally. If it's a fit, I'll respond directly to your email - usually within a few days."
|
||||
)
|
||||
)
|
||||
|
||||
el_div(
|
||||
"style=\"margin-top:3rem;padding-top:2.5rem;border-top:1px solid var(--border)\"",
|
||||
el_p("class=\"label\" style=\"margin-bottom:0.75rem;font-size:0.65rem\"", "Express interest") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9rem;color:var(--t2);line-height:1.75;margin-bottom:2rem\"",
|
||||
"I review every inquiry myself. Fill this out honestly - the questions are a filter, not a formality."
|
||||
) +
|
||||
el_form("id=\"enterprise-form\" class=\"ent-inquiry-form\"",
|
||||
field_name + field_email + field_company + field_size + field_use + field_headcount + error_div + submit_div
|
||||
) +
|
||||
success_div
|
||||
)
|
||||
}
|
||||
|
||||
fn enterprise() -> String {
|
||||
return <section id="enterprise" aria-label="Enterprise">
|
||||
<div class="container">
|
||||
let header: String = el_div(
|
||||
"class=\"enterprise-header\"",
|
||||
el_div(
|
||||
"class=\"enterprise-label-row reveal\"",
|
||||
el_div("class=\"navy-line-left\" style=\"width:4rem;flex-shrink:0\"", "") +
|
||||
el_span("class=\"label\" style=\"color:var(--navy-85)\"", "Enterprise")
|
||||
) +
|
||||
el_div(
|
||||
"class=\"enterprise-head-row\"",
|
||||
el_div(
|
||||
"style=\"max-width:28rem\"",
|
||||
el_h2(
|
||||
"class=\"display-lg reveal\" style=\"transition-delay:80ms\"",
|
||||
"Enterprise-ready " + el_span("class=\"gold\"", "Q1 2027.")
|
||||
) +
|
||||
el_p("class=\"reveal\" style=\"transition-delay:160ms;font-weight:300;font-size:.9375rem;color:var(--t2);line-height:1.7;margin-top:1.25rem\"",
|
||||
"Not an afterthought. Not a future roadmap item. Built into the architecture from the start."
|
||||
)
|
||||
) +
|
||||
el_div(
|
||||
"class=\"reveal\" style=\"transition-delay:240ms;display:flex;flex-direction:column;gap:.75rem;align-items:flex-end\"",
|
||||
el_div(
|
||||
"class=\"ent-badge\"",
|
||||
el_span("class=\"ent-badge-dot\"", "") +
|
||||
"Enterprise discussions open now — launching Q1 2027"
|
||||
) +
|
||||
el_p("style=\"font-size:.75rem;color:rgba(0,82,160,.45)\"",
|
||||
"Use the form below · I review every inquiry · I'll be spending the holidays with my family — we launch Q1"
|
||||
)
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
<div class="enterprise-header">
|
||||
<div class="enterprise-label-row reveal">
|
||||
<div class="navy-line-left" style="width:4rem;flex-shrink:0"></div>
|
||||
<span class="label" style="color:var(--navy-85)">Enterprise</span>
|
||||
</div>
|
||||
<div class="enterprise-head-row">
|
||||
<div style="max-width:28rem">
|
||||
<h2 class="display-lg reveal" style="transition-delay:80ms">
|
||||
Enterprise-ready <span class="gold">Q1 2027.</span>
|
||||
</h2>
|
||||
<p class="reveal" style="transition-delay:160ms;font-weight:300;font-size:.9375rem;color:var(--t2);line-height:1.7;margin-top:1.25rem">
|
||||
Not an afterthought. Not a future roadmap item. Built into the architecture from the start.
|
||||
</p>
|
||||
</div>
|
||||
<div class="reveal" style="transition-delay:240ms;display:flex;flex-direction:column;gap:.75rem;align-items:flex-end">
|
||||
<div class="ent-badge">
|
||||
<span class="ent-badge-dot"></span>
|
||||
Enterprise discussions open now — launching Q1 2027
|
||||
</div>
|
||||
<p style="font-size:.75rem;color:rgba(0,82,160,.45)">Use the form below · I review every inquiry · I'll be spending the holidays with my family — we launch Q1</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
let enterprise_box: String = el_div(
|
||||
"class=\"enterprise-box reveal\"",
|
||||
el_p("class=\"ent-who-label\"", "Who I work with") +
|
||||
el_p("class=\"ent-who-body\"", "I am selective. I built Neuron to expand what people can do - not to help organizations eliminate them. If your interest in this technology is primarily about reducing headcount, I am not your vendor. If it's about making the people you have dramatically more effective, I want to hear from you.") +
|
||||
el_p("class=\"ent-who-note\"", "This isn't a legal hedge. It's a filter. The Enterprise Agreement makes it binding - but I'm raising it here because I'd rather you know before you reach out.") +
|
||||
enterprise_how_it_works() +
|
||||
el_div(
|
||||
"class=\"ent-terms-row\"",
|
||||
el_p("class=\"ent-terms-text\"", "The full Enterprise Agreement is published. Read it before reaching out - no NDA required to evaluate the terms.") +
|
||||
el_a("/legal/enterprise-terms", "class=\"ent-terms-link\"", "Read the Enterprise Agreement →")
|
||||
) +
|
||||
enterprise_inquiry_form()
|
||||
)
|
||||
|
||||
<div class="enterprise-grid">
|
||||
<div class="enterprise-cap card-dark reveal">
|
||||
<h3 class="display-md">Private deployment</h3>
|
||||
<div class="enterprise-cap-rule"></div>
|
||||
<p class="enterprise-cap-body">Run entirely on your infrastructure. Air-gapped. No data leaves your network. Every employee gets their own Neuron instance - your company's institutional knowledge stays inside your walls.</p>
|
||||
</div>
|
||||
<div class="enterprise-cap card-dark reveal" style="transition-delay:130ms">
|
||||
<h3 class="display-md">Institutional memory</h3>
|
||||
<div class="enterprise-cap-rule"></div>
|
||||
<p class="enterprise-cap-body">When an employee leaves, their expertise doesn't. Their memory persists - their patterns, their domain knowledge, their reasoning - available to the team they built it with.</p>
|
||||
</div>
|
||||
<div class="enterprise-cap card-dark reveal" style="transition-delay:260ms">
|
||||
<h3 class="display-md">Team intelligence</h3>
|
||||
<div class="enterprise-cap-rule"></div>
|
||||
<p class="enterprise-cap-body">Shared knowledge packages and cross-instance coordination. The collective intelligence of your organization compounds the same way an individual's does.</p>
|
||||
</div>
|
||||
<div class="enterprise-cap card-dark reveal" style="transition-delay:390ms">
|
||||
<h3 class="display-md">Compliance architecture</h3>
|
||||
<div class="enterprise-cap-rule"></div>
|
||||
<p class="enterprise-cap-body">Custom on-device storage. No cloud database with your data. SOC 2 alignment built into the data model. ExternalSecret-based secrets management. Audit logs at every layer.</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="enterprise-box reveal">
|
||||
<p class="ent-who-label">Who I work with</p>
|
||||
<p class="ent-who-body">I am selective. I built Neuron to expand what people can do - not to help organizations eliminate them. If your interest in this technology is primarily about reducing headcount, I am not your vendor. If it's about making the people you have dramatically more effective, I want to hear from you.</p>
|
||||
<p class="ent-who-note">This isn't a legal hedge. It's a filter. The Enterprise Agreement makes it binding - but I'm raising it here because I'd rather you know before you reach out.</p>
|
||||
|
||||
<div class="ent-how-row">
|
||||
<div class="ent-how-label">
|
||||
<h3 class="display-md" style="font-size:1.25rem">How it works</h3>
|
||||
</div>
|
||||
<div class="ent-steps">
|
||||
<div>
|
||||
<p class="ent-step-num">01</p>
|
||||
<p class="ent-step-title">Express interest</p>
|
||||
<p class="ent-step-body">Send me a note. I review every inquiry myself - no sales funnel, no SDR. If it's a fit, I respond directly.</p>
|
||||
</div>
|
||||
<div>
|
||||
<p class="ent-step-num">02</p>
|
||||
<p class="ent-step-title">Scoped deployment</p>
|
||||
<p class="ent-step-body">I work with your team to scope a private deployment - on your infrastructure, in your network, with your security requirements.</p>
|
||||
</div>
|
||||
<div>
|
||||
<p class="ent-step-num">03</p>
|
||||
<p class="ent-step-title">Per-seat licensing</p>
|
||||
<p class="ent-step-body">Annual per-seat pricing with a volume floor. Custom SLA available. The full Agreement is published before any conversation starts.</p>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div class="ent-terms-row">
|
||||
<p class="ent-terms-text">The full Enterprise Agreement is published. Read it before reaching out - no NDA required to evaluate the terms.</p>
|
||||
<a href="/legal/enterprise-terms" class="ent-terms-link">Read the Enterprise Agreement →</a>
|
||||
</div>
|
||||
|
||||
<!-- Enterprise inquiry form -->
|
||||
<div style="margin-top:3rem;padding-top:2.5rem;border-top:1px solid var(--border)">
|
||||
<p class="label" style="margin-bottom:0.75rem;font-size:0.65rem">Express interest</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9rem;color:var(--t2);line-height:1.75;margin-bottom:2rem">I review every inquiry myself. Fill this out honestly - the questions are a filter, not a formality.</p>
|
||||
|
||||
<form id="enterprise-form" class="ent-inquiry-form">
|
||||
|
||||
<div style="display:flex;flex-direction:column;gap:0.4rem">
|
||||
<label for="ent-name" style="font-family:var(--body);font-size:0.7rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--t3)">Name</label>
|
||||
<input id="ent-name" name="name" type="text" required placeholder="Your name"
|
||||
style="font-family:var(--body);font-size:0.9rem;font-weight:300;color:var(--t1);background:#fff;border:1px solid rgba(0,82,160,.22);padding:0.7rem 0.9rem;outline:none;border-radius:0;-webkit-appearance:none;width:100%;box-sizing:border-box">
|
||||
</div>
|
||||
|
||||
<div style="display:flex;flex-direction:column;gap:0.4rem">
|
||||
<label for="ent-email" style="font-family:var(--body);font-size:0.7rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--t3)">Work email</label>
|
||||
<input id="ent-email" name="email" type="email" required placeholder="you@company.com"
|
||||
style="font-family:var(--body);font-size:0.9rem;font-weight:300;color:var(--t1);background:#fff;border:1px solid rgba(0,82,160,.22);padding:0.7rem 0.9rem;outline:none;border-radius:0;-webkit-appearance:none;width:100%;box-sizing:border-box">
|
||||
</div>
|
||||
|
||||
<div style="display:flex;flex-direction:column;gap:0.4rem">
|
||||
<label for="ent-company" style="font-family:var(--body);font-size:0.7rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--t3)">Organization</label>
|
||||
<input id="ent-company" name="company" type="text" required placeholder="Company or organization name"
|
||||
style="font-family:var(--body);font-size:0.9rem;font-weight:300;color:var(--t1);background:#fff;border:1px solid rgba(0,82,160,.22);padding:0.7rem 0.9rem;outline:none;border-radius:0;-webkit-appearance:none;width:100%;box-sizing:border-box">
|
||||
</div>
|
||||
|
||||
<div style="display:flex;flex-direction:column;gap:0.4rem">
|
||||
<label for="ent-size" style="font-family:var(--body);font-size:0.7rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--t3)">Team size</label>
|
||||
<select id="ent-size" name="size" required
|
||||
style="font-family:var(--body);font-size:0.9rem;font-weight:300;color:var(--t1);background:#fff;border:1px solid rgba(0,82,160,.22);padding:0.7rem 0.9rem;outline:none;border-radius:0;-webkit-appearance:none;cursor:pointer;width:100%;box-sizing:border-box">
|
||||
<option value="">Select…</option>
|
||||
<option value="2-10">2–10 people</option>
|
||||
<option value="11-50">11–50 people</option>
|
||||
<option value="51-200">51–200 people</option>
|
||||
<option value="201-500">201–500 people</option>
|
||||
<option value="500+">500+ people</option>
|
||||
</select>
|
||||
</div>
|
||||
|
||||
<div style="grid-column:1/-1;display:flex;flex-direction:column;gap:0.4rem">
|
||||
<label for="ent-use" style="font-family:var(--body);font-size:0.7rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--t3)">What do you want to use Neuron for?</label>
|
||||
<textarea id="ent-use" name="use_case" required rows="3" placeholder="Describe your intended use case - be specific."
|
||||
style="font-family:var(--body);font-size:0.9rem;font-weight:300;color:var(--t1);background:#fff;border:1px solid rgba(0,82,160,.22);padding:0.7rem 0.9rem;outline:none;border-radius:0;resize:vertical;-webkit-appearance:none;width:100%;box-sizing:border-box"></textarea>
|
||||
</div>
|
||||
|
||||
<div style="grid-column:1/-1;display:flex;flex-direction:column;gap:0.4rem">
|
||||
<label for="ent-headcount" style="font-family:var(--body);font-size:0.7rem;font-weight:500;letter-spacing:0.08em;text-transform:uppercase;color:var(--t3)">Is reducing headcount a primary goal of this deployment?</label>
|
||||
<select id="ent-headcount" name="headcount" required onchange="entHeadcountChange(this.value)"
|
||||
style="font-family:var(--body);font-size:0.9rem;font-weight:300;color:var(--t1);background:#fff;border:1px solid rgba(0,82,160,.22);padding:0.7rem 0.9rem;outline:none;border-radius:0;-webkit-appearance:none;cursor:pointer;width:100%;box-sizing:border-box">
|
||||
<option value="">Select…</option>
|
||||
<option value="no">No - making our team more capable</option>
|
||||
<option value="secondary">It's a secondary factor, not the primary goal</option>
|
||||
<option value="yes">Yes - replacing roles with automation</option>
|
||||
</select>
|
||||
<p id="ent-filter-msg-secondary" style="display:none;font-family:var(--body);font-size:0.875rem;font-weight:300;color:rgba(0,82,160,.75);line-height:1.65;padding:0.75rem 1rem;background:rgba(0,82,160,.04);border-left:2px solid rgba(0,82,160,.3)">
|
||||
I review these personally. I'll consider it - but I want to be direct with you: if headcount reduction is in the picture at all, even as a secondary outcome, your chances here are low. That's not a negotiating position. It's how I built this and what I'm willing to support.
|
||||
</p>
|
||||
<p id="ent-filter-msg-yes" style="display:none;font-family:var(--body);font-size:0.875rem;font-weight:300;color:#c0392b;line-height:1.65;padding:0.75rem 1rem;background:rgba(192,57,43,.05);border-left:2px solid rgba(192,57,43,.4)">
|
||||
Neuron isn't the right fit here. I built this to expand what people can do, not to replace them. If that changes, I'm here.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<div id="ent-form-error" style="grid-column:1/-1;display:none;font-family:var(--body);font-size:0.875rem;color:#c0392b;padding:0.75rem 1rem;background:rgba(192,57,43,.05);border-left:2px solid rgba(192,57,43,.4)"></div>
|
||||
|
||||
<div style="grid-column:1/-1">
|
||||
<button type="submit" id="ent-submit"
|
||||
style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;background:var(--navy);color:#fff;border:none;padding:0.95rem 2rem;cursor:pointer;transition:background .2s">
|
||||
Send inquiry →
|
||||
</button>
|
||||
</div>
|
||||
|
||||
</form>
|
||||
|
||||
<div id="enterprise-success" style="display:none;padding:2rem;background:rgba(0,82,160,.04);border-left:3px solid var(--navy)">
|
||||
<p style="font-family:var(--head);font-size:1.25rem;font-weight:500;color:var(--t1);margin-bottom:0.5rem">Received.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">I review these personally. If it's a fit, I'll respond directly to your email - usually within a few days.</p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<style>
|
||||
.ent-inquiry-form {
|
||||
let style_css: String = ".ent-inquiry-form {
|
||||
display: grid;
|
||||
grid-template-columns: 1fr 1fr;
|
||||
gap: 1rem;
|
||||
}
|
||||
@media (max-width: 600px) {
|
||||
.ent-inquiry-form { grid-template-columns: 1fr; }
|
||||
.ent-inquiry-form > div[style*="grid-column:1/-1"],
|
||||
.ent-inquiry-form > div[style*="grid-column: 1 / -1"] { grid-column: 1; }
|
||||
}
|
||||
</style>
|
||||
<script src="/js/enterprise.js" defer></script>
|
||||
</section>
|
||||
.ent-inquiry-form > div[style*=\"grid-column:1/-1\"],
|
||||
.ent-inquiry-form > div[style*=\"grid-column: 1 / -1\"] { grid-column: 1; }
|
||||
}"
|
||||
|
||||
el_section(
|
||||
"id=\"enterprise\" aria-label=\"Enterprise\"",
|
||||
el_div("class=\"container\"", header + enterprise_cap_cards() + enterprise_box) +
|
||||
"<style>" + style_css + "</style>" +
|
||||
el_script_src("/js/enterprise.js", true)
|
||||
)
|
||||
}
|
||||
|
||||
+169
-131
@@ -4,150 +4,188 @@
|
||||
from styles import { page_open, page_close }
|
||||
from nav import { nav }
|
||||
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h1(attrs: String, text: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_a(href: String, attrs: String, children: String) -> String
|
||||
extern fn el_ul(attrs: String, children: String) -> String
|
||||
extern fn el_li(attrs: String, children: String) -> String
|
||||
extern fn el_em(children: String) -> String
|
||||
|
||||
fn enterprise_terms_page() -> String {
|
||||
return {page_open()}{enterprise_terms_body()}{page_close()}
|
||||
page_open() + enterprise_terms_body() + page_close()
|
||||
}
|
||||
|
||||
fn section(num: String, title: String, body: String) -> String {
|
||||
return <div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;flex-wrap:wrap;gap:0.5rem 1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65);flex-shrink:0">§ {num}</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1);min-width:0;word-break:break-word">{title}</h2>
|
||||
</div>
|
||||
{raw(body)}
|
||||
</div>
|
||||
fn et_section(num: String, title: String, body: String) -> String {
|
||||
let header: String = el_div(
|
||||
"style=\"display:flex;align-items:baseline;flex-wrap:wrap;gap:0.5rem 1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem\"",
|
||||
el_span("style=\"font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65);flex-shrink:0\"", "§ " + num) +
|
||||
el_h2("style=\"font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1);min-width:0;word-break:break-word\"", title)
|
||||
)
|
||||
el_div("style=\"margin-bottom:3rem\"", header + body)
|
||||
}
|
||||
|
||||
fn p(text: String) -> String {
|
||||
return <p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">{raw(text)}</p>
|
||||
fn et_p(text: String) -> String {
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem\"", text)
|
||||
}
|
||||
|
||||
fn p_last(text: String) -> String {
|
||||
return <p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">{raw(text)}</p>
|
||||
fn et_p_last(text: String) -> String {
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8\"", text)
|
||||
}
|
||||
|
||||
fn p_caps(text: String) -> String {
|
||||
return <p style="font-family:var(--body);font-size:0.875rem;font-weight:600;color:var(--t1);line-height:1.7;margin-bottom:1rem">{raw(text)}</p>
|
||||
fn et_p_caps(text: String) -> String {
|
||||
el_p("style=\"font-family:var(--body);font-size:0.875rem;font-weight:600;color:var(--t1);line-height:1.7;margin-bottom:1rem\"", text)
|
||||
}
|
||||
|
||||
fn enterprise_terms_sections_1_4() -> String {
|
||||
et_section("1", "Parties and Scope",
|
||||
et_p("This Enterprise Agreement ("Agreement") is between Neuron, LLC ("Neuron") and the organization entering into an enterprise relationship ("Customer"). It governs all enterprise deployments, including Team, Enterprise, and Private Cloud tiers.") +
|
||||
et_p_last("This Agreement supplements the Neuron Terms of Service. In the event of conflict, this Agreement controls for enterprise use. The parties are bound by the Order Form executed at time of deployment, which specifies tier, seat count, term, and pricing.")
|
||||
) +
|
||||
et_section("2", "License Grant and Usage Rights",
|
||||
et_p("Subject to the terms of this Agreement and timely payment of fees, Neuron grants Customer a limited, non-exclusive, non-transferable, non-sublicensable license to deploy and use the Neuron platform ("Software") solely for Customer's internal business purposes during the Term.") +
|
||||
et_p("The license is scoped to the number of authorized seats, devices, or instances specified in the Order Form. Customer may not exceed the licensed scope without executing a seat expansion. Neuron will not invoice retroactively for inadvertent overage of fewer than 10% of contracted seats if Customer notifies Neuron and brings usage into compliance within 30 days.") +
|
||||
et_p_last("Customer may not: (a) sublicense, resell, or distribute the Software to third parties; (b) reverse engineer, decompile, or attempt to extract source code or trained model weights; (c) use the Software to build a competing product; or (d) remove or obscure any proprietary notices. Private Cloud deployments may be deployed to Customer's infrastructure but may not be transferred or made available to entities other than Customer's own employees and contractors under appropriate confidentiality obligations.")
|
||||
) +
|
||||
et_section("3", "Data and Privacy",
|
||||
et_p("Neuron's architecture is designed to minimize data exposure. In private cloud and air-gapped deployments, no data leaves Customer's infrastructure. Neuron has no access to Customer data in these configurations.") +
|
||||
et_p("In cloud-hosted deployments, Neuron processes Customer data solely to deliver the contracted services. Customer data is stored in an isolated tenant, is not commingled with other customers' data, and is not used for model training, analytics, or any purpose beyond service delivery. When Customer activates network features - including relay, peer-to-peer sync, or collaborative features - data required to operate those features may be transmitted to other network participants or Neuron infrastructure; such transmission is limited to the minimum required, excludes Customer's memory and conversation history unless Customer explicitly enables a sharing feature, and is used only to deliver the activated feature. Network features route data through Neuron's messaging backplane. That data is encrypted end-to-end - Neuron cannot read it - and is not stored or retained after transmission.") +
|
||||
et_p("Customer owns all data processed through the platform. Customer data is not Customer's data in the legal sense of the term as used in data processing frameworks - Customer is the controller. Neuron is the processor. Upon termination, Customer data is returned or destroyed within 30 days at Customer's election. We do not retain copies.") +
|
||||
et_p_last("Where required by applicable law, Neuron will execute a Data Processing Agreement (DPA) as a supplement to this Agreement. Contact enterprise@neurontechnologies.ai to initiate. Neuron will notify Customer within 72 hours of becoming aware of any confirmed breach affecting Customer data.")
|
||||
) +
|
||||
et_section("4", "Values Alignment",
|
||||
et_p("Neuron is built on the principle that AI should expand human capability, not replace it. We are selective about the organizations we work with.") +
|
||||
et_p("Customer represents that it does not intend to use Neuron primarily as a tool to eliminate employee positions, reduce headcount through automation in ways that harm workers, or otherwise use the platform in ways inconsistent with the welfare of the people who work in Customer's organization.") +
|
||||
et_p("Neuron reserves the right to decline, not renew, or terminate any enterprise agreement where Neuron determines, in its reasonable judgment, that the Customer's use of the platform is fundamentally misaligned with these principles. Termination under this section is subject to the notice and cure provisions of § 10.") +
|
||||
et_p_last("We will not enter into agreements with organizations whose primary business model, as Neuron determines in good faith, depends on practices that systematically harm workers, small businesses, or communities. This is not a standard clause in most software agreements. We mean it.")
|
||||
)
|
||||
}
|
||||
|
||||
fn enterprise_terms_sections_5_8() -> String {
|
||||
et_section("5", "Service Levels and Support",
|
||||
et_p("For cloud-hosted deployments, Neuron targets 99.9% monthly uptime, excluding scheduled maintenance windows (communicated at least 48 hours in advance) and circumstances outside Neuron's reasonable control. In the event Neuron fails to meet this target in a given calendar month, Customer may request a service credit equal to 5% of that month's fees for each full percentage point of availability below the target, up to a maximum of 30% of monthly fees. Credits are the sole and exclusive remedy for availability failures.") +
|
||||
et_p("For on-premises and private cloud deployments, Customer is responsible for infrastructure availability. Neuron's SLA obligations apply only to software defects in the distributed build, not to Customer's infrastructure choices.") +
|
||||
et_p_last("Support is provided by email at enterprise@neurontechnologies.ai. Neuron will acknowledge critical issues (complete service outage or data loss risk) within 4 business hours and provide a status update within 24 hours. Standard issues are acknowledged within 2 business days. Neuron does not guarantee resolution timelines for issues requiring platform changes.")
|
||||
) +
|
||||
et_section("6", "Security and Compliance",
|
||||
et_p("Neuron implements security controls commensurate with enterprise software handling sensitive user data. These include: encryption in transit (TLS 1.2+) and at rest for cloud-hosted services; role-based access controls; audit logging at the infrastructure layer; and regular internal security reviews.") +
|
||||
et_p("Neuron will pursue SOC 2 Type II certification and will provide Customer with the most recent available report upon request under a signed NDA. Until certification is achieved, Neuron will make available a written summary of security controls upon request.") +
|
||||
et_p_last("Customer is responsible for: (a) maintaining the security of credentials and API keys used to access the platform; (b) configuring access controls for Customer's own users; (c) compliance with applicable law with respect to the data Customer chooses to input into the platform; and (d) conducting its own security evaluation appropriate to its risk profile before deployment in regulated environments.")
|
||||
) +
|
||||
et_section("7", "Confidentiality",
|
||||
et_p("Each party ("Receiving Party") agrees to protect the other party's ("Disclosing Party") Confidential Information with the same degree of care it uses to protect its own confidential information, but no less than reasonable care. "Confidential Information" means any non-public information disclosed by the Disclosing Party that is designated as confidential or that reasonably should be understood to be confidential given the nature of the information and circumstances of disclosure.") +
|
||||
et_p("Confidential Information does not include information that: (a) becomes publicly known through no breach by the Receiving Party; (b) was already known to the Receiving Party before disclosure; (c) is received from a third party without restriction; or (d) was independently developed by the Receiving Party without use of the Confidential Information.") +
|
||||
et_p_last("These obligations survive termination of this Agreement for three years. Receiving Party may disclose Confidential Information to the extent required by law or court order, provided that Receiving Party gives Disclosing Party prompt written notice and cooperates with any effort to obtain a protective order.")
|
||||
) +
|
||||
et_section("8", "Intellectual Property",
|
||||
et_p("Neuron retains all right, title, and interest in and to the Software, including all improvements, updates, and derivative works, and all intellectual property rights therein. No title to or ownership of the Software transfers to Customer under this Agreement.") +
|
||||
et_p("Customer retains all right, title, and interest in and to Customer's data, including inputs, memorys, and outputs generated through Customer's use of the platform. Neuron does not claim ownership of Customer's outputs. Customer is responsible for evaluating the accuracy and appropriateness of outputs before relying on them.") +
|
||||
et_p_last("This Agreement does not grant Customer any right to use Neuron's trademarks, trade names, or logos except as expressly authorized in writing. Neuron Aligned Partner certification (§ 14) includes a limited right to use the partner designation as specified in the Partner Addendum.")
|
||||
)
|
||||
}
|
||||
|
||||
fn enterprise_terms_sections_9_15() -> String {
|
||||
et_section("9", "Indemnification",
|
||||
et_p("Neuron will defend Customer against third-party claims that the Software, as provided by Neuron and used in accordance with this Agreement, infringes a valid patent, copyright, or trademark, and will indemnify Customer for damages finally awarded in such a proceeding or agreed in settlement. This obligation does not apply to claims arising from: (a) Customer's modification of the Software; (b) Customer's combination of the Software with third-party products or data not provided by Neuron; or (c) Customer's use of the Software in violation of this Agreement.") +
|
||||
et_p_last("Customer will defend Neuron against third-party claims arising from Customer's use of the platform in violation of applicable law, this Agreement, or the rights of third parties, and will indemnify Neuron for damages finally awarded or agreed in settlement. Each party must promptly notify the other of any claim for which indemnification may be sought and must cooperate reasonably in the defense.")
|
||||
) +
|
||||
et_section("10", "Term and Termination",
|
||||
et_p("This Agreement begins on the Effective Date specified in the Order Form and continues for the initial term stated therein, typically twelve months. Unless either party provides written notice of non-renewal at least 30 days before the end of the then-current term, this Agreement automatically renews for successive one-year terms at the pricing in effect at renewal.") +
|
||||
et_p("Either party may terminate this Agreement for material breach upon 30 days' written notice if the breach remains uncured at the end of that period. Neuron may terminate immediately upon written notice if Customer breaches § 2 (unauthorized use of the Software) or § 7 (confidentiality obligations).") +
|
||||
et_p("Neuron may terminate this Agreement under § 4 (Values Alignment) with 60 days' written notice if Neuron determines in good faith that Customer's use of the platform is materially and persistently misaligned with the principles stated therein. Neuron will provide Customer the opportunity to respond and demonstrate alignment before termination takes effect.") +
|
||||
et_p_last("Upon termination: (a) all licenses immediately terminate; (b) Customer must cease use of the Software; (c) each party will return or destroy the other's Confidential Information upon request; and (d) Neuron will make Customer's data available for export for 30 days, after which it will be destroyed. Sections 3 (data ownership and destruction), 7 (confidentiality), 8 (intellectual property), 9 (indemnification), 11 (limitation of liability), and 13 (governing law) survive termination.")
|
||||
) +
|
||||
et_section("11", "Limitation of Liability",
|
||||
et_p_caps("NEURON'S TOTAL LIABILITY UNDER THIS AGREEMENT SHALL NOT EXCEED THE FEES PAID BY CUSTOMER IN THE TWELVE MONTHS PRECEDING THE CLAIM.") +
|
||||
et_p_caps("NEITHER PARTY SHALL BE LIABLE FOR INDIRECT, INCIDENTAL, SPECIAL, CONSEQUENTIAL, OR PUNITIVE DAMAGES, EVEN IF ADVISED OF THEIR POSSIBILITY.") +
|
||||
et_p_last("These limitations do not apply to: (a) Customer's payment obligations; (b) breaches of § 7 (confidentiality); (c) a party's indemnification obligations under § 9; or (d) a party's gross negligence or willful misconduct.")
|
||||
) +
|
||||
et_section("12", "Warranties and Disclaimers",
|
||||
et_p("Neuron warrants that: (a) the Software will perform materially in accordance with its published documentation during the Term; (b) Neuron has the authority to enter into this Agreement and grant the licenses herein; and (c) to Neuron's knowledge, the Software does not knowingly infringe any third-party intellectual property rights.") +
|
||||
et_p("Customer's exclusive remedy for a warranty breach under (a) is for Neuron to use commercially reasonable efforts to correct the non-conformity, or if correction is not commercially practicable within 30 days, to terminate the Agreement and receive a pro-rata refund of prepaid fees for the unused portion of the Term.") +
|
||||
et_p_caps("EXCEPT AS EXPRESSLY SET FORTH IN THIS SECTION, THE SOFTWARE IS PROVIDED "AS IS." NEURON DISCLAIMS ALL OTHER WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT.") +
|
||||
et_p_last("AI-generated outputs are probabilistic and may be inaccurate, incomplete, or inappropriate for specific contexts. Customer is responsible for reviewing outputs before relying on them for any consequential decision. Neuron does not warrant that outputs will be accurate, complete, or suitable for any particular purpose.")
|
||||
) +
|
||||
et_section("13", "Governing Law and Disputes",
|
||||
et_p("This Agreement is governed by the laws of the State of Delaware, without regard to conflict of law principles.") +
|
||||
et_p_last("The parties agree to attempt to resolve disputes through good-faith negotiation before initiating formal proceedings. If negotiation fails within 30 days of written notice of the dispute, disputes shall be resolved by binding arbitration under AAA Commercial Arbitration Rules in Wilmington, Delaware, except that either party may seek injunctive relief in court for IP or confidentiality violations without first arbitrating.")
|
||||
) +
|
||||
et_section("15", "General Provisions",
|
||||
et_p("This Agreement, together with the Order Form and any addenda, constitutes the entire agreement between the parties with respect to its subject matter and supersedes all prior negotiations, representations, and agreements. Any amendment must be in writing and signed by authorized representatives of both parties.") +
|
||||
et_p("If any provision of this Agreement is found unenforceable, it will be modified to the minimum extent necessary to make it enforceable, and the remaining provisions will continue in full force. Failure to enforce any provision is not a waiver of the right to enforce it later.") +
|
||||
et_p("Neither party may assign this Agreement without the other's written consent, except that Neuron may assign to an acquirer of all or substantially all of its business or assets without consent, provided the acquirer assumes all obligations under this Agreement.") +
|
||||
et_p_last("Notices must be in writing and sent to enterprise@neurontechnologies.ai for Neuron, or to the email address specified in the Order Form for Customer. Notices are effective on the day of confirmed receipt.")
|
||||
)
|
||||
}
|
||||
|
||||
fn enterprise_partner_section() -> String {
|
||||
let section_header: String = el_div(
|
||||
"style=\"display:flex;align-items:baseline;flex-wrap:wrap;gap:0.5rem 1rem;margin-bottom:1.25rem;border-bottom:1px solid rgba(0,82,160,.20);padding-bottom:0.75rem\"",
|
||||
el_span("style=\"font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65);flex-shrink:0\"", "§ 14") +
|
||||
el_h2("style=\"font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1);min-width:0;word-break:break-word\"", "Neuron Aligned Partner Program")
|
||||
)
|
||||
|
||||
let cert_quote: String = el_div(
|
||||
"style=\"margin:1.5rem 0;padding:1.25rem 1.5rem;border-left:3px solid var(--navy);background:rgba(0,82,160,.04);box-sizing:border-box\"",
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);line-height:1.8;font-style:italic\"",
|
||||
""We are deploying Neuron to make our people more capable, not to eliminate them. Reducing headcount is not a primary objective of this deployment. We commit to using this technology in a manner consistent with the welfare of our workforce, and we will notify Neuron if our intentions change in ways that materially contradict this commitment.""
|
||||
)
|
||||
)
|
||||
|
||||
let benefits_list: String = el_ul(
|
||||
"style=\"font-family:var(--body);font-weight:300;font-size:0.9rem;color:var(--t2);line-height:1.8;padding-left:1.25rem;margin-bottom:1.5rem\"",
|
||||
el_li("style=\"margin-bottom:0.4rem\"", "Preferential per-seat pricing - specific discount terms are disclosed at the time of certification and reflected in the Order Form") +
|
||||
el_li("style=\"margin-bottom:0.4rem\"", "Membership in the Neuron Aligned Partner Network, a private community of organizations that have made the same commitment") +
|
||||
el_li("style=\"margin-bottom:0.4rem\"", "Optional public listing as a Neuron Aligned Partner - a signal to employees and the market that AI is being used to expand human capability, not eliminate it") +
|
||||
el_li("style=\"margin-bottom:0.4rem\"", "Priority consideration in the enterprise roadmap - Aligned Partners are given more weight in feature prioritization and deployment planning") +
|
||||
el_li("", "Direct access to Neuron leadership for roadmap input and partnership discussions")
|
||||
)
|
||||
|
||||
el_div(
|
||||
"style=\"margin-bottom:3rem;padding:clamp(1.25rem,4vw,2rem) clamp(1rem,4vw,2.25rem);border:1.5px solid rgba(0,82,160,.35);background:rgba(0,82,160,.03);box-sizing:border-box\"",
|
||||
section_header +
|
||||
et_p("Participation in the Neuron Aligned Partner Program is entirely voluntary. No enterprise customer is required to participate, and the standard enterprise relationship under this Agreement is not conditioned on it.") +
|
||||
et_p("An organization that chooses to participate executes a Neuron Aligned Partner Addendum ("Partner Addendum"), a separate document supplementing this Agreement. In the Partner Addendum, Customer makes the following certification:") +
|
||||
cert_quote +
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.9rem;color:var(--t1);line-height:1.6;margin-bottom:0.75rem\"", "Partners who execute the Partner Addendum receive:") +
|
||||
benefits_list +
|
||||
et_p("The certification is self-attested and made in good faith. Neuron does not audit deployment usage to verify the commitment, but relies on the integrity of the partner's representation. If Neuron determines, based on credible evidence, that a partner's use of the platform is materially inconsistent with the certification, Neuron may revoke partner status with 30 days' notice and adjust pricing to standard enterprise rates at the next renewal.") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t3);line-height:1.8\"",
|
||||
"To inquire about the Partner Program, contact enterprise@neurontechnologies.ai with subject line "Aligned Partner.""
|
||||
)
|
||||
)
|
||||
}
|
||||
|
||||
fn enterprise_terms_body() -> String {
|
||||
return {nav()}
|
||||
<div style="max-width:720px;margin:0 auto;padding:6rem clamp(1rem,5vw,2.5rem) 8rem;box-sizing:border-box;overflow-wrap:break-word;word-break:break-word">
|
||||
<div style="margin-bottom:3rem">
|
||||
<a href="/" style="font-family:var(--body);font-size:0.75rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy);text-decoration:none">← Neuron</a>
|
||||
</div>
|
||||
<div style="margin-bottom:4rem;border-bottom:1px solid var(--border);padding-bottom:3rem">
|
||||
<p class="label" style="margin-bottom:1rem">Legal</p>
|
||||
<h1 style="font-family:var(--head);font-size:clamp(2rem,4vw,3rem);font-weight:600;color:var(--t1);margin-bottom:0.75rem;line-height:1.1">Enterprise Agreement</h1>
|
||||
<p style="font-family:var(--body);font-size:0.875rem;color:var(--t3)">Effective May 1, 2026 · Neuron, LLC</p>
|
||||
</div>
|
||||
let back_link: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
el_a("/", "style=\"font-family:var(--body);font-size:0.75rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy);text-decoration:none\"", "← Neuron")
|
||||
)
|
||||
|
||||
{raw(section("1", "Parties and Scope",
|
||||
p("This Enterprise Agreement ("Agreement") is between Neuron, LLC ("Neuron") and the organization entering into an enterprise relationship ("Customer"). It governs all enterprise deployments, including Team, Enterprise, and Private Cloud tiers.")
|
||||
+ p_last("This Agreement supplements the Neuron Terms of Service. In the event of conflict, this Agreement controls for enterprise use. The parties are bound by the Order Form executed at time of deployment, which specifies tier, seat count, term, and pricing.")
|
||||
))}
|
||||
{raw(section("2", "License Grant and Usage Rights",
|
||||
p("Subject to the terms of this Agreement and timely payment of fees, Neuron grants Customer a limited, non-exclusive, non-transferable, non-sublicensable license to deploy and use the Neuron platform ("Software") solely for Customer's internal business purposes during the Term.")
|
||||
+ p("The license is scoped to the number of authorized seats, devices, or instances specified in the Order Form. Customer may not exceed the licensed scope without executing a seat expansion. Neuron will not invoice retroactively for inadvertent overage of fewer than 10% of contracted seats if Customer notifies Neuron and brings usage into compliance within 30 days.")
|
||||
+ p_last("Customer may not: (a) sublicense, resell, or distribute the Software to third parties; (b) reverse engineer, decompile, or attempt to extract source code or trained model weights; (c) use the Software to build a competing product; or (d) remove or obscure any proprietary notices. Private Cloud deployments may be deployed to Customer's infrastructure but may not be transferred or made available to entities other than Customer's own employees and contractors under appropriate confidentiality obligations.")
|
||||
))}
|
||||
{raw(section("3", "Data and Privacy",
|
||||
p("Neuron's architecture is designed to minimize data exposure. In private cloud and air-gapped deployments, no data leaves Customer's infrastructure. Neuron has no access to Customer data in these configurations.")
|
||||
+ p("In cloud-hosted deployments, Neuron processes Customer data solely to deliver the contracted services. Customer data is stored in an isolated tenant, is not commingled with other customers' data, and is not used for model training, analytics, or any purpose beyond service delivery. When Customer activates network features - including relay, peer-to-peer sync, or collaborative features - data required to operate those features may be transmitted to other network participants or Neuron infrastructure; such transmission is limited to the minimum required, excludes Customer's memory and conversation history unless Customer explicitly enables a sharing feature, and is used only to deliver the activated feature. Network features route data through Neuron's messaging backplane. That data is encrypted end-to-end - Neuron cannot read it - and is not stored or retained after transmission.")
|
||||
+ p("Customer owns all data processed through the platform. Customer data is not Customer's data in the legal sense of the term as used in data processing frameworks - Customer is the controller. Neuron is the processor. Upon termination, Customer data is returned or destroyed within 30 days at Customer's election. We do not retain copies.")
|
||||
+ p_last("Where required by applicable law, Neuron will execute a Data Processing Agreement (DPA) as a supplement to this Agreement. Contact enterprise@neurontechnologies.ai to initiate. Neuron will notify Customer within 72 hours of becoming aware of any confirmed breach affecting Customer data.")
|
||||
))}
|
||||
{raw(section("4", "Values Alignment",
|
||||
p("Neuron is built on the principle that AI should expand human capability, not replace it. We are selective about the organizations we work with.")
|
||||
+ p("Customer represents that it does not intend to use Neuron primarily as a tool to eliminate employee positions, reduce headcount through automation in ways that harm workers, or otherwise use the platform in ways inconsistent with the welfare of the people who work in Customer's organization.")
|
||||
+ p("Neuron reserves the right to decline, not renew, or terminate any enterprise agreement where Neuron determines, in its reasonable judgment, that the Customer's use of the platform is fundamentally misaligned with these principles. Termination under this section is subject to the notice and cure provisions of § 10.")
|
||||
+ p_last("We will not enter into agreements with organizations whose primary business model, as Neuron determines in good faith, depends on practices that systematically harm workers, small businesses, or communities. This is not a standard clause in most software agreements. We mean it.")
|
||||
))}
|
||||
{raw(section("5", "Service Levels and Support",
|
||||
p("For cloud-hosted deployments, Neuron targets 99.9% monthly uptime, excluding scheduled maintenance windows (communicated at least 48 hours in advance) and circumstances outside Neuron's reasonable control. In the event Neuron fails to meet this target in a given calendar month, Customer may request a service credit equal to 5% of that month's fees for each full percentage point of availability below the target, up to a maximum of 30% of monthly fees. Credits are the sole and exclusive remedy for availability failures.")
|
||||
+ p("For on-premises and private cloud deployments, Customer is responsible for infrastructure availability. Neuron's SLA obligations apply only to software defects in the distributed build, not to Customer's infrastructure choices.")
|
||||
+ p_last("Support is provided by email at enterprise@neurontechnologies.ai. Neuron will acknowledge critical issues (complete service outage or data loss risk) within 4 business hours and provide a status update within 24 hours. Standard issues are acknowledged within 2 business days. Neuron does not guarantee resolution timelines for issues requiring platform changes.")
|
||||
))}
|
||||
{raw(section("6", "Security and Compliance",
|
||||
p("Neuron implements security controls commensurate with enterprise software handling sensitive user data. These include: encryption in transit (TLS 1.2+) and at rest for cloud-hosted services; role-based access controls; audit logging at the infrastructure layer; and regular internal security reviews.")
|
||||
+ p("Neuron will pursue SOC 2 Type II certification and will provide Customer with the most recent available report upon request under a signed NDA. Until certification is achieved, Neuron will make available a written summary of security controls upon request.")
|
||||
+ p_last("Customer is responsible for: (a) maintaining the security of credentials and API keys used to access the platform; (b) configuring access controls for Customer's own users; (c) compliance with applicable law with respect to the data Customer chooses to input into the platform; and (d) conducting its own security evaluation appropriate to its risk profile before deployment in regulated environments.")
|
||||
))}
|
||||
{raw(section("7", "Confidentiality",
|
||||
p("Each party ("Receiving Party") agrees to protect the other party's ("Disclosing Party") Confidential Information with the same degree of care it uses to protect its own confidential information, but no less than reasonable care. "Confidential Information" means any non-public information disclosed by the Disclosing Party that is designated as confidential or that reasonably should be understood to be confidential given the nature of the information and circumstances of disclosure.")
|
||||
+ p("Confidential Information does not include information that: (a) becomes publicly known through no breach by the Receiving Party; (b) was already known to the Receiving Party before disclosure; (c) is received from a third party without restriction; or (d) was independently developed by the Receiving Party without use of the Confidential Information.")
|
||||
+ p_last("These obligations survive termination of this Agreement for three years. Receiving Party may disclose Confidential Information to the extent required by law or court order, provided that Receiving Party gives Disclosing Party prompt written notice and cooperates with any effort to obtain a protective order.")
|
||||
))}
|
||||
{raw(section("8", "Intellectual Property",
|
||||
p("Neuron retains all right, title, and interest in and to the Software, including all improvements, updates, and derivative works, and all intellectual property rights therein. No title to or ownership of the Software transfers to Customer under this Agreement.")
|
||||
+ p("Customer retains all right, title, and interest in and to Customer's data, including inputs, memorys, and outputs generated through Customer's use of the platform. Neuron does not claim ownership of Customer's outputs. Customer is responsible for evaluating the accuracy and appropriateness of outputs before relying on them.")
|
||||
+ p_last("This Agreement does not grant Customer any right to use Neuron's trademarks, trade names, or logos except as expressly authorized in writing. Neuron Aligned Partner certification (§ 14) includes a limited right to use the partner designation as specified in the Partner Addendum.")
|
||||
))}
|
||||
{raw(section("9", "Indemnification",
|
||||
p("Neuron will defend Customer against third-party claims that the Software, as provided by Neuron and used in accordance with this Agreement, infringes a valid patent, copyright, or trademark, and will indemnify Customer for damages finally awarded in such a proceeding or agreed in settlement. This obligation does not apply to claims arising from: (a) Customer's modification of the Software; (b) Customer's combination of the Software with third-party products or data not provided by Neuron; or (c) Customer's use of the Software in violation of this Agreement.")
|
||||
+ p_last("Customer will defend Neuron against third-party claims arising from Customer's use of the platform in violation of applicable law, this Agreement, or the rights of third parties, and will indemnify Neuron for damages finally awarded or agreed in settlement. Each party must promptly notify the other of any claim for which indemnification may be sought and must cooperate reasonably in the defense.")
|
||||
))}
|
||||
{raw(section("10", "Term and Termination",
|
||||
p("This Agreement begins on the Effective Date specified in the Order Form and continues for the initial term stated therein, typically twelve months. Unless either party provides written notice of non-renewal at least 30 days before the end of the then-current term, this Agreement automatically renews for successive one-year terms at the pricing in effect at renewal.")
|
||||
+ p("Either party may terminate this Agreement for material breach upon 30 days' written notice if the breach remains uncured at the end of that period. Neuron may terminate immediately upon written notice if Customer breaches § 2 (unauthorized use of the Software) or § 7 (confidentiality obligations).")
|
||||
+ p("Neuron may terminate this Agreement under § 4 (Values Alignment) with 60 days' written notice if Neuron determines in good faith that Customer's use of the platform is materially and persistently misaligned with the principles stated therein. Neuron will provide Customer the opportunity to respond and demonstrate alignment before termination takes effect.")
|
||||
+ p_last("Upon termination: (a) all licenses immediately terminate; (b) Customer must cease use of the Software; (c) each party will return or destroy the other's Confidential Information upon request; and (d) Neuron will make Customer's data available for export for 30 days, after which it will be destroyed. Sections 3 (data ownership and destruction), 7 (confidentiality), 8 (intellectual property), 9 (indemnification), 11 (limitation of liability), and 13 (governing law) survive termination.")
|
||||
))}
|
||||
{raw(section("11", "Limitation of Liability",
|
||||
p_caps("NEURON'S TOTAL LIABILITY UNDER THIS AGREEMENT SHALL NOT EXCEED THE FEES PAID BY CUSTOMER IN THE TWELVE MONTHS PRECEDING THE CLAIM.")
|
||||
+ p_caps("NEITHER PARTY SHALL BE LIABLE FOR INDIRECT, INCIDENTAL, SPECIAL, CONSEQUENTIAL, OR PUNITIVE DAMAGES, EVEN IF ADVISED OF THEIR POSSIBILITY.")
|
||||
+ p_last("These limitations do not apply to: (a) Customer's payment obligations; (b) breaches of § 7 (confidentiality); (c) a party's indemnification obligations under § 9; or (d) a party's gross negligence or willful misconduct.")
|
||||
))}
|
||||
{raw(section("12", "Warranties and Disclaimers",
|
||||
p("Neuron warrants that: (a) the Software will perform materially in accordance with its published documentation during the Term; (b) Neuron has the authority to enter into this Agreement and grant the licenses herein; and (c) to Neuron's knowledge, the Software does not knowingly infringe any third-party intellectual property rights.")
|
||||
+ p("Customer's exclusive remedy for a warranty breach under (a) is for Neuron to use commercially reasonable efforts to correct the non-conformity, or if correction is not commercially practicable within 30 days, to terminate the Agreement and receive a pro-rata refund of prepaid fees for the unused portion of the Term.")
|
||||
+ p_caps("EXCEPT AS EXPRESSLY SET FORTH IN THIS SECTION, THE SOFTWARE IS PROVIDED "AS IS." NEURON DISCLAIMS ALL OTHER WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT.")
|
||||
+ p_last("AI-generated outputs are probabilistic and may be inaccurate, incomplete, or inappropriate for specific contexts. Customer is responsible for reviewing outputs before relying on them for any consequential decision. Neuron does not warrant that outputs will be accurate, complete, or suitable for any particular purpose.")
|
||||
))}
|
||||
{raw(section("13", "Governing Law and Disputes",
|
||||
p("This Agreement is governed by the laws of the State of Delaware, without regard to conflict of law principles.")
|
||||
+ p_last("The parties agree to attempt to resolve disputes through good-faith negotiation before initiating formal proceedings. If negotiation fails within 30 days of written notice of the dispute, disputes shall be resolved by binding arbitration under AAA Commercial Arbitration Rules in Wilmington, Delaware, except that either party may seek injunctive relief in court for IP or confidentiality violations without first arbitrating.")
|
||||
))}
|
||||
let page_header: String = el_div(
|
||||
"style=\"margin-bottom:4rem;border-bottom:1px solid var(--border);padding-bottom:3rem\"",
|
||||
el_p("class=\"label\" style=\"margin-bottom:1rem\"", "Legal") +
|
||||
el_h1("style=\"font-family:var(--head);font-size:clamp(2rem,4vw,3rem);font-weight:600;color:var(--t1);margin-bottom:0.75rem;line-height:1.1\"", "Enterprise Agreement") +
|
||||
el_p("style=\"font-family:var(--body);font-size:0.875rem;color:var(--t3)\"", "Effective May 1, 2026 · Neuron, LLC")
|
||||
)
|
||||
|
||||
<!-- Neuron Aligned Partner Program - highlighted section -->
|
||||
<div style="margin-bottom:3rem;padding:clamp(1.25rem,4vw,2rem) clamp(1rem,4vw,2.25rem);border:1.5px solid rgba(0,82,160,.35);background:rgba(0,82,160,.03);box-sizing:border-box">
|
||||
<div style="display:flex;align-items:baseline;flex-wrap:wrap;gap:0.5rem 1rem;margin-bottom:1.25rem;border-bottom:1px solid rgba(0,82,160,.20);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65);flex-shrink:0">§ 14</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1);min-width:0;word-break:break-word">Neuron Aligned Partner Program</h2>
|
||||
</div>
|
||||
let footer_links: String = el_div(
|
||||
"style=\"margin-top:4rem;padding-top:2rem;border-top:1px solid var(--border);display:flex;gap:2rem;flex-wrap:wrap\"",
|
||||
el_a("/", "style=\"font-family:var(--body);font-size:0.8125rem;color:var(--navy);text-decoration:none\"", "← Home") +
|
||||
el_a("/legal/terms", "style=\"font-family:var(--body);font-size:0.8125rem;color:var(--navy);text-decoration:none\"", "Consumer Terms →")
|
||||
)
|
||||
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Participation in the Neuron Aligned Partner Program is entirely voluntary. No enterprise customer is required to participate, and the standard enterprise relationship under this Agreement is not conditioned on it.</p>
|
||||
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">An organization that chooses to participate executes a Neuron Aligned Partner Addendum ("Partner Addendum"), a separate document supplementing this Agreement. In the Partner Addendum, Customer makes the following certification:</p>
|
||||
|
||||
<div style="margin:1.5rem 0;padding:1.25rem 1.5rem;border-left:3px solid var(--navy);background:rgba(0,82,160,.04);box-sizing:border-box">
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);line-height:1.8;font-style:italic">"We are deploying Neuron to make our people more capable, not to eliminate them. Reducing headcount is not a primary objective of this deployment. We commit to using this technology in a manner consistent with the welfare of our workforce, and we will notify Neuron if our intentions change in ways that materially contradict this commitment."</p>
|
||||
</div>
|
||||
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.9rem;color:var(--t1);line-height:1.6;margin-bottom:0.75rem">Partners who execute the Partner Addendum receive:</p>
|
||||
<ul style="font-family:var(--body);font-weight:300;font-size:0.9rem;color:var(--t2);line-height:1.8;padding-left:1.25rem;margin-bottom:1.5rem">
|
||||
<li style="margin-bottom:0.4rem">Preferential per-seat pricing - specific discount terms are disclosed at the time of certification and reflected in the Order Form</li>
|
||||
<li style="margin-bottom:0.4rem">Membership in the Neuron Aligned Partner Network, a private community of organizations that have made the same commitment</li>
|
||||
<li style="margin-bottom:0.4rem">Optional public listing as a Neuron Aligned Partner - a signal to employees and the market that AI is being used to expand human capability, not eliminate it</li>
|
||||
<li style="margin-bottom:0.4rem">Priority consideration in the enterprise roadmap - Aligned Partners are given more weight in feature prioritization and deployment planning</li>
|
||||
<li>Direct access to Neuron leadership for roadmap input and partnership discussions</li>
|
||||
</ul>
|
||||
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">The certification is self-attested and made in good faith. Neuron does not audit deployment usage to verify the commitment, but relies on the integrity of the partner's representation. If Neuron determines, based on credible evidence, that a partner's use of the platform is materially inconsistent with the certification, Neuron may revoke partner status with 30 days' notice and adjust pricing to standard enterprise rates at the next renewal.</p>
|
||||
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t3);line-height:1.8">To inquire about the Partner Program, contact enterprise@neurontechnologies.ai with subject line "Aligned Partner."</p>
|
||||
</div>
|
||||
|
||||
{raw(section("15", "General Provisions",
|
||||
p("This Agreement, together with the Order Form and any addenda, constitutes the entire agreement between the parties with respect to its subject matter and supersedes all prior negotiations, representations, and agreements. Any amendment must be in writing and signed by authorized representatives of both parties.")
|
||||
+ p("If any provision of this Agreement is found unenforceable, it will be modified to the minimum extent necessary to make it enforceable, and the remaining provisions will continue in full force. Failure to enforce any provision is not a waiver of the right to enforce it later.")
|
||||
+ p("Neither party may assign this Agreement without the other's written consent, except that Neuron may assign to an acquirer of all or substantially all of its business or assets without consent, provided the acquirer assumes all obligations under this Agreement.")
|
||||
+ p_last("Notices must be in writing and sent to enterprise@neurontechnologies.ai for Neuron, or to the email address specified in the Order Form for Customer. Notices are effective on the day of confirmed receipt.")
|
||||
))}
|
||||
|
||||
<div style="margin-top:4rem;padding-top:2rem;border-top:1px solid var(--border);display:flex;gap:2rem;flex-wrap:wrap">
|
||||
<a href="/" style="font-family:var(--body);font-size:0.8125rem;color:var(--navy);text-decoration:none">← Home</a>
|
||||
<a href="/legal/terms" style="font-family:var(--body);font-size:0.8125rem;color:var(--navy);text-decoration:none">Consumer Terms →</a>
|
||||
</div>
|
||||
</div>
|
||||
nav() +
|
||||
el_div(
|
||||
"style=\"max-width:720px;margin:0 auto;padding:6rem clamp(1rem,5vw,2.5rem) 8rem;box-sizing:border-box;overflow-wrap:break-word;word-break:break-word\"",
|
||||
back_link +
|
||||
page_header +
|
||||
enterprise_terms_sections_1_4() +
|
||||
enterprise_terms_sections_5_8() +
|
||||
enterprise_terms_sections_9_15() +
|
||||
enterprise_partner_section() +
|
||||
footer_links
|
||||
)
|
||||
}
|
||||
|
||||
+95
-73
@@ -4,88 +4,110 @@
|
||||
// Not greenwashing - a structural argument. The benefit follows from the
|
||||
// architecture; it wasn't engineered as a feature, but it's real.
|
||||
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_input(type_attr: String, attrs: String) -> String
|
||||
extern fn el_br() -> String
|
||||
extern fn el_script_src(src: String, defer_load: Bool) -> String
|
||||
|
||||
fn environmental() -> String {
|
||||
return <section id="environmental" aria-label="Environmental impact" style="padding:8rem 2.5rem;background:var(--bg)">
|
||||
<div class="container-lg">
|
||||
let label_row: String = el_div(
|
||||
"style=\"display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem\"",
|
||||
el_div("class=\"navy-line-left\" style=\"width:3rem;flex-shrink:0\"", "") +
|
||||
el_span("class=\"label reveal\" style=\"color:var(--navy-85)\"", "Environmental impact")
|
||||
)
|
||||
|
||||
<div style="display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start" class="env-grid">
|
||||
let calculator: String = el_div(
|
||||
"class=\"reveal\" style=\"transition-delay:340ms;background:var(--card);border:1px solid rgba(0,82,160,.18);padding:2rem\"",
|
||||
el_p("style=\"font-family:var(--body);font-size:0.7rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--navy);margin-bottom:1.25rem\"", "Savings calculator") +
|
||||
el_p("style=\"font-family:var(--body);font-size:0.875rem;color:var(--t2);margin-bottom:1rem\"",
|
||||
"If you spend " +
|
||||
"<strong id=\"calc-spend\" style=\"color:var(--t1)\">$50</strong>" +
|
||||
"/month on AI…"
|
||||
) +
|
||||
el_input("range", "id=\"calc-slider\" min=\"10\" max=\"500\" step=\"10\" value=\"50\" style=\"width:100%;accent-color:var(--navy);margin-bottom:1.5rem\"") +
|
||||
el_div(
|
||||
"style=\"display:flex;align-items:baseline;gap:0.75rem;margin-bottom:0.375rem\"",
|
||||
el_span("id=\"calc-savings\" style=\"font-family:var(--head);font-size:2.5rem;font-weight:600;color:var(--navy)\"", "$240") +
|
||||
el_span("style=\"font-family:var(--body);font-size:0.7rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--t3)\"", "saved per year")
|
||||
) +
|
||||
el_p("style=\"font-family:var(--body);font-size:0.75rem;color:var(--t3)\"", "Based on estimated token reduction applied to your monthly spend.")
|
||||
)
|
||||
|
||||
<div>
|
||||
<div style="display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem">
|
||||
<div class="navy-line-left" style="width:3rem;flex-shrink:0"></div>
|
||||
<span class="label reveal" style="color:var(--navy-85)">Environmental impact</span>
|
||||
</div>
|
||||
let left_col: String = el_div(
|
||||
"",
|
||||
label_row +
|
||||
el_h2(
|
||||
"class=\"display-lg reveal\" style=\"transition-delay:80ms;margin-bottom:1.5rem\"",
|
||||
"Fewer tokens." + el_br() + el_span("class=\"gold\"", "Same work done.")
|
||||
) +
|
||||
el_p("class=\"reveal\" style=\"transition-delay:160ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:1.25rem\"",
|
||||
"Persistent context means shorter, more targeted prompts on every call. Less computation. Lower cost. A smaller footprint. This isn't a setting you toggle - it's what the architecture does by default."
|
||||
) +
|
||||
el_p("class=\"reveal\" style=\"transition-delay:220ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:1.25rem\"",
|
||||
"Every time you open ChatGPT and explain who you are again, that's computation that didn't need to happen. With Neuron, that context tax doesn't accumulate. Over months of use, the savings compound into a meaningful reduction in total compute - and a meaningful reduction in what you pay."
|
||||
) +
|
||||
el_p("class=\"reveal\" style=\"transition-delay:280ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:2.5rem\"",
|
||||
"This isn't a green marketing claim. It's a consequence of the design. The same architecture that makes Neuron better for you also makes it lighter on the planet."
|
||||
) +
|
||||
calculator +
|
||||
el_script_src("/js/environmental.js", true)
|
||||
)
|
||||
|
||||
<h2 class="display-lg reveal" style="transition-delay:80ms;margin-bottom:1.5rem">
|
||||
Fewer tokens.<br><span class="gold">Same work done.</span>
|
||||
</h2>
|
||||
let card1: String = el_div(
|
||||
"class=\"reveal card-dark\" style=\"transition-delay:100ms;padding:1.75rem 2rem;border-left:3px solid rgba(0,120,84,.40)\"",
|
||||
el_p("style=\"font-family:var(--body);font-size:0.7rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(0,120,84,.70);margin-bottom:0.75rem\"", "Local inference - coming") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem\"", "Your GPU, already powered on") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7\"",
|
||||
"The design: when you run inference locally via Ollama, your device's GPU handles it - hardware that's already consuming power. No data center spins up a cluster for your query. No round-trip. No idle servers waiting at scale. This is where we're headed."
|
||||
)
|
||||
)
|
||||
|
||||
<p class="reveal" style="transition-delay:160ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:1.25rem">
|
||||
Persistent context means shorter, more targeted prompts on every call. Less computation. Lower cost. A smaller footprint. This isn't a setting you toggle - it's what the architecture does by default.
|
||||
</p>
|
||||
let card2: String = el_div(
|
||||
"class=\"reveal card-dark\" style=\"transition-delay:200ms;padding:1.75rem 2rem;border-left:3px solid rgba(0,120,84,.40)\"",
|
||||
el_p("style=\"font-family:var(--body);font-size:0.7rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(0,120,84,.70);margin-bottom:0.75rem\"", "No database server for your data") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem\"", "On-device storage") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7\"",
|
||||
"Your context lives on your device in a purpose-built local storage layer. No cloud database servers running 24/7 to store and serve your conversations. No replication across availability zones. Just your device."
|
||||
)
|
||||
)
|
||||
|
||||
<p class="reveal" style="transition-delay:220ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:1.25rem">
|
||||
Every time you open ChatGPT and explain who you are again, that's computation that didn't need to happen. With Neuron, that context tax doesn't accumulate. Over months of use, the savings compound into a meaningful reduction in total compute - and a meaningful reduction in what you pay.
|
||||
</p>
|
||||
let card3: String = el_div(
|
||||
"class=\"reveal card-dark\" style=\"transition-delay:300ms;padding:1.75rem 2rem;border-left:3px solid rgba(0,120,84,.40)\"",
|
||||
el_p("style=\"font-family:var(--body);font-size:0.7rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(0,120,84,.70);margin-bottom:0.75rem\"", "Persistent context = less recomputation") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem\"", "No re-explaining. No wasted tokens.") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7\"",
|
||||
"Neuron surfaces exactly what's relevant for each conversation - no re-deriving who you are from long histories. Shorter, more targeted prompts. More with less."
|
||||
)
|
||||
)
|
||||
|
||||
<p class="reveal" style="transition-delay:280ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:2.5rem">
|
||||
This isn't a green marketing claim. It's a consequence of the design. The same architecture that makes Neuron better for you also makes it lighter on the planet.
|
||||
</p>
|
||||
let honest: String = el_div(
|
||||
"class=\"reveal\" style=\"transition-delay:400ms;padding:1.25rem 1.75rem;background:rgba(0,0,0,.03);border:1px solid rgba(0,0,0,.07);border-radius:2px\"",
|
||||
el_p("style=\"font-family:var(--body);font-size:0.8125rem;font-weight:300;color:var(--t3);line-height:1.7\"",
|
||||
"<strong style=\"font-weight:500;color:var(--t2)\">The honest picture:</strong>" +
|
||||
" When you use Neuron with BYOK providers (OpenAI, Anthropic, Grok) or Neuron Inference, those queries travel to inference servers - that footprint exists. The savings come from the architecture: persistent memory and local-first design reduce the total computation required to get the same work done."
|
||||
)
|
||||
)
|
||||
|
||||
<div class="reveal" style="transition-delay:340ms;background:var(--card);border:1px solid rgba(0,82,160,.18);padding:2rem">
|
||||
<p style="font-family:var(--body);font-size:0.7rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:var(--navy);margin-bottom:1.25rem">Savings calculator</p>
|
||||
<p style="font-family:var(--body);font-size:0.875rem;color:var(--t2);margin-bottom:1rem">If you spend <strong id="calc-spend" style="color:var(--t1)">$50</strong>/month on AI…</p>
|
||||
<input type="range" id="calc-slider" min="10" max="500" step="10" value="50" style="width:100%;accent-color:var(--navy);margin-bottom:1.5rem">
|
||||
<div style="display:flex;align-items:baseline;gap:0.75rem;margin-bottom:0.375rem">
|
||||
<span id="calc-savings" style="font-family:var(--head);font-size:2.5rem;font-weight:600;color:var(--navy)">$240</span>
|
||||
<span style="font-family:var(--body);font-size:0.7rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--t3)">saved per year</span>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-size:0.75rem;color:var(--t3)">Based on estimated token reduction applied to your monthly spend.</p>
|
||||
</div>
|
||||
let right_col: String = el_div(
|
||||
"style=\"display:flex;flex-direction:column;gap:1.5rem;padding-top:1rem\"",
|
||||
card1 + card2 + card3 + honest
|
||||
)
|
||||
|
||||
<script src="/js/environmental.js" defer></script>
|
||||
</div>
|
||||
let grid: String = el_div(
|
||||
"style=\"display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start\" class=\"env-grid\"",
|
||||
left_col + right_col
|
||||
)
|
||||
|
||||
<div style="display:flex;flex-direction:column;gap:1.5rem;padding-top:1rem">
|
||||
|
||||
<div class="reveal card-dark" style="transition-delay:100ms;padding:1.75rem 2rem;border-left:3px solid rgba(0,120,84,.40)">
|
||||
<p style="font-family:var(--body);font-size:0.7rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(0,120,84,.70);margin-bottom:0.75rem">Local inference - coming</p>
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem">Your GPU, already powered on</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7">
|
||||
The design: when you run inference locally via Ollama, your device's GPU handles it - hardware that's already consuming power. No data center spins up a cluster for your query. No round-trip. No idle servers waiting at scale. This is where we're headed.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<div class="reveal card-dark" style="transition-delay:200ms;padding:1.75rem 2rem;border-left:3px solid rgba(0,120,84,.40)">
|
||||
<p style="font-family:var(--body);font-size:0.7rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(0,120,84,.70);margin-bottom:0.75rem">No database server for your data</p>
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem">On-device storage</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7">
|
||||
Your context lives on your device in a purpose-built local storage layer. No cloud database servers running 24/7 to store and serve your conversations. No replication across availability zones. Just your device.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<div class="reveal card-dark" style="transition-delay:300ms;padding:1.75rem 2rem;border-left:3px solid rgba(0,120,84,.40)">
|
||||
<p style="font-family:var(--body);font-size:0.7rem;font-weight:600;letter-spacing:0.18em;text-transform:uppercase;color:rgba(0,120,84,.70);margin-bottom:0.75rem">Persistent context = less recomputation</p>
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem">No re-explaining. No wasted tokens.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7">
|
||||
Neuron surfaces exactly what's relevant for each conversation - no re-deriving who you are from long histories. Shorter, more targeted prompts. More with less.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<div class="reveal" style="transition-delay:400ms;padding:1.25rem 1.75rem;background:rgba(0,0,0,.03);border:1px solid rgba(0,0,0,.07);border-radius:2px">
|
||||
<p style="font-family:var(--body);font-size:0.8125rem;font-weight:300;color:var(--t3);line-height:1.7">
|
||||
<strong style="font-weight:500;color:var(--t2)">The honest picture:</strong> When you use Neuron with BYOK providers (OpenAI, Anthropic, Grok) or Neuron Inference, those queries travel to inference servers - that footprint exists. The savings come from the architecture: persistent memory and local-first design reduce the total computation required to get the same work done.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
<style>
|
||||
@media (max-width: 768px) {
|
||||
let css: String = "@media (max-width: 768px) {
|
||||
.env-grid { grid-template-columns: 1fr !important; gap: 2rem !important; }
|
||||
}
|
||||
</style>
|
||||
</section>
|
||||
}"
|
||||
|
||||
el_section(
|
||||
"id=\"environmental\" aria-label=\"Environmental impact\" style=\"padding:8rem 2.5rem;background:var(--bg)\"",
|
||||
el_div("class=\"container-lg\"", grid) + "<style>" + css + "</style>"
|
||||
)
|
||||
}
|
||||
|
||||
+49
-25
@@ -1,34 +1,58 @@
|
||||
// components/footer.el - Site footer.
|
||||
|
||||
extern fn el_footer(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_a(href: String, attrs: String, children: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_nav(attrs: String, children: String) -> String
|
||||
extern fn el_img(src: String, alt: String, attrs: String) -> String
|
||||
|
||||
fn footer() -> String {
|
||||
return <footer id="footer" aria-label="Footer">
|
||||
<div class="container">
|
||||
<div class="footer-inner">
|
||||
let brand_img: String = el_img(
|
||||
"/assets/brand/neuron-wordmark-on-light.png",
|
||||
"Neuron",
|
||||
"srcset=\"/assets/brand/neuron-wordmark-on-light@2x.png 2x\" height=\"24\" style=\"display:block;margin-bottom:0.35rem;\""
|
||||
)
|
||||
let brand_tagline: String = el_p("class=\"footer-brand-tagline\"", "Built Different.")
|
||||
let brand_link: String = el_a(
|
||||
"/",
|
||||
"class=\"footer-brand\" aria-label=\"Neuron home\" style=\"display:flex;flex-direction:column;align-items:center;\"",
|
||||
brand_img + brand_tagline
|
||||
)
|
||||
|
||||
<a href="/" class="footer-brand" aria-label="Neuron home" style="display:flex;flex-direction:column;align-items:center;">
|
||||
<img src="/assets/brand/neuron-wordmark-on-light.png" srcset="/assets/brand/neuron-wordmark-on-light@2x.png 2x" alt="Neuron" height="24" style="display:block;margin-bottom:0.35rem;">
|
||||
<p class="footer-brand-tagline">Built Different.</p>
|
||||
</a>
|
||||
let footer_center: String = el_div(
|
||||
"class=\"footer-center\"",
|
||||
el_div("class=\"navy-line\"", "")
|
||||
)
|
||||
|
||||
<div class="footer-center">
|
||||
<div class="navy-line"></div>
|
||||
</div>
|
||||
let footer_nav_links: String =
|
||||
el_a("/legal/terms", "", "Terms") +
|
||||
el_a("/legal/enterprise-terms", "", "Enterprise Agreement") +
|
||||
el_a("mailto:legal@neurontechnologies.ai", "", "Contact")
|
||||
let footer_nav: String = el_nav(
|
||||
"class=\"footer-nav\" aria-label=\"Footer navigation\"",
|
||||
footer_nav_links
|
||||
)
|
||||
let footer_right: String = el_div(
|
||||
"class=\"footer-right\"",
|
||||
el_p("class=\"footer-domain\"", "neurontechnologies.ai") + footer_nav
|
||||
)
|
||||
|
||||
<div class="footer-right">
|
||||
<p class="footer-domain">neurontechnologies.ai</p>
|
||||
<nav class="footer-nav" aria-label="Footer navigation">
|
||||
<a href="/legal/terms">Terms</a>
|
||||
<a href="/legal/enterprise-terms">Enterprise Agreement</a>
|
||||
<a href="mailto:legal@neurontechnologies.ai">Contact</a>
|
||||
</nav>
|
||||
</div>
|
||||
let footer_inner: String = el_div(
|
||||
"class=\"footer-inner\"",
|
||||
brand_link + footer_center + footer_right
|
||||
)
|
||||
|
||||
</div>
|
||||
let footer_bottom: String = el_div(
|
||||
"class=\"footer-bottom\"",
|
||||
el_p("class=\"footer-copy\"", "© 2026 Neuron, LLC. All rights reserved.") +
|
||||
el_p("class=\"footer-tagline-bottom\"", "Your memory. Your AI.")
|
||||
)
|
||||
|
||||
<div class="footer-bottom">
|
||||
<p class="footer-copy">© 2026 Neuron, LLC. All rights reserved.</p>
|
||||
<p class="footer-tagline-bottom">Your memory. Your AI.</p>
|
||||
</div>
|
||||
</div>
|
||||
</footer>
|
||||
let container: String = el_div(
|
||||
"class=\"container\"",
|
||||
footer_inner + footer_bottom
|
||||
)
|
||||
|
||||
el_footer("id=\"footer\" aria-label=\"Footer\"", container)
|
||||
}
|
||||
|
||||
+22
-16
@@ -4,26 +4,32 @@
|
||||
// "Neuron, LLC" footer. Matches the design picked from
|
||||
// /tmp/founding-badge-preview.html.
|
||||
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_img(src: String, alt: String, attrs: String) -> String
|
||||
|
||||
fn founding_badge(member_number: Int) -> String {
|
||||
let num_str: String = int_to_str(member_number)
|
||||
let show_number: Bool = member_number > 0
|
||||
return <div class="founding-badge" aria-label="Founding Member badge">
|
||||
<img class="founding-badge-brain" src="/assets/brand/neuron-brain.png" alt="Neuron" width="40" height="40">
|
||||
<div class="founding-badge-eye">Founding Member</div>
|
||||
{#if show_number}
|
||||
<div class="founding-badge-num">#{num_str}</div>
|
||||
<div class="founding-badge-of">of 1,000</div>
|
||||
{#else}
|
||||
<div class="founding-badge-pending">Your number awaits</div>
|
||||
{/if}
|
||||
<div class="founding-badge-line"></div>
|
||||
<div class="founding-badge-name">Neuron, LLC</div>
|
||||
</div>
|
||||
|
||||
let number_or_pending: String = if show_number {
|
||||
el_div("class=\"founding-badge-num\"", "#" + num_str) +
|
||||
el_div("class=\"founding-badge-of\"", "of 1,000")
|
||||
} else {
|
||||
el_div("class=\"founding-badge-pending\"", "Your number awaits")
|
||||
}
|
||||
|
||||
el_div(
|
||||
"class=\"founding-badge\" aria-label=\"Founding Member badge\"",
|
||||
el_img("/assets/brand/neuron-brain.png", "Neuron", "class=\"founding-badge-brain\" width=\"40\" height=\"40\"") +
|
||||
el_div("class=\"founding-badge-eye\"", "Founding Member") +
|
||||
number_or_pending +
|
||||
el_div("class=\"founding-badge-line\"", "") +
|
||||
el_div("class=\"founding-badge-name\"", "Neuron, LLC")
|
||||
)
|
||||
}
|
||||
|
||||
fn founding_badge_css() -> String {
|
||||
return <style>
|
||||
.founding-badge {
|
||||
let css_a: String = ".founding-badge {
|
||||
width: 200px;
|
||||
background: #fff;
|
||||
border: 1px solid rgba(0,82,160,.18);
|
||||
@@ -83,6 +89,6 @@ fn founding_badge_css() -> String {
|
||||
letter-spacing: .14em;
|
||||
text-transform: uppercase;
|
||||
color: #6B6B7E;
|
||||
}
|
||||
</style>
|
||||
}"
|
||||
"<style>" + css_a + "</style>"
|
||||
}
|
||||
|
||||
+282
-227
@@ -12,6 +12,200 @@
|
||||
// anchors, which the HTML5 parser resolves via the adoption agency algorithm,
|
||||
// producing mismatched </div> tags that break gallery-grid's closing tag and
|
||||
// pull sibling elements into the grid as spurious grid items.
|
||||
|
||||
extern fn el_html_doc(lang: String, head_html: String, body_html: String) -> String
|
||||
extern fn el_meta_charset(charset: String) -> String
|
||||
extern fn el_meta(name: String, content: String) -> String
|
||||
extern fn el_link_stylesheet(href: String) -> String
|
||||
extern fn el_title(text: String) -> String
|
||||
extern fn el_script_src(src: String, defer_load: Bool) -> String
|
||||
extern fn el_script_inline(js: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_nav(attrs: String, children: String) -> String
|
||||
extern fn el_a(href: String, attrs: String, children: String) -> String
|
||||
extern fn el_img(src: String, alt: String, attrs: String) -> String
|
||||
extern fn el_button(attrs: String, label: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_h1(attrs: String, text: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_input(type_attr: String, attrs: String) -> String
|
||||
extern fn el_br() -> String
|
||||
|
||||
fn gallery_css_base() -> String {
|
||||
"*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
|
||||
:root {
|
||||
--bg: #FAFAF8; --bg2: #F0F0EC; --card: #FFFFFF;
|
||||
--navy: #0052A0; --navy-65: rgba(0,82,160,.65); --navy-85: rgba(0,82,160,.85);
|
||||
--t1: #0D0D14; --t2: #3A3A4A; --t3: #6B6B7E;
|
||||
--border: rgba(0,0,0,.07); --border2: rgba(0,0,0,.13);
|
||||
--up: #2E7D32; --down: #C62828;
|
||||
--head: 'Playfair Display', Georgia, serif;
|
||||
--body: 'IBM Plex Sans', system-ui, sans-serif;
|
||||
}
|
||||
html { scroll-behavior: smooth; }
|
||||
html, body { background: var(--bg); color: var(--t1); font-family: var(--body); -webkit-font-smoothing: antialiased; }
|
||||
body::before {
|
||||
content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0;
|
||||
background-image: linear-gradient(rgba(0,0,0,.022) 1px, transparent 1px),
|
||||
linear-gradient(90deg, rgba(0,0,0,.022) 1px, transparent 1px);
|
||||
background-size: 48px 48px;
|
||||
}
|
||||
.label { font-family: var(--body); font-size: .75rem; font-weight: 500; letter-spacing: .2em; text-transform: uppercase; color: var(--navy-65); }
|
||||
.display-lg { font-family: var(--head); font-size: clamp(2rem,4vw,3.25rem); font-weight: 600; line-height: 1.1; letter-spacing: -.02em; color: var(--t1); }
|
||||
.btn-primary { display: inline-flex; align-items: center; gap: .75rem; font-family: var(--body); font-size: .75rem; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; text-decoration: none; color: #fff; background: var(--navy); padding: 1rem 2rem; border: none; cursor: pointer; transition: background 300ms; }
|
||||
.btn-primary:hover { background: #0078D4; }
|
||||
.btn-ghost { display: inline-flex; align-items: center; gap: .75rem; font-family: var(--body); font-size: .75rem; font-weight: 400; letter-spacing: .15em; text-transform: uppercase; text-decoration: none; color: var(--t2); background: transparent; padding: 1rem 2rem; border: 1px solid var(--border2); cursor: pointer; transition: border-color 300ms, color 300ms; }
|
||||
.btn-ghost:hover { border-color: rgba(0,82,160,.35); color: var(--t1); }"
|
||||
}
|
||||
|
||||
fn gallery_css_nav() -> String {
|
||||
"#nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; transition: background 500ms, border-color 500ms; }
|
||||
#nav.scrolled { background: rgba(250,250,248,.95); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); }
|
||||
.nav-inner { max-width: 1280px; margin: 0 auto; padding: 0 2rem; height: 4rem; display: flex; align-items: center; justify-content: space-between; position: relative; }
|
||||
.nav-logo img { height: 2rem; width: auto; display: block; }
|
||||
.nav-links { display: flex; align-items: center; gap: 1.25rem; flex-wrap: nowrap; }
|
||||
.nav-link { font-family: var(--body); font-size: .675rem; font-weight: 400; letter-spacing: .16em; text-transform: uppercase; color: var(--t3); text-decoration: none; white-space: nowrap; transition: color 200ms; }
|
||||
.nav-link:hover { color: var(--t1); }
|
||||
.nav-dropdown { position: relative; display: flex; align-items: center; }
|
||||
.nav-dropdown-btn { background: none; border: none; cursor: pointer; padding: 0; font-family: var(--body); font-size: .675rem; font-weight: 400; letter-spacing: .16em; text-transform: uppercase; color: var(--t3); transition: color 200ms; white-space: nowrap; }
|
||||
.nav-dropdown-btn:hover { color: var(--t1); }
|
||||
.nav-dropdown-menu { display: none; position: absolute; top: calc(100% + .75rem); left: 50%; transform: translateX(-50%); background: #fff; border: 1px solid var(--border2); box-shadow: 0 8px 32px rgba(0,0,0,.10); min-width: 160px; flex-direction: column; z-index: 200; padding: .375rem 0; }
|
||||
.nav-dropdown.open .nav-dropdown-menu { display: flex; }
|
||||
.nav-dropdown-item { font-family: var(--body); font-size: .8125rem; font-weight: 400; color: var(--t2); text-decoration: none; padding: .5rem 1.25rem; transition: background 150ms, color 150ms; white-space: nowrap; }
|
||||
.nav-dropdown-item:hover { background: var(--bg2); color: var(--t1); }
|
||||
.nav-cta { font-family: var(--body); font-size: .675rem; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; color: #fff; background: var(--navy); text-decoration: none; padding: .575rem 1.1rem; white-space: nowrap; box-shadow: 0 2px 12px rgba(0,82,160,.20); transition: background 300ms; }
|
||||
.nav-cta:hover { background: #0078D4; }
|
||||
.nav-hamburger { display: none; flex-direction: column; justify-content: center; gap: 5px; background: none; border: none; cursor: pointer; padding: 6px 4px; z-index: 101; -webkit-tap-highlight-color: transparent; }
|
||||
.nav-hamburger span { display: block; width: 22px; height: 2px; background: var(--t1); border-radius: 1px; transition: transform 280ms ease, opacity 200ms ease; transform-origin: center; }
|
||||
.nav-hamburger[aria-expanded=\"true\"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
|
||||
.nav-hamburger[aria-expanded=\"true\"] span:nth-child(2) { opacity: 0; transform: scaleX(0); }
|
||||
.nav-hamburger[aria-expanded=\"true\"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
|
||||
.nav-mobile { display: none; position: absolute; top: 4rem; left: 0; right: 0; background: rgba(250,250,248,.98); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid var(--border); padding: .5rem 0 1.5rem; flex-direction: column; box-shadow: 0 8px 32px rgba(0,0,0,.08); }
|
||||
.nav-mobile.open { display: flex; }
|
||||
.nav-mobile-link { display: block; padding: .875rem 2rem; font-family: var(--body); font-size: .75rem; font-weight: 400; letter-spacing: .16em; text-transform: uppercase; color: var(--t2); text-decoration: none; border-bottom: 1px solid rgba(0,0,0,.05); transition: color 150ms, background 150ms; }
|
||||
.nav-mobile-link:last-child { border-bottom: none; }
|
||||
.nav-mobile-link:hover { color: var(--t1); background: rgba(0,82,160,.03); }
|
||||
.nav-mobile-cta { display: block; margin: 1rem 2rem 0; padding: .8rem 1.5rem; text-align: center; font-family: var(--body); font-size: .75rem; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; color: #fff; background: var(--navy); text-decoration: none; }
|
||||
@media (max-width: 1060px) { .nav-links { display: none; } .nav-hamburger { display: flex; } }
|
||||
@media (min-width: 1061px) { .nav-mobile { display: none !important; } .nav-hamburger { display: none !important; } }"
|
||||
}
|
||||
|
||||
fn gallery_css_gallery() -> String {
|
||||
".gallery-wrap { max-width: 1100px; margin: 0 auto; padding: 7rem 2.5rem 5rem; position: relative; z-index: 1; }
|
||||
.gallery-header { margin-bottom: 3rem; }
|
||||
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
|
||||
@media (max-width: 900px) { .gallery-grid { grid-template-columns: 1fr 1fr; } }
|
||||
@media (max-width: 600px) { .gallery-grid { grid-template-columns: 1fr; } }
|
||||
.gal-card { background: var(--card); border: 1px solid var(--border); padding: 1.5rem; display: flex; flex-direction: column; gap: .875rem; transition: border-color .15s, box-shadow .15s; }
|
||||
.gal-card:hover { border-color: rgba(0,82,160,.25); box-shadow: 0 4px 20px rgba(0,82,160,.07); }
|
||||
.gal-link { text-decoration: none; color: inherit; display: flex; flex-direction: column; gap: .875rem; flex: 1; }
|
||||
.gal-q { font-family: var(--body); font-weight: 500; font-size: .875rem; color: var(--navy); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
|
||||
.gal-a { font-family: var(--body); font-weight: 300; font-size: .8125rem; color: var(--t2); line-height: 1.7; display: -webkit-box; -webkit-line-clamp: 6; -webkit-box-orient: vertical; overflow: hidden; flex: 1; max-height: 11rem; }
|
||||
.gal-a p { margin: 0; }
|
||||
.gal-a p + p { margin-top: .35rem; }
|
||||
.gal-a ol, .gal-a ul { padding-left: 1.25rem; margin: .25rem 0; }
|
||||
.gal-a li + li { margin-top: .15rem; }
|
||||
.gal-a strong { font-weight: 600; color: var(--t1); }
|
||||
.gal-a em { font-style: italic; }
|
||||
.gal-a code { background: rgba(0,0,0,0.05); padding: .1em .3em; border-radius: 3px; font-family: ui-monospace, 'IBM Plex Mono', Menlo, monospace; font-size: .85em; }
|
||||
.gal-a pre { background: var(--bg2); padding: .5rem; overflow-x: auto; font-size: .75rem; margin: .4rem 0; border-radius: 3px; }
|
||||
.gal-a pre code { background: none; padding: 0; }
|
||||
.gal-a a { color: var(--navy); text-decoration: underline; }
|
||||
.gal-a h1, .gal-a h2, .gal-a h3, .gal-a h4 { font-size: 1em; font-weight: 600; margin: .3rem 0; color: var(--t1); }
|
||||
.gal-a blockquote { border-left: 2px solid var(--border2); padding-left: .5rem; color: var(--t2); margin: .3rem 0; }
|
||||
.gal-a img { max-width: 100%; height: auto; }
|
||||
.gal-meta { display: flex; justify-content: space-between; align-items: center; font-family: var(--body); font-size: .65rem; font-weight: 400; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); margin-top: auto; padding-top: .75rem; border-top: 1px solid var(--border); }
|
||||
.gal-date { font-size: .65rem; color: var(--t3); }
|
||||
.vote-controls { display: inline-flex; align-items: center; gap: .35rem; }
|
||||
.vote-btn { background: transparent; border: 1px solid var(--border2); color: var(--t3); cursor: pointer; padding: .2rem .45rem; font-size: .7rem; line-height: 1; transition: all .15s; -webkit-tap-highlight-color: transparent; }
|
||||
.vote-btn:hover:not(:disabled) { color: var(--navy); border-color: rgba(0,82,160,.35); background: rgba(0,82,160,.04); }
|
||||
.vote-btn:focus-visible { outline: 2px solid var(--navy); outline-offset: 1px; }
|
||||
.vote-btn:disabled { opacity: .55; cursor: not-allowed; }
|
||||
.vote-btn.is-active.vote-up { background: rgba(46,125,50,.10); color: var(--up); border-color: rgba(46,125,50,.45); }
|
||||
.vote-btn.is-active.vote-down { background: rgba(198,40,40,.10); color: var(--down); border-color: rgba(198,40,40,.45); }
|
||||
.vote-btn.is-loading { opacity: .55; cursor: wait; }
|
||||
.vote-score { font-size: .8rem; font-weight: 500; color: var(--t1); min-width: 1.5rem; text-align: center; font-variant-numeric: tabular-nums; }
|
||||
.gallery-controls { display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; flex-wrap: wrap; }
|
||||
.gallery-search { flex: 1; min-width: 200px; font-family: var(--body); font-size: .875rem; font-weight: 300; color: var(--t1); background: #fff; border: 1px solid var(--border2); padding: .625rem 1rem; outline: none; transition: border-color .2s; }
|
||||
.gallery-search:focus { border-color: var(--navy); }
|
||||
.gallery-search::placeholder { color: var(--t3); }
|
||||
.sort-btn { font-family: var(--body); font-size: .7rem; font-weight: 400; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); background: none; border: 1px solid var(--border2); padding: .5rem 1rem; cursor: pointer; transition: all .15s; }
|
||||
.sort-btn:hover, .sort-btn.active { color: var(--navy); border-color: rgba(0,82,160,.3); background: rgba(0,82,160,.03); }
|
||||
.gallery-empty { grid-column: 1/-1; padding: 4rem 0; text-align: center; }
|
||||
.gal-card.hidden { display: none; }"
|
||||
}
|
||||
|
||||
fn gallery_css_modal() -> String {
|
||||
".signin-modal { position: fixed; inset: 0; background: rgba(13,13,20,.55); display: none; align-items: center; justify-content: center; z-index: 1000; padding: 1rem; }
|
||||
.signin-modal.open { display: flex; }
|
||||
.signin-modal-card { background: #fff; border: 1px solid var(--border2); padding: 2rem; max-width: 22rem; width: 100%; box-shadow: 0 16px 48px rgba(0,0,0,.18); }
|
||||
.signin-modal h2 { font-family: var(--head); font-size: 1.4rem; font-weight: 600; color: var(--t1); margin-bottom: .5rem; }
|
||||
.signin-modal p { font-family: var(--body); font-size: .85rem; font-weight: 300; color: var(--t2); line-height: 1.6; margin-bottom: 1.25rem; }
|
||||
.signin-modal input { width: 100%; box-sizing: border-box; font-family: var(--body); font-size: .875rem; font-weight: 300; color: var(--t1); background: #fff; border: 1px solid var(--border2); padding: .75rem 1rem; outline: none; transition: border-color .2s; margin-bottom: .75rem; }
|
||||
.signin-modal input:focus { border-color: var(--navy); }
|
||||
.signin-modal-actions { display: flex; gap: .5rem; justify-content: space-between; align-items: center; }
|
||||
.signin-modal-msg { font-size: .8rem; color: var(--t2); margin-top: .75rem; min-height: 1rem; }
|
||||
.signin-modal .btn-primary { padding: .7rem 1.25rem; font-size: .7rem; }
|
||||
.signin-modal-cancel { background: none; border: none; color: var(--t3); cursor: pointer; font-family: var(--body); font-size: .75rem; letter-spacing: .14em; text-transform: uppercase; padding: .7rem .5rem; }
|
||||
.signin-modal-cancel:hover { color: var(--t1); }"
|
||||
}
|
||||
|
||||
fn gallery_nav_html() -> String {
|
||||
let logo_img: String = el_img(
|
||||
"/assets/brand/neuron-wordmark-on-light.png",
|
||||
"Neuron",
|
||||
"srcset=\"/assets/brand/neuron-wordmark-on-light@2x.png 2x\" height=\"28\""
|
||||
)
|
||||
let logo: String = el_a("/", "class=\"nav-logo\" aria-label=\"Neuron home\"", logo_img)
|
||||
|
||||
let dropdown_menu: String = el_div(
|
||||
"class=\"nav-dropdown-menu\"",
|
||||
el_a("/#mission", "class=\"nav-dropdown-item\"", "Our mission") +
|
||||
el_a("/#safety", "class=\"nav-dropdown-item\"", "Safety") +
|
||||
el_a("/#environmental", "class=\"nav-dropdown-item\"", "Environment")
|
||||
)
|
||||
let dropdown: String = el_div(
|
||||
"class=\"nav-dropdown\"",
|
||||
el_button("class=\"nav-link nav-dropdown-btn\" aria-haspopup=\"true\" aria-expanded=\"false\"", "Mission ▾") +
|
||||
dropdown_menu
|
||||
)
|
||||
|
||||
let nav_links: String = el_div(
|
||||
"class=\"nav-links\"",
|
||||
el_a("/#how-it-works", "class=\"nav-link\"", "How it works") +
|
||||
dropdown +
|
||||
el_a("/#pricing", "class=\"nav-link\"", "Pricing") +
|
||||
el_a("/#marketplace", "class=\"nav-link\"", "Marketplace") +
|
||||
el_a("/#enterprise", "class=\"nav-link\"", "Enterprise") +
|
||||
el_a("/about", "class=\"nav-link\"", "About") +
|
||||
el_a("/said", "class=\"nav-link\"", "Gallery") +
|
||||
el_a("/account", "class=\"nav-link\"", "Account") +
|
||||
el_a("/#pricing", "class=\"nav-cta\"", "Get Access")
|
||||
)
|
||||
|
||||
let hamburger: String = el_button(
|
||||
"class=\"nav-hamburger\" id=\"nav-hamburger\" aria-label=\"Open navigation\" aria-expanded=\"false\" aria-controls=\"nav-mobile\"",
|
||||
el_span("", "") + el_span("", "") + el_span("", "")
|
||||
)
|
||||
|
||||
let nav_mobile: String = el_div(
|
||||
"class=\"nav-mobile\" id=\"nav-mobile\" role=\"navigation\" aria-label=\"Mobile navigation\"",
|
||||
el_a("/#how-it-works", "class=\"nav-mobile-link\"", "How it works") +
|
||||
el_a("/#mission", "class=\"nav-mobile-link\"", "Mission") +
|
||||
el_a("/#safety", "class=\"nav-mobile-link\" style=\"padding-left:1.75rem;font-size:.8rem;color:var(--t3)\"", "- Safety") +
|
||||
el_a("/#environmental", "class=\"nav-mobile-link\" style=\"padding-left:1.75rem;font-size:.8rem;color:var(--t3)\"", "- Environment") +
|
||||
el_a("/#pricing", "class=\"nav-mobile-link\"", "Pricing") +
|
||||
el_a("/#enterprise", "class=\"nav-mobile-link\"", "Enterprise") +
|
||||
el_a("/about", "class=\"nav-mobile-link\"", "About") +
|
||||
el_a("/said", "class=\"nav-mobile-link\"", "Gallery") +
|
||||
el_a("/account", "class=\"nav-mobile-link\"", "Account") +
|
||||
el_a("/#pricing", "class=\"nav-mobile-cta\"", "Get Access")
|
||||
)
|
||||
|
||||
el_nav("id=\"nav\"", el_div("class=\"nav-inner\"", logo + nav_links + hamburger + nav_mobile))
|
||||
}
|
||||
|
||||
fn gallery_page(cards_json: String, supabase_url: String, supabase_anon_key: String) -> String {
|
||||
// Moved from module-level to avoid duplicate main() when linked with other modules.
|
||||
let gallery_share_allowlist: String = "{\"p\":[],\"br\":[],\"strong\":[],\"em\":[],\"u\":[],\"s\":[],\"code\":[],\"pre\":[],\"ul\":[],\"ol\":[],\"li\":[],\"h1\":[],\"h2\":[],\"h3\":[],\"h4\":[],\"blockquote\":[]}"
|
||||
@@ -44,20 +238,20 @@ fn gallery_page(cards_json: String, supabase_url: String, supabase_anon_key: Str
|
||||
}
|
||||
let ts_raw: String = json_get(card, "created_at")
|
||||
let ts_short: String = str_slice(ts_raw, 0, 10)
|
||||
let card_html: String = "<div class=\"gal-card\" data-share-id=\"" + cid + "\" data-score=\"" + score + "\" data-ts=\"" + cid + "\">
|
||||
<a href=\"/share/" + cid + "\" class=\"gal-link\">
|
||||
<div class=\"gal-q\">" + q_html + "</div>
|
||||
<div class=\"gal-a\">" + a_html + "</div>
|
||||
</a>
|
||||
<div class=\"gal-meta\">
|
||||
<div class=\"vote-controls\" data-share-id=\"" + cid + "\">
|
||||
<button type=\"button\" class=\"vote-btn vote-up\" aria-label=\"Upvote\" data-direction=\"up\" disabled>▲</button>
|
||||
<span class=\"vote-score\" data-score=\"" + score + "\">" + score + "</span>
|
||||
<button type=\"button\" class=\"vote-btn vote-down\" aria-label=\"Downvote\" data-direction=\"down\" disabled>▼</button>
|
||||
</div>
|
||||
<span class=\"gal-date\">" + ts_short + " · Read ↗</span>
|
||||
</div>
|
||||
</div>"
|
||||
let card_html: String = "<div class=\"gal-card\" data-share-id=\"" + cid + "\" data-score=\"" + score + "\" data-ts=\"" + cid + "\">" +
|
||||
"<a href=\"/share/" + cid + "\" class=\"gal-link\">" +
|
||||
"<div class=\"gal-q\">" + q_html + "</div>" +
|
||||
"<div class=\"gal-a\">" + a_html + "</div>" +
|
||||
"</a>" +
|
||||
"<div class=\"gal-meta\">" +
|
||||
"<div class=\"vote-controls\" data-share-id=\"" + cid + "\">" +
|
||||
"<button type=\"button\" class=\"vote-btn vote-up\" aria-label=\"Upvote\" data-direction=\"up\" disabled>▲</button>" +
|
||||
"<span class=\"vote-score\" data-score=\"" + score + "\">" + score + "</span>" +
|
||||
"<button type=\"button\" class=\"vote-btn vote-down\" aria-label=\"Downvote\" data-direction=\"down\" disabled>▼</button>" +
|
||||
"</div>" +
|
||||
"<span class=\"gal-date\">" + ts_short + " · Read ↗</span>" +
|
||||
"</div>" +
|
||||
"</div>"
|
||||
let cards_html = cards_html + card_html
|
||||
let i = i + 1
|
||||
}
|
||||
@@ -65,217 +259,78 @@ fn gallery_page(cards_json: String, supabase_url: String, supabase_anon_key: Str
|
||||
"<div style=\"grid-column:1/-1;padding:4rem 0;text-align:center\"><p class=\"label\" style=\"margin-bottom:1rem\">Nothing yet</p><p style=\"font-family:var(--body);font-weight:300;color:var(--t2);line-height:1.7\">Nothing shared yet.</p></div>"
|
||||
} else { "" }
|
||||
|
||||
return <!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width,initial-scale=1">
|
||||
<title>Things Neuron Said</title>
|
||||
<meta name="description" content="Real conversations with Neuron, voted up by users.">
|
||||
<link rel="icon" type="image/png" sizes="32x32" href="/assets/favicon-32.png">
|
||||
<link rel="preconnect" href="https://fonts.googleapis.com">
|
||||
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
|
||||
<link href="https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;1,400&family=IBM+Plex+Sans:wght@300;400;500;600&display=swap" rel="stylesheet">
|
||||
<style>
|
||||
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
|
||||
:root {
|
||||
--bg: #FAFAF8; --bg2: #F0F0EC; --card: #FFFFFF;
|
||||
--navy: #0052A0; --navy-65: rgba(0,82,160,.65); --navy-85: rgba(0,82,160,.85);
|
||||
--t1: #0D0D14; --t2: #3A3A4A; --t3: #6B6B7E;
|
||||
--border: rgba(0,0,0,.07); --border2: rgba(0,0,0,.13);
|
||||
--up: #2E7D32; --down: #C62828;
|
||||
--head: 'Playfair Display', Georgia, serif;
|
||||
--body: 'IBM Plex Sans', system-ui, sans-serif;
|
||||
}
|
||||
html { scroll-behavior: smooth; }
|
||||
html, body { background: var(--bg); color: var(--t1); font-family: var(--body); -webkit-font-smoothing: antialiased; }
|
||||
body::before {
|
||||
content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0;
|
||||
background-image: linear-gradient(rgba(0,0,0,.022) 1px, transparent 1px),
|
||||
linear-gradient(90deg, rgba(0,0,0,.022) 1px, transparent 1px);
|
||||
background-size: 48px 48px;
|
||||
}
|
||||
.label { font-family: var(--body); font-size: .75rem; font-weight: 500; letter-spacing: .2em; text-transform: uppercase; color: var(--navy-65); }
|
||||
.display-lg { font-family: var(--head); font-size: clamp(2rem,4vw,3.25rem); font-weight: 600; line-height: 1.1; letter-spacing: -.02em; color: var(--t1); }
|
||||
.btn-primary { display: inline-flex; align-items: center; gap: .75rem; font-family: var(--body); font-size: .75rem; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; text-decoration: none; color: #fff; background: var(--navy); padding: 1rem 2rem; border: none; cursor: pointer; transition: background 300ms; }
|
||||
.btn-primary:hover { background: #0078D4; }
|
||||
.btn-ghost { display: inline-flex; align-items: center; gap: .75rem; font-family: var(--body); font-size: .75rem; font-weight: 400; letter-spacing: .15em; text-transform: uppercase; text-decoration: none; color: var(--t2); background: transparent; padding: 1rem 2rem; border: 1px solid var(--border2); cursor: pointer; transition: border-color 300ms, color 300ms; }
|
||||
.btn-ghost:hover { border-color: rgba(0,82,160,.35); color: var(--t1); }
|
||||
/* Nav */
|
||||
#nav { position: fixed; top: 0; left: 0; right: 0; z-index: 100; transition: background 500ms, border-color 500ms; }
|
||||
#nav.scrolled { background: rgba(250,250,248,.95); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); }
|
||||
.nav-inner { max-width: 1280px; margin: 0 auto; padding: 0 2rem; height: 4rem; display: flex; align-items: center; justify-content: space-between; position: relative; }
|
||||
.nav-logo img { height: 2rem; width: auto; display: block; }
|
||||
.nav-links { display: flex; align-items: center; gap: 1.25rem; flex-wrap: nowrap; }
|
||||
.nav-link { font-family: var(--body); font-size: .675rem; font-weight: 400; letter-spacing: .16em; text-transform: uppercase; color: var(--t3); text-decoration: none; white-space: nowrap; transition: color 200ms; }
|
||||
.nav-link:hover { color: var(--t1); }
|
||||
.nav-dropdown { position: relative; display: flex; align-items: center; }
|
||||
.nav-dropdown-btn { background: none; border: none; cursor: pointer; padding: 0; font-family: var(--body); font-size: .675rem; font-weight: 400; letter-spacing: .16em; text-transform: uppercase; color: var(--t3); transition: color 200ms; white-space: nowrap; }
|
||||
.nav-dropdown-btn:hover { color: var(--t1); }
|
||||
.nav-dropdown-menu { display: none; position: absolute; top: calc(100% + .75rem); left: 50%; transform: translateX(-50%); background: #fff; border: 1px solid var(--border2); box-shadow: 0 8px 32px rgba(0,0,0,.10); min-width: 160px; flex-direction: column; z-index: 200; padding: .375rem 0; }
|
||||
.nav-dropdown.open .nav-dropdown-menu { display: flex; }
|
||||
.nav-dropdown-item { font-family: var(--body); font-size: .8125rem; font-weight: 400; color: var(--t2); text-decoration: none; padding: .5rem 1.25rem; transition: background 150ms, color 150ms; white-space: nowrap; }
|
||||
.nav-dropdown-item:hover { background: var(--bg2); color: var(--t1); }
|
||||
.nav-cta { font-family: var(--body); font-size: .675rem; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; color: #fff; background: var(--navy); text-decoration: none; padding: .575rem 1.1rem; white-space: nowrap; box-shadow: 0 2px 12px rgba(0,82,160,.20); transition: background 300ms; }
|
||||
.nav-cta:hover { background: #0078D4; }
|
||||
.nav-hamburger { display: none; flex-direction: column; justify-content: center; gap: 5px; background: none; border: none; cursor: pointer; padding: 6px 4px; z-index: 101; -webkit-tap-highlight-color: transparent; }
|
||||
.nav-hamburger span { display: block; width: 22px; height: 2px; background: var(--t1); border-radius: 1px; transition: transform 280ms ease, opacity 200ms ease; transform-origin: center; }
|
||||
.nav-hamburger[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
|
||||
.nav-hamburger[aria-expanded="true"] span:nth-child(2) { opacity: 0; transform: scaleX(0); }
|
||||
.nav-hamburger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
|
||||
.nav-mobile { display: none; position: absolute; top: 4rem; left: 0; right: 0; background: rgba(250,250,248,.98); backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px); border-bottom: 1px solid var(--border); padding: .5rem 0 1.5rem; flex-direction: column; box-shadow: 0 8px 32px rgba(0,0,0,.08); }
|
||||
.nav-mobile.open { display: flex; }
|
||||
.nav-mobile-link { display: block; padding: .875rem 2rem; font-family: var(--body); font-size: .75rem; font-weight: 400; letter-spacing: .16em; text-transform: uppercase; color: var(--t2); text-decoration: none; border-bottom: 1px solid rgba(0,0,0,.05); transition: color 150ms, background 150ms; }
|
||||
.nav-mobile-link:last-child { border-bottom: none; }
|
||||
.nav-mobile-link:hover { color: var(--t1); background: rgba(0,82,160,.03); }
|
||||
.nav-mobile-cta { display: block; margin: 1rem 2rem 0; padding: .8rem 1.5rem; text-align: center; font-family: var(--body); font-size: .75rem; font-weight: 500; letter-spacing: .15em; text-transform: uppercase; color: #fff; background: var(--navy); text-decoration: none; }
|
||||
@media (max-width: 1060px) { .nav-links { display: none; } .nav-hamburger { display: flex; } }
|
||||
@media (min-width: 1061px) { .nav-mobile { display: none !important; } .nav-hamburger { display: none !important; } }
|
||||
/* Gallery */
|
||||
.gallery-wrap { max-width: 1100px; margin: 0 auto; padding: 7rem 2.5rem 5rem; position: relative; z-index: 1; }
|
||||
.gallery-header { margin-bottom: 3rem; }
|
||||
.gallery-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
|
||||
@media (max-width: 900px) { .gallery-grid { grid-template-columns: 1fr 1fr; } }
|
||||
@media (max-width: 600px) { .gallery-grid { grid-template-columns: 1fr; } }
|
||||
.gal-card { background: var(--card); border: 1px solid var(--border); padding: 1.5rem; display: flex; flex-direction: column; gap: .875rem; transition: border-color .15s, box-shadow .15s; }
|
||||
.gal-card:hover { border-color: rgba(0,82,160,.25); box-shadow: 0 4px 20px rgba(0,82,160,.07); }
|
||||
.gal-link { text-decoration: none; color: inherit; display: flex; flex-direction: column; gap: .875rem; flex: 1; }
|
||||
.gal-q { font-family: var(--body); font-weight: 500; font-size: .875rem; color: var(--navy); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
|
||||
.gal-a { font-family: var(--body); font-weight: 300; font-size: .8125rem; color: var(--t2); line-height: 1.7; display: -webkit-box; -webkit-line-clamp: 6; -webkit-box-orient: vertical; overflow: hidden; flex: 1; max-height: 11rem; }
|
||||
.gal-a p { margin: 0; }
|
||||
.gal-a p + p { margin-top: .35rem; }
|
||||
.gal-a ol, .gal-a ul { padding-left: 1.25rem; margin: .25rem 0; }
|
||||
.gal-a li + li { margin-top: .15rem; }
|
||||
.gal-a strong { font-weight: 600; color: var(--t1); }
|
||||
.gal-a em { font-style: italic; }
|
||||
.gal-a code { background: rgba(0,0,0,0.05); padding: .1em .3em; border-radius: 3px; font-family: ui-monospace, 'IBM Plex Mono', Menlo, monospace; font-size: .85em; }
|
||||
.gal-a pre { background: var(--bg2); padding: .5rem; overflow-x: auto; font-size: .75rem; margin: .4rem 0; border-radius: 3px; }
|
||||
.gal-a pre code { background: none; padding: 0; }
|
||||
.gal-a a { color: var(--navy); text-decoration: underline; }
|
||||
.gal-a h1, .gal-a h2, .gal-a h3, .gal-a h4 { font-size: 1em; font-weight: 600; margin: .3rem 0; color: var(--t1); }
|
||||
.gal-a blockquote { border-left: 2px solid var(--border2); padding-left: .5rem; color: var(--t2); margin: .3rem 0; }
|
||||
.gal-a img { max-width: 100%; height: auto; }
|
||||
.gal-meta { display: flex; justify-content: space-between; align-items: center; font-family: var(--body); font-size: .65rem; font-weight: 400; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); margin-top: auto; padding-top: .75rem; border-top: 1px solid var(--border); }
|
||||
.gal-date { font-size: .65rem; color: var(--t3); }
|
||||
/* Vote controls */
|
||||
.vote-controls { display: inline-flex; align-items: center; gap: .35rem; }
|
||||
.vote-btn { background: transparent; border: 1px solid var(--border2); color: var(--t3); cursor: pointer; padding: .2rem .45rem; font-size: .7rem; line-height: 1; transition: all .15s; -webkit-tap-highlight-color: transparent; }
|
||||
.vote-btn:hover:not(:disabled) { color: var(--navy); border-color: rgba(0,82,160,.35); background: rgba(0,82,160,.04); }
|
||||
.vote-btn:focus-visible { outline: 2px solid var(--navy); outline-offset: 1px; }
|
||||
.vote-btn:disabled { opacity: .55; cursor: not-allowed; }
|
||||
.vote-btn.is-active.vote-up { background: rgba(46,125,50,.10); color: var(--up); border-color: rgba(46,125,50,.45); }
|
||||
.vote-btn.is-active.vote-down { background: rgba(198,40,40,.10); color: var(--down); border-color: rgba(198,40,40,.45); }
|
||||
.vote-btn.is-loading { opacity: .55; cursor: wait; }
|
||||
.vote-score { font-size: .8rem; font-weight: 500; color: var(--t1); min-width: 1.5rem; text-align: center; font-variant-numeric: tabular-nums; }
|
||||
.gallery-controls { display: flex; align-items: center; gap: 1rem; margin-bottom: 2rem; flex-wrap: wrap; }
|
||||
.gallery-search { flex: 1; min-width: 200px; font-family: var(--body); font-size: .875rem; font-weight: 300; color: var(--t1); background: #fff; border: 1px solid var(--border2); padding: .625rem 1rem; outline: none; transition: border-color .2s; }
|
||||
.gallery-search:focus { border-color: var(--navy); }
|
||||
.gallery-search::placeholder { color: var(--t3); }
|
||||
.sort-btn { font-family: var(--body); font-size: .7rem; font-weight: 400; letter-spacing: .1em; text-transform: uppercase; color: var(--t3); background: none; border: 1px solid var(--border2); padding: .5rem 1rem; cursor: pointer; transition: all .15s; }
|
||||
.sort-btn:hover, .sort-btn.active { color: var(--navy); border-color: rgba(0,82,160,.3); background: rgba(0,82,160,.03); }
|
||||
.gallery-empty { grid-column: 1/-1; padding: 4rem 0; text-align: center; }
|
||||
.gal-card.hidden { display: none; }
|
||||
/* Sign-in modal */
|
||||
.signin-modal { position: fixed; inset: 0; background: rgba(13,13,20,.55); display: none; align-items: center; justify-content: center; z-index: 1000; padding: 1rem; }
|
||||
.signin-modal.open { display: flex; }
|
||||
.signin-modal-card { background: #fff; border: 1px solid var(--border2); padding: 2rem; max-width: 22rem; width: 100%; box-shadow: 0 16px 48px rgba(0,0,0,.18); }
|
||||
.signin-modal h2 { font-family: var(--head); font-size: 1.4rem; font-weight: 600; color: var(--t1); margin-bottom: .5rem; }
|
||||
.signin-modal p { font-family: var(--body); font-size: .85rem; font-weight: 300; color: var(--t2); line-height: 1.6; margin-bottom: 1.25rem; }
|
||||
.signin-modal input { width: 100%; box-sizing: border-box; font-family: var(--body); font-size: .875rem; font-weight: 300; color: var(--t1); background: #fff; border: 1px solid var(--border2); padding: .75rem 1rem; outline: none; transition: border-color .2s; margin-bottom: .75rem; }
|
||||
.signin-modal input:focus { border-color: var(--navy); }
|
||||
.signin-modal-actions { display: flex; gap: .5rem; justify-content: space-between; align-items: center; }
|
||||
.signin-modal-msg { font-size: .8rem; color: var(--t2); margin-top: .75rem; min-height: 1rem; }
|
||||
.signin-modal .btn-primary { padding: .7rem 1.25rem; font-size: .7rem; }
|
||||
.signin-modal-cancel { background: none; border: none; color: var(--t3); cursor: pointer; font-family: var(--body); font-size: .75rem; letter-spacing: .14em; text-transform: uppercase; padding: .7rem .5rem; }
|
||||
.signin-modal-cancel:hover { color: var(--t1); }
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
<nav id="nav">
|
||||
<div class="nav-inner">
|
||||
<a href="/" class="nav-logo" aria-label="Neuron home"><img src="/assets/brand/neuron-wordmark-on-light.png" srcset="/assets/brand/neuron-wordmark-on-light@2x.png 2x" alt="Neuron" height="28"></a>
|
||||
<div class="nav-links">
|
||||
<a href="/#how-it-works" class="nav-link">How it works</a>
|
||||
<div class="nav-dropdown">
|
||||
<button class="nav-link nav-dropdown-btn" aria-haspopup="true" aria-expanded="false">Mission ▾</button>
|
||||
<div class="nav-dropdown-menu">
|
||||
<a href="/#mission" class="nav-dropdown-item">Our mission</a>
|
||||
<a href="/#safety" class="nav-dropdown-item">Safety</a>
|
||||
<a href="/#environmental" class="nav-dropdown-item">Environment</a>
|
||||
</div>
|
||||
</div>
|
||||
<a href="/#pricing" class="nav-link">Pricing</a>
|
||||
<a href="/#marketplace" class="nav-link">Marketplace</a>
|
||||
<a href="/#enterprise" class="nav-link">Enterprise</a>
|
||||
<a href="/about" class="nav-link">About</a>
|
||||
<a href="/said" class="nav-link">Gallery</a>
|
||||
<a href="/account" class="nav-link">Account</a>
|
||||
<a href="/#pricing" class="nav-cta">Get Access</a>
|
||||
</div>
|
||||
<button class="nav-hamburger" id="nav-hamburger" aria-label="Open navigation" aria-expanded="false" aria-controls="nav-mobile">
|
||||
<span></span><span></span><span></span>
|
||||
</button>
|
||||
<div class="nav-mobile" id="nav-mobile" role="navigation" aria-label="Mobile navigation">
|
||||
<a href="/#how-it-works" class="nav-mobile-link">How it works</a>
|
||||
<a href="/#mission" class="nav-mobile-link">Mission</a>
|
||||
<a href="/#safety" class="nav-mobile-link" style="padding-left:1.75rem;font-size:.8rem;color:var(--t3)">- Safety</a>
|
||||
<a href="/#environmental" class="nav-mobile-link" style="padding-left:1.75rem;font-size:.8rem;color:var(--t3)">- Environment</a>
|
||||
<a href="/#pricing" class="nav-mobile-link">Pricing</a>
|
||||
<a href="/#enterprise" class="nav-mobile-link">Enterprise</a>
|
||||
<a href="/about" class="nav-mobile-link">About</a>
|
||||
<a href="/said" class="nav-mobile-link">Gallery</a>
|
||||
<a href="/account" class="nav-mobile-link">Account</a>
|
||||
<a href="/#pricing" class="nav-mobile-cta">Get Access</a>
|
||||
</div>
|
||||
</div>
|
||||
</nav>
|
||||
|
||||
<div class="gallery-wrap">
|
||||
<div class="gallery-header">
|
||||
<p class="label" style="margin-bottom:1rem">Things Neuron Said</p>
|
||||
<h1 class="display-lg" style="margin-bottom:1rem">Real conversations.<br>No curation.</h1>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:.9375rem;color:var(--t2);line-height:1.75;max-width:36rem">
|
||||
People chatted with Neuron and shared the exchanges that mattered. Voted up by readers. The best ones rise.
|
||||
</p>
|
||||
</div>
|
||||
<div class="gallery-controls">
|
||||
<input type="search" id="gal-search" class="gallery-search" placeholder="Search conversations..." autocomplete="off">
|
||||
<div style="display:flex;gap:.5rem;flex-shrink:0">
|
||||
<button class="sort-btn active" id="sort-top" onclick="setSort('top',this)">Top</button>
|
||||
<button class="sort-btn" id="sort-new" onclick="setSort('new',this)">Newest</button>
|
||||
</div>
|
||||
</div>
|
||||
<div class="gallery-grid" id="gallery-grid">{raw(cards_html)}{raw(empty_html)}</div>
|
||||
<div id="no-results" style="display:none;padding:3rem 0;text-align:center">
|
||||
<p style="font-family:var(--body);font-weight:300;color:var(--t3)">No conversations match that search.</p>
|
||||
</div>
|
||||
<div style="margin-top:3rem">
|
||||
<a href="/" class="btn-ghost">← Back to site</a>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<!-- Magic-link sign-in modal -->
|
||||
<div class="signin-modal" id="signin-modal" role="dialog" aria-modal="true" aria-labelledby="signin-title">
|
||||
<div class="signin-modal-card">
|
||||
<h2 id="signin-title">Sign in to vote</h2>
|
||||
<p>We will email you a sign-in link. No password needed.</p>
|
||||
<input type="email" id="signin-email" placeholder="your@email.com" autocomplete="email">
|
||||
<div class="signin-modal-actions">
|
||||
<button type="button" class="signin-modal-cancel" id="signin-cancel">Cancel</button>
|
||||
<button type="button" class="btn-primary" id="signin-send">Send link</button>
|
||||
</div>
|
||||
<p class="signin-modal-msg" id="signin-msg"></p>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<script src="https://cdn.jsdelivr.net/npm/@supabase/supabase-js@2/dist/umd/supabase.min.js"></script>
|
||||
<script>
|
||||
window.NEURON_CFG=window.NEURON_CFG||{};
|
||||
window.NEURON_CFG.supabase_url="{supabase_url}";
|
||||
window.NEURON_CFG.supabase_anon_key="{supabase_anon_key}";
|
||||
</script>
|
||||
<script src="/js/gallery.js" defer></script>
|
||||
</body>
|
||||
</html>
|
||||
let all_css: String = gallery_css_base() + gallery_css_nav() + gallery_css_gallery() + gallery_css_modal()
|
||||
let style_block: String = "<style>" + all_css + "</style>"
|
||||
|
||||
let head_html: String =
|
||||
el_meta_charset("UTF-8") +
|
||||
"<meta name=\"viewport\" content=\"width=device-width,initial-scale=1\">" +
|
||||
el_title("Things Neuron Said") +
|
||||
el_meta("description", "Real conversations with Neuron, voted up by users.") +
|
||||
"<link rel=\"icon\" type=\"image/png\" sizes=\"32x32\" href=\"/assets/favicon-32.png\">" +
|
||||
"<link rel=\"preconnect\" href=\"https://fonts.googleapis.com\">" +
|
||||
"<link rel=\"preconnect\" href=\"https://fonts.gstatic.com\" crossorigin>" +
|
||||
"<link href=\"https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;1,400&family=IBM+Plex+Sans:wght@300;400;500;600&display=swap\" rel=\"stylesheet\">" +
|
||||
style_block
|
||||
|
||||
let sort_controls: String = el_div(
|
||||
"style=\"display:flex;gap:.5rem;flex-shrink:0\"",
|
||||
el_button("class=\"sort-btn active\" id=\"sort-top\" onclick=\"setSort('top',this)\"", "Top") +
|
||||
el_button("class=\"sort-btn\" id=\"sort-new\" onclick=\"setSort('new',this)\"", "Newest")
|
||||
)
|
||||
let gallery_controls: String = el_div(
|
||||
"class=\"gallery-controls\"",
|
||||
el_input("search", "id=\"gal-search\" class=\"gallery-search\" placeholder=\"Search conversations...\" autocomplete=\"off\"") +
|
||||
sort_controls
|
||||
)
|
||||
|
||||
let no_results: String = el_div(
|
||||
"id=\"no-results\" style=\"display:none;padding:3rem 0;text-align:center\"",
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;color:var(--t3)\"", "No conversations match that search.")
|
||||
)
|
||||
|
||||
let gallery_header: String = el_div(
|
||||
"class=\"gallery-header\"",
|
||||
el_p("class=\"label\" style=\"margin-bottom:1rem\"", "Things Neuron Said") +
|
||||
el_h1("class=\"display-lg\" style=\"margin-bottom:1rem\"", "Real conversations." + el_br() + "No curation.") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:.9375rem;color:var(--t2);line-height:1.75;max-width:36rem\"",
|
||||
"People chatted with Neuron and shared the exchanges that mattered. Voted up by readers. The best ones rise."
|
||||
)
|
||||
)
|
||||
|
||||
let gallery_grid: String = el_div("class=\"gallery-grid\" id=\"gallery-grid\"", cards_html + empty_html)
|
||||
|
||||
let gallery_wrap: String = el_div(
|
||||
"class=\"gallery-wrap\"",
|
||||
gallery_header + gallery_controls + gallery_grid + no_results +
|
||||
el_div("style=\"margin-top:3rem\"", el_a("/", "class=\"btn-ghost\"", "← Back to site"))
|
||||
)
|
||||
|
||||
let signin_modal: String = el_div(
|
||||
"class=\"signin-modal\" id=\"signin-modal\" role=\"dialog\" aria-modal=\"true\" aria-labelledby=\"signin-title\"",
|
||||
el_div(
|
||||
"class=\"signin-modal-card\"",
|
||||
el_h2("id=\"signin-title\"", "Sign in to vote") +
|
||||
el_p("", "We will email you a sign-in link. No password needed.") +
|
||||
el_input("email", "id=\"signin-email\" placeholder=\"your@email.com\" autocomplete=\"email\"") +
|
||||
el_div(
|
||||
"class=\"signin-modal-actions\"",
|
||||
el_button("type=\"button\" class=\"signin-modal-cancel\" id=\"signin-cancel\"", "Cancel") +
|
||||
el_button("type=\"button\" class=\"btn-primary\" id=\"signin-send\"", "Send link")
|
||||
) +
|
||||
el_p("class=\"signin-modal-msg\" id=\"signin-msg\"", "")
|
||||
)
|
||||
)
|
||||
|
||||
let cfg_js: String = "window.NEURON_CFG=window.NEURON_CFG||{};window.NEURON_CFG.supabase_url=\"" + supabase_url + "\";window.NEURON_CFG.supabase_anon_key=\"" + supabase_anon_key + "\";"
|
||||
|
||||
let body_html: String =
|
||||
gallery_nav_html() +
|
||||
gallery_wrap +
|
||||
signin_modal +
|
||||
"<script src=\"https://cdn.jsdelivr.net/npm/@supabase/supabase-js@2/dist/umd/supabase.min.js\"></script>" +
|
||||
el_script_inline(cfg_js) +
|
||||
el_script_src("/js/gallery.js", true)
|
||||
|
||||
el_html_doc("en", head_html, body_html)
|
||||
}
|
||||
|
||||
+42
-24
@@ -4,34 +4,52 @@
|
||||
// Glow orbs are pure CSS absolute-positioned divs.
|
||||
// Entrance animations are CSS keyframes with class-based delays.
|
||||
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_h1(attrs: String, text: String) -> String
|
||||
extern fn el_a(href: String, attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
|
||||
fn hero() -> String {
|
||||
return <section id="hero" aria-label="Hero">
|
||||
<div class="glow-tl" aria-hidden="true"></div>
|
||||
<div class="glow-br" aria-hidden="true"></div>
|
||||
let glows: String =
|
||||
el_div("class=\"glow-tl\" aria-hidden=\"true\"", "") +
|
||||
el_div("class=\"glow-br\" aria-hidden=\"true\"", "")
|
||||
|
||||
<p class="label hero-label animate-up-1">One builder. Patented. No permission.</p>
|
||||
let label: String = el_p(
|
||||
"class=\"label hero-label animate-up-1\"",
|
||||
"One builder. Patented. No permission."
|
||||
)
|
||||
|
||||
<h1 class="display-xl hero-headline animate-up-2">
|
||||
Every AI resets when you close the tab.
|
||||
<em class="gold" style="font-style:normal">I built the one that doesn't.</em>
|
||||
</h1>
|
||||
let headline_em: String = el_span("class=\"gold\" style=\"font-style:normal\"",
|
||||
"I built the one that doesn't."
|
||||
)
|
||||
let headline: String = el_h1(
|
||||
"class=\"display-xl hero-headline animate-up-2\"",
|
||||
"Every AI resets when you close the tab. " + headline_em
|
||||
)
|
||||
|
||||
<p class="hero-sub animate-up-3">
|
||||
Runs on your machine. Remembers everything. Priced below ChatGPT on day one.
|
||||
</p>
|
||||
let sub: String = el_p(
|
||||
"class=\"hero-sub animate-up-3\"",
|
||||
"Runs on your machine. Remembers everything. Priced below ChatGPT on day one."
|
||||
)
|
||||
|
||||
<div class="hero-ctas animate-up-5">
|
||||
<a href="#pricing" class="btn-primary">
|
||||
Preorder <span>→</span>
|
||||
</a>
|
||||
<a href="#how-it-works" class="btn-ghost">
|
||||
See how it works
|
||||
</a>
|
||||
</div>
|
||||
let cta_primary: String = el_a(
|
||||
"#pricing",
|
||||
"class=\"btn-primary\"",
|
||||
"Preorder " + el_span("", "→")
|
||||
)
|
||||
let cta_ghost: String = el_a(
|
||||
"#how-it-works",
|
||||
"class=\"btn-ghost\"",
|
||||
"See how it works"
|
||||
)
|
||||
let ctas: String = el_div("class=\"hero-ctas animate-up-5\"", cta_primary + cta_ghost)
|
||||
|
||||
<div class="hero-scroll" aria-hidden="true">
|
||||
<span>Scroll</span>
|
||||
<div class="hero-scroll-line"></div>
|
||||
</div>
|
||||
</section>
|
||||
let scroll_inner: String =
|
||||
el_span("", "Scroll") +
|
||||
el_div("class=\"hero-scroll-line\"", "")
|
||||
let scroll: String = el_div("class=\"hero-scroll\" aria-hidden=\"true\"", scroll_inner)
|
||||
|
||||
el_section("id=\"hero\" aria-label=\"Hero\"", glows + label + headline + sub + ctas + scroll)
|
||||
}
|
||||
|
||||
+56
-43
@@ -1,52 +1,65 @@
|
||||
// components/how_it_works.el - "Three moments. Permanent context." steps.
|
||||
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_h3(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_br() -> String
|
||||
|
||||
fn how_it_works() -> String {
|
||||
return <section id="how-it-works" aria-label="How it works">
|
||||
<div class="container">
|
||||
let header: String = el_div(
|
||||
"class=\"hiw-header\"",
|
||||
el_div("class=\"navy-line\" style=\"margin-bottom:5rem\"", "") +
|
||||
el_div(
|
||||
"class=\"hiw-label-row reveal\"",
|
||||
el_div("class=\"navy-line-left\" style=\"width:4rem;flex-shrink:0\"", "") +
|
||||
el_span("class=\"label\"", "How it works")
|
||||
) +
|
||||
el_h2(
|
||||
"class=\"display-lg hiw-headline reveal\" style=\"transition-delay:80ms\"",
|
||||
"Three moments." + el_br() + el_span("class=\"gold\"", "Permanent context.")
|
||||
)
|
||||
)
|
||||
|
||||
<div class="hiw-header">
|
||||
<div class="navy-line" style="margin-bottom:5rem"></div>
|
||||
<div class="hiw-label-row reveal">
|
||||
<div class="navy-line-left" style="width:4rem;flex-shrink:0"></div>
|
||||
<span class="label">How it works</span>
|
||||
</div>
|
||||
<h2 class="display-lg hiw-headline reveal" style="transition-delay:80ms">
|
||||
Three moments.<br>
|
||||
<span class="gold">Permanent context.</span>
|
||||
</h2>
|
||||
</div>
|
||||
let step1: String = el_div(
|
||||
"class=\"reveal\"",
|
||||
el_div(
|
||||
"class=\"step-circle-row\"",
|
||||
el_div("class=\"step-circle\"", el_span("class=\"step-num\"", "01")) +
|
||||
el_span("class=\"step-aside\"", "5 minutes")
|
||||
) +
|
||||
el_h3("class=\"display-md step-title\"", "Create your account") +
|
||||
el_p("class=\"step-body\"", "Sign up once. Your account links your license key to your identity - that's what keeps your memory yours and nobody else's. Then install with a single command. Runs locally. No cloud sync, no permissions you didn't grant.")
|
||||
)
|
||||
|
||||
<div class="steps-grid">
|
||||
let step2: String = el_div(
|
||||
"class=\"reveal\" style=\"transition-delay:180ms\"",
|
||||
el_div(
|
||||
"class=\"step-circle-row\"",
|
||||
el_div("class=\"step-circle\"", el_span("class=\"step-num\"", "02")) +
|
||||
el_span("class=\"step-aside\"", "Just once")
|
||||
) +
|
||||
el_h3("class=\"display-md step-title\"", "Your first session") +
|
||||
el_p("class=\"step-body\"", "Introduce yourself once. Neuron builds a model of your work, your preferences, and your context from the first conversation.")
|
||||
)
|
||||
|
||||
<div class="reveal">
|
||||
<div class="step-circle-row">
|
||||
<div class="step-circle"><span class="step-num">01</span></div>
|
||||
<span class="step-aside">5 minutes</span>
|
||||
</div>
|
||||
<h3 class="display-md step-title">Create your account</h3>
|
||||
<p class="step-body">Sign up once. Your account links your license key to your identity - that's what keeps your memory yours and nobody else's. Then install with a single command. Runs locally. No cloud sync, no permissions you didn't grant.</p>
|
||||
</div>
|
||||
let step3: String = el_div(
|
||||
"class=\"reveal\" style=\"transition-delay:360ms\"",
|
||||
el_div(
|
||||
"class=\"step-circle-row\"",
|
||||
el_div("class=\"step-circle\"", el_span("class=\"step-num\"", "03")) +
|
||||
el_span("class=\"step-aside\"", "Every session")
|
||||
) +
|
||||
el_h3("class=\"display-md step-title\"", "Never start over") +
|
||||
el_p("class=\"step-body\"", "Open a new session days or months later. Neuron remembers. Every project, every decision, every thread - exactly where you left it.")
|
||||
)
|
||||
|
||||
<div class="reveal" style="transition-delay:180ms">
|
||||
<div class="step-circle-row">
|
||||
<div class="step-circle"><span class="step-num">02</span></div>
|
||||
<span class="step-aside">Just once</span>
|
||||
</div>
|
||||
<h3 class="display-md step-title">Your first session</h3>
|
||||
<p class="step-body">Introduce yourself once. Neuron builds a model of your work, your preferences, and your context from the first conversation.</p>
|
||||
</div>
|
||||
let steps_grid: String = el_div("class=\"steps-grid\"", step1 + step2 + step3)
|
||||
|
||||
<div class="reveal" style="transition-delay:360ms">
|
||||
<div class="step-circle-row">
|
||||
<div class="step-circle"><span class="step-num">03</span></div>
|
||||
<span class="step-aside">Every session</span>
|
||||
</div>
|
||||
<h3 class="display-md step-title">Never start over</h3>
|
||||
<p class="step-body">Open a new session days or months later. Neuron remembers. Every project, every decision, every thread - exactly where you left it.</p>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</section>
|
||||
el_section(
|
||||
"id=\"how-it-works\" aria-label=\"How it works\"",
|
||||
el_div("class=\"container\"", header + steps_grid)
|
||||
)
|
||||
}
|
||||
|
||||
+71
-51
@@ -1,59 +1,79 @@
|
||||
// components/inference.el - Neuron inference section.
|
||||
// "My model. My infrastructure. Cheaper than theirs."
|
||||
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
|
||||
fn inference() -> String {
|
||||
return <section id="inference" aria-label="Neuron inference">
|
||||
<div class="container">
|
||||
<div class="inference-grid">
|
||||
let label_row: String = el_div(
|
||||
"class=\"inference-label-row reveal\"",
|
||||
el_div("class=\"navy-line-left\" style=\"width:3rem;flex-shrink:0\"", "") +
|
||||
el_span("class=\"label\"", "Neuron inference - Q3 2026")
|
||||
)
|
||||
|
||||
<div>
|
||||
<div class="inference-label-row reveal">
|
||||
<div class="navy-line-left" style="width:3rem;flex-shrink:0"></div>
|
||||
<span class="label">Neuron inference - Q3 2026</span>
|
||||
</div>
|
||||
<h2 class="display-lg inference-headline reveal" style="transition-delay:80ms">
|
||||
My model. My infrastructure.
|
||||
<span class="gold"> Targeting Q3 2026.</span>
|
||||
</h2>
|
||||
<p class="inference-body reveal" style="transition-delay:160ms">
|
||||
Four companies control nearly all frontier AI inference today. Every query you send strengthens their position - and their pricing power over you. That changes in Q3 2026 - sooner if we can.
|
||||
</p>
|
||||
<p class="inference-body reveal" style="transition-delay:240ms">
|
||||
Neuron will be both the product and the model. Purpose-built for how Neuron thinks, how your context is structured, how to do more with fewer tokens. It will run on Soma, our own inference infrastructure. Priced below OpenAI, Anthropic, and Google. Not as a loss leader. As a permanent competitive position.
|
||||
</p>
|
||||
<p class="inference-body reveal" style="transition-delay:320ms">
|
||||
Until then: bring your own API keys - Anthropic, OpenAI, whoever. When Neuron Inference launches, it will be cheaper, faster, and purpose-built for Neuron. You can switch whenever you want.
|
||||
</p>
|
||||
<p class="inference-body reveal" style="transition-delay:400ms">
|
||||
Every user on Neuron inference is compute that doesn't flow to the monopoly. That's not just a cost story. It's a power one.
|
||||
</p>
|
||||
</div>
|
||||
let headline: String = el_h2(
|
||||
"class=\"display-lg inference-headline reveal\" style=\"transition-delay:80ms\"",
|
||||
"My model. My infrastructure." +
|
||||
el_span("class=\"gold\"", " Targeting Q3 2026.")
|
||||
)
|
||||
|
||||
<div class="inference-stats">
|
||||
<div class="stat-row reveal">
|
||||
<div class="stat-row-head">
|
||||
<span class="stat-num">4</span>
|
||||
<span class="stat-label">Companies control frontier inference</span>
|
||||
</div>
|
||||
<p class="stat-body">OpenAI, Google, Anthropic, Meta. Nearly every AI query flows through them. We're building the exit ramp.</p>
|
||||
</div>
|
||||
<div class="stat-row reveal" style="transition-delay:120ms">
|
||||
<div class="stat-row-head">
|
||||
<span class="stat-num">Neuron</span>
|
||||
<span class="stat-label">The model - Q3 2026</span>
|
||||
</div>
|
||||
<p class="stat-body">A model built for Neuron specifically - not a generic wrapper. Your full context, years of accumulated intelligence, purpose-built inference. The model is the floor. Neuron is the ceiling.</p>
|
||||
</div>
|
||||
<div class="stat-row reveal" style="transition-delay:240ms">
|
||||
<div class="stat-row-head">
|
||||
<span class="stat-num">< theirs</span>
|
||||
<span class="stat-label">Priced below the incumbents</span>
|
||||
</div>
|
||||
<p class="stat-body">Below OpenAI pricing at launch. Below Anthropic. Below Google. Metered - you pay for what you use. And cheaper than any of them on every tier.</p>
|
||||
</div>
|
||||
</div>
|
||||
let body_col: String = el_div(
|
||||
"",
|
||||
label_row +
|
||||
headline +
|
||||
el_p("class=\"inference-body reveal\" style=\"transition-delay:160ms\"",
|
||||
"Four companies control nearly all frontier AI inference today. Every query you send strengthens their position - and their pricing power over you. That changes in Q3 2026 - sooner if we can."
|
||||
) +
|
||||
el_p("class=\"inference-body reveal\" style=\"transition-delay:240ms\"",
|
||||
"Neuron will be both the product and the model. Purpose-built for how Neuron thinks, how your context is structured, how to do more with fewer tokens. It will run on Soma, our own inference infrastructure. Priced below OpenAI, Anthropic, and Google. Not as a loss leader. As a permanent competitive position."
|
||||
) +
|
||||
el_p("class=\"inference-body reveal\" style=\"transition-delay:320ms\"",
|
||||
"Until then: bring your own API keys - Anthropic, OpenAI, whoever. When Neuron Inference launches, it will be cheaper, faster, and purpose-built for Neuron. You can switch whenever you want."
|
||||
) +
|
||||
el_p("class=\"inference-body reveal\" style=\"transition-delay:400ms\"",
|
||||
"Every user on Neuron inference is compute that doesn't flow to the monopoly. That's not just a cost story. It's a power one."
|
||||
)
|
||||
)
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
let stat1: String = el_div(
|
||||
"class=\"stat-row reveal\"",
|
||||
el_div(
|
||||
"class=\"stat-row-head\"",
|
||||
el_span("class=\"stat-num\"", "4") +
|
||||
el_span("class=\"stat-label\"", "Companies control frontier inference")
|
||||
) +
|
||||
el_p("class=\"stat-body\"", "OpenAI, Google, Anthropic, Meta. Nearly every AI query flows through them. We're building the exit ramp.")
|
||||
)
|
||||
|
||||
let stat2: String = el_div(
|
||||
"class=\"stat-row reveal\" style=\"transition-delay:120ms\"",
|
||||
el_div(
|
||||
"class=\"stat-row-head\"",
|
||||
el_span("class=\"stat-num\"", "Neuron") +
|
||||
el_span("class=\"stat-label\"", "The model - Q3 2026")
|
||||
) +
|
||||
el_p("class=\"stat-body\"", "A model built for Neuron specifically - not a generic wrapper. Your full context, years of accumulated intelligence, purpose-built inference. The model is the floor. Neuron is the ceiling.")
|
||||
)
|
||||
|
||||
let stat3: String = el_div(
|
||||
"class=\"stat-row reveal\" style=\"transition-delay:240ms\"",
|
||||
el_div(
|
||||
"class=\"stat-row-head\"",
|
||||
el_span("class=\"stat-num\"", "< theirs") +
|
||||
el_span("class=\"stat-label\"", "Priced below the incumbents")
|
||||
) +
|
||||
el_p("class=\"stat-body\"", "Below OpenAI pricing at launch. Below Anthropic. Below Google. Metered - you pay for what you use. And cheaper than any of them on every tier.")
|
||||
)
|
||||
|
||||
let stats_col: String = el_div("class=\"inference-stats\"", stat1 + stat2 + stat3)
|
||||
|
||||
let grid: String = el_div("class=\"inference-grid\"", body_col + stats_col)
|
||||
|
||||
el_section(
|
||||
"id=\"inference\" aria-label=\"Neuron inference\"",
|
||||
el_div("class=\"container\"", grid)
|
||||
)
|
||||
}
|
||||
|
||||
+82
-69
@@ -1,81 +1,94 @@
|
||||
// components/local_first.el - Privacy principles / local-first manifesto.
|
||||
// Left: manifesto text. Right: six sticky principles.
|
||||
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_strong(children: String) -> String
|
||||
|
||||
fn local_first() -> String {
|
||||
return <section id="local-first" aria-label="Local-first">
|
||||
<div class="container-lg">
|
||||
let label_row: String = el_div(
|
||||
"class=\"lf-label-row reveal\"",
|
||||
el_div("class=\"navy-line-left\" style=\"width:3rem;flex-shrink:0\"", "") +
|
||||
el_span("class=\"label\" style=\"color:var(--navy-85)\"", "Local first")
|
||||
)
|
||||
|
||||
<div class="lf-label-row reveal">
|
||||
<div class="navy-line-left" style="width:3rem;flex-shrink:0"></div>
|
||||
<span class="label" style="color:var(--navy-85)">Local first</span>
|
||||
</div>
|
||||
let manifesto_closer: String = el_div(
|
||||
"class=\"lf-manifesto-closer reveal\" style=\"transition-delay:600ms\"",
|
||||
el_p("",
|
||||
"Neuron is a direct rejection of that model. It runs on your machine. " +
|
||||
el_strong("Your memory never leaves.") +
|
||||
" I don't sell data, serve ads, or profile you. The only thing I sell is the software - and once you have it, it's yours."
|
||||
)
|
||||
)
|
||||
|
||||
<div class="lf-grid">
|
||||
let left_col: String = el_div(
|
||||
"",
|
||||
el_h2("class=\"display-lg lf-headline reveal\"", "You are not the product.") +
|
||||
el_p("class=\"lf-manifesto-para reveal\" style=\"transition-delay:100ms\"",
|
||||
"The company that gave you free search built the most powerful ad-targeting machine in history. The one that promised to connect the world optimized it for outrage - because outrage drives engagement, and engagement drives revenue. The one that gave everyone a voice sold that attention to the highest bidder. These aren't accidents. They're the business model."
|
||||
) +
|
||||
el_p("class=\"lf-manifesto-para reveal\" style=\"transition-delay:200ms\"",
|
||||
"I've watched this play out across two decades. Every free product is the same transaction: something useful in exchange for something you didn't know you were selling - your attention, your behavior, your future choices. The product is always “free.” The price is always you."
|
||||
) +
|
||||
el_p("class=\"lf-manifesto-para reveal\" style=\"transition-delay:300ms\"",
|
||||
"The harm is real. Teenage depression rates tracked the rise of algorithmic social feeds. Political polarization accelerated when engagement algorithms learned that outrage outperformed nuance. Billions of people had their data harvested, leaked, and weaponized - often without knowing. Democratic processes were manipulated at scale. And in every case, the companies responsible kept growing."
|
||||
) +
|
||||
el_p("class=\"lf-manifesto-para reveal\" style=\"transition-delay:400ms\"",
|
||||
"Now AI is doing the same thing - faster and deeper. Your queries train their models. Your thought patterns become datasets. The way you reason, what you struggle with, what you're afraid of - it's all captured. You get a useful tool. They get a map of your mind."
|
||||
) +
|
||||
manifesto_closer
|
||||
)
|
||||
|
||||
<div>
|
||||
<h2 class="display-lg lf-headline reveal">You are not the product.</h2>
|
||||
let principle1: String = el_div(
|
||||
"class=\"lf-principle reveal\"",
|
||||
el_p("class=\"lf-principle-label\"", "Your machine. Full stop.") +
|
||||
el_p("class=\"lf-principle-body\"", "Neuron runs on your hardware. The memory, the agent loop, every conversation - none of it leaves your machine. Not to my servers. Not to anyone's.")
|
||||
)
|
||||
let principle2: String = el_div(
|
||||
"class=\"lf-principle reveal\" style=\"transition-delay:120ms\"",
|
||||
el_p("class=\"lf-principle-label\"", "No training on your data.") +
|
||||
el_p("class=\"lf-principle-body\"", "Your queries don't improve a model you don't own. Your patterns aren't analyzed to serve you better ads. Your context belongs to you - not a training pipeline.")
|
||||
)
|
||||
let principle3: String = el_div(
|
||||
"class=\"lf-principle reveal\" style=\"transition-delay:240ms\"",
|
||||
el_p("class=\"lf-principle-label\"", "No ads. Ever.") +
|
||||
el_p("class=\"lf-principle-body\"", "Not on the free tier. Not on paid. Not in any future version. Ads require surveillance. Surveillance requires your data. I'm not building that.")
|
||||
)
|
||||
let principle4: String = el_div(
|
||||
"class=\"lf-principle reveal\" style=\"transition-delay:360ms\"",
|
||||
el_p("class=\"lf-principle-label\"", "No telemetry for local use.") +
|
||||
el_p("class=\"lf-principle-body\"", "When Neuron runs locally, I don't collect usage data. When you opt into Neuron cloud services - sync, backup, inbox - those services use the data they need to function. Nothing more.")
|
||||
)
|
||||
let principle5: String = el_div(
|
||||
"class=\"lf-principle reveal\" style=\"transition-delay:480ms\"",
|
||||
el_p("class=\"lf-principle-label\"", "Nothing to breach.") +
|
||||
el_p("class=\"lf-principle-body\"", "I can't be hacked for your data because I don't have it. I can't be subpoenaed for your conversations because I've never seen them. I can't expose what I've never held. Your data living on your machine isn't just a privacy stance - it's a security one.")
|
||||
)
|
||||
let principle6: String = el_div(
|
||||
"class=\"lf-principle reveal\" style=\"transition-delay:600ms\"",
|
||||
el_p("class=\"lf-principle-label\"", "Unreadable even if taken.") +
|
||||
el_p("class=\"lf-principle-body\"", "Everything Neuron touches is encrypted with post-quantum cryptography - ML-KEM for key exchange, ML-DSA for signatures. Both are NIST-finalized standards (FIPS 203/204), already deployed at scale across the web. Designed to withstand quantum computers, not just the ones that exist today.")
|
||||
)
|
||||
|
||||
<p class="lf-manifesto-para reveal" style="transition-delay:100ms">
|
||||
The company that gave you free search built the most powerful ad-targeting machine in history. The one that promised to connect the world optimized it for outrage - because outrage drives engagement, and engagement drives revenue. The one that gave everyone a voice sold that attention to the highest bidder. These aren't accidents. They're the business model.
|
||||
</p>
|
||||
<p class="lf-manifesto-para reveal" style="transition-delay:200ms">
|
||||
I've watched this play out across two decades. Every free product is the same transaction: something useful in exchange for something you didn't know you were selling - your attention, your behavior, your future choices. The product is always “free.” The price is always you.
|
||||
</p>
|
||||
<p class="lf-manifesto-para reveal" style="transition-delay:300ms">
|
||||
The harm is real. Teenage depression rates tracked the rise of algorithmic social feeds. Political polarization accelerated when engagement algorithms learned that outrage outperformed nuance. Billions of people had their data harvested, leaked, and weaponized - often without knowing. Democratic processes were manipulated at scale. And in every case, the companies responsible kept growing.
|
||||
</p>
|
||||
<p class="lf-manifesto-para reveal" style="transition-delay:400ms">
|
||||
Now AI is doing the same thing - faster and deeper. Your queries train their models. Your thought patterns become datasets. The way you reason, what you struggle with, what you're afraid of - it's all captured. You get a useful tool. They get a map of your mind.
|
||||
</p>
|
||||
<div class="lf-manifesto-closer reveal" style="transition-delay:600ms">
|
||||
<p>
|
||||
Neuron is a direct rejection of that model. It runs on your machine. <strong>Your memory never leaves.</strong> I don't sell data, serve ads, or profile you. The only thing I sell is the software - and once you have it, it's yours.
|
||||
</p>
|
||||
</div>
|
||||
</div>
|
||||
let right_col: String = el_div(
|
||||
"class=\"lf-principles\"",
|
||||
principle1 + principle2 + principle3 + principle4 + principle5 + principle6
|
||||
)
|
||||
|
||||
<div class="lf-principles">
|
||||
let grid: String = el_div("class=\"lf-grid\"", left_col + right_col)
|
||||
|
||||
<div class="lf-principle reveal">
|
||||
<p class="lf-principle-label">Your machine. Full stop.</p>
|
||||
<p class="lf-principle-body">Neuron runs on your hardware. The memory, the agent loop, every conversation - none of it leaves your machine. Not to my servers. Not to anyone's.</p>
|
||||
</div>
|
||||
let callout: String = el_div(
|
||||
"class=\"lf-callout reveal\"",
|
||||
el_p("class=\"lf-callout-h\"", "The industry remembers you for them.") +
|
||||
el_p("class=\"lf-callout-h2\"", "Neuron remembers you for you.") +
|
||||
el_p("class=\"lf-callout-sub\"", "Local-first isn't a feature. It's a commitment.")
|
||||
)
|
||||
|
||||
<div class="lf-principle reveal" style="transition-delay:120ms">
|
||||
<p class="lf-principle-label">No training on your data.</p>
|
||||
<p class="lf-principle-body">Your queries don't improve a model you don't own. Your patterns aren't analyzed to serve you better ads. Your context belongs to you - not a training pipeline.</p>
|
||||
</div>
|
||||
|
||||
<div class="lf-principle reveal" style="transition-delay:240ms">
|
||||
<p class="lf-principle-label">No ads. Ever.</p>
|
||||
<p class="lf-principle-body">Not on the free tier. Not on paid. Not in any future version. Ads require surveillance. Surveillance requires your data. I'm not building that.</p>
|
||||
</div>
|
||||
|
||||
<div class="lf-principle reveal" style="transition-delay:360ms">
|
||||
<p class="lf-principle-label">No telemetry for local use.</p>
|
||||
<p class="lf-principle-body">When Neuron runs locally, I don't collect usage data. When you opt into Neuron cloud services - sync, backup, inbox - those services use the data they need to function. Nothing more.</p>
|
||||
</div>
|
||||
|
||||
<div class="lf-principle reveal" style="transition-delay:480ms">
|
||||
<p class="lf-principle-label">Nothing to breach.</p>
|
||||
<p class="lf-principle-body">I can't be hacked for your data because I don't have it. I can't be subpoenaed for your conversations because I've never seen them. I can't expose what I've never held. Your data living on your machine isn't just a privacy stance - it's a security one.</p>
|
||||
</div>
|
||||
|
||||
<div class="lf-principle reveal" style="transition-delay:600ms">
|
||||
<p class="lf-principle-label">Unreadable even if taken.</p>
|
||||
<p class="lf-principle-body">Everything Neuron touches is encrypted with post-quantum cryptography - ML-KEM for key exchange, ML-DSA for signatures. Both are NIST-finalized standards (FIPS 203/204), already deployed at scale across the web. Designed to withstand quantum computers, not just the ones that exist today.</p>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="lf-callout reveal">
|
||||
<p class="lf-callout-h">The industry remembers you for them.</p>
|
||||
<p class="lf-callout-h2">Neuron remembers you for you.</p>
|
||||
<p class="lf-callout-sub">Local-first isn't a feature. It's a commitment.</p>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</section>
|
||||
el_section(
|
||||
"id=\"local-first\" aria-label=\"Local-first\"",
|
||||
el_div("class=\"container-lg\"", label_row + grid + callout)
|
||||
)
|
||||
}
|
||||
|
||||
+163
-130
@@ -1,140 +1,119 @@
|
||||
// components/marketplace.el - Marketplace section.
|
||||
// Explains the plugin marketplace - what it is, how it works, coming soon.
|
||||
|
||||
fn marketplace() -> String {
|
||||
return <section id="marketplace" aria-label="Neuron Marketplace">
|
||||
<div class="container">
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_h3(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_button(attrs: String, label: String) -> String
|
||||
extern fn el_form(attrs: String, children: String) -> String
|
||||
extern fn el_label(for_id: String, attrs: String, children: String) -> String
|
||||
extern fn el_input(type_attr: String, attrs: String) -> String
|
||||
extern fn el_textarea(attrs: String, value: String) -> String
|
||||
extern fn el_script_src(src: String, defer_load: Bool) -> String
|
||||
|
||||
<div class="marketplace-header">
|
||||
<div class="marketplace-label-row reveal">
|
||||
<div class="navy-line-left" style="width:4rem;flex-shrink:0"></div>
|
||||
<span class="label" style="color:var(--navy-85)">Marketplace</span>
|
||||
<div style="margin-left:1rem;background:rgba(0,82,160,.1);color:var(--navy);font-family:var(--body);font-size:0.65rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;padding:0.25rem 0.75rem;border-radius:2px">Coming soon</div>
|
||||
</div>
|
||||
fn marketplace_svg1() -> String {
|
||||
"<svg width=\"28\" height=\"28\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">" +
|
||||
"<path d=\"M12 2L2 7l10 5 10-5-10-5z\"/><path d=\"M2 17l10 5 10-5\"/><path d=\"M2 12l10 5 10-5\"/>" +
|
||||
"</svg>"
|
||||
}
|
||||
|
||||
<h2 class="display-lg reveal" style="transition-delay:80ms;max-width:38rem">
|
||||
Extend Neuron.<span class="gold" style="display:block">Build for it.</span>
|
||||
</h2>
|
||||
<p class="reveal" style="transition-delay:160ms;font-weight:300;font-size:.9375rem;color:var(--t2);line-height:1.75;max-width:36rem;margin-top:1.25rem">
|
||||
Neuron does one thing exceptionally well: it knows you. The Marketplace extends what it can do with that knowledge - connecting it to your tools, your workflows, and capabilities built by people who understand your domain better than any general-purpose AI ever will.
|
||||
</p>
|
||||
</div>
|
||||
fn marketplace_svg2() -> String {
|
||||
"<svg width=\"28\" height=\"28\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">" +
|
||||
"<circle cx=\"12\" cy=\"12\" r=\"10\"/><path d=\"M12 8v4l3 3\"/>" +
|
||||
"</svg>"
|
||||
}
|
||||
|
||||
<div class="marketplace-grid reveal" style="transition-delay:200ms">
|
||||
fn marketplace_svg3() -> String {
|
||||
"<svg width=\"28\" height=\"28\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1.5\" stroke-linecap=\"round\" stroke-linejoin=\"round\" aria-hidden=\"true\">" +
|
||||
"<path d=\"M12 2v20M17 5H9.5a3.5 3.5 0 0 0 0 7h5a3.5 3.5 0 0 1 0 7H6\"/>" +
|
||||
"</svg>"
|
||||
}
|
||||
|
||||
<div class="marketplace-card card-dark">
|
||||
<div class="marketplace-card-icon">
|
||||
<svg width="28" height="28" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true">
|
||||
<path d="M12 2L2 7l10 5 10-5-10-5z"/><path d="M2 17l10 5 10-5"/><path d="M2 12l10 5 10-5"/>
|
||||
</svg>
|
||||
</div>
|
||||
<h3 class="display-md marketplace-card-title">Plugins that know you</h3>
|
||||
<p class="marketplace-card-body">Every plugin in the Marketplace has access to your memory - with your permission. A legal plugin knows your deal history. A coding plugin knows your architecture decisions. An email plugin knows your relationships and communication style. The context travels with you.</p>
|
||||
</div>
|
||||
fn marketplace_cards() -> String {
|
||||
let card1: String = el_div(
|
||||
"class=\"marketplace-card card-dark\"",
|
||||
el_div("class=\"marketplace-card-icon\"", marketplace_svg1()) +
|
||||
el_h3("class=\"display-md marketplace-card-title\"", "Plugins that know you") +
|
||||
el_p("class=\"marketplace-card-body\"", "Every plugin in the Marketplace has access to your memory - with your permission. A legal plugin knows your deal history. A coding plugin knows your architecture decisions. An email plugin knows your relationships and communication style. The context travels with you.")
|
||||
)
|
||||
let card2: String = el_div(
|
||||
"class=\"marketplace-card card-dark\" style=\"transition-delay:120ms\"",
|
||||
el_div("class=\"marketplace-card-icon\"", marketplace_svg2()) +
|
||||
el_h3("class=\"display-md marketplace-card-title\"", "Built by domain experts") +
|
||||
el_p("class=\"marketplace-card-body\"", "General AI is good at general things. The Marketplace is for specialists. The person building a plugin for contract attorneys or orthopedic surgeons or professional traders isn't us. It's someone who has spent years in that world. We give them the platform. They bring the depth.")
|
||||
)
|
||||
let card3: String = el_div(
|
||||
"class=\"marketplace-card card-dark\" style=\"transition-delay:240ms\"",
|
||||
el_div("class=\"marketplace-card-icon\"", marketplace_svg3()) +
|
||||
el_h3("class=\"display-md marketplace-card-title\"", "Revenue for builders") +
|
||||
el_p("class=\"marketplace-card-body\"", "Developers earn recurring revenue when users install their plugins. We handle billing, distribution, and the infrastructure. You handle the product. Every plugin that ships earns you a share of every subscription for as long as that user stays. Build once, earn indefinitely.")
|
||||
)
|
||||
el_div("class=\"marketplace-grid reveal\" style=\"transition-delay:200ms\"", card1 + card2 + card3)
|
||||
}
|
||||
|
||||
<div class="marketplace-card card-dark" style="transition-delay:120ms">
|
||||
<div class="marketplace-card-icon">
|
||||
<svg width="28" height="28" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true">
|
||||
<circle cx="12" cy="12" r="10"/><path d="M12 8v4l3 3"/>
|
||||
</svg>
|
||||
</div>
|
||||
<h3 class="display-md marketplace-card-title">Built by domain experts</h3>
|
||||
<p class="marketplace-card-body">General AI is good at general things. The Marketplace is for specialists. The person building a plugin for contract attorneys or orthopedic surgeons or professional traders isn't us. It's someone who has spent years in that world. We give them the platform. They bring the depth.</p>
|
||||
</div>
|
||||
fn marketplace_tags_block(label: String, tags: String) -> String {
|
||||
el_div(
|
||||
"style=\"margin-bottom:2rem\"",
|
||||
el_p("class=\"label\" style=\"margin-bottom:1rem;color:var(--navy-65)\"", label) +
|
||||
el_div("class=\"marketplace-tags\"", tags)
|
||||
)
|
||||
}
|
||||
|
||||
<div class="marketplace-card card-dark" style="transition-delay:240ms">
|
||||
<div class="marketplace-card-icon">
|
||||
<svg width="28" height="28" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" aria-hidden="true">
|
||||
<path d="M12 2v20M17 5H9.5a3.5 3.5 0 0 0 0 7h5a3.5 3.5 0 0 1 0 7H6"/>
|
||||
</svg>
|
||||
</div>
|
||||
<h3 class="display-md marketplace-card-title">Revenue for builders</h3>
|
||||
<p class="marketplace-card-body">Developers earn recurring revenue when users install their plugins. We handle billing, distribution, and the infrastructure. You handle the product. Every plugin that ships earns you a share of every subscription for as long as that user stays. Build once, earn indefinitely.</p>
|
||||
</div>
|
||||
fn marketplace_tag(t: String) -> String {
|
||||
el_span("class=\"marketplace-tag\"", t)
|
||||
}
|
||||
|
||||
</div>
|
||||
fn marketplace_categories() -> String {
|
||||
let connectors: String =
|
||||
marketplace_tag("Gmail") + marketplace_tag("Slack") + marketplace_tag("Google Calendar") + marketplace_tag("Google Drive") +
|
||||
marketplace_tag("Notion") + marketplace_tag("GitHub") + marketplace_tag("Linear") + marketplace_tag("More connectors at launch")
|
||||
let following: String =
|
||||
marketplace_tag("Process packets") + marketplace_tag("Knowledge packets")
|
||||
let imprints: String =
|
||||
marketplace_tag("CEO") + marketplace_tag("CTO") + marketplace_tag("CFO") + marketplace_tag("CMO") + marketplace_tag("COO") + marketplace_tag("More C-suite")
|
||||
|
||||
<div class="marketplace-categories reveal" style="transition-delay:320ms">
|
||||
el_div(
|
||||
"class=\"marketplace-categories reveal\" style=\"transition-delay:320ms\"",
|
||||
marketplace_tags_block("Connectors - day one", connectors) +
|
||||
marketplace_tags_block("Following launch", following) +
|
||||
el_div(
|
||||
"",
|
||||
el_p("class=\"label\" style=\"margin-bottom:1rem;color:var(--navy-65)\"", "Imprints - starting with") +
|
||||
el_div("class=\"marketplace-tags\"", imprints)
|
||||
)
|
||||
)
|
||||
}
|
||||
|
||||
<div style="margin-bottom:2rem">
|
||||
<p class="label" style="margin-bottom:1rem;color:var(--navy-65)">Connectors - day one</p>
|
||||
<div class="marketplace-tags">
|
||||
<span class="marketplace-tag">Gmail</span>
|
||||
<span class="marketplace-tag">Slack</span>
|
||||
<span class="marketplace-tag">Google Calendar</span>
|
||||
<span class="marketplace-tag">Google Drive</span>
|
||||
<span class="marketplace-tag">Notion</span>
|
||||
<span class="marketplace-tag">GitHub</span>
|
||||
<span class="marketplace-tag">Linear</span>
|
||||
<span class="marketplace-tag">More connectors at launch</span>
|
||||
</div>
|
||||
</div>
|
||||
fn marketplace_dev_form() -> String {
|
||||
let input_style: String = "class=\"dev-input\""
|
||||
let field_name: String = el_div(
|
||||
"class=\"dev-field\"",
|
||||
el_label("dev-name", "class=\"dev-label\"", "Name") +
|
||||
el_input("text", "id=\"dev-name\" required placeholder=\"Your name\" " + input_style)
|
||||
)
|
||||
let field_email: String = el_div(
|
||||
"class=\"dev-field\"",
|
||||
el_label("dev-email", "class=\"dev-label\"", "Email") +
|
||||
el_input("email", "id=\"dev-email\" required placeholder=\"you@example.com\" " + input_style)
|
||||
)
|
||||
let field_idea: String = el_div(
|
||||
"class=\"dev-field dev-field-full\"",
|
||||
el_label("dev-idea", "class=\"dev-label\"", "What do you want to build?") +
|
||||
el_textarea("id=\"dev-idea\" required rows=\"5\" placeholder=\"Tell me about the plugin or integration you have in mind...\" class=\"dev-input dev-textarea\"", "")
|
||||
)
|
||||
let submit_row: String = el_div(
|
||||
"class=\"dev-field-full\"",
|
||||
el_button("type=\"submit\" class=\"btn-primary\"", "Send interest →") +
|
||||
el_p("id=\"dev-msg\" style=\"font-family:var(--body);font-size:0.8rem;color:var(--t3);margin-top:0.75rem;display:none\"", "")
|
||||
)
|
||||
el_form("id=\"dev-form\" class=\"dev-form-grid\"", field_name + field_email + field_idea + submit_row)
|
||||
}
|
||||
|
||||
<div style="margin-bottom:2rem">
|
||||
<p class="label" style="margin-bottom:1rem;color:var(--navy-65)">Following launch</p>
|
||||
<div class="marketplace-tags">
|
||||
<span class="marketplace-tag">Process packets</span>
|
||||
<span class="marketplace-tag">Knowledge packets</span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div>
|
||||
<p class="label" style="margin-bottom:1rem;color:var(--navy-65)">Imprints - starting with</p>
|
||||
<div class="marketplace-tags">
|
||||
<span class="marketplace-tag">CEO</span>
|
||||
<span class="marketplace-tag">CTO</span>
|
||||
<span class="marketplace-tag">CFO</span>
|
||||
<span class="marketplace-tag">CMO</span>
|
||||
<span class="marketplace-tag">COO</span>
|
||||
<span class="marketplace-tag">More C-suite</span>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="marketplace-cta reveal" style="transition-delay:400ms">
|
||||
<div class="marketplace-cta-inner">
|
||||
<div>
|
||||
<p style="font-family:var(--body);font-weight:500;font-size:1rem;color:var(--t1);margin-bottom:0.5rem">Building something?</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.6">The developer program opens before the Marketplace does. If you're interested in building a plugin, get in touch early - early developers shape the API.</p>
|
||||
</div>
|
||||
<button onclick="document.getElementById('developer-interest').style.display='block';document.getElementById('developer-interest').scrollIntoView({behavior:'smooth',block:'start'});this.style.display='none';" class="btn-ghost" style="white-space:nowrap;flex-shrink:0">Developer interest →</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<!-- Developer interest form — hidden until button click -->
|
||||
<div id="developer-interest" class="container" style="display:none;margin-top:4rem;padding-top:4rem;border-top:1px solid rgba(0,82,160,.10)">
|
||||
<div style="max-width:42rem">
|
||||
<p class="label" style="margin-bottom:0.75rem;color:var(--navy-85)">Developer Program</p>
|
||||
<h3 style="font-family:var(--display);font-size:1.75rem;font-weight:400;color:var(--t1);letter-spacing:-0.01em;margin-bottom:1rem;line-height:1.2">Get early access</h3>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9rem;color:var(--t2);line-height:1.75;margin-bottom:2.5rem">The developer program opens before the Marketplace does. Early developers shape the plugin API. Tell me what you want to build.</p>
|
||||
<form id="dev-form" class="dev-form-grid">
|
||||
<div class="dev-field">
|
||||
<label for="dev-name" class="dev-label">Name</label>
|
||||
<input id="dev-name" type="text" required placeholder="Your name" class="dev-input">
|
||||
</div>
|
||||
<div class="dev-field">
|
||||
<label for="dev-email" class="dev-label">Email</label>
|
||||
<input id="dev-email" type="email" required placeholder="you@example.com" class="dev-input">
|
||||
</div>
|
||||
<div class="dev-field dev-field-full">
|
||||
<label for="dev-idea" class="dev-label">What do you want to build?</label>
|
||||
<textarea id="dev-idea" required rows="5" placeholder="Tell me about the plugin or integration you have in mind..." class="dev-input dev-textarea"></textarea>
|
||||
</div>
|
||||
<div class="dev-field-full">
|
||||
<button type="submit" class="btn-primary">Send interest →</button>
|
||||
<p id="dev-msg" style="font-family:var(--body);font-size:0.8rem;color:var(--t3);margin-top:0.75rem;display:none"></p>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<script src="/js/marketplace.js" defer></script>
|
||||
|
||||
<style>
|
||||
#marketplace { padding: 6rem 0; }
|
||||
fn marketplace_style() -> String {
|
||||
let css: String = "#marketplace { padding: 6rem 0; }
|
||||
.marketplace-header { margin-bottom: 4rem; }
|
||||
.marketplace-label-row { display: flex; align-items: center; gap: 1.5rem; margin-bottom: 2rem; }
|
||||
.marketplace-grid {
|
||||
@@ -187,8 +166,6 @@ fn marketplace() -> String {
|
||||
background: rgba(0,82,160,.02);
|
||||
}
|
||||
@media (max-width: 640px) { .marketplace-cta-inner { flex-direction: column; align-items: flex-start; } }
|
||||
|
||||
/* Developer interest form */
|
||||
.dev-form-grid {
|
||||
display: grid;
|
||||
grid-template-columns: 1fr 1fr;
|
||||
@@ -225,8 +202,64 @@ fn marketplace() -> String {
|
||||
border-color: var(--navy);
|
||||
box-shadow: 0 0 0 3px rgba(0,82,160,.08);
|
||||
}
|
||||
.dev-textarea { resize: vertical; min-height: 120px; }
|
||||
</style>
|
||||
|
||||
</section>
|
||||
.dev-textarea { resize: vertical; min-height: 120px; }"
|
||||
"<style>" + css + "</style>"
|
||||
}
|
||||
|
||||
fn marketplace() -> String {
|
||||
let header: String = el_div(
|
||||
"class=\"marketplace-header\"",
|
||||
el_div(
|
||||
"class=\"marketplace-label-row reveal\"",
|
||||
el_div("class=\"navy-line-left\" style=\"width:4rem;flex-shrink:0\"", "") +
|
||||
el_span("class=\"label\" style=\"color:var(--navy-85)\"", "Marketplace") +
|
||||
el_div("style=\"margin-left:1rem;background:rgba(0,82,160,.1);color:var(--navy);font-family:var(--body);font-size:0.65rem;font-weight:500;letter-spacing:0.12em;text-transform:uppercase;padding:0.25rem 0.75rem;border-radius:2px\"", "Coming soon")
|
||||
) +
|
||||
el_h2(
|
||||
"class=\"display-lg reveal\" style=\"transition-delay:80ms;max-width:38rem\"",
|
||||
"Extend Neuron." + el_span("class=\"gold\" style=\"display:block\"", "Build for it.")
|
||||
) +
|
||||
el_p("class=\"reveal\" style=\"transition-delay:160ms;font-weight:300;font-size:.9375rem;color:var(--t2);line-height:1.75;max-width:36rem;margin-top:1.25rem\"",
|
||||
"Neuron does one thing exceptionally well: it knows you. The Marketplace extends what it can do with that knowledge - connecting it to your tools, your workflows, and capabilities built by people who understand your domain better than any general-purpose AI ever will."
|
||||
)
|
||||
)
|
||||
|
||||
let cta: String = el_div(
|
||||
"class=\"marketplace-cta reveal\" style=\"transition-delay:400ms\"",
|
||||
el_div(
|
||||
"class=\"marketplace-cta-inner\"",
|
||||
el_div(
|
||||
"",
|
||||
el_p("style=\"font-family:var(--body);font-weight:500;font-size:1rem;color:var(--t1);margin-bottom:0.5rem\"", "Building something?") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.6\"",
|
||||
"The developer program opens before the Marketplace does. If you're interested in building a plugin, get in touch early - early developers shape the API."
|
||||
)
|
||||
) +
|
||||
el_button(
|
||||
"onclick=\"document.getElementById('developer-interest').style.display='block';document.getElementById('developer-interest').scrollIntoView({behavior:'smooth',block:'start'});this.style.display='none';\" class=\"btn-ghost\" style=\"white-space:nowrap;flex-shrink:0\"",
|
||||
"Developer interest →"
|
||||
)
|
||||
)
|
||||
)
|
||||
|
||||
let dev_section: String = el_div(
|
||||
"id=\"developer-interest\" class=\"container\" style=\"display:none;margin-top:4rem;padding-top:4rem;border-top:1px solid rgba(0,82,160,.10)\"",
|
||||
el_div(
|
||||
"style=\"max-width:42rem\"",
|
||||
el_p("class=\"label\" style=\"margin-bottom:0.75rem;color:var(--navy-85)\"", "Developer Program") +
|
||||
el_h3("style=\"font-family:var(--display);font-size:1.75rem;font-weight:400;color:var(--t1);letter-spacing:-0.01em;margin-bottom:1rem;line-height:1.2\"", "Get early access") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9rem;color:var(--t2);line-height:1.75;margin-bottom:2.5rem\"",
|
||||
"The developer program opens before the Marketplace does. Early developers shape the plugin API. Tell me what you want to build."
|
||||
) +
|
||||
marketplace_dev_form()
|
||||
)
|
||||
)
|
||||
|
||||
el_section(
|
||||
"id=\"marketplace\" aria-label=\"Neuron Marketplace\"",
|
||||
el_div("class=\"container\"", header + marketplace_cards() + marketplace_categories() + cta) +
|
||||
dev_section +
|
||||
el_script_src("/js/marketplace.js", true) +
|
||||
marketplace_style()
|
||||
)
|
||||
}
|
||||
|
||||
+116
-77
@@ -1,91 +1,130 @@
|
||||
// components/mission.el - Origin story + manifesto + problems grid.
|
||||
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_strong(children: String) -> String
|
||||
extern fn el_a(href: String, attrs: String, children: String) -> String
|
||||
|
||||
fn mission() -> String {
|
||||
return <section id="mission" aria-label="Mission">
|
||||
<div class="container">
|
||||
let label_row: String = el_div(
|
||||
"class=\"mission-label-row reveal\"",
|
||||
el_div("class=\"navy-line-left\" style=\"width:4rem;flex-shrink:0\"", "") +
|
||||
el_span("class=\"label\"", "The mission") +
|
||||
el_div("style=\"height:1px;width:4rem;background:linear-gradient(to left,transparent,rgba(0,82,160,.35));flex-shrink:0\"", "")
|
||||
)
|
||||
|
||||
<div class="navy-line" style="margin-bottom:5rem"></div>
|
||||
let origin: String = el_div(
|
||||
"class=\"mission-origin\"",
|
||||
label_row +
|
||||
el_h2("class=\"display-lg mission-headline reveal\" style=\"transition-delay:80ms\"", "Why I built this") +
|
||||
el_p("class=\"mission-body-para reveal\" style=\"transition-delay:160ms\"",
|
||||
"Every AI tool you use today resets when you close the tab. It doesn't know you tomorrow. It doesn't remember what mattered yesterday. It can't grow with you over years."
|
||||
) +
|
||||
el_p("class=\"mission-body-para reveal\" style=\"transition-delay:240ms\"",
|
||||
"I built Neuron because intelligence should compound. The same way a great mentor gets more valuable the longer you work with them - knowing your context, your patterns, your goals - your AI should too."
|
||||
) +
|
||||
el_p("class=\"mission-body-para mission-body-emphasis reveal\" style=\"transition-delay:320ms\"",
|
||||
"Neuron is private by design. It runs on your hardware. " +
|
||||
el_strong("Your data never leaves your machine.") +
|
||||
" No training on your data. No telemetry. No cloud dependency."
|
||||
) +
|
||||
el_p("class=\"mission-body-para reveal\" style=\"transition-delay:400ms\"",
|
||||
"This isn't a chat interface. It's the AI that becomes yours."
|
||||
)
|
||||
)
|
||||
|
||||
<div class="mission-origin">
|
||||
<div class="mission-label-row reveal">
|
||||
<div class="navy-line-left" style="width:4rem;flex-shrink:0"></div>
|
||||
<span class="label">The mission</span>
|
||||
<div style="height:1px;width:4rem;background:linear-gradient(to left,transparent,rgba(0,82,160,.35));flex-shrink:0"></div>
|
||||
</div>
|
||||
<h2 class="display-lg mission-headline reveal" style="transition-delay:80ms">Why I built this</h2>
|
||||
let bigtech: String = el_div(
|
||||
"class=\"mission-bigtech reveal\" style=\"transition-delay:600ms\"",
|
||||
el_p("class=\"mission-bigtech-label\"", "Why I built this on my own") +
|
||||
el_p("",
|
||||
"I didn't just approach one of the largest technology companies in the world - I got the meeting. Got the NDAs signed. Created deliverables in real time. Showed them benchmarks with full auditability. Some of their own people understood immediately what it meant."
|
||||
) +
|
||||
el_p("",
|
||||
"They saw it. Seemed to engage meaningfully. Then, within two days, lawyers were involved. I decided to just finish the project on my own."
|
||||
) +
|
||||
el_p("class=\"muted\"",
|
||||
"Not: how do we solve this at scale? Not: what does this mean for the people we serve? Their instinct was to protect enterprise revenue and manage legal exposure. The actual human impact - the people whose lives those enterprises touch - didn't enter the conversation."
|
||||
) +
|
||||
el_p("class=\"muted\"",
|
||||
"That's the difference. " +
|
||||
"<strong style=\"color:var(--t1)\">They're optimizing for the enterprise. I'm building for the people those enterprises are supposed to serve.</strong>"
|
||||
) +
|
||||
el_p("",
|
||||
"I told them I could build and distribute this by myself. Maybe they didn't believe me. That meeting was April 22nd, 2026. I'm writing this on April 25th. You're looking at the proof. " +
|
||||
el_a("/checkout?plan=founding", "", "I hope you'll preorder it.")
|
||||
)
|
||||
)
|
||||
|
||||
<p class="mission-body-para reveal" style="transition-delay:160ms">
|
||||
Every AI tool you use today resets when you close the tab. It doesn't know you tomorrow. It doesn't remember what mattered yesterday. It can't grow with you over years.
|
||||
</p>
|
||||
<p class="mission-body-para reveal" style="transition-delay:240ms">
|
||||
I built Neuron because intelligence should compound. The same way a great mentor gets more valuable the longer you work with them - knowing your context, your patterns, your goals - your AI should too.
|
||||
</p>
|
||||
<p class="mission-body-para mission-body-emphasis reveal" style="transition-delay:320ms">
|
||||
Neuron is private by design. It runs on your hardware. <strong>Your data never leaves your machine.</strong> No training on your data. No telemetry. No cloud dependency.
|
||||
</p>
|
||||
<p class="mission-body-para reveal" style="transition-delay:400ms">
|
||||
This isn't a chat interface. It's the AI that becomes yours.
|
||||
</p>
|
||||
</div>
|
||||
let problem1: String = el_div(
|
||||
"class=\"problem-item reveal\"",
|
||||
el_p("class=\"problem-label\"", "Synthetic media without accountability") +
|
||||
el_p("class=\"problem-body\"", "Generative AI makes it trivially easy to produce harmful content at scale - and nearly impossible to trace. This is a problem the industry is largely ignoring. I'm not. I'm engaged with it seriously and expect to have answers in place before it becomes unmanageable.")
|
||||
)
|
||||
let problem2: String = el_div(
|
||||
"class=\"problem-item reveal\" style=\"transition-delay:120ms\"",
|
||||
el_p("class=\"problem-label\"", "Epistemic collapse") +
|
||||
el_p("class=\"problem-body\"", "AI can now generate persuasive content at any volume, on any position. The next generation is growing up in an environment where signal and noise are becoming indistinguishable. I think deeply about what it means to build tools that contribute to that problem - and how to build ones that don't.")
|
||||
)
|
||||
let problem3: String = el_div(
|
||||
"class=\"problem-item reveal\" style=\"transition-delay:240ms\"",
|
||||
el_p("class=\"problem-label\"", "Concentration of inference") +
|
||||
el_p("class=\"problem-body\"", "Four companies control nearly all frontier AI inference. Every query strengthens their position. I think that concentration of power is a structural risk - not just a pricing problem - and I'm building with that in mind.")
|
||||
)
|
||||
let problem4: String = el_div(
|
||||
"class=\"problem-item reveal\" style=\"transition-delay:360ms\"",
|
||||
el_p("class=\"problem-label\"", "The accountability gap") +
|
||||
el_p("class=\"problem-body\"", "When an AI agent takes a bad action, there is currently no clear legal or technical accountability. That's going to matter more as agents do more. I take this seriously. I'm building toward answers - not waiting for regulators to force the question.")
|
||||
)
|
||||
|
||||
<div class="mission-bigtech reveal" style="transition-delay:600ms">
|
||||
<p class="mission-bigtech-label">Why I built this on my own</p>
|
||||
<p>
|
||||
I didn't just approach one of the largest technology companies in the world - I got the meeting. Got the NDAs signed. Created deliverables in real time. Showed them benchmarks with full auditability. Some of their own people understood immediately what it meant.
|
||||
</p>
|
||||
<p>
|
||||
They saw it. Seemed to engage meaningfully. Then, within two days, lawyers were involved. I decided to just finish the project on my own.
|
||||
</p>
|
||||
<p class="muted">
|
||||
Not: how do we solve this at scale? Not: what does this mean for the people we serve? Their instinct was to protect enterprise revenue and manage legal exposure. The actual human impact - the people whose lives those enterprises touch - didn't enter the conversation.
|
||||
</p>
|
||||
<p class="muted">
|
||||
That's the difference. <strong style="color:var(--t1)">They're optimizing for the enterprise. I'm building for the people those enterprises are supposed to serve.</strong>
|
||||
</p>
|
||||
<p>
|
||||
I told them I could build and distribute this by myself. Maybe they didn't believe me. That meeting was April 22nd, 2026. I'm writing this on April 25th. You're looking at the proof. <a href="/checkout?plan=founding">I hope you'll preorder it.</a>
|
||||
</p>
|
||||
</div>
|
||||
let problems_grid: String = el_div(
|
||||
"class=\"problems-grid\"",
|
||||
problem1 + problem2 + problem3 + problem4 +
|
||||
el_div("class=\"problems-grid-bottom\"", "")
|
||||
)
|
||||
|
||||
<div class="mission-problems">
|
||||
<div class="mission-sub-row reveal">
|
||||
<div class="mission-sub-line"></div>
|
||||
<span class="label">What I'm building against</span>
|
||||
</div>
|
||||
let closer: String = el_div(
|
||||
"class=\"mission-closer reveal\"",
|
||||
el_p("", "The industry built tools to make AI easier to use. " +
|
||||
el_span("", "I'm building tools to make it safer to trust.")
|
||||
)
|
||||
)
|
||||
|
||||
<div class="problems-grid">
|
||||
<div class="problem-item reveal">
|
||||
<p class="problem-label">Synthetic media without accountability</p>
|
||||
<p class="problem-body">Generative AI makes it trivially easy to produce harmful content at scale - and nearly impossible to trace. This is a problem the industry is largely ignoring. I'm not. I'm engaged with it seriously and expect to have answers in place before it becomes unmanageable.</p>
|
||||
</div>
|
||||
<div class="problem-item reveal" style="transition-delay:120ms">
|
||||
<p class="problem-label">Epistemic collapse</p>
|
||||
<p class="problem-body">AI can now generate persuasive content at any volume, on any position. The next generation is growing up in an environment where signal and noise are becoming indistinguishable. I think deeply about what it means to build tools that contribute to that problem - and how to build ones that don't.</p>
|
||||
</div>
|
||||
<div class="problem-item reveal" style="transition-delay:240ms">
|
||||
<p class="problem-label">Concentration of inference</p>
|
||||
<p class="problem-body">Four companies control nearly all frontier AI inference. Every query strengthens their position. I think that concentration of power is a structural risk - not just a pricing problem - and I'm building with that in mind.</p>
|
||||
</div>
|
||||
<div class="problem-item reveal" style="transition-delay:360ms">
|
||||
<p class="problem-label">The accountability gap</p>
|
||||
<p class="problem-body">When an AI agent takes a bad action, there is currently no clear legal or technical accountability. That's going to matter more as agents do more. I take this seriously. I'm building toward answers - not waiting for regulators to force the question.</p>
|
||||
</div>
|
||||
<div class="problems-grid-bottom"></div>
|
||||
</div>
|
||||
let commitment: String = el_div(
|
||||
"class=\"reveal\" style=\"max-width:44rem;margin-top:3.5rem;padding:2rem 2.5rem;border-left:3px solid rgba(0,82,160,.30);background:rgba(0,82,160,.02)\"",
|
||||
el_p("style=\"font-family:var(--body);font-weight:500;font-size:1rem;color:var(--t1);margin-bottom:1rem\"", "Nobody's perfect.") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem\"",
|
||||
"Neuron isn't either. There is a gap between what the AI industry is delivering and what the world actually needs. Bridging that gap is the work - not a one-time product release, but continuous work, done in the open, built on the trust that users place in it."
|
||||
) +
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--navy);line-height:1.6\"",
|
||||
"That's my commitment. To keep working. To be honest about the problems. To build something that earns trust by doing the hard things right."
|
||||
)
|
||||
)
|
||||
|
||||
<div class="mission-closer reveal">
|
||||
<p>The industry built tools to make AI easier to use. <span>I'm building tools to make it safer to trust.</span></p>
|
||||
</div>
|
||||
let sub_row: String = el_div(
|
||||
"class=\"mission-sub-row reveal\"",
|
||||
el_div("class=\"mission-sub-line\"", "") +
|
||||
el_span("class=\"label\"", "What I'm building against")
|
||||
)
|
||||
|
||||
<div class="reveal" style="max-width:44rem;margin-top:3.5rem;padding:2rem 2.5rem;border-left:3px solid rgba(0,82,160,.30);background:rgba(0,82,160,.02)">
|
||||
<p style="font-family:var(--body);font-weight:500;font-size:1rem;color:var(--t1);margin-bottom:1rem">Nobody's perfect.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Neuron isn't either. There is a gap between what the AI industry is delivering and what the world actually needs. Bridging that gap is the work - not a one-time product release, but continuous work, done in the open, built on the trust that users place in it.</p>
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--navy);line-height:1.6">That's my commitment. To keep working. To be honest about the problems. To build something that earns trust by doing the hard things right.</p>
|
||||
</div>
|
||||
let problems: String = el_div(
|
||||
"class=\"mission-problems\"",
|
||||
sub_row + problems_grid + closer + commitment
|
||||
)
|
||||
|
||||
</div>
|
||||
let bottom_line: String = el_div(
|
||||
"class=\"container\" style=\"margin-top:5rem\"",
|
||||
el_div("class=\"navy-line\"", "")
|
||||
)
|
||||
|
||||
</div>
|
||||
<div class="container" style="margin-top:5rem"><div class="navy-line"></div></div>
|
||||
</section>
|
||||
el_section(
|
||||
"id=\"mission\" aria-label=\"Mission\"",
|
||||
el_div(
|
||||
"class=\"container\"",
|
||||
el_div("class=\"navy-line\" style=\"margin-bottom:5rem\"", "") +
|
||||
origin + bigtech + problems
|
||||
) + bottom_line
|
||||
)
|
||||
}
|
||||
|
||||
+64
-44
@@ -3,52 +3,72 @@
|
||||
// Responsive: desktop shows full link bar, ≤1060px collapses to hamburger.
|
||||
// Hamburger toggles .nav-mobile panel. Closes on link click or outside click.
|
||||
|
||||
extern fn el_nav(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_a(href: String, attrs: String, children: String) -> String
|
||||
extern fn el_img(src: String, alt: String, attrs: String) -> String
|
||||
extern fn el_button(attrs: String, label: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_script_src(src: String, defer_load: Bool) -> String
|
||||
|
||||
fn nav() -> String {
|
||||
return <nav id="nav">
|
||||
<div class="nav-inner">
|
||||
<a href="/" class="nav-logo" aria-label="Neuron home"><img src="/assets/brand/neuron-wordmark-on-light.png" srcset="/assets/brand/neuron-wordmark-on-light@2x.png 2x" alt="Neuron" height="28"></a>
|
||||
let logo_img: String = el_img(
|
||||
"/assets/brand/neuron-wordmark-on-light.png",
|
||||
"Neuron",
|
||||
"srcset=\"/assets/brand/neuron-wordmark-on-light@2x.png 2x\" height=\"28\""
|
||||
)
|
||||
let logo: String = el_a("/", "class=\"nav-logo\" aria-label=\"Neuron home\"", logo_img)
|
||||
|
||||
<!-- Order mirrors page section order: how-it-works → enterprise →
|
||||
mission/safety/environment → marketplace → pricing. -->
|
||||
<div class="nav-links">
|
||||
<a href="/#how-it-works" class="nav-link">How it works</a>
|
||||
<a href="/#enterprise" class="nav-link">Enterprise</a>
|
||||
<div class="nav-dropdown">
|
||||
<button class="nav-link nav-dropdown-btn" aria-haspopup="true" aria-expanded="false">Mission ▾</button>
|
||||
<div class="nav-dropdown-menu">
|
||||
<a href="/#mission" class="nav-dropdown-item">Our mission</a>
|
||||
<a href="/#safety" class="nav-dropdown-item">Safety</a>
|
||||
<a href="/#environmental" class="nav-dropdown-item">Environment</a>
|
||||
</div>
|
||||
</div>
|
||||
<a href="/#marketplace" class="nav-link">Marketplace</a>
|
||||
<a href="/#pricing" class="nav-link">Pricing</a>
|
||||
<a href="/about" class="nav-link">About</a>
|
||||
<a href="/said" class="nav-link">Gallery</a>
|
||||
<a href="/account" class="nav-link">Account</a>
|
||||
<a href="/#pricing" class="nav-cta">Get Access</a>
|
||||
</div>
|
||||
let dropdown_menu: String = el_div(
|
||||
"class=\"nav-dropdown-menu\"",
|
||||
el_a("/#mission", "class=\"nav-dropdown-item\"", "Our mission") +
|
||||
el_a("/#safety", "class=\"nav-dropdown-item\"", "Safety") +
|
||||
el_a("/#environmental", "class=\"nav-dropdown-item\"", "Environment")
|
||||
)
|
||||
let dropdown: String = el_div(
|
||||
"class=\"nav-dropdown\"",
|
||||
el_button("class=\"nav-link nav-dropdown-btn\" aria-haspopup=\"true\" aria-expanded=\"false\"", "Mission ▾") +
|
||||
dropdown_menu
|
||||
)
|
||||
|
||||
<button class="nav-hamburger" id="nav-hamburger" aria-label="Open navigation" aria-expanded="false" aria-controls="nav-mobile">
|
||||
<span></span>
|
||||
<span></span>
|
||||
<span></span>
|
||||
</button>
|
||||
let nav_links: String = el_div(
|
||||
"class=\"nav-links\"",
|
||||
el_a("/#how-it-works", "class=\"nav-link\"", "How it works") +
|
||||
el_a("/#enterprise", "class=\"nav-link\"", "Enterprise") +
|
||||
dropdown +
|
||||
el_a("/#marketplace", "class=\"nav-link\"", "Marketplace") +
|
||||
el_a("/#pricing", "class=\"nav-link\"", "Pricing") +
|
||||
el_a("/about", "class=\"nav-link\"", "About") +
|
||||
el_a("/said", "class=\"nav-link\"", "Gallery") +
|
||||
el_a("/account", "class=\"nav-link\"", "Account") +
|
||||
el_a("/#pricing", "class=\"nav-cta\"", "Get Access")
|
||||
)
|
||||
|
||||
<div class="nav-mobile" id="nav-mobile" role="navigation" aria-label="Mobile navigation">
|
||||
<a href="/#how-it-works" class="nav-mobile-link">How it works</a>
|
||||
<a href="/#enterprise" class="nav-mobile-link">Enterprise</a>
|
||||
<a href="/#mission" class="nav-mobile-link">Mission</a>
|
||||
<a href="/#safety" class="nav-mobile-link" style="padding-left:1.75rem;font-size:0.8rem;color:var(--t3)">- Safety</a>
|
||||
<a href="/#environmental" class="nav-mobile-link" style="padding-left:1.75rem;font-size:0.8rem;color:var(--t3)">- Environment</a>
|
||||
<a href="/#marketplace" class="nav-mobile-link">Marketplace</a>
|
||||
<a href="/#pricing" class="nav-mobile-link">Pricing</a>
|
||||
<a href="/about" class="nav-mobile-link">About</a>
|
||||
<a href="/said" class="nav-mobile-link">Gallery</a>
|
||||
<a href="/account" class="nav-mobile-link">Account</a>
|
||||
<a href="/#pricing" class="nav-mobile-cta">Get Access</a>
|
||||
</div>
|
||||
</div>
|
||||
<script src="/js/nav.js" defer></script>
|
||||
</nav>
|
||||
let hamburger_spans: String =
|
||||
el_span("", "") +
|
||||
el_span("", "") +
|
||||
el_span("", "")
|
||||
let hamburger: String = el_button(
|
||||
"class=\"nav-hamburger\" id=\"nav-hamburger\" aria-label=\"Open navigation\" aria-expanded=\"false\" aria-controls=\"nav-mobile\"",
|
||||
hamburger_spans
|
||||
)
|
||||
|
||||
let nav_mobile: String = el_div(
|
||||
"class=\"nav-mobile\" id=\"nav-mobile\" role=\"navigation\" aria-label=\"Mobile navigation\"",
|
||||
el_a("/#how-it-works", "class=\"nav-mobile-link\"", "How it works") +
|
||||
el_a("/#enterprise", "class=\"nav-mobile-link\"", "Enterprise") +
|
||||
el_a("/#mission", "class=\"nav-mobile-link\"", "Mission") +
|
||||
el_a("/#safety", "class=\"nav-mobile-link\" style=\"padding-left:1.75rem;font-size:0.8rem;color:var(--t3)\"", "- Safety") +
|
||||
el_a("/#environmental", "class=\"nav-mobile-link\" style=\"padding-left:1.75rem;font-size:0.8rem;color:var(--t3)\"", "- Environment") +
|
||||
el_a("/#marketplace", "class=\"nav-mobile-link\"", "Marketplace") +
|
||||
el_a("/#pricing", "class=\"nav-mobile-link\"", "Pricing") +
|
||||
el_a("/about", "class=\"nav-mobile-link\"", "About") +
|
||||
el_a("/said", "class=\"nav-mobile-link\"", "Gallery") +
|
||||
el_a("/account", "class=\"nav-mobile-link\"", "Account") +
|
||||
el_a("/#pricing", "class=\"nav-mobile-cta\"", "Get Access")
|
||||
)
|
||||
|
||||
let nav_inner: String = el_div("class=\"nav-inner\"", logo + nav_links + hamburger + nav_mobile)
|
||||
|
||||
el_nav("id=\"nav\"", nav_inner + el_script_src("/js/nav.js", true))
|
||||
}
|
||||
|
||||
+41
-31
@@ -4,40 +4,50 @@
|
||||
// Cards use reveal animation class (CSS IntersectionObserver polyfill
|
||||
// provided by a tiny inline <script> in the page shell).
|
||||
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h3(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
|
||||
fn pillars() -> String {
|
||||
return <section id="pillars" aria-label="Core pillars">
|
||||
<div class="container">
|
||||
<div class="pillars-label reveal">
|
||||
<div class="navy-line-left" style="width:4rem;flex-shrink:0"></div>
|
||||
<span class="label">Why Neuron</span>
|
||||
</div>
|
||||
<div class="pillars-grid">
|
||||
let label_row: String = el_div(
|
||||
"class=\"pillars-label reveal\"",
|
||||
el_div("class=\"navy-line-left\" style=\"width:4rem;flex-shrink:0\"", "") +
|
||||
el_span("class=\"label\"", "Why Neuron")
|
||||
)
|
||||
|
||||
<div class="pillar-card card-dark reveal">
|
||||
<span class="pillar-numeral" aria-hidden="true">I</span>
|
||||
<h3 class="display-md pillar-title">Remembers</h3>
|
||||
<div class="pillar-rule"></div>
|
||||
<p class="pillar-body">Every session picks up where you left off. Every project. Every context. No more re-explaining who you are, what you're building, or what matters to you.</p>
|
||||
<p class="pillar-detail">Zero re-orientation</p>
|
||||
</div>
|
||||
let card1: String = el_div(
|
||||
"class=\"pillar-card card-dark reveal\"",
|
||||
el_span("class=\"pillar-numeral\" aria-hidden=\"true\"", "I") +
|
||||
el_h3("class=\"display-md pillar-title\"", "Remembers") +
|
||||
el_div("class=\"pillar-rule\"", "") +
|
||||
el_p("class=\"pillar-body\"", "Every session picks up where you left off. Every project. Every context. No more re-explaining who you are, what you're building, or what matters to you.") +
|
||||
el_p("class=\"pillar-detail\"", "Zero re-orientation")
|
||||
)
|
||||
|
||||
<div class="pillar-card card-dark reveal" style="transition-delay:150ms">
|
||||
<span class="pillar-numeral" aria-hidden="true">II</span>
|
||||
<h3 class="display-md pillar-title">Sharpens</h3>
|
||||
<div class="pillar-rule"></div>
|
||||
<p class="pillar-body">The longer you use it, the sharper it gets. Every session builds on the last. Neuron Inference arrives Q3 2026 - not a wrapper around someone else's model. Purpose-built. Built for you.</p>
|
||||
<p class="pillar-detail">Specific to you</p>
|
||||
</div>
|
||||
let card2: String = el_div(
|
||||
"class=\"pillar-card card-dark reveal\" style=\"transition-delay:150ms\"",
|
||||
el_span("class=\"pillar-numeral\" aria-hidden=\"true\"", "II") +
|
||||
el_h3("class=\"display-md pillar-title\"", "Sharpens") +
|
||||
el_div("class=\"pillar-rule\"", "") +
|
||||
el_p("class=\"pillar-body\"", "The longer you use it, the sharper it gets. Every session builds on the last. Neuron Inference arrives Q3 2026 - not a wrapper around someone else's model. Purpose-built. Built for you.") +
|
||||
el_p("class=\"pillar-detail\"", "Specific to you")
|
||||
)
|
||||
|
||||
<div class="pillar-card card-dark reveal" style="transition-delay:300ms">
|
||||
<span class="pillar-numeral" aria-hidden="true">III</span>
|
||||
<h3 class="display-md pillar-title">Yours</h3>
|
||||
<div class="pillar-rule"></div>
|
||||
<p class="pillar-body">Runs locally. Your data never leaves. No cloud dependency, no telemetry, no training on your conversations. Complete ownership. And unlike every other AI subscription - we're not charging you to remember you.</p>
|
||||
<p class="pillar-detail">Fully private</p>
|
||||
</div>
|
||||
let card3: String = el_div(
|
||||
"class=\"pillar-card card-dark reveal\" style=\"transition-delay:300ms\"",
|
||||
el_span("class=\"pillar-numeral\" aria-hidden=\"true\"", "III") +
|
||||
el_h3("class=\"display-md pillar-title\"", "Yours") +
|
||||
el_div("class=\"pillar-rule\"", "") +
|
||||
el_p("class=\"pillar-body\"", "Runs locally. Your data never leaves. No cloud dependency, no telemetry, no training on your conversations. Complete ownership. And unlike every other AI subscription - we're not charging you to remember you.") +
|
||||
el_p("class=\"pillar-detail\"", "Fully private")
|
||||
)
|
||||
|
||||
</div>
|
||||
</div>
|
||||
</section>
|
||||
let grid: String = el_div("class=\"pillars-grid\"", card1 + card2 + card3)
|
||||
|
||||
el_section(
|
||||
"id=\"pillars\" aria-label=\"Core pillars\"",
|
||||
el_div("class=\"container\"", label_row + grid)
|
||||
)
|
||||
}
|
||||
|
||||
+141
-107
@@ -2,6 +2,15 @@
|
||||
// Accepts the founding counter values as parameters so main.el can inject
|
||||
// server-side rendered counts without JS.
|
||||
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_ul(attrs: String, children: String) -> String
|
||||
extern fn el_li(attrs: String, children: String) -> String
|
||||
extern fn el_button(attrs: String, label: String) -> String
|
||||
|
||||
fn founding_spots_html(sold: Int, total: Int) -> String {
|
||||
let remaining: Int = total - sold
|
||||
let pct: Int = (sold * 100) / total
|
||||
@@ -9,11 +18,47 @@ fn founding_spots_html(sold: Int, total: Int) -> String {
|
||||
let remaining_str: String = int_to_str(remaining)
|
||||
let sold_str: String = int_to_str(sold)
|
||||
let total_str: String = int_to_str(total)
|
||||
return <div class="founding-spots">
|
||||
<p class="founding-spots-label">Only {remaining_str} left</p>
|
||||
<div class="founding-spots-bar"><div class="founding-spots-fill" style="width:{pct_str}%"></div></div>
|
||||
<p class="founding-spots-sub">{sold_str} of {total_str} claimed</p>
|
||||
</div>
|
||||
|
||||
el_div(
|
||||
"class=\"founding-spots\"",
|
||||
el_p("class=\"founding-spots-label\"", "Only " + remaining_str + " left") +
|
||||
el_div(
|
||||
"class=\"founding-spots-bar\"",
|
||||
el_div("class=\"founding-spots-fill\" style=\"width:" + pct_str + "%\"", "")
|
||||
) +
|
||||
el_p("class=\"founding-spots-sub\"", sold_str + " of " + total_str + " claimed")
|
||||
)
|
||||
}
|
||||
|
||||
fn pricing_free_features() -> String {
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Persistent memory - never resets")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Bring your own API keys (OpenAI, Anthropic, Grok...)")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Local inference via Ollama (coming)")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Neuron Inference included when it launches - Q3 2026")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Unlimited projects")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "3 marketplace plugins included")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Core built-in capabilities"))
|
||||
}
|
||||
|
||||
fn pricing_pro_features() -> String {
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Bring your own API keys - use any model, any provider")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Neuron Inference - Q3 2026, priced below OpenAI and Anthropic")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Everything in Free")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Unlimited projects")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Full plugin marketplace")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Advanced integrations - IDE, Slack, and more")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Early access to new features"))
|
||||
}
|
||||
|
||||
fn pricing_founding_features() -> String {
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Neuron Inference (Q3 2026) - founding member rate, priced below the major APIs")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Everything in Professional - forever")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Never pay again - lifetime updates included")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Founding member badge in the app")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Private founding member community")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Shape the roadmap - your votes carry more weight")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Beta features before general release")) +
|
||||
el_li("", el_span("class=\"dash\"", "-") + el_span("", "Name in the credits"))
|
||||
}
|
||||
|
||||
fn pricing(sold: Int, total: Int) -> String {
|
||||
@@ -24,113 +69,102 @@ fn pricing(sold: Int, total: Int) -> String {
|
||||
let remaining_str: String = int_to_str(remaining)
|
||||
let total_str: String = int_to_str(total)
|
||||
|
||||
return <section id="pricing" aria-label="Pricing">
|
||||
<div class="container">
|
||||
let header: String = el_div(
|
||||
"class=\"pricing-header\"",
|
||||
el_div(
|
||||
"class=\"pricing-label-row reveal\"",
|
||||
el_div("style=\"height:1px;width:4rem;background:linear-gradient(to right,transparent,rgba(0,82,160,.35))\"", "") +
|
||||
el_span("class=\"label\" style=\"color:var(--navy-85)\"", "Pricing") +
|
||||
el_div("style=\"height:1px;width:4rem;background:linear-gradient(to left,transparent,rgba(0,82,160,.35))\"", "")
|
||||
) +
|
||||
el_h2("class=\"display-lg pricing-headline reveal\" style=\"transition-delay:80ms\"", "Own it. Don't rent it.") +
|
||||
el_p("class=\"pricing-sub reveal\" style=\"transition-delay:160ms\"",
|
||||
"Bring your own API keys on day one. Neuron Inference - our own model layer, priced below the major APIs - launches Q3 2026."
|
||||
)
|
||||
)
|
||||
|
||||
<div class="pricing-header">
|
||||
<div class="pricing-label-row reveal">
|
||||
<div style="height:1px;width:4rem;background:linear-gradient(to right,transparent,rgba(0,82,160,.35))"></div>
|
||||
<span class="label" style="color:var(--navy-85)">Pricing</span>
|
||||
<div style="height:1px;width:4rem;background:linear-gradient(to left,transparent,rgba(0,82,160,.35))"></div>
|
||||
</div>
|
||||
<h2 class="display-lg pricing-headline reveal" style="transition-delay:80ms">Own it. Don't rent it.</h2>
|
||||
<p class="pricing-sub reveal" style="transition-delay:160ms">Bring your own API keys on day one. Neuron Inference - our own model layer, priced below the major APIs - launches Q3 2026.</p>
|
||||
</div>
|
||||
let card_free: String = el_div(
|
||||
"class=\"pricing-card card-dark reveal\"",
|
||||
el_p("class=\"pricing-tier\"", "Free") +
|
||||
el_div(
|
||||
"class=\"pricing-price-row\"",
|
||||
el_span("class=\"pricing-price\"", "$0") +
|
||||
el_span("class=\"pricing-cadence\"", "forever")
|
||||
) +
|
||||
el_p("class=\"pricing-tagline\"", "Start building your memory. No card required.") +
|
||||
el_ul("class=\"pricing-features\"", pricing_free_features()) +
|
||||
el_div("style=\"flex:1\"", "") +
|
||||
el_div(
|
||||
"class=\"pricing-cta pricing-cta-ghost\"",
|
||||
el_button("class=\"pricing-cta-ghost\" data-checkout=\"free\"", "Preorder free tier →")
|
||||
)
|
||||
)
|
||||
|
||||
<div class="pricing-grid">
|
||||
let card_pro: String = el_div(
|
||||
"class=\"pricing-card card-dark reveal\" style=\"transition-delay:150ms\"",
|
||||
el_p("class=\"pricing-tier\"", "Professional") +
|
||||
el_div(
|
||||
"class=\"pricing-price-row\"",
|
||||
el_span("class=\"pricing-price\"", "$19") +
|
||||
el_span("class=\"pricing-cadence\"", "/ month")
|
||||
) +
|
||||
el_p("class=\"pricing-tagline\"", "Full access. Use your own API keys now. Neuron Inference when it launches.") +
|
||||
el_ul("class=\"pricing-features\"", pricing_pro_features()) +
|
||||
el_div("style=\"flex:1\"", "") +
|
||||
el_div(
|
||||
"class=\"pricing-cta pricing-cta-navy\"",
|
||||
el_button("class=\"pricing-cta-navy\" data-checkout=\"professional\"", "Preorder →")
|
||||
)
|
||||
)
|
||||
|
||||
<div class="pricing-card card-dark reveal">
|
||||
<p class="pricing-tier">Free</p>
|
||||
<div class="pricing-price-row">
|
||||
<span class="pricing-price">$0</span>
|
||||
<span class="pricing-cadence">forever</span>
|
||||
</div>
|
||||
<p class="pricing-tagline">Start building your memory. No card required.</p>
|
||||
<ul class="pricing-features">
|
||||
<li><span class="dash">-</span><span>Persistent memory - never resets</span></li>
|
||||
<li><span class="dash">-</span><span>Bring your own API keys (OpenAI, Anthropic, Grok...)</span></li>
|
||||
<li><span class="dash">-</span><span>Local inference via Ollama (coming)</span></li>
|
||||
<li><span class="dash">-</span><span>Neuron Inference included when it launches - Q3 2026</span></li>
|
||||
<li><span class="dash">-</span><span>Unlimited projects</span></li>
|
||||
<li><span class="dash">-</span><span>3 marketplace plugins included</span></li>
|
||||
<li><span class="dash">-</span><span>Core built-in capabilities</span></li>
|
||||
</ul>
|
||||
<div style="flex:1"></div>
|
||||
<div class="pricing-cta pricing-cta-ghost">
|
||||
<button class="pricing-cta-ghost" data-checkout="free">Preorder free tier →</button>
|
||||
</div>
|
||||
</div>
|
||||
let card_founding: String = el_div(
|
||||
"class=\"pricing-card featured reveal\" style=\"transition-delay:300ms\"",
|
||||
el_p("class=\"pricing-tier\"", "Founding Member") +
|
||||
el_div(
|
||||
"class=\"pricing-price-row\"",
|
||||
el_span("class=\"pricing-price\"", "$199") +
|
||||
el_span("class=\"pricing-cadence\"", "lifetime")
|
||||
) +
|
||||
el_p("class=\"pricing-tagline\"", "Pay once. Everything, forever. Including Neuron Inference when it launches.") +
|
||||
spots_html +
|
||||
el_ul("class=\"pricing-features\"", pricing_founding_features()) +
|
||||
el_div("style=\"flex:1\"", "") +
|
||||
el_div(
|
||||
"class=\"pricing-cta pricing-cta-solid\"",
|
||||
el_button("class=\"pricing-cta-solid\" data-checkout=\"founding\"", "Preorder — claim your spot →")
|
||||
)
|
||||
)
|
||||
|
||||
<div class="pricing-card card-dark reveal" style="transition-delay:150ms">
|
||||
<p class="pricing-tier">Professional</p>
|
||||
<div class="pricing-price-row">
|
||||
<span class="pricing-price">$19</span>
|
||||
<span class="pricing-cadence">/ month</span>
|
||||
</div>
|
||||
<p class="pricing-tagline">Full access. Use your own API keys now. Neuron Inference when it launches.</p>
|
||||
<ul class="pricing-features">
|
||||
<li><span class="dash">-</span><span>Bring your own API keys - use any model, any provider</span></li>
|
||||
<li><span class="dash">-</span><span>Neuron Inference - Q3 2026, priced below OpenAI and Anthropic</span></li>
|
||||
<li><span class="dash">-</span><span>Everything in Free</span></li>
|
||||
<li><span class="dash">-</span><span>Unlimited projects</span></li>
|
||||
<li><span class="dash">-</span><span>Full plugin marketplace</span></li>
|
||||
<li><span class="dash">-</span><span>Advanced integrations - IDE, Slack, and more</span></li>
|
||||
<li><span class="dash">-</span><span>Early access to new features</span></li>
|
||||
</ul>
|
||||
<div style="flex:1"></div>
|
||||
<div class="pricing-cta pricing-cta-navy">
|
||||
<button class="pricing-cta-navy" data-checkout="professional">Preorder →</button>
|
||||
</div>
|
||||
</div>
|
||||
let grid: String = el_div("class=\"pricing-grid\"", card_free + card_pro + card_founding)
|
||||
|
||||
<div class="pricing-card featured reveal" style="transition-delay:300ms">
|
||||
<p class="pricing-tier">Founding Member</p>
|
||||
<div class="pricing-price-row">
|
||||
<span class="pricing-price">$199</span>
|
||||
<span class="pricing-cadence">lifetime</span>
|
||||
</div>
|
||||
<p class="pricing-tagline">Pay once. Everything, forever. Including Neuron Inference when it launches.</p>
|
||||
let banner_fill: String = el_div(
|
||||
"class=\"founding-banner-fill\" style=\"width:" + pct_str + "%\"",
|
||||
""
|
||||
)
|
||||
let banner: String = el_div(
|
||||
"class=\"founding-banner reveal\"",
|
||||
el_div(
|
||||
"",
|
||||
el_p("class=\"founding-banner-label\"", "Founding Member Spots") +
|
||||
el_div(
|
||||
"style=\"display:flex;align-items:baseline;gap:.5rem;margin:.25rem 0\"",
|
||||
el_span("class=\"founding-banner-count\"", remaining_str) +
|
||||
el_span("class=\"founding-banner-sub\"", "remaining of " + el_span("", total_str))
|
||||
) +
|
||||
el_div("class=\"founding-banner-bar\"", banner_fill)
|
||||
) +
|
||||
el_button("class=\"btn-primary\" data-checkout=\"founding\" style=\"white-space:nowrap\"", "Preorder →")
|
||||
)
|
||||
|
||||
{raw(spots_html)}
|
||||
let fine1: String = el_p("class=\"pricing-fine reveal\" style=\"margin-top:2.5rem\"",
|
||||
"Bring your own API keys · Local inference via Ollama (coming) · Neuron Inference - Q3 2026 · Your data stays yours"
|
||||
)
|
||||
let fine2: String = el_p("class=\"pricing-fine reveal\" style=\"margin-top:1rem;font-size:0.8rem\"",
|
||||
"Includes 2 devices per plan · Additional devices available at a small extra cost · We're not greedy"
|
||||
)
|
||||
|
||||
<ul class="pricing-features">
|
||||
<li><span class="dash">-</span><span>Neuron Inference (Q3 2026) - founding member rate, priced below the major APIs</span></li>
|
||||
<li><span class="dash">-</span><span>Everything in Professional - forever</span></li>
|
||||
<li><span class="dash">-</span><span>Never pay again - lifetime updates included</span></li>
|
||||
<li><span class="dash">-</span><span>Founding member badge in the app</span></li>
|
||||
<li><span class="dash">-</span><span>Private founding member community</span></li>
|
||||
<li><span class="dash">-</span><span>Shape the roadmap - your votes carry more weight</span></li>
|
||||
<li><span class="dash">-</span><span>Beta features before general release</span></li>
|
||||
<li><span class="dash">-</span><span>Name in the credits</span></li>
|
||||
</ul>
|
||||
|
||||
<div style="flex:1"></div>
|
||||
<div class="pricing-cta pricing-cta-solid">
|
||||
<button class="pricing-cta-solid" data-checkout="founding">Preorder — claim your spot →</button>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<div class="founding-banner reveal">
|
||||
<div>
|
||||
<p class="founding-banner-label">Founding Member Spots</p>
|
||||
<div style="display:flex;align-items:baseline;gap:.5rem;margin:.25rem 0">
|
||||
<span class="founding-banner-count">{remaining_str}</span>
|
||||
<span class="founding-banner-sub">remaining of <span>{total_str}</span></span>
|
||||
</div>
|
||||
<div class="founding-banner-bar"><div class="founding-banner-fill" style="width:{pct_str}%"></div></div>
|
||||
</div>
|
||||
<button class="btn-primary" data-checkout="founding" style="white-space:nowrap">Preorder →</button>
|
||||
</div>
|
||||
|
||||
<p class="pricing-fine reveal" style="margin-top:2.5rem">
|
||||
Bring your own API keys · Local inference via Ollama (coming) · Neuron Inference - Q3 2026 · Your data stays yours
|
||||
</p>
|
||||
<p class="pricing-fine reveal" style="margin-top:1rem;font-size:0.8rem">
|
||||
Includes 2 devices per plan · Additional devices available at a small extra cost · We're not greedy
|
||||
</p>
|
||||
|
||||
</div>
|
||||
</section>
|
||||
el_section(
|
||||
"id=\"pricing\" aria-label=\"Pricing\"",
|
||||
el_div("class=\"container\"", header + grid + banner + fine1 + fine2)
|
||||
)
|
||||
}
|
||||
|
||||
+141
-100
@@ -5,105 +5,146 @@
|
||||
// designate a trusted contact that bypasses the default notification
|
||||
// path when a signal warrants it.
|
||||
|
||||
fn safety() -> String {
|
||||
return <section id="safety" aria-label="Safety" style="padding:8rem 2.5rem;background:var(--bg2)">
|
||||
<div class="container-lg">
|
||||
extern fn el_section(attrs: String, children: String) -> String
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_a(href: String, attrs: String, children: String) -> String
|
||||
extern fn el_em(children: String) -> String
|
||||
extern fn el_br() -> String
|
||||
|
||||
<!-- Intro text -->
|
||||
<div style="max-width:44rem;margin-bottom:3.5rem">
|
||||
<div style="display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem">
|
||||
<div class="navy-line-left" style="width:3rem;flex-shrink:0"></div>
|
||||
<span class="label reveal" style="color:var(--navy-85)">Safety</span>
|
||||
</div>
|
||||
<h2 class="display-lg reveal" style="transition-delay:80ms;margin-bottom:1.5rem">
|
||||
Safety built in.<br>Not bolted on.
|
||||
</h2>
|
||||
<p class="reveal" style="transition-delay:160ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:1.25rem">
|
||||
Most AI products treat safety as a content filter. Block a list of topics, add a disclaimer, call it done. That's not safety. That's liability management.
|
||||
</p>
|
||||
<p class="reveal" style="transition-delay:220ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:1.25rem">
|
||||
Real safety means thinking about who might need help and what help actually looks like in a crisis. The person closest to you is sometimes the source of the problem. A system that routes every distress signal to your primary contact can alert the very person you need protection from.
|
||||
</p>
|
||||
<p class="reveal" style="transition-delay:280ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8">
|
||||
I built something different. I called it the Hard Bell.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<!-- 2x2 card grid -->
|
||||
<div style="display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem">
|
||||
|
||||
<div class="reveal card-dark" style="transition-delay:100ms;padding:1.75rem 2rem;border-left:3px solid rgba(0,82,160,.40)">
|
||||
<p style="font-family:var(--body);font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:0.75rem">Hard Bell</p>
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem">A trusted contact the threat can't intercept</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7">
|
||||
Any user can designate a Hard Bell contact - a friend, a relative, a colleague - set up in a calm moment, independent of any shared account. When a signal warrants it, that contact is reached directly. It works the same way for everyone: adult, teen, or child.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<div class="reveal card-dark" style="transition-delay:150ms;padding:1.75rem 2rem;border-left:3px solid rgba(0,82,160,.40)">
|
||||
<p style="font-family:var(--body);font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:0.75rem">Emergency routing</p>
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem">Emergency services first - not notification</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7">
|
||||
Physical danger and crisis signals route to emergency services and crisis lines. Neuron evaluates the content of the signal, not the account type. No one in your contact list can disable or redirect this path.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<div class="reveal card-dark" style="transition-delay:200ms;padding:1.75rem 2rem;border-left:3px solid rgba(0,82,160,.40)">
|
||||
<p style="font-family:var(--body);font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:0.75rem">Family accounts</p>
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem">Oversight without surveillance</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7">
|
||||
For family accounts, parents see what they need to see. A child's conversations remain private unless a wellbeing signal triggers notification - and even then, the routing logic accounts for the possibility that the parent could be the source of harm.
|
||||
</p>
|
||||
<p style="font-family:var(--body);font-weight:500;font-size:0.875rem;color:var(--t1);line-height:1.7;margin-top:0.75rem">
|
||||
We protect the kids. They come first.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
<div class="reveal card-dark" style="transition-delay:250ms;padding:1.75rem 2rem;border-left:3px solid rgba(0,82,160,.40)">
|
||||
<p style="font-family:var(--body);font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:0.75rem">Mandatory reporting</p>
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem">If real harm is intended, authorities may be contacted</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7">
|
||||
If Neuron detects credible, specific indicators of intended harm - to the user or to someone else - emergency services or relevant authorities may be contacted. Every user agrees to this at account creation. You cannot opt out.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<!-- People first card — full width -->
|
||||
<div class="reveal card-dark" style="padding:2rem 2.5rem;border-left:3px solid var(--navy);margin-bottom:1.5rem">
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1.25rem">This applies to anyone planning mass harm, a shooting, or serious self-harm. Not just child protection - anyone. The same logic holds: a misunderstanding can be resolved. A person's life can't be given back to them.</p>
|
||||
<p style="font-family:var(--body);font-weight:700;font-size:1.125rem;color:var(--navy);line-height:1.4">People first, always.</p>
|
||||
</div>
|
||||
|
||||
<!-- Statement + stat cards — each full width -->
|
||||
<div style="display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem">
|
||||
|
||||
<div class="reveal card-dark" style="padding:2rem 2.5rem;border-left:3px solid rgba(0,82,160,.30)">
|
||||
<p style="font-family:var(--body);font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:0.75rem">Why the routing works this way</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:0.75rem">According to federal child maltreatment data (HHS, Child Maltreatment 2023), approximately 89% of child abuse victims are maltreated by a parent or caregiver. The emergency contact on file is not always a safe contact.</p>
|
||||
<p style="font-family:var(--body);font-size:0.75rem;color:var(--t3)">Source: U.S. Department of Health & Human Services, Administration for Children and Families, <em>Child Maltreatment 2023</em>. <a href="https://www.acf.hhs.gov/cb/data-research/child-maltreatment" target="_blank" rel="noopener" style="color:var(--navy)">acf.hhs.gov/cb/data-research/child-maltreatment</a></p>
|
||||
</div>
|
||||
|
||||
<div class="reveal card-dark" style="padding:2rem 2.5rem;border-left:3px solid var(--navy)">
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);line-height:1.8;margin-bottom:0.75rem">I recognize I will lose business over this. That doesn't matter to me.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">This is still local. Neuron, LLC does not see your conversations. When a safety signal fires, the contact is made by your local instance - not by our servers. We are not in the loop. We cannot be. That's the architecture.</p>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<!-- Required block -->
|
||||
<div class="reveal" style="padding:2rem 2.5rem;border:1px solid rgba(0,82,160,.15);background:rgba(0,82,160,.03)">
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">
|
||||
<strong style="color:var(--t1);font-weight:500">Required before you can use Neuron.</strong> You must designate a Hard Bell contact during setup - before anything else. This is not a settings page you visit later. It happens first.
|
||||
</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">
|
||||
If you don't have someone to designate, you can use 988 - the Suicide & Crisis Lifeline - as your Hard Bell contact. The system will accept it. The point is that no one goes in without a line out.
|
||||
</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">
|
||||
I'm also establishing a Neuron crisis line - free, 24/7, staffed. Because I recognize that some people don't have anyone. The technology shouldn't make that worse. It should be the thing that catches you when nothing else does.
|
||||
</p>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
</section>
|
||||
fn safety_intro() -> String {
|
||||
let label_row: String = el_div(
|
||||
"style=\"display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem\"",
|
||||
el_div("class=\"navy-line-left\" style=\"width:3rem;flex-shrink:0\"", "") +
|
||||
el_span("class=\"label reveal\" style=\"color:var(--navy-85)\"", "Safety")
|
||||
)
|
||||
el_div(
|
||||
"style=\"max-width:44rem;margin-bottom:3.5rem\"",
|
||||
label_row +
|
||||
el_h2(
|
||||
"class=\"display-lg reveal\" style=\"transition-delay:80ms;margin-bottom:1.5rem\"",
|
||||
"Safety built in." + el_br() + "Not bolted on."
|
||||
) +
|
||||
el_p("class=\"reveal\" style=\"transition-delay:160ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:1.25rem\"",
|
||||
"Most AI products treat safety as a content filter. Block a list of topics, add a disclaimer, call it done. That's not safety. That's liability management."
|
||||
) +
|
||||
el_p("class=\"reveal\" style=\"transition-delay:220ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8;margin-bottom:1.25rem\"",
|
||||
"Real safety means thinking about who might need help and what help actually looks like in a crisis. The person closest to you is sometimes the source of the problem. A system that routes every distress signal to your primary contact can alert the very person you need protection from."
|
||||
) +
|
||||
el_p("class=\"reveal\" style=\"transition-delay:280ms;font-family:var(--body);font-weight:300;font-size:1rem;color:var(--t2);line-height:1.8\"",
|
||||
"I built something different. I called it the Hard Bell."
|
||||
)
|
||||
)
|
||||
}
|
||||
|
||||
fn safety_cards() -> String {
|
||||
let card_style: String = "padding:1.75rem 2rem;border-left:3px solid rgba(0,82,160,.40)"
|
||||
|
||||
let card1: String = el_div(
|
||||
"class=\"reveal card-dark\" style=\"transition-delay:100ms;" + card_style + "\"",
|
||||
el_p("style=\"font-family:var(--body);font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:0.75rem\"", "Hard Bell") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem\"", "A trusted contact the threat can't intercept") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7\"",
|
||||
"Any user can designate a Hard Bell contact - a friend, a relative, a colleague - set up in a calm moment, independent of any shared account. When a signal warrants it, that contact is reached directly. It works the same way for everyone: adult, teen, or child."
|
||||
)
|
||||
)
|
||||
|
||||
let card2: String = el_div(
|
||||
"class=\"reveal card-dark\" style=\"transition-delay:150ms;" + card_style + "\"",
|
||||
el_p("style=\"font-family:var(--body);font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:0.75rem\"", "Emergency routing") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem\"", "Emergency services first - not notification") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7\"",
|
||||
"Physical danger and crisis signals route to emergency services and crisis lines. Neuron evaluates the content of the signal, not the account type. No one in your contact list can disable or redirect this path."
|
||||
)
|
||||
)
|
||||
|
||||
let card3: String = el_div(
|
||||
"class=\"reveal card-dark\" style=\"transition-delay:200ms;" + card_style + "\"",
|
||||
el_p("style=\"font-family:var(--body);font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:0.75rem\"", "Family accounts") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem\"", "Oversight without surveillance") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7\"",
|
||||
"For family accounts, parents see what they need to see. A child's conversations remain private unless a wellbeing signal triggers notification - and even then, the routing logic accounts for the possibility that the parent could be the source of harm."
|
||||
) +
|
||||
el_p("style=\"font-family:var(--body);font-weight:500;font-size:0.875rem;color:var(--t1);line-height:1.7;margin-top:0.75rem\"",
|
||||
"We protect the kids. They come first."
|
||||
)
|
||||
)
|
||||
|
||||
let card4: String = el_div(
|
||||
"class=\"reveal card-dark\" style=\"transition-delay:250ms;" + card_style + "\"",
|
||||
el_p("style=\"font-family:var(--body);font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:0.75rem\"", "Mandatory reporting") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);margin-bottom:0.5rem\"", "If real harm is intended, authorities may be contacted") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.7\"",
|
||||
"If Neuron detects credible, specific indicators of intended harm - to the user or to someone else - emergency services or relevant authorities may be contacted. Every user agrees to this at account creation. You cannot opt out."
|
||||
)
|
||||
)
|
||||
|
||||
el_div("style=\"display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem\"",
|
||||
card1 + card2 + card3 + card4
|
||||
)
|
||||
}
|
||||
|
||||
fn safety_statements() -> String {
|
||||
let people_first: String = el_div(
|
||||
"class=\"reveal card-dark\" style=\"padding:2rem 2.5rem;border-left:3px solid var(--navy);margin-bottom:1.5rem\"",
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1.25rem\"",
|
||||
"This applies to anyone planning mass harm, a shooting, or serious self-harm. Not just child protection - anyone. The same logic holds: a misunderstanding can be resolved. A person's life can't be given back to them."
|
||||
) +
|
||||
el_p("style=\"font-family:var(--body);font-weight:700;font-size:1.125rem;color:var(--navy);line-height:1.4\"",
|
||||
"People first, always."
|
||||
)
|
||||
)
|
||||
|
||||
let stat_card1: String = el_div(
|
||||
"class=\"reveal card-dark\" style=\"padding:2rem 2.5rem;border-left:3px solid rgba(0,82,160,.30)\"",
|
||||
el_p("style=\"font-family:var(--body);font-size:0.75rem;font-weight:700;letter-spacing:0.14em;text-transform:uppercase;color:var(--navy);margin-bottom:0.75rem\"", "Why the routing works this way") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:0.75rem\"",
|
||||
"According to federal child maltreatment data (HHS, Child Maltreatment 2023), approximately 89% of child abuse victims are maltreated by a parent or caregiver. The emergency contact on file is not always a safe contact."
|
||||
) +
|
||||
el_p("style=\"font-family:var(--body);font-size:0.75rem;color:var(--t3)\"",
|
||||
"Source: U.S. Department of Health & Human Services, Administration for Children and Families, " +
|
||||
el_em("Child Maltreatment 2023") +
|
||||
". " +
|
||||
el_a("https://www.acf.hhs.gov/cb/data-research/child-maltreatment", "target=\"_blank\" rel=\"noopener\" style=\"color:var(--navy)\"", "acf.hhs.gov/cb/data-research/child-maltreatment")
|
||||
)
|
||||
)
|
||||
|
||||
let stat_card2: String = el_div(
|
||||
"class=\"reveal card-dark\" style=\"padding:2rem 2.5rem;border-left:3px solid var(--navy)\"",
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.9375rem;color:var(--t1);line-height:1.8;margin-bottom:0.75rem\"",
|
||||
"I recognize I will lose business over this. That doesn't matter to me."
|
||||
) +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8\"",
|
||||
"This is still local. Neuron, LLC does not see your conversations. When a safety signal fires, the contact is made by your local instance - not by our servers. We are not in the loop. We cannot be. That's the architecture."
|
||||
)
|
||||
)
|
||||
|
||||
let statements: String = el_div(
|
||||
"style=\"display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem\"",
|
||||
stat_card1 + stat_card2
|
||||
)
|
||||
|
||||
let required: String = el_div(
|
||||
"class=\"reveal\" style=\"padding:2rem 2.5rem;border:1px solid rgba(0,82,160,.15);background:rgba(0,82,160,.03)\"",
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem\"",
|
||||
"<strong style=\"color:var(--t1);font-weight:500\">Required before you can use Neuron.</strong> You must designate a Hard Bell contact during setup - before anything else. This is not a settings page you visit later. It happens first."
|
||||
) +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem\"",
|
||||
"If you don't have someone to designate, you can use 988 - the Suicide & Crisis Lifeline - as your Hard Bell contact. The system will accept it. The point is that no one goes in without a line out."
|
||||
) +
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8\"",
|
||||
"I'm also establishing a Neuron crisis line - free, 24/7, staffed. Because I recognize that some people don't have anyone. The technology shouldn't make that worse. It should be the thing that catches you when nothing else does."
|
||||
)
|
||||
)
|
||||
|
||||
people_first + statements + required
|
||||
}
|
||||
|
||||
fn safety() -> String {
|
||||
el_section(
|
||||
"id=\"safety\" aria-label=\"Safety\" style=\"padding:8rem 2.5rem;background:var(--bg2)\"",
|
||||
el_div("class=\"container-lg\"", safety_intro() + safety_cards() + safety_statements())
|
||||
)
|
||||
}
|
||||
|
||||
+149
-129
@@ -4,151 +4,171 @@
|
||||
from styles import { page_open, page_close }
|
||||
from nav import { nav }
|
||||
|
||||
extern fn el_div(attrs: String, children: String) -> String
|
||||
extern fn el_span(attrs: String, children: String) -> String
|
||||
extern fn el_h1(attrs: String, text: String) -> String
|
||||
extern fn el_h2(attrs: String, text: String) -> String
|
||||
extern fn el_p(attrs: String, children: String) -> String
|
||||
extern fn el_a(href: String, attrs: String, children: String) -> String
|
||||
extern fn el_strong(children: String) -> String
|
||||
|
||||
fn terms_page() -> String {
|
||||
return {page_open()}{nav()}{terms_body()}{page_close()}
|
||||
page_open() + nav() + terms_body() + page_close()
|
||||
}
|
||||
|
||||
fn terms_section_head(num: String, title: String) -> String {
|
||||
el_div(
|
||||
"style=\"display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem\"",
|
||||
el_span("style=\"font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)\"", "§ " + num) +
|
||||
el_h2("style=\"font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)\"", title)
|
||||
)
|
||||
}
|
||||
|
||||
fn terms_p(text: String) -> String {
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem\"", text)
|
||||
}
|
||||
|
||||
fn terms_p_last(text: String) -> String {
|
||||
el_p("style=\"font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8\"", text)
|
||||
}
|
||||
|
||||
fn terms_p_caps(text: String) -> String {
|
||||
el_p("style=\"font-family:var(--body);font-size:0.875rem;font-weight:600;color:var(--t1);line-height:1.7;margin-bottom:1rem\"", text)
|
||||
}
|
||||
|
||||
fn terms_body() -> String {
|
||||
return <div style="max-width:720px;margin:0 auto;padding:6rem 2.5rem 8rem">
|
||||
<div style="margin-bottom:3rem">
|
||||
<a href="/" style="font-family:var(--body);font-size:0.75rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy);text-decoration:none">← Neuron</a>
|
||||
</div>
|
||||
<div style="margin-bottom:4rem;border-bottom:1px solid var(--border);padding-bottom:3rem">
|
||||
<p class="label" style="margin-bottom:1rem">Legal</p>
|
||||
<h1 style="font-family:var(--head);font-size:clamp(2rem,4vw,3rem);font-weight:600;color:var(--t1);margin-bottom:0.75rem;line-height:1.1">Terms of Service</h1>
|
||||
<p style="font-family:var(--body);font-size:0.875rem;color:var(--t3)">Effective May 1, 2026 · Neuron, LLC</p>
|
||||
</div>
|
||||
let back_link: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
el_a("/", "style=\"font-family:var(--body);font-size:0.75rem;font-weight:500;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy);text-decoration:none\"", "← Neuron")
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 1</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">Using Neuron</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Using Neuron means you've read these terms and agree to them. That's it. No buried consent, no dark patterns. If something here doesn't sit right with you, email us before using the product - we'll talk through it.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">These terms cover every version of Neuron: free, Professional, and Founding Member. Enterprise use has its own agreement. If you're deploying Neuron for an organization, that's the one you want.</p>
|
||||
</div>
|
||||
let page_header: String = el_div(
|
||||
"style=\"margin-bottom:4rem;border-bottom:1px solid var(--border);padding-bottom:3rem\"",
|
||||
el_p("class=\"label\" style=\"margin-bottom:1rem\"", "Legal") +
|
||||
el_h1("style=\"font-family:var(--head);font-size:clamp(2rem,4vw,3rem);font-weight:600;color:var(--t1);margin-bottom:0.75rem;line-height:1.1\"", "Terms of Service") +
|
||||
el_p("style=\"font-family:var(--body);font-size:0.875rem;color:var(--t3)\"", "Effective May 1, 2026 · Neuron, LLC")
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 2</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">What You Can Do With It</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">You can install and use Neuron on devices you own or control. That's the license. Personal, non-transferable.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Each plan includes <strong style="color:var(--t1);font-weight:500">two devices</strong>. Additional devices are available at a small extra cost. We're not greedy about it - two covers most people, and if you need more, you can add them.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">The free tier doesn't expire. Paid licenses are what they say they are. Founding Member licenses are perpetual - you bought it, you own it. I won't change that.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">You can't resell it, sublicense it, or redistribute it without asking first. If you want to do something creative with it, ask. The answer might be yes.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem"><strong style="color:var(--t1);font-weight:500">License validation.</strong> To use Neuron, the software validates your license against our license server on startup. This applies to all tiers, including Free. The validation confirms your license is active and in good standing. We do not collect your data during this process - the check is limited to license status only.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8"><strong style="color:var(--t1);font-weight:500">Revocation.</strong> If you violate these terms, abuse the system, or engage in conduct that causes harm to other users or to Neuron, LLC, we can revoke your license. This means the software will stop functioning. Revocation is a last resort - we will contact you first when possible. But it is a real consequence, and you should understand that when you agree to use the product.</p>
|
||||
</div>
|
||||
let s1: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("1", "Using Neuron") +
|
||||
terms_p("Using Neuron means you've read these terms and agree to them. That's it. No buried consent, no dark patterns. If something here doesn't sit right with you, email us before using the product - we'll talk through it.") +
|
||||
terms_p_last("These terms cover every version of Neuron: free, Professional, and Founding Member. Enterprise use has its own agreement. If you're deploying Neuron for an organization, that's the one you want.")
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 3</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">Your Data</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Your memory, your conversations, your context - all of it lives on your device. I don't have access to it. I don't collect it. It doesn't move in the course of normal use.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">When you turn on network features - sync, relay, collaborative tools - only what those features need to run gets transmitted. Not your memory, not your conversations, unless you explicitly turn on something that shares them with people you've chosen. I don't sell that data. I don't use it for anything except running the feature you asked for. Turning on a network feature is your consent to that.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Network features route data through Neuron's messaging backplane. That data is encrypted end-to-end - we cannot read it - and is not stored or retained after transmission. Participating in the network is your consent to this transient routing.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">Your data is yours. Nothing in these terms gives me any claim to your content, your memory, or anything you create using Neuron.</p>
|
||||
</div>
|
||||
let s2: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("2", "What You Can Do With It") +
|
||||
terms_p("You can install and use Neuron on devices you own or control. That's the license. Personal, non-transferable.") +
|
||||
terms_p("Each plan includes " + "<strong style=\"color:var(--t1);font-weight:500\">two devices</strong>" + ". Additional devices are available at a small extra cost. We're not greedy about it - two covers most people, and if you need more, you can add them.") +
|
||||
terms_p("The free tier doesn't expire. Paid licenses are what they say they are. Founding Member licenses are perpetual - you bought it, you own it. I won't change that.") +
|
||||
terms_p("You can't resell it, sublicense it, or redistribute it without asking first. If you want to do something creative with it, ask. The answer might be yes.") +
|
||||
terms_p("<strong style=\"color:var(--t1);font-weight:500\">License validation.</strong> To use Neuron, the software validates your license against our license server on startup. This applies to all tiers, including Free. The validation confirms your license is active and in good standing. We do not collect your data during this process - the check is limited to license status only.") +
|
||||
terms_p_last("<strong style=\"color:var(--t1);font-weight:500\">Revocation.</strong> If you violate these terms, abuse the system, or engage in conduct that causes harm to other users or to Neuron, LLC, we can revoke your license. This means the software will stop functioning. Revocation is a last resort - we will contact you first when possible. But it is a real consequence, and you should understand that when you agree to use the product.")
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 4</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">Inference</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Neuron routes inference to whatever provider you configure - your own keys for OpenAI, Anthropic, Grok, any compatible endpoint. When you use a third-party provider, your prompts go through their infrastructure. Their terms apply. I don't control what they do with it.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">Neuron Inference - our own inference layer, launching Q3 2026 - will not store your requests, will not train on them, and will not share them. A separate data addendum will cover the details when it launches.</p>
|
||||
</div>
|
||||
let s3: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("3", "Your Data") +
|
||||
terms_p("Your memory, your conversations, your context - all of it lives on your device. I don't have access to it. I don't collect it. It doesn't move in the course of normal use.") +
|
||||
terms_p("When you turn on network features - sync, relay, collaborative tools - only what those features need to run gets transmitted. Not your memory, not your conversations, unless you explicitly turn on something that shares them with people you've chosen. I don't sell that data. I don't use it for anything except running the feature you asked for. Turning on a network feature is your consent to that.") +
|
||||
terms_p("Network features route data through Neuron's messaging backplane. That data is encrypted end-to-end - we cannot read it - and is not stored or retained after transmission. Participating in the network is your consent to this transient routing.") +
|
||||
terms_p_last("Your data is yours. Nothing in these terms gives me any claim to your content, your memory, or anything you create using Neuron.")
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 5</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">The Network Layer</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Neuron includes access to a proprietary distributed network infrastructure (Patent Pending: US Provisional 64/036,821). Its architecture, operational logic, and internal protocols are trade secrets. What matters here is what it means for you.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">The Neuron AI you interact with develops over time - its responses and capabilities change as the system progresses. This is by design. By using Neuron, you acknowledge that: (a) AI responses may change as the system develops; (b) Neuron, LLC makes no warranty as to the consistency, stability, or predictability of AI outputs at any given point in its development; and (c) AI outputs are a function of development state, not a fixed specification.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">When you enable network features, your interactions may be processed by or through Neuron's distributed network infrastructure. All such data is encrypted in transit. Neuron, LLC cannot read, inspect, retain, or produce the contents of network traffic as an architectural constraint - not merely as a policy. Because we cannot read network traffic, <span style="font-weight:500;color:var(--t1)">Neuron, LLC is not liable for any content, output, or consequence arising from data processed within the network layer</span>, including outputs produced during system development or content you introduce that is processed by the network.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">You agree to indemnify and hold harmless Neuron, LLC, its affiliates, and its officers from any claims, damages, or legal proceedings arising from: (a) your reliance on AI outputs during active development periods; (b) content you originate and introduce through network features; (c) your violation of applicable law in connection with network participation; or (d) any attempt to reverse-engineer, probe, circumvent, or replicate proprietary network architecture or system mechanisms.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">The network layer is decentralized by design. Neuron, LLC does not guarantee its availability, continuity, or performance, and may modify, suspend, or discontinue network features at any time. Network participation does not create an agency relationship between participants, and no participant acts on behalf of Neuron, LLC in any capacity.</p>
|
||||
</div>
|
||||
let s4: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("4", "Inference") +
|
||||
terms_p("Neuron routes inference to whatever provider you configure - your own keys for OpenAI, Anthropic, Grok, any compatible endpoint. When you use a third-party provider, your prompts go through their infrastructure. Their terms apply. I don't control what they do with it.") +
|
||||
terms_p_last("Neuron Inference - our own inference layer, launching Q3 2026 - will not store your requests, will not train on them, and will not share them. A separate data addendum will cover the details when it launches.")
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 6</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">What You Can't Do</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Don't use Neuron to generate content designed to harm people, defraud anyone, or break the law.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Don't try to reverse-engineer the licensing or security mechanisms.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Don't extract or resell proprietary components.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">If you violate these, your license can be revoked. That means the software stops working. We can also suspend access to cloud services and the network layer. This applies to all tiers - there is no free pass because your tier is free.</p>
|
||||
</div>
|
||||
let s5: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("5", "The Network Layer") +
|
||||
terms_p("Neuron includes access to a proprietary distributed network infrastructure (Patent Pending: US Provisional 64/036,821). Its architecture, operational logic, and internal protocols are trade secrets. What matters here is what it means for you.") +
|
||||
terms_p("The Neuron AI you interact with develops over time - its responses and capabilities change as the system progresses. This is by design. By using Neuron, you acknowledge that: (a) AI responses may change as the system develops; (b) Neuron, LLC makes no warranty as to the consistency, stability, or predictability of AI outputs at any given point in its development; and (c) AI outputs are a function of development state, not a fixed specification.") +
|
||||
terms_p("When you enable network features, your interactions may be processed by or through Neuron's distributed network infrastructure. All such data is encrypted in transit. Neuron, LLC cannot read, inspect, retain, or produce the contents of network traffic as an architectural constraint - not merely as a policy. Because we cannot read network traffic, " + "<span style=\"font-weight:500;color:var(--t1)\">Neuron, LLC is not liable for any content, output, or consequence arising from data processed within the network layer</span>" + ", including outputs produced during system development or content you introduce that is processed by the network.") +
|
||||
terms_p("You agree to indemnify and hold harmless Neuron, LLC, its affiliates, and its officers from any claims, damages, or legal proceedings arising from: (a) your reliance on AI outputs during active development periods; (b) content you originate and introduce through network features; (c) your violation of applicable law in connection with network participation; or (d) any attempt to reverse-engineer, probe, circumvent, or replicate proprietary network architecture or system mechanisms.") +
|
||||
terms_p_last("The network layer is decentralized by design. Neuron, LLC does not guarantee its availability, continuity, or performance, and may modify, suspend, or discontinue network features at any time. Network participation does not create an agency relationship between participants, and no participant acts on behalf of Neuron, LLC in any capacity.")
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 7</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">Ownership</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Neuron and everything in it is my intellectual property. Six patents and counting. These terms don't transfer any of that to you.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">Everything you create using Neuron - outputs, memory nodes, artifacts - is yours. I make no claim to it. Not now, not ever.</p>
|
||||
</div>
|
||||
let s6: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("6", "What You Can't Do") +
|
||||
terms_p("Don't use Neuron to generate content designed to harm people, defraud anyone, or break the law.") +
|
||||
terms_p("Don't try to reverse-engineer the licensing or security mechanisms.") +
|
||||
terms_p("Don't extract or resell proprietary components.") +
|
||||
terms_p_last("If you violate these, your license can be revoked. That means the software stops working. We can also suspend access to cloud services and the network layer. This applies to all tiers - there is no free pass because your tier is free.")
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 8</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">No Warranty</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-size:0.875rem;font-weight:600;color:var(--t1);line-height:1.7;margin-bottom:1rem">THE SOFTWARE IS PROVIDED "AS IS." NEURON, LLC MAKES NO WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">Software has bugs. Security has limits. Use your judgment. You use Neuron at your own risk.</p>
|
||||
</div>
|
||||
let s7: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("7", "Ownership") +
|
||||
terms_p("Neuron and everything in it is my intellectual property. Six patents and counting. These terms don't transfer any of that to you.") +
|
||||
terms_p_last("Everything you create using Neuron - outputs, memory nodes, artifacts - is yours. I make no claim to it. Not now, not ever.")
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 9</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">Liability Cap</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-size:0.875rem;font-weight:600;color:var(--t1);line-height:1.7;margin-bottom:1rem">TO THE EXTENT PERMITTED BY LAW, NEURON, LLC IS NOT LIABLE FOR INDIRECT, INCIDENTAL, SPECIAL, CONSEQUENTIAL, OR PUNITIVE DAMAGES ARISING FROM YOUR USE OF THE SOFTWARE.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">If something goes wrong and you have a claim against me, the most I owe you is what you paid in the twelve months before it happened. That's the cap.</p>
|
||||
</div>
|
||||
let s8: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("8", "No Warranty") +
|
||||
terms_p_caps("THE SOFTWARE IS PROVIDED "AS IS." NEURON, LLC MAKES NO WARRANTIES, EXPRESS OR IMPLIED, INCLUDING WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT.") +
|
||||
terms_p_last("Software has bugs. Security has limits. Use your judgment. You use Neuron at your own risk.")
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 10</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">Changes</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">I'll update these terms when I need to. Material changes get announced on the site and, where I have your email, directly. Continued use after a change means you accept the new terms.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">Founding Member licenses are locked. I won't retroactively change what you signed up for.</p>
|
||||
</div>
|
||||
let s9: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("9", "Liability Cap") +
|
||||
terms_p_caps("TO THE EXTENT PERMITTED BY LAW, NEURON, LLC IS NOT LIABLE FOR INDIRECT, INCIDENTAL, SPECIAL, CONSEQUENTIAL, OR PUNITIVE DAMAGES ARISING FROM YOUR USE OF THE SOFTWARE.") +
|
||||
terms_p_last("If something goes wrong and you have a claim against me, the most I owe you is what you paid in the twelve months before it happened. That's the cap.")
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 11</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">Children and Family Accounts</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">Children 13 and over may use Neuron independently. Children under 13 may only use Neuron as part of a family account established by a parent or legal guardian. By setting up a family account that includes a minor, the parent or guardian provides verifiable consent for the child's use and accepts these terms on the child's behalf.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">When a child's Neuron instance is part of a family account, certain information - including usage activity and relevant context - may be shared from the child's local instance to the parent's local instance. This sharing happens device-to-device and does not pass through or get stored on Neuron's servers.</p>
|
||||
let s10: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("10", "Changes") +
|
||||
terms_p("I'll update these terms when I need to. Material changes get announced on the site and, where I have your email, directly. Continued use after a change means you accept the new terms.") +
|
||||
terms_p_last("Founding Member licenses are locked. I won't retroactively change what you signed up for.")
|
||||
)
|
||||
|
||||
<div style="margin:1.5rem 0;padding:1.5rem;border-left:3px solid rgba(0,82,160,.35);background:rgba(0,82,160,.04)">
|
||||
<p style="font-family:var(--body);font-weight:600;font-size:0.875rem;color:var(--t1);margin-bottom:0.875rem;letter-spacing:0.04em">Hard Bell - Required acknowledgment for family accounts</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.875rem;color:var(--t2);line-height:1.8;margin-bottom:0.875rem">Federal data shows approximately 89% of child maltreatment is perpetrated by a parent or caregiver (HHS, Child Maltreatment 2023). The person listed as the primary contact is not always a safe contact. This system is built with that reality in mind.</p>
|
||||
<p style="font-family:var(--body);font-weight:400;font-size:0.875rem;color:var(--t1);line-height:1.8">When you create a family account that includes a minor, you are agreeing unconditionally to the following: <strong>if a safety signal is triggered by a child's account, the parent or guardian named on the family account will not be the first contact reached.</strong> Emergency services and independently designated trusted contacts are notified first. This is not a setting that can be changed. By creating a family account, you accept this structure.</p>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-weight:500;font-size:0.9375rem;color:var(--t1);line-height:1.8;margin-bottom:0.75rem">Mandatory reporting - applies to all accounts.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8;margin-bottom:1rem">By creating any Neuron account, you acknowledge and agree that: <strong style="color:var(--t1);font-weight:500">if Neuron detects credible, specific indicators of intended harm to a person - including harm to the account holder themselves - emergency services or relevant authorities may be contacted.</strong> This is not limited to family accounts. It applies to every user. This is not a privacy violation. It is the only honest answer to what a system that knows you this well is obligated to do when someone is in genuine danger. You cannot opt out of this. If you are unwilling to agree, do not create an account.</p>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">Parents control what is visible to them through their local instance and can revoke family account access at any time. If you believe a child is using Neuron outside of a family account, contact legal@neurontechnologies.ai and we will address it promptly.</p>
|
||||
</div>
|
||||
let hard_bell_block: String = el_div(
|
||||
"style=\"margin:1.5rem 0;padding:1.5rem;border-left:3px solid rgba(0,82,160,.35);background:rgba(0,82,160,.04)\"",
|
||||
el_p("style=\"font-family:var(--body);font-weight:600;font-size:0.875rem;color:var(--t1);margin-bottom:0.875rem;letter-spacing:0.04em\"", "Hard Bell - Required acknowledgment for family accounts") +
|
||||
terms_p("Federal data shows approximately 89% of child maltreatment is perpetrated by a parent or caregiver (HHS, Child Maltreatment 2023). The person listed as the primary contact is not always a safe contact. This system is built with that reality in mind.") +
|
||||
el_p("style=\"font-family:var(--body);font-weight:400;font-size:0.875rem;color:var(--t1);line-height:1.8\"",
|
||||
"When you create a family account that includes a minor, you are agreeing unconditionally to the following: " +
|
||||
"<strong>if a safety signal is triggered by a child's account, the parent or guardian named on the family account will not be the first contact reached.</strong>" +
|
||||
" Emergency services and independently designated trusted contacts are notified first. This is not a setting that can be changed. By creating a family account, you accept this structure."
|
||||
)
|
||||
)
|
||||
|
||||
<div style="margin-bottom:3rem">
|
||||
<div style="display:flex;align-items:baseline;gap:1rem;margin-bottom:1.25rem;border-bottom:1px solid var(--border);padding-bottom:0.75rem">
|
||||
<span style="font-family:var(--body);font-size:0.75rem;font-weight:600;letter-spacing:0.15em;text-transform:uppercase;color:var(--navy-65)">§ 12</span>
|
||||
<h2 style="font-family:var(--head);font-size:1.25rem;font-weight:600;color:var(--t1)">Governing Law</h2>
|
||||
</div>
|
||||
<p style="font-family:var(--body);font-weight:300;font-size:0.9375rem;color:var(--t2);line-height:1.8">These terms are governed by the laws of Delaware. Disputes go to the courts of Delaware.</p>
|
||||
</div>
|
||||
let s11: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("11", "Children and Family Accounts") +
|
||||
terms_p("Children 13 and over may use Neuron independently. Children under 13 may only use Neuron as part of a family account established by a parent or legal guardian. By setting up a family account that includes a minor, the parent or guardian provides verifiable consent for the child's use and accepts these terms on the child's behalf.") +
|
||||
terms_p("When a child's Neuron instance is part of a family account, certain information - including usage activity and relevant context - may be shared from the child's local instance to the parent's local instance. This sharing happens device-to-device and does not pass through or get stored on Neuron's servers.") +
|
||||
hard_bell_block +
|
||||
el_p("style=\"font-family:var(--body);font-weight:500;font-size:0.9375rem;color:var(--t1);line-height:1.8;margin-bottom:0.75rem\"", "Mandatory reporting - applies to all accounts.") +
|
||||
terms_p("By creating any Neuron account, you acknowledge and agree that: " + "<strong style=\"color:var(--t1);font-weight:500\">if Neuron detects credible, specific indicators of intended harm to a person - including harm to the account holder themselves - emergency services or relevant authorities may be contacted.</strong>" + " This is not limited to family accounts. It applies to every user. This is not a privacy violation. It is the only honest answer to what a system that knows you this well is obligated to do when someone is in genuine danger. You cannot opt out of this. If you are unwilling to agree, do not create an account.") +
|
||||
terms_p_last("Parents control what is visible to them through their local instance and can revoke family account access at any time. If you believe a child is using Neuron outside of a family account, contact legal@neurontechnologies.ai and we will address it promptly.")
|
||||
)
|
||||
|
||||
<div style="margin-top:4rem;padding-top:2rem;border-top:1px solid var(--border);display:flex;gap:2rem;flex-wrap:wrap">
|
||||
<a href="/" style="font-family:var(--body);font-size:0.8125rem;color:var(--navy);text-decoration:none">← Home</a>
|
||||
<a href="/legal/enterprise-terms" style="font-family:var(--body);font-size:0.8125rem;color:var(--navy);text-decoration:none">Enterprise Agreement →</a>
|
||||
</div>
|
||||
</div>
|
||||
let s12: String = el_div(
|
||||
"style=\"margin-bottom:3rem\"",
|
||||
terms_section_head("12", "Governing Law") +
|
||||
terms_p_last("These terms are governed by the laws of Delaware. Disputes go to the courts of Delaware.")
|
||||
)
|
||||
|
||||
let footer_links: String = el_div(
|
||||
"style=\"margin-top:4rem;padding-top:2rem;border-top:1px solid var(--border);display:flex;gap:2rem;flex-wrap:wrap\"",
|
||||
el_a("/", "style=\"font-family:var(--body);font-size:0.8125rem;color:var(--navy);text-decoration:none\"", "← Home") +
|
||||
el_a("/legal/enterprise-terms", "style=\"font-family:var(--body);font-size:0.8125rem;color:var(--navy);text-decoration:none\"", "Enterprise Agreement →")
|
||||
)
|
||||
|
||||
el_div(
|
||||
"style=\"max-width:720px;margin:0 auto;padding:6rem 2.5rem 8rem\"",
|
||||
back_link +
|
||||
page_header +
|
||||
s1 + s2 + s3 + s4 + s5 + s6 + s7 + s8 + s9 + s10 + s11 + s12 +
|
||||
footer_links
|
||||
)
|
||||
}
|
||||
|
||||
+1
-1
@@ -2,5 +2,5 @@
|
||||
// Removed — section taken out per design decision.
|
||||
|
||||
fn viral() -> String {
|
||||
return ""
|
||||
""
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user