/* sections.jsx — D'SHINE landing All sections except booking + app shell. Exposed on window. */ const { useState, useEffect, useRef, useMemo } = React; /* ──────────────────────────────────────────────────────────── Sparkle helpers ──────────────────────────────────────────────────────────── */ function SparkleField({ count = 18 }) { const sparkles = useMemo(() => { return Array.from({ length: count }).map((_, i) => ({ id: i, left: Math.random() * 100, top: Math.random() * 100, sz: 6 + Math.random() * 14, del: Math.random() * 4, dur: 3 + Math.random() * 3, op: 0.3 + Math.random() * 0.5, })); }, [count]); return ( ); } /* ──────────────────────────────────────────────────────────── NAV ──────────────────────────────────────────────────────────── */ function Nav() { const [scrolled, setScrolled] = useState(false); useEffect(() => { const onScroll = () => setScrolled(window.scrollY > 24); onScroll(); window.addEventListener("scroll", onScroll, { passive: true }); return () => window.removeEventListener("scroll", onScroll); }, []); return ( ); } /* ──────────────────────────────────────────────────────────── HERO ──────────────────────────────────────────────────────────── */ function Hero({ sparklesOn }) { // Leer datos del admin si existen const h = (typeof window !== 'undefined' && window.DSHINE_HERO) || {}; const eyebrow = h.heroEyebrow || "Estética & Belleza · Pereira"; const line1 = h.heroLine1 || "Tu mejor"; const line2 = h.heroLine2 || "versión brilla"; const line3 = h.heroLine3 || "en D'SHINE."; const sub = h.heroSub || "Cuidado facial, depilación láser y maquillaje social en un espacio pensado para que te sientas única. Tratamientos personalizados con la confianza de Daniela Hernández."; const cta1 = h.ctaPrimary || "Reservar cita"; const cta2 = h.ctaSecondary|| "Ver servicios"; return (
{sparklesOn && }
{eyebrow}

{line1} {line2} {line3}

{sub}

Foto · Daniela Hernández
retrato editorial
Atención personalizada
+5 años de experiencia
Tecnología láser premium
Ubicación
Pereira, Risaralda
Atención
8am — 7pm
Reservas
+57 300 203 1782
Desliza
); } /* ──────────────────────────────────────────────────────────── MARQUEE ──────────────────────────────────────────────────────────── */ function Marquee() { const items = [ "Estética Facial", "Depilación Láser", "Maquillaje Social", "DermaPen", "Limpieza Profunda", "Hidratación de Labios", "Hollywood Peeling", ]; const block = ( {items.map((t, i) => ( {t} ))} ); return ( ); } /* ──────────────────────────────────────────────────────────── SERVICIOS ──────────────────────────────────────────────────────────── */ function Servicios() { const svcs = [ { num: "01", name: "Cuidado y estética facial", desc: "Protocolos personalizados: limpieza profunda, DermaPen, hidratación con ácido hialurónico y Hollywood Peeling para una piel luminosa.", tags: ["Limpieza facial", "DermaPen", "Peeling"], label: "Tratamiento facial · clínica", }, { num: "02", name: "Depilación láser", desc: "Tecnología láser segura y efectiva. Sesiones rápidas, mínimas molestias y resultados duraderos en todas las zonas del cuerpo.", tags: ["Bikini", "Axilas", "Piernas"], label: "Equipo láser premium", }, { num: "03", name: "Maquillaje social", desc: "Maquillaje profesional para eventos, sesiones y momentos especiales. Looks pensados para realzar tu belleza natural.", tags: ["Eventos", "Novias", "Sesión"], label: "Maquillaje editorial", }, ]; return (
Nuestros servicios

Tres especialidades.
Una sola obsesión: tu bienestar.

Cada servicio es diseñado contigo, no para ti. Trabajamos con productos premium y tecnología certificada, en un espacio limpio, cálido y absolutamente discreto.

{svcs.map((s, i) => ( ))}
); } /* ──────────────────────────────────────────────────────────── SOBRE ──────────────────────────────────────────────────────────── */ function Sobre() { return (
Retrato editorial · Daniela en cabina
Fundadora & especialista Daniela Hernández
{(() => { const s = (typeof window !== 'undefined' && window.DSHINE_SOBRE) || {}; const t1 = s.aboutTitle1 || "Belleza con propósito,"; const t2 = s.aboutTitle2 || "cuidado con alma."; const p1 = s.aboutPara1 || "D'SHINE nace de la convicción de que verse bien empieza por sentirse bien. Cada protocolo se diseña en una valoración inicial honesta, con productos premium, tecnología certificada y un trato que recordarás."; const p2 = s.aboutPara2 || "Atiendo personalmente cada cita porque tu piel — y tu confianza — merecen exactamente eso: atención dedicada."; const firma = s.aboutFirm || "— Daniela Hernández"; const years = s.statYears || "+5"; const clients= s.statClients || "1k+"; const svcs = s.statServices || "3"; return (<> Sobre D'SHINE

{t1}
{t2}

{p1}

{p2}

{firma}

{years}
Años de experiencia
{clients.includes('+') ? <>{clients.replace('+','')}+ : clients}
Clientas felices
{svcs}
Especialidades
); })()}
); } /* ──────────────────────────────────────────────────────────── PRECIOS / PAQUETES ──────────────────────────────────────────────────────────── */ function Precios() { const pkgs = [ { name: "Esencial", tag: "Para empezar", price: "180", featured: false, items: [ "Limpieza facial profunda", "Hidratación con ácido hialurónico", "Valoración personalizada", "Recomendaciones de cuidado en casa", ], }, { name: "Signature", tag: "Más reservado", price: "320", featured: true, items: [ "Limpieza facial profunda + DermaPen", "Hollywood Peeling", "Depilación láser · 1 zona pequeña", "Hidratación de labios", "Kit post-tratamiento incluido", ], }, { name: "Glow", tag: "Cuerpo completo", price: "560", featured: false, items: [ "Depilación láser · zona completa", "Tratamiento facial premium", "Maquillaje social para 1 evento", "Sesión de seguimiento incluida", ], }, ]; return (
Paquetes · D'SHINE

Cuidado curado
en tres niveles.

Paquetes diseñados para acompañarte: desde tu primera visita hasta rutinas integrales. Precios en pesos colombianos.

{pkgs.map((p, i) => ( ))}

✦ ¿Quieres algo a tu medida? Escríbenos por WhatsApp y armamos un protocolo para ti.

); } /* ──────────────────────────────────────────────────────────── TESTIMONIOS ──────────────────────────────────────────────────────────── */ function Testimonios() { const data = [ { q: "La atención de Daniela es de otro nivel. Mi piel cambió después de tres sesiones — y la cabina huele a calma.", n: "Valentina M.", m: "Cliente · Pereira", ini: "V", }, { q: "Hice depilación láser bikini + axilas y los resultados fueron increíbles. Sin dolor, sin enrojecimientos y un trato impecable.", n: "Camila R.", m: "Cliente · Dosquebradas", ini: "C", }, { q: "Me maquilló para mi matrimonio y duró 14 horas perfecto. Daniela entiende lo que cada rostro necesita.", n: "Laura V.", m: "Novia 2025", ini: "L", }, { q: "Llevaba años buscando un lugar de confianza. D'SHINE se siente premium sin perder lo cercano. Mi rutina ahora vive aquí.", n: "Andrea P.", m: "Cliente · Pereira", ini: "A", }, { q: "El Hollywood Peeling fue otra cosa. Me sentí cuidada, escuchada, y salí brillando de verdad. 10/10.", n: "Mariana S.", m: "Cliente · Cartago", ini: "M", }, ]; const [idx, setIdx] = useState(0); const [perView, setPerView] = useState(3); useEffect(() => { const onR = () => { const w = window.innerWidth; setPerView(w < 640 ? 1 : w < 900 ? 2 : 3); }; onR(); window.addEventListener("resize", onR); return () => window.removeEventListener("resize", onR); }, []); const maxIdx = Math.max(0, data.length - perView); const safeIdx = Math.min(idx, maxIdx); const prev = () => setIdx((i) => Math.max(0, i - 1)); const next = () => setIdx((i) => Math.min(maxIdx, i + 1)); // Auto-advance useEffect(() => { const t = setInterval(() => { setIdx((i) => (i + 1 > maxIdx ? 0 : i + 1)); }, 6500); return () => clearInterval(t); }, [maxIdx]); const stride = 100 / perView; return (
Testimonios

Voces que brillan con nosotras.

{data.map((t, i) => (
{[0,1,2,3,4].map((j) => )}

{t.q}

{t.ini}
{t.n}
{t.m}
))}
{Array.from({ length: maxIdx + 1 }).map((_, i) => (
); } /* ──────────────────────────────────────────────────────────── UBICACIÓN ──────────────────────────────────────────────────────────── */ function Ubicacion() { const c = (typeof window !== 'undefined' && window.DSHINE_CONTACT) || {}; const phone = c.phone || "573002031782"; const insta = c.instagram || "dshine_estetica"; const addr1 = c.address1 || "Cra 12 #1A-65"; const addr2 = c.address2 || "Barrio Popular Modelo"; const city = c.city || "Pereira, Risaralda"; const hours = c.hours || "Lun — Sáb · 8:00 am — 7:00 pm"; const waMsg = c.waMessage || "Hola D'SHINE, quiero reservar una cita ✨"; const waUrl = "https://wa.me/" + phone + "?text=" + encodeURIComponent(waMsg); return (
D'SHINE
Visítanos

Estamos en el corazón
de Pereira.

Un espacio cuidado al detalle, fácil de encontrar y diseñado para que cada visita se sienta como un pequeño retiro.

Dirección
{addr1}
{addr2}
{city}
Horario
{hours}
WhatsApp
+{phone}
Instagram
@{insta}
WhatsApp directo Reservar cita
); } /* ──────────────────────────────────────────────────────────── FOOTER ──────────────────────────────────────────────────────────── */ function Footer() { return ( ); } /* ──────────────────────────────────────────────────────────── Export ──────────────────────────────────────────────────────────── */ Object.assign(window, { Nav, Hero, Marquee, Servicios, Sobre, Precios, Testimonios, Ubicacion, Footer, SparkleField, });