case study / juraan bronze sculptor

we studied bronze to design pixels

An award-winning Mongolian sculptor with four decades of bronze work and zero online presence. 910studio took this from blank canvas to shipped product — researching the lost-wax casting process to extract the color palette, designing a custom typeface from scratch, engineering a 7-layer vignette system, and building a cinematic gallery experience that makes a screen feel like a dark room full of bronze. Solo execution. Design to deploy.

client

Juraan (Lkhagvasuren Nyamkhuu)

executor

910studio (solo)

scope

Research, Design, Custom Font, Frontend, Deploy

stack

SvelteKit / Tailwind / Lenis / Vercel

live

juraan.com

Juraan in his studio
Lkhagvasuren Nyamkhuu (Juraan)The Client
God and Devil — bronze duality
God and Devil — the signature pieceBronze, 2024
01The Brief

The client had 37 years of work. We had zero references.

No existing brand. No style guide. No mood board. No previous website. The client — a sculptor with Government Palace commissions, Noma Concours awards, solo exhibitions across four countries — had never been represented digitally. We were starting from the material itself.

The challenge for 910studio wasn't "build a portfolio." It was figuring out how to make a screen carry the weight of bronze. How do you translate the warmth of patina, the darkness of a foundry, the scale of a 115cm Pegasus into pixels? A template would insult the work. We needed to derive every design decision from the medium itself.

37+

Sculptures to Catalog

Multi-angle photography

0

Existing Brand Assets

No logo, no colors, no type

5

Pages to Design

Each with unique layout

1

Person Executing

Design → Code → Deploy

02Our Process

We studied bronze casting before opening Figma

910studio's first move wasn't wireframes — it was research. We studied the lost-wax bronze casting process end to end. Not for content — to extract the design language from the material. Every color, texture, and mood decision on the site traces back to how bronze is physically made.

01

Wax Sculpting

The sculptor shapes the original in wax over a clay core. Every texture, every fingerprint is intentional — this is the only stage where the artist's hand directly touches the form.

02

Mold & Cast

A ceramic shell encases the wax. Molten bronze at 1,200°C replaces it. The wax burns away — 'lost wax' casting. Nothing is preserved except the form itself.

03

Patination

Chemical oxidation gives bronze its color. Heat + acid + time. The warm golden-brown (#D4AF7A) that became our primary accent — pulled directly from this stage.

"The color isn't chosen. It's discovered."

#D4AF7A — the exact warm gold of patinated bronze became the primary accent for the entire site.

03Color System

We reverse-engineered the palette from physical bronze

With zero brand assets to work from, we derived the entire color system from the casting environment. Near-black (#0A0A0A) maps to the foundry darkness. Bronze Light (#D4AF7A) is fresh patina. Bronze Dark (#8C4A1B) is aged oxidation. Even text colors reference smoke and ash. This isn't a picked palette — it's a discovered one.

Bronze Light

#D4AF7A

Bronze

#CD7F32

Bronze Dark

#8C4A1B

Background

#0A0A0A

Elevated

#141414

Text Primary

#E5E5E5

Text Secondary

#A3A3A3

Border

#262626

04Typography

We designed a typeface that exists nowhere else

No existing font carried the right weight. So we made one. The "Juraan" display typeface was designed from scratch for this project — not licensed, not sourced, not on Google Fonts. It's used exclusively for the hero and key headers. One weight, one purpose: presence.

JuraanFont-Regular.ttf — Custom Display TypefaceLive Font
scroll to load font showcase

type system

RoleFontUsage
DisplayJuraan (Custom)Hero titles, section headers. One weight, maximum presence.
HeadingCinzelSection titles, navigation. Classical authority.
EditorialPlayfair DisplaySubtitles, pull quotes. Italic for editorial grace.
BodySabonLong-form text. Optimized for reading on dark backgrounds.
TechnicalJetBrains MonoLabels, metadata, dimensions. Monospace precision.

Fluid type scaling via CSS clamp() — hero ranges from 3rem to 6rem, H1 from 2.5rem to 4rem, body from 1rem to 1.125rem. Zero breakpoint overrides for font sizes.

05Design Direction

We built a gallery, not a website

The core design decision: this should feel like walking into a gallery at night, not browsing a web page. We used near-black backgrounds as gallery walls, layered vignettes as dramatic lighting, and film grain for analog texture. Sculptures emerge from darkness — grayscale by default, color on hover. The metaphor drives every technical choice.

hero

Video + 7-Layer Vignette

Background video overlaid with: base darkness, primary radial vignette, secondary tight vignette, refined inner shadow, corner gradients, edge burn, and animated film grain. Seven layers, one feeling: depth.

gallery

Bento Grid, 6 Size Variations

Six size patterns — hero pieces get 2x3 cells, smaller works get 1x1. The rhythm prevents monotony across 37+ sculptures. Stagger-reveal on scroll.

feature page

Cinematic Split — God & Devil

Full-screen three-panel — Devil left, narrative center, Buddha right. Radial vignette unifies both sculptures. Click-to-zoom modals. Completely different mobile layout.

interaction

Grayscale → Color on Hover

Desktop images load grayscale, reveal full color on hover. Sculptures emerge into light as you engage. Mobile shows full color immediately — touch doesn't hover.

06Feature Build

We gave the signature piece its own layout system

The "God and Devil" duality is the client's signature work — it deserved more than a gallery card. We built a dedicated page with a cinematic split layout: Devil left, Buddha right, narrative center. A unified radial vignette composites both figures into one frame. The structure mirrors the theme — two equal halves, no hierarchy. Completely different mobile adaptation.

Devil in Meditation

Devil in Meditation

Buddha

Buddha

Two pieces in eternal dialogue — neither purely good nor evilBronze, 45x50x32 each

"The layout IS the concept."

Two equal panels, no hierarchy, one composition — the structure mirrors the Buddhist duality the sculpture explores. 910studio design rationale.

07Editorial Grid

We shot the exhibition, then designed around it

The 2024 solo exhibition gave us real-world content to work with. We built an editorial photo grid on the homepage — 12-column CSS grid with intentional asymmetry. Hero shot at 8 columns, side stack at 4, bottom row splits between portrait pairs and a wide composition. Not a photo dump — it's structured storytelling.

Sculpture at exhibition
Exhibition crowd
Traditional musician
God and Devil at exhibition
Editorial grid — desktop loads grayscale, reveals color on hover12-Column Grid
08Content System

We catalogued 37+ sculptures into a bento grid

Each sculpture needed multi-angle photography, material data, and dimensions — all organized in a way that doesn't bore you at piece #12. We built a bento grid with 6 size variations: hero pieces get 2x3 cells, smaller works fill the rhythm. The pattern repeats without repetition. IntersectionObserver staggers the reveals so the gallery unfolds as you scroll.

Wind
Wind67x60x30
Pegasus
Pegasus115x85x30
Dragon
Dragon92x37x30
Chairman
Chairman103x70x40
Desireling
Desireling114x66x60
Deer
Deer83x70x36
Moose
Moose81x90x40
Mind's Cosmos
Mind's Cosmos100x45x35

8 of 37+ pieces shown. All bronze, cast and patinated. Full collection at juraan.com/gallery

09Delivery

Five pages shipped, each with a unique layout

We shipped five pages — each sharing the dark gallery system but with unique layout treatment. The constraint: no two pages should feel the same, but all should feel like they belong together. Here's what we built.

Homepage

Video hero with 7-layer vignette system + film grain, artist intro, God & Devil highlight, bento gallery preview, exhibition editorial grid.

Gallery

Bento grid with 6 size variations. Stagger-reveal via IntersectionObserver. Background image with 85% overlay.

God & Devil

Cinematic split layout — Devil left, Buddha right, center narrative. Unified vignette. Zoom modals.

About

Sticky portrait (grayscale → color). Full biography, exhibitions since 1987, awards, Government Palace commission.

Contact

Form with subject selector, studio info, Viber integration. Background texture overlay.

10Stack

Why we chose SvelteKit over Next.js for this one

A sculptor's portfolio doesn't need React's runtime weight. We picked SvelteKit for minimal JS overhead, Lenis for physically smooth scroll, and Tailwind v4 for fast iteration with @theme tokens. Fluid type via clamp() — zero breakpoint overrides. Custom Svelte actions for the stagger-reveal gallery. Deployed on Vercel with adapter-vercel.

LayerChoiceWhy
FrameworkSvelteKitMinimal JS overhead. A sculptor's site doesn't need React's weight.
StylingTailwind CSS v4Utility-first with @theme tokens. Fast iteration, zero naming debates.
ScrollLenisSmooth scroll that feels physical — matches the tactile nature of bronze.
TypographyCSS clamp()Fluid scaling. Hero: clamp(3rem, 8vw, 6rem). Zero breakpoints.
ImagesOptimizedImageServes desktop/mobile variants via <picture>. Different crops per viewport.
AnimationIntersectionObserverStagger-reveal on gallery items. No animation library needed.
DeployVercelEdge delivery. adapter-vercel. Preview deploys for client review.
11Outcome

Shipped. One person. Design to deploy.

910studio took this from zero brand assets to a live cinematic portfolio. Material research, color extraction, custom font design, 7-layer vignette engineering, bento gallery system, cinematic split layout, editorial grid, fluid typography, responsive optimization, Vercel deployment — all executed solo. The client now has a permanent digital gallery at juraan.com.

37+

Sculptures Catalogued

Full bronze collection with multi-angle gallery photography, dimensions, and materials.

5

Pages Shipped

Homepage, Gallery, God & Devil feature, About, Contact — each with unique layout treatment.

1

Custom Font

Hand-drawn Juraan display typeface. Not licensed, not Google Fonts — made from scratch.

like what you see?

start a project ->
910studio

creative web studio

loading 0%

now playing

utah* — mewtwo