Hero 1

Full-bleed hero card over an animated light-beam shader, with a glass pill nav, a trust badge, a serif headline, dual CTA and a three-stat footer.

Preview

Installation

npx shadcn@latest add https://hirael.com/r/hero-01.json

Code

components/blocks/hero-01.tsx
"use client";

import * as React from "react";
import dynamic from "next/dynamic";
import { ArrowRight } from "lucide-react";

import { Button } from "@/registry/hirael/ui/button";

const Hero01Backdrop = dynamic(() => import("./hero-01-backdrop"), {
  ssr: false,
  loading: () => <div className="size-full bg-muted/20" />,
});

const NAV_LINKS = ["Product", "Docs", "Pricing", "Changelog"] as const;

const STATS = [
  { value: "4,000+", label: "Teams" },
  { value: "60+", label: "Countries" },
  { value: "99.9%", label: "Uptime" },
] as const;

export default function Hero01() {
  const [active, setActive] = React.useState(false);

  return (
    <section
      data-slot="hero"
      className="flex w-full items-center justify-center bg-background px-4 py-12 md:px-6"
    >
      <div
        className="relative w-full max-w-7xl"
        onMouseEnter={() => setActive(true)}
        onMouseLeave={() => setActive(false)}
      >
        <div className="relative isolate flex min-h-[680px] flex-col overflow-hidden rounded-[40px] border border-border bg-card text-card-foreground shadow-sm">
          <div
            aria-hidden
            data-slot="hero-backdrop"
            className="pointer-events-none absolute inset-0 opacity-40 mix-blend-multiply dark:opacity-10 dark:mix-blend-screen"
          >
            <Hero01Backdrop active={active} />
          </div>

          <nav
            data-slot="hero-nav"
            className="relative z-10 flex items-center justify-between gap-4 px-6 py-5 md:px-10"
          >
            <span className="flex items-center gap-2 text-base font-medium tracking-tight text-foreground">
              Aperture
            </span>
            <div className="hidden items-center gap-7 text-sm text-muted-foreground md:flex">
              {NAV_LINKS.map((link) => (
                <a
                  key={link}
                  href="#"
                  className="transition-colors hover:text-foreground"
                >
                  {link}
                </a>
              ))}
            </div>
            <div className="flex items-center gap-2">
              <a
                href="#"
                className="hidden text-sm text-muted-foreground transition-colors hover:text-foreground sm:inline"
              >
                Sign in
              </a>
              <Button asChild size="sm" className="rounded-full">
                <a href="#">Get started</a>
              </Button>
            </div>
          </nav>

          <div className="relative z-10 flex flex-1 flex-col items-center justify-center px-6 py-20 text-center md:px-10">
            <h1 className="max-w-4xl font-serif text-5xl font-medium leading-[1.04] tracking-tight text-foreground sm:text-6xl md:text-7xl">
              The interface layer your product was missing.
            </h1>

            <p className="mt-6 max-w-xl text-lg leading-relaxed text-muted-foreground">
              Drop in accessible components and ship a polished UI in an
              afternoon, no design system required.
            </p>

            <div className="mt-10 flex flex-col items-center gap-3 sm:flex-row">
              <Button
                asChild
                size="lg"
                className="group h-12 rounded-full px-7 text-base"
              >
                <a href="#">
                  Start building
                  <ArrowRight className="size-4 transition-transform duration-300 group-hover:translate-x-0.5 rtl:rotate-180 rtl:group-hover:-translate-x-0.5" />
                </a>
              </Button>
              <Button
                asChild
                size="lg"
                variant="ghost"
                className="h-12 rounded-full px-7 text-base"
              >
                <a href="#">Read the docs</a>
              </Button>
            </div>
          </div>

          <div
            data-slot="hero-stats"
            className="relative z-10 flex items-center justify-center gap-8 border-t border-border px-6 py-7 md:gap-16 md:px-10"
          >
            {STATS.map((stat, i) => (
              <React.Fragment key={stat.label}>
                {i > 0 && <span aria-hidden className="h-9 w-px bg-border" />}
                <div className="text-center">
                  <div className="font-serif text-2xl font-medium text-foreground md:text-3xl">
                    {stat.value}
                  </div>
                  <div className="mt-1 text-xs uppercase tracking-[0.14em] text-muted-foreground">
                    {stat.label}
                  </div>
                </div>
              </React.Fragment>
            ))}
          </div>
        </div>
      </div>
    </section>
  );
}

Dependencies

shadcn registry

button

npm

shaderslucide-react