'use client'; import { useState } from 'react'; import Link from 'next/link'; import { PawPrint, Mail, ArrowLeft } from 'lucide-react'; export default function ForgotPasswordPage() { const [email, setEmail] = useState(''); const [loading, setLoading] = useState(false); const [sent, setSent] = useState(false); const [error, setError] = useState(null); const handleSubmit = async (e: React.FormEvent) => { e.preventDefault(); setError(null); setLoading(true); try { // TODO: substituir por chamada real Ć  API quando o fluxo de reset estiver implementado await new Promise((r) => setTimeout(r, 800)); setSent(true); } catch { setError('Erro ao enviar email. Tenta de novo.'); } finally { setLoading(false); } }; if (sent) { return (
šŸ“¬

Email enviado!

Se {email} estiver registado, receberƔs um email com instruƧƵes para repor a tua palavra-passe.

Voltar ao login
); } return (
PawLink

Esqueceste a palavra-passe?

Introduz o teu email e enviamos um link para repor a palavra-passe.

{error && (
{error}
)}
setEmail(e.target.value)} placeholder="o.teu@email.pt" required autoComplete="email" style={{ width: '100%', padding: '12px 16px 12px 40px', background: 'var(--cream)', border: '1.5px solid var(--parchment)', borderRadius: '10px', fontFamily: 'var(--font-body)', fontSize: '15px', color: 'var(--soil)', outline: 'none', transition: 'border-color 180ms ease', minHeight: '48px' }} onFocus={(e) => (e.target.style.borderColor = 'var(--terra)')} onBlur={(e) => (e.target.style.borderColor = 'var(--parchment)')} />
Voltar ao login
); }