A standards first web framework

Today Nue takes a new, more natural direction: it becomes a standards first web framework. The focus has always been to strip away artificial layers and help developers take modern HTML, CSS, and JavaScript to their absolute peak. This shift is important, because now we can more directly work on solving the two key issues in frontend development:

1: The frontend engineering problem

I have lived through the eras of DHTML, jQuery, and now the era of React. I experienced positive growth in the first two eras, but this last one has been painful to watch: instead of building on web standards, we've buried them under layers of abstractions. What began as HTML, CSS, and JavaScript has devolved into a complex build orchestration demanding hundreds of dependencies, even for a simple page.

We've normalized this extraordinary complexity. Landing pages are turned into JavaScript monoliths with hundreds of lines of TypeScript. Blog posts that should be static content require multiple React components and a chain of plugins. Documentation and blogging areas need a new framework with different patterns and a separate maintenance burden.

The cost is more than just complexity, build times, and development speed. It's the whole culture of web development. Teams spend more time wrestling with framework documentation than solving real problems. Build times that should take milliseconds are taking minutes. Each day we drift further from the web's core strengths.

The biggest trouble is this: the more you invest in learning today's frameworks, the more technical debt you accumulate in your mind. React patterns from just a few years ago are now considered antipatterns. State management solutions keep cycling through Redux, MobX, Recoil, and countless others. Meanwhile, the web platform itself has quietly evolved to provide native solutions for most of what these frameworks try to solve.

2: The design engineering problem

I've been building frontends for almost three decades now. I remember when CSS was released to Internet Explorer 3.0. Ever since, I've enjoyed working in the intersection between design and engineering. My heroes aren't framework creators but the masters of Bauhaus: Mies van der Rohe and Dieter Rams. They showed how mathematics and systematic thinking create more impact than anything else.

Today should be the golden age for design engineering. Modern CSS finally gives us the power to express sophisticated design systems through mathematics. We can create linear, typographic scales, color relationships through OKLCH calculations, and layouts with container queries. We have endless possibilities for systematic design.

But the JavaScript monolith has blocked the progress:

  1. First, JavaScript engineers have hijacked the conversation. They obsess over global namespace pollution, dead code elimination, or type safety while completely missing the point. When was the last time you saw engineers debating the merits of the Perfect Fifth typographic scale or the principles behind Dieter Rams's systematic approach?

  2. The core issue, however, is the inability to participate in the actual craft. Design decisions are buried in React components with cryptic expressions like flex items-center shadow-lg p-6 hover:bg-gray-50 dark:bg-gray-800 py-[calc(theme(spacing[2.5])-1px)]. This might make sense for JavaScript engineers, but it's an insult to systematic design.

  3. The gap between design and engineering has never been wider. There's even a name for it: a designer-developer handoff. The path from Figma to React is cryptic. Meanwhile, the amazing dynamics between CSS variables and calc() remains unexplored.

By coupling design decisions to JavaScript components, we've created a design monoculture. You cannot take a headless structure and apply different designs to it. You can't switch between Rams's human-centric functionalism and Mies's architectural minimalism.

The JavaScript monolith isn't just a technical problem, it is suffocating the creative results of systematic design. The grand, architectural idea of form follows function is dead.

The standards first web framework

To relieve my disappointment with the frontend ecosystem, I'm showing a better way to build websites. It is based on the following foundations:

  1. Standards first: Browsers have evolved significantly in the past decade. By working with the standards rather than against them, we create better products with less code.

  2. HTML first: semantic HTML is the foundation for everything: layouts, server components, and interactive islands. The same syntax and mental model is better for developers, search engines, and screen readers.

  3. Content first: Rich Markdown syntax handles everything from marketing to documentation. Content lives in clean, accessible files — not in JavaScript.

  4. Design systems: modern, systematic CSS is more powerful than you think. Learn to build design systems, and you'll get better interfaces with less code.

Here's what this enables:

  1. Faster tooling: Content updates in 10-50ms, style changes in 5-20ms, and component modifications in 20-100ms. It's a whole new hot-reloading experience.

  2. Cleaner code: No TypeScript imports, no utility classes, no state management complexity. Just clean, minimalistic code that naturally separates content, structure, and styling.

  3. Faster pages: The fastest page load is one that requires just a single request. No framework initialization, no cumulative layout shifts, no waiting for JavaScript. When content and styling arrive together, pages simply appear.

Learn how Nue works →

Standards first

“Nue is exactly what it promises: faster tooling, cleaner code, and a liberating experience. You must try it.”

Mauricio Wolff, Staff Product Designer at Miro


Now a little bit about the future.

The design system of my dreams

I'm slowly building something I've dreamed about since CSS was invented: A global design system that takes mathematical relationships to their ultimate conclusion. When finished, it will be as simple as:

nue create startup --design rams

Let's dive into this. First off, this command structure is the very reason I started building Nue in the first place. It demonstrates the benefits of separation of concerns as clearly as possible. A template defines the function — whether it's a blog, an idea showcase, a startup platform, or an enterprise site. The design system defines the form, which brings the template to life through a user-selected look and feel.

Behind the rams command argument is something called a global design system that acts as a basis for four wildly different mathematical expressions:

  1. Mies — This design system is obviously special for me. It's the hardcore minimalism that many designers look up to. The result looks remarkably similar to Linear, but achieves its commanding presence through mathematical precision: stark contrasts, intense whitespace, and bold architectural functionalism. Check Seagram Building in New York and you'll get the idea.

  2. Rams — Dieter Rams is the man behind Apple's design philosophy. Like Mies, he used mathematics to achieve harmony. This design system is perhaps closest to what current utility-first frameworks aim for. Think Stripe, but without the decorative stripes.

  3. MurielMuriel Cooper revolutionized digital design at MIT by showing how mathematical systems could create both precision and joy. This system builds on her work, proving how systematic thinking enables creative freedom. Like Apple, it achieves playfulness through calculation — but goes further by making every relationship mathematically pure.

Imagine what this means for web development: you can create an Apple-like startup site for one client, a Stripe-like platform for another, and a Linear-inspired interface for a third. All through a single command that takes seconds rather than the months of custom development these looks typically require.

But even this is just the beginning…

Single-page applications

Once the design systems are out, I'll release the next major piece: single-page applications. These sit right in the middle of design and engineering and want Nue to take these artforms to their absolute peak. Three key methods:

  1. Architecture is based on MVC (model, view, controller) which creates the much-needed separation of concerns. JS engineers work on pure business logic. UI developers craft the experience. Everyone stays in their zone of expertise.

  2. The design system is clearly separated. Change the look and feel of the website from Mies to Muriel, and the SPA will follow. Form follows function.

  3. The SPA becomes a seamless part of your marketing site: the design system, performance, and view transitions. The movement between static and dynamic pages is seamless. It all feels like one product.

Think what this means for agencies and freelancers:

nue create spa --function crm --todir app --design inherit

This creates a complete startup platform, all expressing itself through the same sophisticated design system. What previously required multiple teams and months of development now emerges from one command.

You can see how this changes things. Instead of building from scratch, you get Linear-level design, Stripe-level functionality, and a consistent UX in an instant.