Agency — Software / Dev Shop Landing
A dark, engineering-grade landing page for Northbyte, a fictional software and product studio, built on a near-black canvas with a mono-lime accent, slate highlights, and a Space Grotesk and JetBrains Mono pairing. The hero pairs a strong headline with a live typewriter terminal that runs a deploy log on loop, plus count-up proof stats. Below sit a scrolling tech stack, a four-practice services grid, case studies with hard metrics, a four-step engagement model, a senior team row, a rotating testimonial carousel, and a validated start-a-project form.
MCP
Code
:root {
--bg: #0c0e12;
--bg-2: #0f1217;
--panel: #141821;
--panel-2: #1a1f2a;
--line: #232a36;
--line-2: #2c3543;
--ink: #e8edf4;
--muted: #99a4b4;
--faint: #6a7585;
--lime: #c4f042;
--lime-2: #9fe000;
--lime-ink: #0c0e12;
--slate: #5b6bff;
--radius: 14px;
--radius-sm: 9px;
--ease: cubic-bezier(.16, .84, .44, 1);
--mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
--sans: "Space Grotesk", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
margin: 0;
font-family: var(--sans);
background: var(--bg);
color: var(--ink);
line-height: 1.5;
-webkit-font-smoothing: antialiased;
text-rendering: optimizeLegibility;
overflow-x: hidden;
}
h1, h2, h3, h4 { margin: 0; line-height: 1.08; letter-spacing: -.02em; font-weight: 700; }
p { margin: 0; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
ul, ol { margin: 0; padding: 0; list-style: none; }
.container { width: min(1180px, 100% - 3rem); margin-inline: auto; }
.skip-link {
position: absolute; left: -999px; top: 0; z-index: 200;
background: var(--lime); color: var(--lime-ink); padding: .6rem 1rem; border-radius: 0 0 8px 0; font-weight: 600;
}
.skip-link:focus { left: 0; }
/* ---------- buttons ---------- */
.btn {
display: inline-flex; align-items: center; gap: .5rem;
font-family: var(--sans); font-weight: 600; font-size: .94rem;
padding: .68rem 1.15rem; border-radius: var(--radius-sm);
border: 1px solid transparent; cursor: pointer; transition: transform .18s var(--ease), background .18s, border-color .18s, box-shadow .18s;
}
.btn--lg { padding: .9rem 1.5rem; font-size: 1rem; }
.btn--solid { background: var(--lime); color: var(--lime-ink); box-shadow: 0 8px 24px -10px var(--lime-2); }
.btn--solid:hover { transform: translateY(-2px); box-shadow: 0 14px 34px -12px var(--lime-2); }
.btn--ghost { background: transparent; color: var(--ink); border-color: var(--line-2); }
.btn--ghost:hover { border-color: var(--lime); color: var(--lime); transform: translateY(-2px); }
.btn:focus-visible { outline: 2px solid var(--lime); outline-offset: 2px; }
.eyebrow {
display: inline-flex; align-items: center; gap: .55rem;
font-family: var(--mono); font-size: .76rem; letter-spacing: .14em; text-transform: uppercase;
color: var(--lime); margin: 0 0 1rem;
}
.eyebrow .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--lime); box-shadow: 0 0 0 4px rgba(196,240,66,.14); }
.grad {
background: linear-gradient(100deg, var(--lime), #e6ff8a 60%, var(--slate));
-webkit-background-clip: text; background-clip: text; color: transparent;
}
/* ---------- nav ---------- */
.nav {
position: sticky; top: 0; z-index: 100;
border-bottom: 1px solid transparent;
transition: background .25s, border-color .25s, backdrop-filter .25s;
}
.nav.scrolled { background: rgba(12,14,18,.82); backdrop-filter: blur(12px); border-bottom-color: var(--line); }
.nav__inner { display: flex; align-items: center; gap: 1.5rem; height: 70px; }
.brand { display: inline-flex; align-items: center; gap: .55rem; font-weight: 700; }
.brand__mark { color: var(--lime); display: inline-flex; }
.brand__word { font-size: 1.12rem; letter-spacing: -.02em; }
.brand__word b { color: var(--lime); font-weight: 700; }
.brand__cursor { color: var(--lime); animation: blink 1.1s steps(1) infinite; }
@keyframes blink { 50% { opacity: 0; } }
.nav__links { display: flex; gap: 1.5rem; margin-inline: auto; }
.nav__links a { font-size: .92rem; color: var(--muted); position: relative; padding: .25rem 0; transition: color .18s; }
.nav__links a::after { content: ""; position: absolute; left: 0; bottom: -2px; width: 0; height: 2px; background: var(--lime); transition: width .22s var(--ease); }
.nav__links a:hover { color: var(--ink); }
.nav__links a:hover::after { width: 100%; }
.nav__cta { display: flex; gap: .6rem; }
.nav__toggle { display: none; flex-direction: column; gap: 5px; background: none; border: 0; cursor: pointer; padding: 8px; }
.nav__toggle span { width: 22px; height: 2px; background: var(--ink); border-radius: 2px; transition: transform .25s, opacity .2s; }
.nav__toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
/* ---------- hero ---------- */
.hero { position: relative; padding: clamp(3rem, 8vw, 6.5rem) 0 clamp(3rem, 7vw, 5.5rem); overflow: hidden; }
.hero__grid {
position: absolute; inset: 0; z-index: 0; pointer-events: none;
background:
radial-gradient(620px 360px at 78% 6%, rgba(196,240,66,.13), transparent 70%),
radial-gradient(560px 420px at 12% 92%, rgba(91,107,255,.10), transparent 70%),
linear-gradient(rgba(35,42,54,.5) 1px, transparent 1px) 0 0 / 100% 46px,
linear-gradient(90deg, rgba(35,42,54,.5) 1px, transparent 1px) 0 0 / 46px 100%;
-webkit-mask-image: radial-gradient(circle at 50% 35%, #000, transparent 78%);
mask-image: radial-gradient(circle at 50% 35%, #000, transparent 78%);
opacity: .5;
}
.hero__inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem, 5vw, 4rem); align-items: center; }
.hero__title { font-size: clamp(2.4rem, 6vw, 4.3rem); margin: 0 0 1.2rem; }
.hero__sub { color: var(--muted); font-size: clamp(1rem, 1.4vw, 1.18rem); max-width: 34ch; margin: 0 0 1.8rem; }
.hero__actions { display: flex; flex-wrap: wrap; gap: .8rem; margin-bottom: 2.4rem; }
.hero__proof { display: flex; gap: 2rem; flex-wrap: wrap; }
.hero__proof li { display: flex; flex-direction: column; }
.hero__proof b { font-family: var(--mono); font-size: 1.7rem; color: var(--lime); }
.hero__proof span { font-size: .8rem; color: var(--faint); letter-spacing: .02em; }
/* terminal */
.terminal {
background: linear-gradient(180deg, var(--panel), var(--bg-2));
border: 1px solid var(--line); border-radius: var(--radius);
box-shadow: 0 40px 80px -40px rgba(0,0,0,.8), inset 0 1px 0 rgba(255,255,255,.03);
overflow: hidden;
}
.terminal__bar { display: flex; align-items: center; gap: .5rem; padding: .7rem 1rem; border-bottom: 1px solid var(--line); background: rgba(255,255,255,.02); }
.tdot { width: 11px; height: 11px; border-radius: 50%; }
.tdot--r { background: #ff5f56; } .tdot--y { background: #ffbd2e; } .tdot--g { background: var(--lime-2); }
.terminal__title { margin-left: .6rem; font-family: var(--mono); font-size: .78rem; color: var(--faint); }
.terminal__body { margin: 0; padding: 1.3rem 1.4rem; font-family: var(--mono); font-size: .86rem; line-height: 1.75; min-height: 240px; white-space: pre-wrap; }
.terminal__body .tk-c { color: var(--faint); }
.terminal__body .tk-k { color: var(--slate); }
.terminal__body .tk-g { color: var(--lime); }
.terminal__body .tk-w { color: var(--ink); }
.caret { color: var(--lime); animation: blink 1.05s steps(1) infinite; font-family: var(--mono); }
/* ---------- stack ---------- */
.stack { padding: 2.2rem 0; border-block: 1px solid var(--line); background: var(--bg-2); }
.stack__label { font-family: var(--mono); font-size: .76rem; color: var(--faint); text-transform: uppercase; letter-spacing: .12em; margin: 0 0 1.1rem; }
.stack__row { display: flex; flex-wrap: wrap; gap: .6rem .8rem; }
.stack__row li {
font-family: var(--mono); font-size: .85rem; color: var(--muted);
padding: .4rem .8rem; border: 1px solid var(--line); border-radius: 999px; background: var(--panel);
transition: color .18s, border-color .18s, transform .18s;
}
.stack__row li:hover { color: var(--lime); border-color: var(--lime); transform: translateY(-2px); }
/* ---------- sections ---------- */
.section { padding: clamp(3.5rem, 8vw, 6rem) 0; }
.section--alt { background: var(--bg-2); border-block: 1px solid var(--line); }
.section__head { max-width: 60ch; margin-bottom: 2.6rem; }
.section__head h2 { font-size: clamp(1.8rem, 3.6vw, 2.7rem); }
.section__lead { color: var(--muted); margin-top: .8rem; font-size: 1.05rem; }
/* services */
.cards { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.1rem; }
.card {
background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius);
padding: 1.6rem 1.4rem; transition: transform .22s var(--ease), border-color .22s, box-shadow .22s;
position: relative; overflow: hidden;
}
.card::before { content: ""; position: absolute; inset: 0 0 auto 0; height: 2px; background: linear-gradient(90deg, var(--lime), transparent); transform: scaleX(0); transform-origin: left; transition: transform .3s var(--ease); }
.card:hover { transform: translateY(-5px); border-color: var(--line-2); box-shadow: 0 30px 60px -36px rgba(0,0,0,.7); }
.card:hover::before { transform: scaleX(1); }
.card__ico { font-family: var(--mono); font-size: 1.3rem; color: var(--lime); width: 46px; height: 46px; display: grid; place-items: center; border: 1px solid var(--line-2); border-radius: 11px; background: rgba(196,240,66,.06); margin-bottom: 1.1rem; }
.card h3 { font-size: 1.18rem; margin-bottom: .5rem; }
.card p { color: var(--muted); font-size: .94rem; }
.card__list { margin-top: 1rem; display: flex; flex-direction: column; gap: .4rem; }
.card__list li { font-family: var(--mono); font-size: .78rem; color: var(--faint); padding-left: 1.1rem; position: relative; }
.card__list li::before { content: "›"; position: absolute; left: 0; color: var(--lime); }
/* cases */
.cases { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
.case { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.6rem; display: flex; flex-direction: column; transition: transform .22s var(--ease), border-color .22s; }
.case:hover { transform: translateY(-4px); border-color: var(--lime); }
.case__top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.case__tag { font-family: var(--mono); font-size: .7rem; text-transform: uppercase; letter-spacing: .1em; color: var(--lime); background: rgba(196,240,66,.08); border: 1px solid var(--line-2); padding: .25rem .6rem; border-radius: 999px; }
.case__name { font-family: var(--mono); font-size: .82rem; color: var(--faint); }
.case h3 { font-size: 1.12rem; margin-bottom: .55rem; }
.case p { color: var(--muted); font-size: .92rem; flex: 1; }
.case__metrics { display: flex; gap: 1.4rem; margin-top: 1.3rem; padding-top: 1.2rem; border-top: 1px solid var(--line); }
.case__metrics b { display: block; font-family: var(--mono); font-size: 1.35rem; color: var(--ink); }
.case__metrics span { font-size: .72rem; color: var(--faint); }
/* process */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.1rem; counter-reset: s; }
.step { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.6rem 1.4rem; position: relative; transition: border-color .2s, transform .2s; }
.step:hover { border-color: var(--line-2); transform: translateY(-3px); }
.step__n { font-family: var(--mono); font-size: 2rem; font-weight: 700; color: var(--lime); opacity: .55; display: block; margin-bottom: .8rem; }
.step h3 { font-size: 1.1rem; margin-bottom: .45rem; }
.step p { color: var(--muted); font-size: .92rem; }
/* team */
.team { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.1rem; }
.member { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.4rem; text-align: center; transition: transform .2s, border-color .2s; }
.member:hover { transform: translateY(-4px); border-color: var(--line-2); }
.member__ph { width: 84px; height: 84px; margin: 0 auto .9rem; border-radius: 50%; display: grid; place-items: center; font-family: var(--mono); font-weight: 700; font-size: 1.4rem; color: var(--lime-ink); background: linear-gradient(135deg, var(--lime), var(--lime-2)); }
.member__ph::after { content: attr(data-i); }
.member h3 { font-size: 1.02rem; }
.member p { font-family: var(--mono); font-size: .78rem; color: var(--faint); margin-top: .3rem; }
/* testimonials */
.voices { text-align: center; }
.quotes { position: relative; max-width: 760px; margin: 0 auto; min-height: 160px; }
.quote { position: absolute; inset: 0; opacity: 0; transform: translateY(12px); transition: opacity .45s, transform .45s; pointer-events: none; margin: 0; }
.quote.is-active { opacity: 1; transform: none; position: relative; pointer-events: auto; }
.quote p { font-size: clamp(1.15rem, 2.4vw, 1.6rem); line-height: 1.45; letter-spacing: -.01em; }
.quote footer { margin-top: 1.4rem; display: flex; flex-direction: column; gap: .15rem; }
.quote footer b { color: var(--lime); }
.quote footer span { font-family: var(--mono); font-size: .8rem; color: var(--faint); }
.quotes__dots { display: flex; gap: .55rem; justify-content: center; margin-top: 1.8rem; }
.qdot { width: 10px; height: 10px; border-radius: 50%; border: 1px solid var(--line-2); background: transparent; cursor: pointer; padding: 0; transition: background .2s, border-color .2s, transform .2s; }
.qdot:hover { transform: scale(1.2); }
.qdot.is-active { background: var(--lime); border-color: var(--lime); }
.qdot:focus-visible { outline: 2px solid var(--lime); outline-offset: 3px; }
/* cta */
.cta { padding: clamp(3.5rem, 8vw, 6rem) 0; background: var(--bg-2); border-top: 1px solid var(--line); }
.cta__inner {
display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4rem); align-items: start;
background: linear-gradient(160deg, var(--panel), var(--bg-2)); border: 1px solid var(--line);
border-radius: 20px; padding: clamp(1.8rem, 4vw, 3rem);
box-shadow: 0 40px 90px -50px rgba(196,240,66,.25);
}
.cta__copy h2 { font-size: clamp(1.8rem, 3.4vw, 2.6rem); }
.cta__copy p { color: var(--muted); margin-top: .8rem; }
.cta__bullets { margin-top: 1.6rem; display: flex; flex-direction: column; gap: .7rem; }
.cta__bullets li { font-family: var(--mono); font-size: .86rem; color: var(--ink); padding-left: 1.5rem; position: relative; }
.cta__bullets li::before { content: "✓"; position: absolute; left: 0; color: var(--lime); font-weight: 700; }
.cta__form { display: flex; flex-direction: column; gap: 1rem; }
.field { display: flex; flex-direction: column; gap: .4rem; }
.field label { font-family: var(--mono); font-size: .78rem; color: var(--muted); letter-spacing: .04em; }
.field input, .field textarea {
font-family: var(--sans); font-size: .95rem; color: var(--ink);
background: var(--bg); border: 1px solid var(--line-2); border-radius: var(--radius-sm);
padding: .75rem .85rem; resize: vertical; transition: border-color .18s, box-shadow .18s;
}
.field input::placeholder, .field textarea::placeholder { color: var(--faint); }
.field input:focus, .field textarea:focus { outline: none; border-color: var(--lime); box-shadow: 0 0 0 3px rgba(196,240,66,.16); }
.field.invalid input, .field.invalid textarea { border-color: #ff6b6b; box-shadow: 0 0 0 3px rgba(255,107,107,.14); }
.cta__note { font-size: .78rem; color: var(--faint); font-family: var(--mono); }
/* footer */
.footer { background: var(--bg); border-top: 1px solid var(--line); padding: 3rem 0 1.6rem; }
.footer__inner { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2rem; padding-bottom: 2rem; border-bottom: 1px solid var(--line); }
.footer__brand p { color: var(--faint); font-size: .9rem; margin-top: .8rem; max-width: 34ch; }
.footer__col h4 { font-family: var(--mono); font-size: .76rem; text-transform: uppercase; letter-spacing: .12em; color: var(--muted); margin-bottom: 1rem; }
.footer__col a { display: block; color: var(--faint); font-size: .92rem; padding: .25rem 0; transition: color .18s; }
.footer__col a:hover { color: var(--lime); }
.footer__bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 1.4rem; }
.footer__bottom span { font-size: .8rem; color: var(--faint); }
.totop { font-family: var(--mono); font-size: .8rem; color: var(--muted); background: none; border: 1px solid var(--line-2); border-radius: 8px; padding: .4rem .7rem; cursor: pointer; transition: color .18s, border-color .18s; }
.totop:hover { color: var(--lime); border-color: var(--lime); }
/* toast */
.toast {
position: fixed; left: 50%; bottom: 1.6rem; transform: translate(-50%, 140%);
background: var(--lime); color: var(--lime-ink); font-weight: 600; font-size: .9rem;
padding: .8rem 1.3rem; border-radius: 10px; box-shadow: 0 16px 40px -16px rgba(196,240,66,.6);
z-index: 300; transition: transform .35s var(--ease); max-width: 90vw;
}
.toast.show { transform: translate(-50%, 0); }
/* reveal */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }
/* ---------- responsive ---------- */
@media (max-width: 920px) {
.cards, .steps, .team { grid-template-columns: repeat(2, 1fr); }
.cases { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
.nav__cta { display: none; }
.nav__toggle { display: flex; }
.nav__links {
position: fixed; inset: 70px 0 auto 0; flex-direction: column; gap: 0; margin: 0;
background: rgba(12,14,18,.97); backdrop-filter: blur(14px); border-bottom: 1px solid var(--line);
padding: .5rem 1.5rem 1.5rem; transform: translateY(-120%); transition: transform .3s var(--ease);
}
.nav__links.open { transform: none; }
.nav__links a { padding: .85rem 0; border-bottom: 1px solid var(--line); width: 100%; }
.hero__inner, .cta__inner, .footer__inner { grid-template-columns: 1fr; }
.footer__inner { gap: 1.6rem; }
.terminal { order: -1; }
}
@media (max-width: 520px) {
.container { width: min(1180px, 100% - 2rem); }
.cards, .steps, .team { grid-template-columns: 1fr; }
.hero__proof { gap: 1.3rem; }
.case__metrics { gap: 1rem; }
.footer__bottom { flex-direction: column; gap: 1rem; text-align: center; }
}(function () {
"use strict";
var reduce = window.matchMedia("(prefers-reduced-motion: reduce)").matches;
/* ---------- toast ---------- */
var toastEl = document.getElementById("toast");
var toastTimer;
function toast(msg) {
if (!toastEl) return;
toastEl.textContent = msg;
toastEl.classList.add("show");
clearTimeout(toastTimer);
toastTimer = setTimeout(function () { toastEl.classList.remove("show"); }, 3200);
}
/* ---------- sticky nav state ---------- */
var nav = document.getElementById("nav");
function onScroll() {
if (nav) nav.classList.toggle("scrolled", window.scrollY > 12);
}
onScroll();
window.addEventListener("scroll", onScroll, { passive: true });
/* ---------- mobile menu ---------- */
var toggle = document.getElementById("navToggle");
var links = document.getElementById("primary-nav");
function closeMenu() {
if (!toggle || !links) return;
toggle.setAttribute("aria-expanded", "false");
toggle.setAttribute("aria-label", "Open menu");
links.classList.remove("open");
}
if (toggle && links) {
toggle.addEventListener("click", function () {
var open = toggle.getAttribute("aria-expanded") === "true";
toggle.setAttribute("aria-expanded", String(!open));
toggle.setAttribute("aria-label", open ? "Open menu" : "Close menu");
links.classList.toggle("open", !open);
});
links.addEventListener("click", function (e) {
if (e.target.tagName === "A") closeMenu();
});
document.addEventListener("keydown", function (e) {
if (e.key === "Escape") closeMenu();
});
}
/* ---------- scroll reveal ---------- */
var revealEls = Array.prototype.slice.call(document.querySelectorAll(".reveal"));
if (reduce || !("IntersectionObserver" in window)) {
revealEls.forEach(function (el) { el.classList.add("in"); });
} else {
var io = new IntersectionObserver(function (entries) {
entries.forEach(function (en) {
if (en.isIntersecting) {
en.target.classList.add("in");
io.unobserve(en.target);
}
});
}, { threshold: 0.14, rootMargin: "0px 0px -40px 0px" });
revealEls.forEach(function (el) { io.observe(el); });
}
/* ---------- count-up ---------- */
function runCount(el) {
var target = parseFloat(el.getAttribute("data-count")) || 0;
var suffix = el.getAttribute("data-suffix") || "";
if (reduce) { el.textContent = target + suffix; return; }
var start = null, dur = 1400;
function step(ts) {
if (!start) start = ts;
var p = Math.min((ts - start) / dur, 1);
var eased = 1 - Math.pow(1 - p, 3);
el.textContent = Math.round(target * eased) + suffix;
if (p < 1) requestAnimationFrame(step);
else el.textContent = target + suffix;
}
requestAnimationFrame(step);
}
var counters = Array.prototype.slice.call(document.querySelectorAll("[data-count]"));
if ("IntersectionObserver" in window) {
var cio = new IntersectionObserver(function (entries) {
entries.forEach(function (en) {
if (en.isIntersecting) { runCount(en.target); cio.unobserve(en.target); }
});
}, { threshold: 0.6 });
counters.forEach(function (el) { cio.observe(el); });
} else {
counters.forEach(runCount);
}
/* ---------- terminal typewriter ---------- */
var term = document.getElementById("termCode");
if (term) {
var lines = [
{ t: "$ ", c: "tk-g" }, { t: "northbyte deploy --env prod\n", c: "tk-w" },
{ t: "→ ", c: "tk-k" }, { t: "running 412 tests", c: "tk-w" }, { t: " … ", c: "tk-c" }, { t: "all green\n", c: "tk-g" },
{ t: "→ ", c: "tk-k" }, { t: "building image", c: "tk-w" }, { t: " … ", c: "tk-c" }, { t: "ok (38s)\n", c: "tk-g" },
{ t: "→ ", c: "tk-k" }, { t: "rolling out canary 5% → 100%\n", c: "tk-w" },
{ t: "✓ ", c: "tk-g" }, { t: "p99 latency", c: "tk-w" }, { t: " 41ms", c: "tk-g" }, { t: " uptime", c: "tk-w" }, { t: " 99.98%\n", c: "tk-g" },
{ t: "# ", c: "tk-c" }, { t: "shipped to prod. no incidents.", c: "tk-c" }
];
if (reduce) {
term.innerHTML = lines.map(function (s) {
return '<span class="' + s.c + '">' + escapeHtml(s.t) + "</span>";
}).join("");
} else {
var li = 0, ci = 0, current = null;
function tick() {
if (li >= lines.length) {
setTimeout(function () { term.innerHTML = ""; li = 0; ci = 0; current = null; tick(); }, 3800);
return;
}
var seg = lines[li];
if (ci === 0) {
current = document.createElement("span");
current.className = seg.c;
term.appendChild(current);
}
current.textContent += seg.t.charAt(ci);
ci++;
if (ci >= seg.t.length) { li++; ci = 0; }
var ch = seg.t.charAt(Math.max(ci - 1, 0));
var delay = ch === "\n" ? 240 : (18 + Math.random() * 38);
setTimeout(tick, delay);
}
tick();
}
}
function escapeHtml(s) {
return s.replace(/[&<>]/g, function (m) { return { "&": "&", "<": "<", ">": ">" }[m]; });
}
/* ---------- testimonials carousel ---------- */
var quotes = Array.prototype.slice.call(document.querySelectorAll(".quote"));
var qdots = Array.prototype.slice.call(document.querySelectorAll(".qdot"));
var qi = 0, qTimer;
function showQuote(n) {
qi = (n + quotes.length) % quotes.length;
quotes.forEach(function (q, i) { q.classList.toggle("is-active", i === qi); });
qdots.forEach(function (d, i) {
d.classList.toggle("is-active", i === qi);
d.setAttribute("aria-selected", String(i === qi));
});
}
function autoQuote() {
clearInterval(qTimer);
if (reduce) return;
qTimer = setInterval(function () { showQuote(qi + 1); }, 5500);
}
qdots.forEach(function (d, i) {
d.addEventListener("click", function () { showQuote(i); autoQuote(); });
});
if (quotes.length) { showQuote(0); autoQuote(); }
/* ---------- contact form ---------- */
var form = document.getElementById("startForm");
if (form) {
form.addEventListener("submit", function (e) {
e.preventDefault();
var ok = true, firstBad = null;
["f-name", "f-email", "f-scope"].forEach(function (id) {
var el = document.getElementById(id);
var field = el.closest(".field");
var valid = el.value.trim().length > 0;
if (id === "f-email") valid = valid && /^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(el.value.trim());
field.classList.toggle("invalid", !valid);
if (!valid && ok) { ok = false; firstBad = el; }
});
if (!ok) { if (firstBad) firstBad.focus(); toast("Please fill in every field correctly."); return; }
var name = document.getElementById("f-name").value.trim().split(" ")[0];
form.reset();
toast("Thanks, " + name + " — a senior engineer will reply within a day.");
});
form.addEventListener("input", function (e) {
var f = e.target.closest(".field");
if (f) f.classList.remove("invalid");
});
}
/* ---------- back to top ---------- */
var toTop = document.getElementById("toTop");
if (toTop) {
toTop.addEventListener("click", function () {
window.scrollTo({ top: 0, behavior: reduce ? "auto" : "smooth" });
});
}
/* ---------- CTA link toasts ---------- */
document.querySelectorAll('a[href="#start"]').forEach(function (a) {
a.addEventListener("click", function () {
setTimeout(function () { toast("Tell us what you're building below ↓"); }, 360);
});
});
})();<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Northbyte — Software & Product Engineering Studio</title>
<meta name="description" content="Northbyte is a fictional software studio that ships web, mobile, AI, and platform products for ambitious teams." />
<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=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;700&display=swap" rel="stylesheet" />
<link rel="stylesheet" href="style.css" />
</head>
<body>
<a class="skip-link" href="#main">Skip to content</a>
<!-- ===== NAV ===== -->
<header class="nav" id="nav">
<div class="container nav__inner">
<a class="brand" href="#top" aria-label="Northbyte home">
<span class="brand__mark" aria-hidden="true">
<svg viewBox="0 0 32 32" width="28" height="28"><path d="M6 24V8l12 11V8h4v16l-12-11v11z" fill="currentColor"/></svg>
</span>
<span class="brand__word">north<b>byte</b><span class="brand__cursor" aria-hidden="true">_</span></span>
</a>
<nav class="nav__links" id="primary-nav" aria-label="Primary">
<a href="#services">Services</a>
<a href="#work">Work</a>
<a href="#process">Process</a>
<a href="#team">Team</a>
<a href="#voices">Clients</a>
</nav>
<div class="nav__cta">
<a class="btn btn--ghost" href="#stack">Stack</a>
<a class="btn btn--solid" href="#start">Start a project</a>
</div>
<button class="nav__toggle" id="navToggle" aria-expanded="false" aria-controls="primary-nav" aria-label="Open menu">
<span></span><span></span><span></span>
</button>
</div>
</header>
<main id="main">
<span id="top"></span>
<!-- ===== HERO ===== -->
<section class="hero">
<div class="container hero__inner">
<div class="hero__copy reveal">
<p class="eyebrow"><span class="dot"></span> shipping product since 2014</p>
<h1 class="hero__title">We build software<br />that <span class="grad">survives prod.</span></h1>
<p class="hero__sub">Northbyte is a senior engineering studio. We design, build, and operate web, mobile, AI, and platform products — from zero-to-one MVPs to systems doing nine figures in traffic.</p>
<div class="hero__actions">
<a class="btn btn--solid btn--lg" href="#start">Start a project <span aria-hidden="true">→</span></a>
<a class="btn btn--ghost btn--lg" href="#work">See case studies</a>
</div>
<ul class="hero__proof">
<li><b data-count="120">0</b><span>products shipped</span></li>
<li><b data-count="99" data-suffix=".98%">0</b><span>uptime delivered</span></li>
<li><b data-count="38">0</b><span>senior engineers</span></li>
</ul>
</div>
<!-- terminal motif -->
<div class="terminal reveal" aria-hidden="true">
<div class="terminal__bar">
<span class="tdot tdot--r"></span><span class="tdot tdot--y"></span><span class="tdot tdot--g"></span>
<span class="terminal__title">~/northbyte — deploy</span>
</div>
<pre class="terminal__body"><code id="termCode"></code><span class="caret">█</span></pre>
</div>
</div>
<div class="hero__grid" aria-hidden="true"></div>
</section>
<!-- ===== STACK / LOGOS ===== -->
<section class="stack" id="stack" aria-label="Technology stack">
<div class="container">
<p class="stack__label">// production stack we run every day</p>
<ul class="stack__row reveal">
<li>TypeScript</li><li>Rust</li><li>Go</li><li>React</li><li>Postgres</li>
<li>Kubernetes</li><li>Terraform</li><li>gRPC</li><li>Kafka</li><li>PyTorch</li>
</ul>
</div>
</section>
<!-- ===== SERVICES ===== -->
<section class="section" id="services">
<div class="container">
<header class="section__head reveal">
<p class="eyebrow"><span class="dot"></span> services</p>
<h2>Four practices, one delivery team</h2>
<p class="section__lead">Embedded squads that own outcomes — not tickets. Pick a practice or let us run the whole roadmap.</p>
</header>
<div class="cards">
<article class="card reveal">
<div class="card__ico">{ }</div>
<h3>Web platforms</h3>
<p>High-traffic Next.js & edge apps, design systems, and the CI/CD to ship them daily without fear.</p>
<ul class="card__list"><li>SSR & edge rendering</li><li>Design systems</li><li>Core Web Vitals</li></ul>
</article>
<article class="card reveal">
<div class="card__ico">[ ]</div>
<h3>Mobile</h3>
<p>Native-grade React Native and Swift/Kotlin apps with offline sync, push, and store-ready releases.</p>
<ul class="card__list"><li>React Native</li><li>Offline-first</li><li>App Store / Play</li></ul>
</article>
<article class="card reveal">
<div class="card__ico">>_</div>
<h3>AI & data</h3>
<p>RAG, evals, and inference pipelines wired to real product surfaces — with guardrails and observability.</p>
<ul class="card__list"><li>RAG & agents</li><li>Eval harnesses</li><li>Vector & OLAP</li></ul>
</article>
<article class="card reveal">
<div class="card__ico"></></div>
<h3>Platform & SRE</h3>
<p>Kubernetes, IaC, and observability that turns 3am pages into dashboards. We operate what we build.</p>
<ul class="card__list"><li>Terraform / K8s</li><li>SLOs & on-call</li><li>Cost engineering</li></ul>
</article>
</div>
</div>
</section>
<!-- ===== WORK / CASE STUDIES ===== -->
<section class="section section--alt" id="work">
<div class="container">
<header class="section__head reveal">
<p class="eyebrow"><span class="dot"></span> selected work</p>
<h2>Outcomes, measured in prod</h2>
<p class="section__lead">A few fictional engagements and the numbers that mattered to the business.</p>
</header>
<div class="cases">
<article class="case reveal">
<header class="case__top"><span class="case__tag">fintech</span><span class="case__name">Ledgerline</span></header>
<h3>Re-platformed payments onto an event-driven core</h3>
<p>Replaced a monolith with a Go + Kafka pipeline, cutting settlement latency and unlocking real-time reconciliation.</p>
<ul class="case__metrics">
<li><b>−74%</b><span>p99 latency</span></li>
<li><b>3.1M</b><span>tx / day</span></li>
<li><b>11wk</b><span>to launch</span></li>
</ul>
</article>
<article class="case reveal">
<header class="case__top"><span class="case__tag">health AI</span><span class="case__name">Vitamark</span></header>
<h3>Shipped a RAG copilot for clinical operations</h3>
<p>Built retrieval, evals, and a streaming UI on top of a HIPAA-aligned data plane with full audit trails.</p>
<ul class="case__metrics">
<li><b>+42%</b><span>ops throughput</span></li>
<li><b>0.3s</b><span>first token</span></li>
<li><b>98%</b><span>eval pass</span></li>
</ul>
</article>
<article class="case reveal">
<header class="case__top"><span class="case__tag">marketplace</span><span class="case__name">Stagehand</span></header>
<h3>Scaled a two-sided marketplace to Black-Friday load</h3>
<p>Edge caching, queue-backed checkout, and autoscaling held a 9x traffic spike with zero downtime.</p>
<ul class="case__metrics">
<li><b>9×</b><span>peak traffic</span></li>
<li><b>100%</b><span>uptime</span></li>
<li><b>−61%</b><span>infra cost</span></li>
</ul>
</article>
</div>
</div>
</section>
<!-- ===== PROCESS ===== -->
<section class="section" id="process">
<div class="container">
<header class="section__head reveal">
<p class="eyebrow"><span class="dot"></span> engagement model</p>
<h2>How we plug in</h2>
<p class="section__lead">Two-week loops, demoable every Friday, with one senior lead accountable end to end.</p>
</header>
<ol class="steps">
<li class="step reveal"><span class="step__n">01</span><h3>Discovery sprint</h3><p>One week to map the domain, risks, and a thin vertical slice we can ship.</p></li>
<li class="step reveal"><span class="step__n">02</span><h3>Architecture</h3><p>Lightweight RFCs, an ADR log, and an SLO target before a line of product code.</p></li>
<li class="step reveal"><span class="step__n">03</span><h3>Build loops</h3><p>Two-week iterations behind feature flags, shipped to prod continuously.</p></li>
<li class="step reveal"><span class="step__n">04</span><h3>Operate</h3><p>We carry the pager, tune cost, and hand off a system your team actually owns.</p></li>
</ol>
</div>
</section>
<!-- ===== TEAM ===== -->
<section class="section section--alt" id="team">
<div class="container">
<header class="section__head reveal">
<p class="eyebrow"><span class="dot"></span> the crew</p>
<h2>Senior by default</h2>
<p class="section__lead">No bench, no offshore handoffs. The people in the pitch are the people in the PRs.</p>
</header>
<div class="team">
<article class="member reveal"><div class="member__ph" data-i="MR"></div><h3>Mara Reyes</h3><p>Principal · Platform</p></article>
<article class="member reveal"><div class="member__ph" data-i="JK"></div><h3>Jonah Kessler</h3><p>Staff · AI & Data</p></article>
<article class="member reveal"><div class="member__ph" data-i="AD"></div><h3>Amina Diallo</h3><p>Lead · Mobile</p></article>
<article class="member reveal"><div class="member__ph" data-i="TV"></div><h3>Theo Vance</h3><p>Principal · Web</p></article>
</div>
</div>
</section>
<!-- ===== TESTIMONIALS ===== -->
<section class="section voices" id="voices">
<div class="container">
<header class="section__head reveal">
<p class="eyebrow"><span class="dot"></span> client voices</p>
<h2>What it's like to ship with us</h2>
</header>
<div class="quotes" id="quotes">
<blockquote class="quote is-active">
<p>"Northbyte embedded two engineers and within a quarter our deploy frequency went from monthly to daily. They left us a system we can actually run."</p>
<footer><b>Priya Nandakumar</b><span>VP Engineering, Ledgerline</span></footer>
</blockquote>
<blockquote class="quote">
<p>"The AI copilot they built passes our evals and our compliance review. Rare to find a studio that takes both seriously."</p>
<footer><b>Daniel Cho</b><span>CTO, Vitamark</span></footer>
</blockquote>
<blockquote class="quote">
<p>"We hit 9x traffic on launch day and the dashboards stayed green. Best money we've spent on engineering, full stop."</p>
<footer><b>Lena Ortiz</b><span>Founder, Stagehand</span></footer>
</blockquote>
</div>
<div class="quotes__dots" role="tablist" aria-label="Testimonials">
<button class="qdot is-active" role="tab" aria-label="Testimonial 1"></button>
<button class="qdot" role="tab" aria-label="Testimonial 2"></button>
<button class="qdot" role="tab" aria-label="Testimonial 3"></button>
</div>
</div>
</section>
<!-- ===== CTA / START ===== -->
<section class="cta" id="start">
<div class="container cta__inner reveal">
<div class="cta__copy">
<h2>Start a project</h2>
<p>Tell us what you're building. We'll reply within one business day with a senior, not a sales rep.</p>
<ul class="cta__bullets">
<li>Fixed-scope discovery sprint</li>
<li>Senior lead from day one</li>
<li>Code & infra you own</li>
</ul>
</div>
<form class="cta__form" id="startForm" novalidate>
<div class="field">
<label for="f-name">Name</label>
<input id="f-name" name="name" type="text" autocomplete="name" required placeholder="Ada Lovelace" />
</div>
<div class="field">
<label for="f-email">Work email</label>
<input id="f-email" name="email" type="email" autocomplete="email" required placeholder="you@company.com" />
</div>
<div class="field">
<label for="f-scope">What are you building?</label>
<textarea id="f-scope" name="scope" rows="3" required placeholder="A payments platform that needs to scale to…"></textarea>
</div>
<button class="btn btn--solid btn--lg" type="submit">Send brief <span aria-hidden="true">→</span></button>
<p class="cta__note">No spam. We reply within one business day.</p>
</form>
</div>
</section>
</main>
<!-- ===== FOOTER ===== -->
<footer class="footer">
<div class="container footer__inner">
<div class="footer__brand">
<span class="brand__word">north<b>byte</b></span>
<p>A fictional software & product engineering studio. We build things that survive prod.</p>
</div>
<nav class="footer__col" aria-label="Services"><h4>Services</h4><a href="#services">Web</a><a href="#services">Mobile</a><a href="#services">AI & Data</a><a href="#services">Platform</a></nav>
<nav class="footer__col" aria-label="Studio"><h4>Studio</h4><a href="#work">Work</a><a href="#process">Process</a><a href="#team">Team</a><a href="#start">Contact</a></nav>
<nav class="footer__col" aria-label="Social"><h4>Elsewhere</h4><a href="#top">GitHub</a><a href="#top">Bluesky</a><a href="#top">RSS</a></nav>
</div>
<div class="container footer__bottom">
<span>© 2026 Northbyte Studio — illustrative demo, not a real company.</span>
<button class="totop" id="toTop" aria-label="Back to top">top ↑</button>
</div>
</footer>
<div class="toast" id="toast" role="status" aria-live="polite"></div>
<script src="script.js"></script>
</body>
</html>Software / Dev Shop Landing
A full one-page marketing site for Northbyte, a fictional software and product engineering studio. The design leans technical and precise: a near-black #0c0e12 canvas, a single mono-lime accent with a slate secondary, a faint masked grid in the hero, and a Space Grotesk body paired with JetBrains Mono for labels and code. A transparent sticky nav condenses to a blurred bar on scroll and collapses into an accessible slide-down mobile menu.
The hero motif is a working terminal that types out a deploy log on a loop — tests passing, image building, canary rollout, p99 latency — with a blinking caret, while three proof stats count up as they scroll into view. From there the page moves through a hover-reactive tech-stack row, a four-practice services grid (web, mobile, AI & data, platform), three case studies with hard before/after metrics, a numbered engagement model, a senior team row, and a rotating testimonial carousel with clickable dots and autoplay. A “start a project” section closes with an inline-validated brief form (name, work email, scope) that confirms via a toast. Scroll-reveal, hover and active states, keyboard support, full responsiveness down to ~360px, and prefers-reduced-motion fallbacks are wired throughout in vanilla JS.
Illustrative UI only — fictional brand, not a real product.