/* Minimal overrides — Tailwind handles the rest */
html { -webkit-font-smoothing: antialiased; }

/* Smooth anchor scroll offset for fixed nav */
:target { scroll-margin-top: 80px; }

/* ── Load animations (hero) ───────────────────────────────────────────────── */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-8px); }
}

.hero-badge   { animation: fadeInUp 0.5s ease both; }
.hero-title   { animation: fadeInUp 0.55s ease 0.1s both; }
.hero-sub     { animation: fadeInUp 0.55s ease 0.2s both; }
.hero-buttons { animation: fadeInUp 0.55s ease 0.3s both; }
.hero-note    { animation: fadeInUp 0.55s ease 0.45s both; }

/* ── Scroll reveal ────────────────────────────────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}
.reveal-left {
  opacity: 0;
  transform: translateX(-28px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal-right {
  opacity: 0;
  transform: translateX(28px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.reveal.visible,
.reveal-left.visible,
.reveal-right.visible {
  opacity: 1;
  transform: none;
}

/* Stagger helpers */
.delay-1 { transition-delay: 0.1s; }
.delay-2 { transition-delay: 0.2s; }
.delay-3 { transition-delay: 0.3s; }
.delay-4 { transition-delay: 0.4s; }
.delay-5 { transition-delay: 0.5s; }
.delay-6 { transition-delay: 0.6s; }

/* ── Feature card hover lift ──────────────────────────────────────────────── */
.feature-card {
  transition: transform 0.22s ease, box-shadow 0.22s ease;
}
.feature-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.08);
}

/* ── Floating mock UI card ────────────────────────────────────────────────── */
.stat-float { animation: float 4s ease-in-out infinite; }

/* ── Legal pages (Privacy / Terms) ───────────────────────────────────────── */
.prose-legal { color: #374151; line-height: 1.75; font-size: 0.9375rem; }
.prose-legal p  { margin-bottom: 1rem; }
.prose-legal h2 { font-size: 1.25rem; font-weight: 700; color: #111827; margin: 2.25rem 0 0.75rem; border-top: 1px solid #f3f4f6; padding-top: 1.75rem; }
.prose-legal h3 { font-size: 1rem; font-weight: 600; color: #111827; margin: 1.5rem 0 0.5rem; }
.prose-legal ul { list-style: disc; padding-left: 1.5rem; margin-bottom: 1rem; }
.prose-legal ul li { margin-bottom: 0.35rem; }
.prose-legal address { font-style: normal; background: #f9fafb; border: 1px solid #e5e7eb; border-radius: 0.75rem; padding: 1rem 1.25rem; margin-bottom: 1rem; line-height: 1.9; }
.prose-legal a { color: #4f72ff; text-decoration: underline; }
.prose-legal a:hover { color: #2d48c0; }
.prose-legal table { width: 100%; border-collapse: collapse; margin-bottom: 1.25rem; font-size: 0.875rem; }
.prose-legal th { text-align: left; background: #f3f4f6; font-weight: 600; color: #111827; padding: 0.625rem 0.875rem; border: 1px solid #e5e7eb; }
.prose-legal td { padding: 0.625rem 0.875rem; border: 1px solid #e5e7eb; vertical-align: top; }
.prose-legal tr:nth-child(even) td { background: #f9fafb; }
