/* =============================================
   M2 IMOBILIÁRIA — ANIMATIONS
   ============================================= */

/* --- Scroll Reveal --- */
.reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}

.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

.reveal-left {
  opacity: 0;
  transform: translateX(-40px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.reveal-left.visible { opacity: 1; transform: translateX(0); }

.reveal-right {
  opacity: 0;
  transform: translateX(40px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.reveal-right.visible { opacity: 1; transform: translateX(0); }

.reveal-scale {
  opacity: 0;
  transform: scale(0.9);
  transition: opacity 0.6s ease, transform 0.6s cubic-bezier(0.34,1.2,0.64,1);
}
.reveal-scale.visible { opacity: 1; transform: scale(1); }

/* Stagger delays for children */
.stagger > *:nth-child(1) { transition-delay: 0ms; }
.stagger > *:nth-child(2) { transition-delay: 100ms; }
.stagger > *:nth-child(3) { transition-delay: 200ms; }
.stagger > *:nth-child(4) { transition-delay: 300ms; }
.stagger > *:nth-child(5) { transition-delay: 400ms; }
.stagger > *:nth-child(6) { transition-delay: 500ms; }

/* --- Gold Shimmer --- */
@keyframes goldShimmer {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}

.text-shimmer {
  background: linear-gradient(90deg,
    var(--gold) 0%,
    var(--gold-light) 30%,
    #fff8dc 50%,
    var(--gold-light) 70%,
    var(--gold) 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: goldShimmer 4s linear infinite;
}

/* --- Fade in --- */
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
.fade-in { animation: fadeIn 0.5s ease forwards; }

/* --- Slide up --- */
@keyframes slideUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}
.slide-up { animation: slideUp 0.6s ease forwards; }

/* Hero text animations */
@keyframes heroTitle {
  from { opacity: 0; transform: translateY(40px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes heroSub {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes heroBar {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.hero-title-anim   { animation: heroTitle 0.9s ease 0.2s both; }
.hero-sub-anim     { animation: heroSub  0.9s ease 0.5s both; }
.hero-bar-anim     { animation: heroBar  0.9s ease 0.8s both; }

/* --- Particle / dot grid background --- */
.dot-bg {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(201,168,76,0.08) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}

/* --- Gold line decorators --- */
.gold-line {
  display: inline-block;
  width: 60px;
  height: 3px;
  background: var(--gold-gradient);
  border-radius: 2px;
  margin: var(--space-4) 0;
}

/* --- Hover card glow --- */
@keyframes cardGlow {
  0%, 100% { box-shadow: 0 0 20px rgba(201,168,76,0.0); }
  50%       { box-shadow: 0 0 30px rgba(201,168,76,0.2); }
}

/* --- Page transition --- */
@keyframes pageIn {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.page-transition { animation: pageIn 0.4s ease forwards; }

/* --- Number counter --- */
@keyframes countUp {
  from { opacity: 0; transform: scale(0.8); }
  to   { opacity: 1; transform: scale(1); }
}
.count-anim { animation: countUp 0.5s ease forwards; }

/* --- Image overlay hover --- */
.img-hover-zoom {
  overflow: hidden;
  border-radius: inherit;
}
.img-hover-zoom img {
  transition: transform 0.6s ease;
}
.img-hover-zoom:hover img {
  transform: scale(1.06);
}

/* --- Badge pulse --- */
@keyframes badgePulse {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.05); }
}
.badge-new { animation: badgePulse 2s ease infinite; }
