/* 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 (
{sparkles.map((s) => (
))}
);
}
/* ────────────────────────────────────────────────────────────
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 (
D' SHINE
Estética · Pereira
Reservar
);
}
/* ────────────────────────────────────────────────────────────
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 (
);
}
/* ────────────────────────────────────────────────────────────
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) => (
{s.num} / 03
))}
);
}
/* ────────────────────────────────────────────────────────────
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
>);
})()}
);
}
/* ────────────────────────────────────────────────────────────
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) => (
{p.name}
{p.tag}
$ {p.price}
mil COP
{p.items.map((it) => {it} )}
Reservar paquete
))}
✦ ¿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}
))}
{Array.from({ length: maxIdx + 1 }).map((_, i) => (
setIdx(i)}
aria-label={`Ir al testimonio ${i + 1}`}
/>
))}
);
}
/* ────────────────────────────────────────────────────────────
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 (
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}
);
}
/* ────────────────────────────────────────────────────────────
FOOTER
──────────────────────────────────────────────────────────── */
function Footer() {
return (
);
}
/* ────────────────────────────────────────────────────────────
Export
──────────────────────────────────────────────────────────── */
Object.assign(window, {
Nav, Hero, Marquee, Servicios, Sobre, Precios, Testimonios, Ubicacion, Footer, SparkleField,
});