/* global React, ReactDOM */ const { useState, useEffect, useRef } = React; const PHONE = "619-617-4905"; const PHONE_RAW = "6196174905"; /* ──────────── BRAND MARK ──────────── */ function BrandMark() { return ( Stars Party Bus ); } /* ──────────── NAV ──────────── */ function Nav() { const [scrolled, setScrolled] = useState(false); const [open, setOpen] = useState(false); useEffect(() => { const onScroll = () => setScrolled(window.scrollY > 30); onScroll(); window.addEventListener("scroll", onScroll); return () => window.removeEventListener("scroll", onScroll); }, []); useEffect(() => { document.body.style.overflow = open ? "hidden" : ""; }, [open]); const links = [ ["Experience", "#experience"], ["Occasions", "#occasions"], ["Gallery", "#gallery"], ["About", "#about"], ["Pricing", "#pricing"], ["Hostess Add-On", "#hostess"], ["FAQ", "#faq"], ]; return ( <>
{links.map(([l, h]) => ( setOpen(false)}>{l} ))}
Call · {PHONE} Text · {PHONE} setOpen(false)}>Book Your Date →
); } /* ──────────── HERO ──────────── */ function Hero() { return (
San Diego Party Bus Temecula Wine Tours North County

Start the Night like Stars.

A VIP party bus experience for birthdays, bachelorettes, girls’ nights out and Temecula wine tours. Pink-lit. Driver-included. Unforgettable from first pickup to final drop-off.

Book Your Date Call or Text Available 7 days
{PHONE}
Scroll
); } /* ──────────── EXPERIENCE ──────────── */ function Experience() { return (
The Stars Difference

Transportation + experience.

The night doesn’t start at the door of the club. It starts the moment the bus pulls up. Pink lighting, your playlist on a custom sound system, champagne in hand, and ten of your favorite people. We don’t move groups — we open a chapter.

  • VIP Arrival
  • LED Lighting
  • Custom Playlist
  • Champagne Welcome
  • Pro Driver
  • Photo-Worthy

“The night starts before you
even reach the club.”

Luxury Stars Party Bus arrival experience
10–12
VIP guests
per ride
); } /* ──────────── OCCASIONS ──────────── */ const OCCASIONS = [ { num: "01", name: "Bachelorette Parties", hint: "Sashes, champagne, pink-lit pickups.", img: "assets/bachelorette-daytime.png" }, { num: "02", name: "Birthday Celebrations", hint: "Make her arrival the moment.", img: "assets/interior-cheer.png" }, { num: "03", name: "Girls Night Out", hint: "No driver, no Ubers, no waiting.", img: "assets/mansion-girls-night.png" }, { num: "04", name: "Temecula Wine Tours", hint: "Vineyard hopping, in style.", img: "assets/interior-toast.png" }, { num: "05", name: "VIP Club Hopping 🍾", hint: "Hit every spot. Skip every line.", img: "assets/interior-duo.png" }, { num: "06", name: "Graduation Celebrations 🎓", hint: "Cap, gown, and a pink bus.", img: "assets/bus-group-daytime.png" }, { num: "07", name: "Concert & Festival Transport 🎶", hint: "Arrive together. Leave together.", img: "assets/bus-exterior-sunset.png" }, { num: "08", name: "Divorce & Fresh Start Nights 💋", hint: "Close one chapter. Open another.", img: "assets/pink-carpet-bachelorette.png" }, { num: "09", name: "Prom & Homecoming ✨", hint: "Your most iconic arrival yet.", img: "assets/interior-duo.png" }, { num: "10", name: "Corporate & Team Events 🥂", hint: "Reward the team. Elevate the night.", img: "assets/bus-group-daytime.png" }, { num: "11", name: "Date Night Experiences ❤️", hint: "Intimate. Memorable. Just for two.", img: "assets/interior-duo.png" }, { num: "12", name: "Holiday Parties 🎄", hint: "Deck the bus. Sip the season.", img: "assets/interior-dance.png" }, ]; function Occasions() { return (
What we’re here for

Built for the moments
that deserve a story.

Twelve occasions, one signature experience. Each one fully decorated and scripted to your group — from playlist to pickup time.

{OCCASIONS.map((o) => (
— {o.num}
{o.name}
{o.hint} →
))}
); } /* ──────────── GALLERY ──────────── */ const GALLERY = [ { cls: "g-a", img: "assets/interior-cheer.png", tag: "the entrance" }, { cls: "g-b", img: "assets/mansion-bride-group.png", tag: "bachelorette" }, { cls: "g-c", img: "assets/mansion-girls-night.png", tag: "girls night" }, { cls: "g-d", img: "assets/mansion-boarding.png", tag: "arrival" }, { cls: "g-e", img: "assets/interior-dance.png", tag: "dance floor" }, { cls: "g-f", img: "assets/mansion-couples.png", tag: "date night" }, { cls: "g-g", img: "assets/mansion-bachelorette.png", tag: "the squad" }, ]; function Gallery() { return ( ); } /* ──────────── ABOUT ──────────── */ function About() { return (
Stars Party Bus luxury arrival
Built for the
main characters.
About Stars Party Bus

A luxury nightlife
experience, built for her.

Stars Party Bus was created to give women and VIP groups a luxury nightlife experience that feels unforgettable from the first pickup to the final drop-off.

Family-owned. Based in San Diego, CA. Fully insured. And obsessed with making sure your night opens like a film and ends like a memory.

10–12
Guest Capacity
2
Service Cities
5★
Group Reviews
); } /* ──────────── VIP HOSTESS ADD-ON ──────────── */ function HostessAddon() { return (
Elevate the Experience

VIP Hostess
Add-On ✨

Enhance your party bus experience with a dedicated hostess for just $75/hour. She'll lead games, keep the energy high, and make sure every guest feels like a star from pickup to drop-off.

🎮
Games & Vibes
Interactive games, music curation, and energy management all night long.
💎
Onboard Glam Station
Face gems, rhinestones, glitter accents & light makeup touch-ups. Arrive camera-ready.
Add a Hostess to My Booking
VIP Glam Station hosted by Stars Party Bus hostess
$75/hr
Add-On
); } /* ──────────── PRICING ──────────── */ function Pricing() { return (
Simple & Premium

One rate. Every detail included.

⭐ Limited Time Offer — Lock In This Price! Price going up soon · Book before it does Starting at
$250/hr
three-hour minimum on peak nights
  • Pink LED interior lighting
  • Premium sound system
  • Custom playlist control
  • Professional driver
  • Cooler & ice included
  • Decorations available
Check Availability
Rate includes driver, fuel, and insurance. Gratuity not included.
); } /* ──────────── FAQ ──────────── */ const FAQS = [ { q: "How many guests fit on the bus?", a: "Our bus comfortably seats up to 15 guests with full perimeter seating, a dance floor, and pink LED lighting throughout. Perfect for intimate groups who want the full VIP experience." }, { q: "Where are you located?", a: "We are based in San Diego, CA. We serve all of San Diego — including downtown, La Jolla, Pacific Beach, North County, Carlsbad, and Encinitas. We also travel to Temecula for wine tours and pick up guests from the Temecula area who want to come enjoy San Diego nightlife. Note: pickups outside San Diego may include a travel fee — contact us and we’ll give you a quick quote." }, { q: "How does booking work?", a: "Fill out the form or text us at 619-617-4905 and we’ll confirm availability within hours. A $250 deposit holds your date — the remaining balance is due before or on the day of your event. You’ll receive all the details including your driver’s info and pickup time in advance." }, { q: "What is the deposit?", a: "The deposit to reserve your date is $250. This goes toward your total balance and secures your booking. The remaining balance is due before your event." }, { q: "What’s the alcohol policy?", a: "Guests 21+ are welcome to bring their own alcohol onboard. To keep things safe and spill-free, all drinks must be in covered containers with lids — no open champagne flutes or open cups. We recommend tumblers, lidded cups, or covered champagne glasses. We will have cups available, but please plan accordingly so everyone can celebrate safely." }, { q: "Can the driver make multiple stops?", a: "Absolutely. Most of our nights include a curated route — a pickup, dinner, nightlife stops, and a drop-off. Send us your ideal itinerary and we’ll build it with you." }, { q: "Can you decorate the bus for my event?", a: "Yes! If you have a theme, let us know in advance and we can decorate the bus to match — for an additional fee. Whether it’s a bachelorette, birthday, holiday, or any special vibe, just tell us what you’re going for and we’ll make it happen. Note: we don’t do balloon arrangements, but custom theme decor is absolutely available. Just give us enough notice so we can have everything ready before your pickup." }, { q: "Is there a minimum booking?", a: "Three hours minimum. Wine tours to Temecula typically run longer — contact us for a custom quote based on your group’s itinerary." }, ]; function FaqItem({ q, a, open, onToggle }) { return (
{q}
); } function FAQ() { const [open, setOpen] = useState(0); return (
Good to know

Questions,
answered.

Anything we missed? Text us at {PHONE} — we usually reply within minutes.

{FAQS.map((f, i) => ( setOpen(open === i ? -1 : i)} /> ))}
); } /* ──────────── CONTACT FORM ──────────── */ function Contact() { const [form, setForm] = useState({ name: "", phone: "", email: "", date: "", occasion: "", group: "", pickup: "", notes: "" }); const [errors, setErrors] = useState({}); const [sent, setSent] = useState(false); const set = (k, v) => setForm({ ...form, [k]: v }); const submit = async (e) => { e.preventDefault(); const errs = {}; if (!form.name.trim()) errs.name = "Required"; if (!form.phone.trim()) errs.phone = "Required"; if (!form.email.trim() || !form.email.includes("@")) errs.email = "Valid email required"; if (!form.date) errs.date = "Required"; if (!form.occasion) errs.occasion = "Required"; setErrors(errs); if (Object.keys(errs).length > 0) return; try { const res = await fetch("https://api.web3forms.com/submit", { method: "POST", headers: { "Content-Type": "application/json", "Accept": "application/json" }, body: JSON.stringify({ access_key: "45911350-e8c9-4bc4-9c50-896939eb99cb", subject: "⭐ New Booking Request — Stars Party Bus", from_name: "Stars Party Bus Website", name: form.name, phone: form.phone, email: form.email, date: form.date, occasion: form.occasion, group: form.group, pickup: form.pickup, notes: form.notes, }), }); const data = await res.json(); setSent(true); } catch { setSent(true); } }; if (sent) { return (

Request received.

We’ll text you back within a few hours to confirm availability for {form.date}. For anything urgent, text us directly at {PHONE}.

); } return (
Reserve Your Night

Tell us about
the night.

Fill out the form and we’ll text back within a few hours to confirm your date and walk you through every detail.

Call or text {PHONE} Email starspartybus@gmail.com TikTok @stars.partybus Instagram @starspartybus
set("name", e.target.value)} placeholder="Your name" /> {errors.name && {errors.name}}
set("phone", e.target.value)} placeholder="(___) ___-____" /> {errors.phone && {errors.phone}}
set("email", e.target.value)} placeholder="you@email.com" type="email"/> {errors.email && {errors.email}}
set("date", e.target.value)} type="date" /> {errors.date && {errors.date}}
{errors.occasion && {errors.occasion}}