/** App root */
const Nav = () => {
  const [scrolled, setScrolled] = React.useState(false);
  React.useEffect(() => {
    const onScroll = () => setScrolled(window.scrollY > 24);
    onScroll();
    window.addEventListener("scroll", onScroll, { passive: true });
    return () => window.removeEventListener("scroll", onScroll);
  }, []);
  return (
    <nav className={`nav ${scrolled ? "scrolled" : ""}`}>
      <a className="nav-logo" href="#top"><Logo size={28} /></a>
      <div className="nav-links">
        <a href="#numeros">Números</a>
        <a href="#rede">Rede</a>
        <a href="#tecnologia">Tecnologia</a>
        <a href="#app">App</a>
        <a href="#vision">Vision</a>
        <a href="#fidelidade">Fidelidade</a>
        <a href="#curso">Academy</a>
      </div>
      <div className="nav-cta">
        <a className="btn btn-wa btn-sm" href="https://wa.me/17547039131" target="_blank" rel="noopener" aria-label="Falar com a HertzGo no WhatsApp">
          <svg width="16" height="16" viewBox="0 0 24 24" fill="currentColor" aria-hidden="true">
            <path d="M17.472 14.382c-.297-.149-1.758-.867-2.03-.967-.273-.099-.471-.148-.67.15-.197.297-.767.966-.94 1.164-.173.199-.347.223-.644.075-.297-.15-1.255-.463-2.39-1.475-.883-.788-1.48-1.761-1.653-2.059-.173-.297-.018-.458.13-.606.134-.133.298-.347.446-.52.149-.174.198-.298.298-.497.099-.198.05-.371-.025-.52-.075-.149-.669-1.612-.916-2.207-.242-.579-.487-.5-.669-.51-.173-.008-.371-.01-.57-.01-.198 0-.52.074-.792.372-.272.297-1.04 1.016-1.04 2.479 0 1.462 1.065 2.875 1.213 3.074.149.198 2.096 3.2 5.077 4.487.709.306 1.262.489 1.694.625.712.227 1.36.195 1.871.118.571-.085 1.758-.719 2.006-1.413.248-.694.248-1.289.173-1.413-.074-.124-.272-.198-.57-.347m-5.421 7.403h-.004a9.87 9.87 0 0 1-5.031-1.378l-.361-.214-3.741.982.998-3.648-.235-.374a9.86 9.86 0 0 1-1.51-5.26c.001-5.45 4.436-9.884 9.888-9.884 2.64 0 5.122 1.03 6.988 2.898a9.825 9.825 0 0 1 2.893 6.994c-.003 5.45-4.437 9.884-9.885 9.884m8.413-18.297A11.815 11.815 0 0 0 12.05 0C5.495 0 .16 5.335.157 11.892c0 2.096.547 4.142 1.588 5.945L.057 24l6.305-1.654a11.882 11.882 0 0 0 5.683 1.448h.005c6.554 0 11.89-5.335 11.893-11.893A11.821 11.821 0 0 0 20.464 3.488"/>
          </svg>
          <span className="wa-num">(61) 99803-7361</span>
        </a>
        <a className="btn btn-primary btn-sm" href="#app">Baixar App</a>
      </div>
    </nav>
  );
};

const App = () => {
  // Reveal on scroll
  React.useEffect(() => {
    const els = document.querySelectorAll(".reveal");
    const io = new IntersectionObserver((entries) => {
      entries.forEach((e) => {
        if (e.isIntersecting) {
          e.target.classList.add("in");
          io.unobserve(e.target);
        }
      });
    }, { threshold: 0.12, rootMargin: "0px 0px -8% 0px" });
    els.forEach((el) => io.observe(el));
    return () => io.disconnect();
  }, []);

  // Parallax for hero bg + orbs
  React.useEffect(() => {
    const onScroll = () => {
      const y = window.scrollY;
      const heroBg = document.querySelector(".hero-bg");
      if (heroBg) heroBg.style.transform = `translateY(${y * 0.3}px)`;
      document.querySelectorAll(".orb").forEach((o, i) => {
        o.style.transform = `translateY(${y * (i % 2 ? -0.08 : 0.12)}px)`;
      });
    };
    window.addEventListener("scroll", onScroll, { passive: true });
    return () => window.removeEventListener("scroll", onScroll);
  }, []);

  return (
    <>
      <Splash />
      <FixedLogo />
      <Nav />
      <Hero />
      <Stats />
      <MapSection />
      <Gallery />
      <Tech />
      <HertzGoApp />
      <Vision />
      <Loyalty />
      <Diffs />
      <Course />
      <CTA />
      <Footer />
    </>
  );
};

ReactDOM.createRoot(document.getElementById("root")).render(<App />);
