Header 76



<section
id="relume"
class="grid grid-cols-1 gap-y-16 pt-16 md:grid-flow-row md:pt-24 lg:grid-flow-col lg:grid-cols-2 lg:items-center lg:pt-0"
>
<div class="mx-[5%] max-w-[40rem] justify-self-start lg:ml-[5vw] lg:mr-20 lg:justify-self-end">
<h1 class="mb-5 text-6xl font-bold md:mb-6 md:text-9xl lg:text-10xl">
Medium length hero heading goes here
</h1>
<p class="md:text-md">
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse varius enim in eros
elementum tristique. Duis cursus, mi quis viverra ornare, eros dolor interdum nulla, ut
commodo diam libero vitae erat.
</p>
<div class="mt-6 flex flex-wrap gap-4 md:mt-8">
<button
class="focus-visible:ring-border-primary inline-flex gap-3 items-center justify-center whitespace-nowrap ring-offset-white transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 border border-border-primary bg-background-alternative text-text-alternative px-6 py-3"
title="Button"
>
Button</button
><button
class="focus-visible:ring-border-primary inline-flex gap-3 items-center justify-center whitespace-nowrap ring-offset-white transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 border border-border-primary text-text-primary bg-background-primary px-6 py-3"
title="Button"
>
Button
</button>
</div>
</div>
<div class="h-[30rem] overflow-hidden pl-[5vw] pr-[5vw] md:h-[40rem] lg:h-screen lg:pl-0">
<div class="grid w-full grid-cols-2 gap-x-4">
<div
class="-mt-[120%] grid size-full animate-loop-vertically columns-2 grid-cols-1 gap-4 self-center"
>
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 1"
/>
</div>
</div>
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 2"
/>
</div>
</div>
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 3"
/>
</div>
</div>
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 4"
/>
</div>
</div>
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 5"
/>
</div>
</div>
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 6"
/>
</div>
</div>
</div>
<div class="grid size-full animate-loop-vertically grid-cols-1 gap-4">
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 1"
/>
</div>
</div>
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 2"
/>
</div>
</div>
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 3"
/>
</div>
</div>
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 4"
/>
</div>
</div>
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 5"
/>
</div>
</div>
<div class="grid size-full grid-cols-1 gap-4">
<div class="relative w-full pt-[120%]">
<img
class="absolute inset-0 size-full object-cover"
src="https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg"
alt="Relume placeholder image 6"
/>
</div>
</div>
</div>
</div>
</div>
</section>
import { Button } from "@relume_io/relume-ui";
import type { ButtonProps } from "@relume_io/relume-ui";
type ImageProps = {
src: string;
alt?: string;
};
type Props = {
heading: string;
description: string;
buttons: ButtonProps[];
images: ImageProps[];
};
export type Header76Props = React.ComponentPropsWithoutRef<"section"> & Partial<Props>;
export const Header76 = (props: Header76Props) => {
const { heading, description, buttons, images } = {
...Header76Defaults,
...props,
};
return (
<section
id="relume"
className="grid grid-cols-1 gap-y-16 pt-16 md:grid-flow-row md:pt-24 lg:grid-flow-col lg:grid-cols-2 lg:items-center lg:pt-0"
>
<div className="mx-[5%] max-w-[40rem] justify-self-start lg:ml-[5vw] lg:mr-20 lg:justify-self-end">
<h1 className="mb-5 text-6xl font-bold md:mb-6 md:text-9xl lg:text-10xl">{heading}</h1>
<p className="md:text-md">{description}</p>
<div className="mt-6 flex flex-wrap gap-4 md:mt-8">
{buttons.map((button, index) => (
<Button key={index} {...button}>
{button.title}
</Button>
))}
</div>
</div>
<div className="h-[30rem] overflow-hidden pl-[5vw] pr-[5vw] md:h-[40rem] lg:h-screen lg:pl-0">
<div className="grid w-full grid-cols-2 gap-x-4">
<div className="-mt-[120%] grid size-full animate-loop-vertically columns-2 grid-cols-1 gap-4 self-center">
{images.map((image, index) => (
<div key={index} className="grid size-full grid-cols-1 gap-4">
<div className="relative w-full pt-[120%]">
<img
className="absolute inset-0 size-full object-cover"
src={image.src}
alt={image.alt}
/>
</div>
</div>
))}
</div>
<div className="grid size-full animate-loop-vertically grid-cols-1 gap-4">
{images.map((image, index) => (
<div key={index} className="grid size-full grid-cols-1 gap-4">
<div className="relative w-full pt-[120%]">
<img
className="absolute inset-0 size-full object-cover"
src={image.src}
alt={image.alt}
/>
</div>
</div>
))}
</div>
</div>
</div>
</section>
);
};
export const Header76Defaults: Props = {
heading: "Medium length hero heading goes here",
description:
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse varius enim in eros elementum tristique. Duis cursus, mi quis viverra ornare, eros dolor interdum nulla, ut commodo diam libero vitae erat.",
buttons: [{ title: "Button" }, { title: "Button", variant: "secondary" }],
images: [
{
src: "https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg",
alt: "Relume placeholder image 1",
},
{
src: "https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg",
alt: "Relume placeholder image 2",
},
{
src: "https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg",
alt: "Relume placeholder image 3",
},
{
src: "https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg",
alt: "Relume placeholder image 4",
},
{
src: "https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg",
alt: "Relume placeholder image 5",
},
{
src: "https://d22po4pjz3o32e.cloudfront.net/placeholder-image.svg",
alt: "Relume placeholder image 6",
},
],
};
Need help?
For installation guidelines and API information, visit the docs.
Examples
No items found.