hero video background fullwidth overlay hero video background fullwidth overlay cinematic media hero section with video background full-width video hero
Hero Video
Fetch pattern JSON:
curl https://webspire.de/patterns/hero/video.json video.html
<section class="ws-hero relative flex min-h-[80vh] items-center overflow-hidden">
<!-- Video background -->
<video autoplay loop muted playsinline class="absolute inset-0 h-full w-full object-cover">
<source src="#replace-with-video-url" type="video/mp4">
</video>
<!-- Overlay -->
<div class="absolute inset-0 bg-gradient-to-t from-black/80 via-black/50 to-black/30" aria-hidden="true"></div>
<!-- Content -->
<div class="relative mx-auto max-w-3xl px-6 py-32 text-center">
<h1 class="text-balance text-4xl font-bold tracking-tight text-white sm:text-5xl lg:text-6xl">Build something extraordinary</h1>
<p class="mx-auto mt-6 max-w-xl text-pretty text-lg text-[var(--ws-hero-text-soft)]">Production-ready UI patterns that help you ship beautiful products faster. No dependencies, just copy and paste.</p>
<div class="mt-10 flex flex-wrap justify-center gap-4">
<a href="#" class="rounded-xl bg-white px-6 py-3 text-sm font-semibold text-slate-900 shadow-lg transition hover:bg-slate-100">Get started</a> <!-- ws-ok -->
<a href="#" class="rounded-xl border border-white/30 bg-white/10 px-6 py-3 text-sm font-semibold text-white backdrop-blur transition hover:bg-white/20">Watch demo</a>
</div>
</div>
</section>
Details
Responsive Dark Mode Tailwind Only SSR Safe Copy & Paste
Stable Published
herovideobackgroundfullwidthoverlay
Slots
| Name | Required | Description |
|---|---|---|
| video | Yes | Background video element with poster fallback. |
| overlay | Yes | Dark gradient overlay for text readability. |
| content | Yes | Centered headline, description, and CTA buttons. |
Full-viewport hero with a looping background video, dark gradient overlay for contrast, and centered white text with headline, description, and two CTA buttons. Video is muted and autoplays. Falls back to poster image if video can’t load.