Merge version_2 into main

Merge version_2 into main
This commit was merged in pull request #1.
This commit is contained in:
2026-05-28 00:58:50 +00:00
3 changed files with 106 additions and 300 deletions

View File

@@ -34,33 +34,19 @@ export default function LandingPage() {
<NavbarStyleFullscreen
navItems={[
{
name: "Home",
id: "home",
},
name: "Home", id: "home"},
{
name: "About Us",
id: "about",
},
name: "About Us", id: "about"},
{
name: "Services",
id: "services",
},
name: "Services", id: "services"},
{
name: "Pricing",
id: "pricing",
},
name: "Pricing", id: "pricing"},
{
name: "Testimonials",
id: "testimonials",
},
name: "Testimonials", id: "testimonials"},
{
name: "FAQ",
id: "faq",
},
name: "FAQ", id: "faq"},
{
name: "Contact",
id: "contact",
},
name: "Contact", id: "contact"},
]}
brandName="Van Der Sande Plumbing"
bottomLeftText="Expert Plumbing Solutions"
@@ -71,47 +57,30 @@ export default function LandingPage() {
<div id="home" data-section="home">
<HeroBillboardGallery
background={{
variant: "plain",
}}
variant: "plain"}}
title="Expert Plumbing Solutions You Can Trust"
description="Reliable, efficient, and professional plumbing services for your home or business. We're here when you need us most."
tagAnimation="none"
buttons={[
{
text: "Get a Free Estimate",
href: "#contact",
},
text: "Get a Free Estimate", href: "#contact"},
{
text: "Our Services",
href: "#services",
},
text: "Our Services", href: "#services"},
]}
buttonAnimation="none"
mediaItems={[
{
imageSrc: "http://img.b2bpic.net/free-photo/plumbing-professional-doing-his-job_23-2150721577.jpg",
imageAlt: "Plumber working on modern piping system",
},
imageSrc: "http://img.b2bpic.net/free-photo/plumbing-professional-doing-his-job_23-2150721577.jpg", imageAlt: "Plumber working on modern piping system"},
{
imageSrc: "http://img.b2bpic.net/free-photo/plumbing-professional-doing-his-job_23-2150721522.jpg",
imageAlt: "Plumber fixing a kitchen sink",
},
imageSrc: "http://img.b2bpic.net/free-photo/plumbing-professional-doing-his-job_23-2150721522.jpg", imageAlt: "Plumber fixing a kitchen sink"},
{
imageSrc: "http://img.b2bpic.net/free-photo/plumbing-professional-doing-his-job_23-2150721536.jpg",
imageAlt: "Plumber inspecting a water heater",
},
imageSrc: "http://img.b2bpic.net/free-photo/plumbing-professional-doing-his-job_23-2150721536.jpg", imageAlt: "Plumber inspecting a water heater"},
{
imageSrc: "http://img.b2bpic.net/free-photo/medium-shot-man-taking-shower_23-2150323100.jpg",
imageAlt: "Plumber installing a new bathroom fixture",
},
imageSrc: "http://img.b2bpic.net/free-photo/medium-shot-man-taking-shower_23-2150323100.jpg", imageAlt: "Plumber installing a new bathroom fixture"},
{
imageSrc: "http://img.b2bpic.net/free-photo/adjustment-young-adult-man-protective-helmet-gloves-bright-vest-crouching-looking-tool-sideways-camera-construction-site_259150-57664.jpg",
imageAlt: "Plumber checking an outdoor drainage pipe",
},
imageSrc: "http://img.b2bpic.net/free-photo/adjustment-young-adult-man-protective-helmet-gloves-bright-vest-crouching-looking-tool-sideways-camera-construction-site_259150-57664.jpg", imageAlt: "Plumber checking an outdoor drainage pipe"},
{
imageSrc: "http://img.b2bpic.net/free-photo/female-plumber-working-fix-problems-client-s-house_23-2150990731.jpg",
imageAlt: "Happy customer shaking hands with a plumber",
},
imageSrc: "http://img.b2bpic.net/free-photo/female-plumber-working-fix-problems-client-s-house_23-2150990731.jpg", imageAlt: "Happy customer shaking hands with a plumber"},
]}
mediaAnimation="opacity"
/>
@@ -124,17 +93,11 @@ export default function LandingPage() {
description="At Van Der Sande Plumbing, we combine decades of experience with modern techniques to deliver unparalleled service. Our commitment to quality, integrity, and customer satisfaction sets us apart. From routine maintenance to emergency repairs, we handle every job with precision and care."
metrics={[
{
value: "25+",
title: "Years Experience",
},
value: "25+", title: "Years Experience"},
{
value: "5-Star",
title: "Rated Service",
},
value: "5-Star", title: "Rated Service"},
{
value: "100%",
title: "Satisfaction",
},
value: "100%", title: "Satisfaction"},
]}
tagAnimation="none"
imageSrc="http://img.b2bpic.net/free-photo/mixed-race-man-drawing-sunny-loft-listening-music-earphonesimages-with-sunny-flairs_633478-1152.jpg"
@@ -152,34 +115,22 @@ export default function LandingPage() {
features={[
{
icon: Wrench,
title: "Emergency Repairs",
description: "Rapid response for unexpected leaks, bursts, and blockages, available 24/7.",
},
title: "Emergency Repairs", description: "Rapid response for unexpected leaks, bursts, and blockages, available 24/7."},
{
icon: Droplet,
title: "Pipe Leak Detection & Repair",
description: "Advanced techniques to pinpoint and fix leaks, preventing costly water damage.",
},
title: "Pipe Leak Detection & Repair", description: "Advanced techniques to pinpoint and fix leaks, preventing costly water damage."},
{
icon: Gauge,
title: "Water Heater Services",
description: "Installation, repair, and maintenance for all types of water heaters, including tankless.",
},
title: "Water Heater Services", description: "Installation, repair, and maintenance for all types of water heaters, including tankless."},
{
icon: Droplet,
title: "Drain Cleaning",
description: "Thorough cleaning services to clear stubborn clogs and restore proper drainage flow.",
},
title: "Drain Cleaning", description: "Thorough cleaning services to clear stubborn clogs and restore proper drainage flow."},
{
icon: Droplets,
title: "Fixture Installation",
description: "Professional installation of faucets, sinks, toilets, and other plumbing fixtures.",
},
title: "Fixture Installation", description: "Professional installation of faucets, sinks, toilets, and other plumbing fixtures."},
{
icon: Droplets,
title: "Sewer Line Solutions",
description: "Comprehensive sewer line inspection, repair, and replacement services.",
},
title: "Sewer Line Solutions", description: "Comprehensive sewer line inspection, repair, and replacement services."},
]}
title="Comprehensive Plumbing Services"
description="We offer a full range of residential and commercial plumbing solutions tailored to your specific requirements."
@@ -195,65 +146,23 @@ export default function LandingPage() {
useInvertedBackground={true}
products={[
{
id: "hydro-jetting",
brand: "Specialized Service",
name: "Hydro Jetting Drain Cleaning",
price: "Starting at $250",
rating: 5,
reviewCount: "85 Reviews",
imageSrc: "http://img.b2bpic.net/free-photo/shot-oilfield-worker-checking-quality-gas-pipes-construction-site_342744-363.jpg",
imageAlt: "Hydro jetting equipment cleaning a pipe",
},
id: "hydro-jetting", brand: "Specialized Service", name: "Hydro Jetting Drain Cleaning", price: "Starting at $250", rating: 5,
reviewCount: "85 Reviews", imageSrc: "http://img.b2bpic.net/free-photo/shot-oilfield-worker-checking-quality-gas-pipes-construction-site_342744-363.jpg", imageAlt: "Hydro jetting equipment cleaning a pipe"},
{
id: "tankless-heater",
brand: "Energy Efficient",
name: "Tankless Water Heater Installation",
price: "Starting at $1,500",
rating: 5,
reviewCount: "120 Reviews",
imageSrc: "http://img.b2bpic.net/free-photo/abstract-daytime-shadows-from-outdoors_23-2149080188.jpg",
imageAlt: "Tankless water heater installed in a home",
},
id: "tankless-heater", brand: "Energy Efficient", name: "Tankless Water Heater Installation", price: "Starting at $1,500", rating: 5,
reviewCount: "120 Reviews", imageSrc: "http://img.b2bpic.net/free-photo/abstract-daytime-shadows-from-outdoors_23-2149080188.jpg", imageAlt: "Tankless water heater installed in a home"},
{
id: "sump-pump",
brand: "Flood Prevention",
name: "Sump Pump Repair & Installation",
price: "Starting at $300",
rating: 4,
reviewCount: "60 Reviews",
imageSrc: "http://img.b2bpic.net/free-photo/modern-architectural-building_181624-527.jpg",
imageAlt: "Sump pump in a basement",
},
id: "sump-pump", brand: "Flood Prevention", name: "Sump Pump Repair & Installation", price: "Starting at $300", rating: 4,
reviewCount: "60 Reviews", imageSrc: "http://img.b2bpic.net/free-photo/modern-architectural-building_181624-527.jpg", imageAlt: "Sump pump in a basement"},
{
id: "garbage-disposal",
brand: "Kitchen Essential",
name: "Garbage Disposal Replacement",
price: "Starting at $180",
rating: 4,
reviewCount: "90 Reviews",
imageSrc: "http://img.b2bpic.net/free-photo/plumbing-professional-doing-his-job_23-2150721517.jpg",
imageAlt: "New garbage disposal unit under a kitchen sink",
},
id: "garbage-disposal", brand: "Kitchen Essential", name: "Garbage Disposal Replacement", price: "Starting at $180", rating: 4,
reviewCount: "90 Reviews", imageSrc: "http://img.b2bpic.net/free-photo/plumbing-professional-doing-his-job_23-2150721517.jpg", imageAlt: "New garbage disposal unit under a kitchen sink"},
{
id: "water-filter",
brand: "Healthy Living",
name: "Whole Home Water Filtration",
price: "Starting at $800",
rating: 5,
reviewCount: "75 Reviews",
imageSrc: "http://img.b2bpic.net/free-photo/close-up-hyaluronic-acid-tratment_23-2149286719.jpg",
imageAlt: "Water filtration system installed in a utility closet",
},
id: "water-filter", brand: "Healthy Living", name: "Whole Home Water Filtration", price: "Starting at $800", rating: 5,
reviewCount: "75 Reviews", imageSrc: "http://img.b2bpic.net/free-photo/close-up-hyaluronic-acid-tratment_23-2149286719.jpg", imageAlt: "Water filtration system installed in a utility closet"},
{
id: "maintenance-plan",
brand: "Peace of Mind",
name: "Preventative Maintenance Plans",
price: "Starting at $150/year",
rating: 5,
reviewCount: "150 Reviews",
imageSrc: "http://img.b2bpic.net/free-photo/plumbing-professional-doing-his-job_23-2150721542.jpg",
imageAlt: "Plumber checking pipes for maintenance",
},
id: "maintenance-plan", brand: "Peace of Mind", name: "Preventative Maintenance Plans", price: "Starting at $150/year", rating: 5,
reviewCount: "150 Reviews", imageSrc: "http://img.b2bpic.net/free-photo/plumbing-professional-doing-his-job_23-2150721542.jpg", imageAlt: "Plumber checking pipes for maintenance"},
]}
title="Our Signature Plumbing Solutions"
description="Explore our most popular and essential plumbing services designed to ensure your systems run smoothly and efficiently."
@@ -268,59 +177,31 @@ export default function LandingPage() {
useInvertedBackground={false}
plans={[
{
id: "basic-call",
badge: "Standard",
badgeIcon: Home,
price: "$99",
subtitle: "Basic Service Call Fee",
buttons: [
id: "basic-call", badge: "Standard", badgeIcon: Home,
price: "$99", subtitle: "Basic Service Call Fee", buttons: [
{
text: "Schedule Now",
href: "#contact",
},
text: "Schedule Now", href: "#contact"},
],
features: [
"Diagnostic service",
"Minor repairs (parts extra)",
"Expert consultation",
],
"Diagnostic service", "Minor repairs (parts extra)", "Expert consultation"],
},
{
id: "annual-maintenance",
badge: "Best Value",
badgeIcon: CalendarCheck,
price: "$150/year",
subtitle: "Annual Maintenance Plan",
buttons: [
id: "annual-maintenance", badge: "Best Value", badgeIcon: CalendarCheck,
price: "$150/year", subtitle: "Annual Maintenance Plan", buttons: [
{
text: "Enroll Today",
href: "#contact",
},
text: "Enroll Today", href: "#contact"},
],
features: [
"Annual plumbing inspection",
"Priority scheduling",
"10% discount on repairs",
],
"Annual plumbing inspection", "Priority scheduling", "10% discount on repairs"],
},
{
id: "premium-protection",
badge: "Complete Care",
badgeIcon: ShieldCheck,
price: "$299/year",
subtitle: "Premium Protection Plan",
buttons: [
id: "premium-protection", badge: "Complete Care", badgeIcon: ShieldCheck,
price: "$299/year", subtitle: "Premium Protection Plan", buttons: [
{
text: "Learn More",
href: "#contact",
},
text: "Learn More", href: "#contact"},
],
features: [
"2 annual inspections",
"20% discount on repairs",
"Emergency priority service",
"Free drain camera inspection",
],
"2 annual inspections", "20% discount on repairs", "Emergency priority service", "Free drain camera inspection"],
},
]}
title="Transparent Pricing for Quality Service"
@@ -338,50 +219,20 @@ export default function LandingPage() {
uniformGridCustomHeightClasses="min-h-95 2xl:min-h-105"
testimonials={[
{
id: "1",
name: "Sarah Johnson",
role: "Homeowner",
company: "Local Resident",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/stylish-woman-wearing-yellow-bandana_273609-13338.jpg",
imageAlt: "Photo of Sarah Johnson",
},
id: "1", name: "Sarah Johnson", role: "Homeowner", company: "Local Resident", rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/stylish-woman-wearing-yellow-bandana_273609-13338.jpg", imageAlt: "Photo of Sarah Johnson"},
{
id: "2",
name: "Michael Chen",
role: "Restaurant Owner",
company: "The Bistro",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/retired-businessman-turning-laptop-enjoying-cup-coffee_482257-4942.jpg",
imageAlt: "Photo of Michael Chen",
},
id: "2", name: "Michael Chen", role: "Restaurant Owner", company: "The Bistro", rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/retired-businessman-turning-laptop-enjoying-cup-coffee_482257-4942.jpg", imageAlt: "Photo of Michael Chen"},
{
id: "3",
name: "Emily Rodriguez",
role: "Property Manager",
company: "Elite Properties",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/grandpa-cooking-together-with-grandkid_52683-116808.jpg",
imageAlt: "Photo of Emily Rodriguez",
},
id: "3", name: "Emily Rodriguez", role: "Property Manager", company: "Elite Properties", rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/grandpa-cooking-together-with-grandkid_52683-116808.jpg", imageAlt: "Photo of Emily Rodriguez"},
{
id: "4",
name: "David Kim",
role: "Small Business Owner",
company: "Kim's Cafe",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/cute-couple-having-breakfast-kitchen_23-2147894760.jpg",
imageAlt: "Photo of David Kim",
},
id: "4", name: "David Kim", role: "Small Business Owner", company: "Kim's Cafe", rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/cute-couple-having-breakfast-kitchen_23-2147894760.jpg", imageAlt: "Photo of David Kim"},
{
id: "5",
name: "Jessica Lee",
role: "Apartment Resident",
company: "City Living",
rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/cheerful-mother-daughter-with-speech-bubble_23-2147788255.jpg",
imageAlt: "Photo of Jessica Lee",
},
id: "5", name: "Jessica Lee", role: "Apartment Resident", company: "City Living", rating: 5,
imageSrc: "http://img.b2bpic.net/free-photo/cheerful-mother-daughter-with-speech-bubble_23-2147788255.jpg", imageAlt: "Photo of Jessica Lee"},
]}
title="What Our Happy Customers Say"
description="Don't just take our word for it hear from homeowners and businesses who trust Van Der Sande Plumbing for their needs."
@@ -394,14 +245,7 @@ export default function LandingPage() {
textboxLayout="default"
useInvertedBackground={false}
names={[
"Local Business Alliance",
"Certified Plumbers Guild",
"Home Services Network",
"Community Partner Program",
"Quality Tradesmen Association",
"Sustainable Plumbing Initiative",
"Residential Solutions Group",
]}
"Local Business Alliance", "Certified Plumbers Guild", "Home Services Network", "Community Partner Program", "Quality Tradesmen Association", "Sustainable Plumbing Initiative", "Residential Solutions Group"]}
title="Trusted by Local Communities & Industry Associations"
description="Proudly serving our community and upholding the highest standards of plumbing excellence. Our commitment to quality is recognized."
tagAnimation="none"
@@ -416,30 +260,19 @@ export default function LandingPage() {
useInvertedBackground={true}
faqs={[
{
id: "1",
title: "What areas do you serve?",
content: "We proudly serve the greater [Your City/Region] area, including [mention specific towns/neighborhoods].",
},
id: "1", title: "What areas do you serve?", content: "We proudly serve the greater [Your City/Region] area, including Springfield, Riverdale, and Westview for all residential and commercial plumbing needs."},
{
id: "2",
title: "Do you offer emergency services?",
content: "Yes, we provide 24/7 emergency plumbing services for urgent issues like burst pipes or severe leaks.",
},
id: "2", title: "Do you offer emergency services?", content: "Yes, we provide 24/7 emergency plumbing services for urgent issues like burst pipes, severe leaks, and major clogs. Call us anytime for immediate assistance."},
{
id: "3",
title: "How much does a service call cost?",
content: "Our basic service call fee is $99, which includes diagnosis. Any repairs or additional work will be quoted upfront.",
},
id: "3", title: "How much does a service call cost?", content: "Our basic service call fee is $99, which includes a thorough diagnosis of your plumbing issue. Any necessary repairs or additional work will be quoted upfront before any work begins."},
{
id: "4",
title: "Are your plumbers licensed and insured?",
content: "Absolutely. All our plumbers are fully licensed, certified, and insured for your peace of mind.",
},
id: "4", title: "Are your plumbers licensed and insured?", content: "Absolutely. All our plumbers are fully licensed, certified, and insured professionals, ensuring high-quality, safe, and reliable service for your complete peace of mind."},
{
id: "5",
title: "What payment methods do you accept?",
content: "We accept all major credit cards, debit cards, and cash. Financing options may also be available for larger projects.",
},
id: "5", title: "What payment methods do you accept?", content: "We accept all major credit cards (Visa, MasterCard, Amex), debit cards, and cash. For larger projects, we may also offer flexible financing options please ask for details."},
{
id: "6", title: "Do you provide any guarantees or warranties?", content: "Yes, we stand by our work. All our repairs and installations come with a comprehensive warranty on parts and labor. Specific warranty details will be provided with your service agreement."},
{
id: "7", title: "How can I schedule an appointment?", content: "You can schedule an appointment by calling us directly at (123) 456-7890, or by filling out the contact form on our website. We offer flexible scheduling to fit your busy life."},
]}
imageSrc="http://img.b2bpic.net/free-photo/steel-pipelines-cables-plant_1359-137.jpg"
imageAlt="Plumbing blueprint and diagram"
@@ -448,6 +281,10 @@ export default function LandingPage() {
title="Frequently Asked Questions"
description="Find quick answers to common questions about our services, pricing, and scheduling."
tagAnimation="none"
buttons={[
{ text: "Schedule Service", href: "#contact" },
{ text: "View All Services", href: "#services" },
]}
buttonAnimation="none"
faqsAnimation="slide-up"
/>
@@ -457,19 +294,18 @@ export default function LandingPage() {
<ContactSplit
useInvertedBackground={false}
background={{
variant: "plain",
}}
tag="Contact Us"
title="Get a Free Estimate Today"
description="Ready for reliable plumbing service? Contact us now to schedule an appointment or get a free, no-obligation estimate for your next project."
variant: "plain"}}
tag="Get in Touch"
title="Ready to Schedule Service or Get a Free Estimate?"
description="Fill out the form below to connect with our expert team. We'll get back to you promptly to discuss your plumbing needs and provide a tailored solution."
tagAnimation="none"
imageSrc="http://img.b2bpic.net/free-photo/male-plumber-working-with-client-fix-kitchen-problems_23-2150990682.jpg"
imageAlt="Friendly plumber talking to a customer"
mediaAnimation="opacity"
mediaPosition="right"
inputPlaceholder="Enter your email"
buttonText="Schedule Now"
termsText="By clicking 'Schedule Now' you're confirming that you agree with our Terms and Conditions."
inputPlaceholder="Enter your email for a callback"
buttonText="Request a Callback"
termsText="By clicking 'Request a Callback' you're confirming that you agree with our Terms and Conditions."
/>
</div>
@@ -478,75 +314,45 @@ export default function LandingPage() {
logoText="Van Der Sande Plumbing"
columns={[
{
title: "Services",
items: [
title: "Services", items: [
{
label: "Emergency Repairs",
href: "#services",
},
label: "Emergency Repairs", href: "#services"},
{
label: "Drain Cleaning",
href: "#services",
},
label: "Drain Cleaning", href: "#services"},
{
label: "Water Heaters",
href: "#services",
},
label: "Water Heaters", href: "#services"},
{
label: "Pipe Repair",
href: "#services",
},
label: "Pipe Repair", href: "#services"},
],
},
{
title: "Company",
items: [
title: "Company", items: [
{
label: "About Us",
href: "#about",
},
label: "About Us", href: "#about"},
{
label: "Testimonials",
href: "#testimonials",
},
label: "Testimonials", href: "#testimonials"},
{
label: "Careers",
href: "#",
},
label: "Careers", href: "#"},
],
},
{
title: "Resources",
items: [
title: "Resources", items: [
{
label: "FAQ",
href: "#faq",
},
label: "FAQ", href: "#faq"},
{
label: "Blog",
href: "#",
},
label: "Blog", href: "#"},
{
label: "Service Areas",
href: "#",
},
label: "Service Areas", href: "#"},
],
},
{
title: "Contact",
items: [
title: "Contact", items: [
{
label: "Get an Estimate",
href: "#contact",
},
label: "Get an Estimate", href: "#contact"},
{
label: "Call Us: (123) 456-7890",
href: "tel:1234567890",
},
label: "Call Us: (123) 456-7890", href: "tel:1234567890"},
{
label: "Email: info@vandersandeplumbing.com",
href: "mailto:info@vandersandeplumbing.com",
},
label: "Email: info@vandersandeplumbing.com", href: "mailto:info@vandersandeplumbing.com"},
],
},
]}

View File

@@ -11,7 +11,7 @@ html {
body {
background-color: var(--background);
color: var(--foreground);
font-family: var(--font-font-family: var(--font-roboto), sans-serif;), sans-serif;
font-family: var(--font-inter), sans-serif;), sans-serif;
position: relative;
min-height: 100vh;
overscroll-behavior: none;
@@ -24,5 +24,5 @@ h3,
h4,
h5,
h6 {
font-family: var(--font-font-family: var(--font-roboto), sans-serif;), sans-serif;
font-family: var(--font-dm-sans), sans-serif;), sans-serif;
}

View File

@@ -10,15 +10,15 @@
--accent: #ffffff;
--background-accent: #ffffff; */
--background: #f5faff;
--card: #f1f8ff;
--foreground: #001122;
--primary-cta: #15479c;
--background: #020617;
--card: #0f172a;
--foreground: #e2e8f0;
--primary-cta: #c4d8f9;
--primary-cta-text: #f5faff;
--secondary-cta: #ffffff;
--secondary-cta: #041633;
--secondary-cta-text: #001122;
--accent: #a8cce8;
--background-accent: #7ba3cf;
--accent: #2d30f3;
--background-accent: #1d4ed8;
/* text sizing - set by ThemeProvider */
/* --text-2xs: clamp(0.465rem, 0.62vw, 0.62rem);