feat: initial commit — Webflow to Next.js conversion

QuantumLab template converted to Next.js 16 + React 19 + TypeScript:
- 8 page routes (home, about, blog, contact, careers, team-members, coming-soon, 404)
- Dynamic routes for blog posts, career positions, and team members
- GSAP animations (marquee, counters, button hovers)
- IntersectionObserver-based scroll reveal (blur-to-clear transitions)
- Dark mode with next-themes
- React Hook Form + Zod contact form
- Framer Motion page transitions
- Lottie animations via lottie-web

Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
This commit is contained in:
Leon-in
2026-04-26 18:19:56 +08:00
commit 95eb362bfc
134 changed files with 25831 additions and 0 deletions
+147
View File
@@ -0,0 +1,147 @@
import Image from "next/image"
import Link from "next/link"
export default function BlogPreviewSection() {
return (
<section className="section overflow-hidden">
<div className="w-layout-blockcontainer container-default w-container">
<div data-w-id="b227046f-7b8d-96be-04ed-4ad8f3500f81" style={{"opacity": "0", "filter": "blur(8px)"}} className="title-left-content-right">
<div className="inner-container _480px">
<div className="subtitle">
</div>
<div className="mg-top-4x-extra-small">
<h2>
Our latest news & articles </h2>
</div>
<div className="mg-top-5x-extra-small">
<p>
ipsum dolor sit amet consectetur nec quis suspendisse nulla. </p>
</div>
</div>
<Link id="w-node-_99805214-dd54-e7f3-2549-05c0df1040fb-df1040fb" href="/blog" className="primary-button w-inline-block">
<div className="button-content">
<div>
See all articles</div>
<div className="button-icon-wrapper primary">
<svg xmlns="http://www.w3.org/2000/svg" width="100%" viewBox="0 0 17 17" fill="none" className="squared-icon">
<path d="M6.25391 3.45312L10.7458 8.01563L6.25391 12.5781" stroke="currentColor" strokeWidth="1.5" strokeLinecap="square">
</path>
</svg>
<div className="button-icon-bg">
</div>
<div className="button-icon-bg-inside">
</div>
</div>
</div>
</Link>
</div>
<div className="mg-top-regular">
<div data-w-id="f1b0018b-51d6-aaa6-2d43-c2ee184868a3" style={{"opacity": "0", "filter": "blur(8px)"}} className="w-dyn-list">
<div role="list" className="w-dyn-items">
<div role="listitem" className="flex-item w-dyn-item">
<div className="blog-featured-v1-wrapper">
<div className="border-wrapper">
<Link href="/blog-posts/ai-powered-predictive-models-and-their-impact-across-industries" className="blog-card-v1 w-inline-block">
<div className="blog-v1-image-wrapper">
<Image alt="AI-powAI-powered predictive models and their impact across industries" src="/assets/wubflow-shield-nocodexport-dev/68a342b7066c56fa60eb3b39/68a6e7e2a643b738b2cb06fc_ai-powered-predictive-models-and-their-impact-thumbnail-quantum-webflow-template.png" sizes="(max-width: 767px) 100vw, (max-width: 991px) 95vw, 939.96533203125px" className="image" fill style={{ objectFit: "cover" }} />
</div>
<div className="blog-v1-content">
<div className="inner-container _420px">
<h3 className="display-6">AI-powered predictive models and their impact across industries </h3>
<div className="mg-top-4x-extra-small">
<p className="text-paragraph">
ipsum dolor sit amet consectetur sit mi lacus quis vitae sed pellentesque libero ultricies neque. </p>
</div>
<div className="mg-top-3x-extra-small">
<div className="blog-details-wrapper">
<div className="item-details">
, 2025 </div>
<div className="item-details-divider">
</div>
<div className="item-details">
</div>
</div>
</div>
</div>
<div className="bottom-right-button-wrapper">
<div className="icon-button">
<svg xmlns="http://www.w3.org/2000/svg" width="100%" viewBox="0 0 17 17" fill="none" className="squared-icon">
<path d="M6.25391 3.45312L10.7458 8.01563L6.25391 12.5781" stroke="currentColor" strokeWidth="1.5" strokeLinecap="square">
</path>
</svg>
<div className="icon-button-bg">
</div>
</div>
</div>
</div>
</Link>
</div>
<div data-wf--corner-gradient-outline--variant="base" className="corner-gradient-wrapper">
<div className="corner-gradient-horizontal top-left">
</div>
<div className="corner-gradient-horizontal bottom-left">
</div>
<div className="corner-gradient-horizontal top-right">
</div>
<div className="corner-gradient-horizontal bottom-right">
</div>
</div>
</div>
</div>
<div role="listitem" className="flex-item w-dyn-item">
<div className="blog-featured-v1-wrapper">
<div className="border-wrapper">
<Link href="/blog-posts/how-ai-is-shaping-the-future-of-healthcare-and-medicine" className="blog-card-v1 w-inline-block">
<div className="blog-v1-image-wrapper">
<Image alt="How AI How AI is shaping the future of healthcare and medicine" src="/assets/wubflow-shield-nocodexport-dev/68a342b7066c56fa60eb3b39/68a6e7c24025d4081cbfa426_how-ai-is-shaping-the-future-thumbnail-quantum-webflow-template.png" sizes="(max-width: 767px) 100vw, (max-width: 991px) 95vw, 939.96533203125px" className="image" fill style={{ objectFit: "cover" }} />
</div>
<div className="blog-v1-content">
<div className="inner-container _420px">
<h3 className="display-6">How AI is shaping the future of healthcare and medicine </h3>
<div className="mg-top-4x-extra-small">
<p className="text-paragraph">
ipsum dolor sit amet consectetur sit mi lacus quis vitae sed pellentesque libero ultricies neque. </p>
</div>
<div className="mg-top-3x-extra-small">
<div className="blog-details-wrapper">
<div className="item-details">
, 2025 </div>
<div className="item-details-divider">
</div>
<div className="item-details">
Applications</div>
</div>
</div>
</div>
<div className="bottom-right-button-wrapper">
<div className="icon-button">
<svg xmlns="http://www.w3.org/2000/svg" width="100%" viewBox="0 0 17 17" fill="none" className="squared-icon">
<path d="M6.25391 3.45312L10.7458 8.01563L6.25391 12.5781" stroke="currentColor" strokeWidth="1.5" strokeLinecap="square">
</path>
</svg>
<div className="icon-button-bg">
</div>
</div>
</div>
</div>
</Link>
</div>
<div data-wf--corner-gradient-outline--variant="base" className="corner-gradient-wrapper">
<div className="corner-gradient-horizontal top-left">
</div>
<div className="corner-gradient-horizontal bottom-left">
</div>
<div className="corner-gradient-horizontal top-right">
</div>
<div className="corner-gradient-horizontal bottom-right">
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
</section>
)
}