/* ============================================================
   animations.css — AR Odontologia e Estética
   ============================================================ */

/* Shape orgânico do hero */
@keyframes morph {
  0%, 100% {
    border-radius: 60% 40% 55% 45% / 50% 60% 40% 50%;
  }
  33% {
    border-radius: 50% 50% 40% 60% / 60% 40% 60% 40%;
  }
  66% {
    border-radius: 45% 55% 60% 40% / 40% 55% 45% 60%;
  }
}

/* Chips flutuantes */
@keyframes float-chip {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-8px); }
}

/* Ribbon infinito */
@keyframes scroll-ribbon {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Fade-up (usado via IntersectionObserver) */
.fi {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .7s ease, transform .7s ease;
}
.fi.v  { opacity: 1; transform: none; }
.fi-d1 { transition-delay: .1s; }
.fi-d2 { transition-delay: .2s; }
.fi-d3 { transition-delay: .3s; }
.fi-d4 { transition-delay: .4s; }

/* Zoom hover em cards de imagem */
.card-img-wrap {
  overflow: hidden;
  border-radius: var(--radius);
}

.card-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
}

.card-img-wrap:hover img {
  transform: scale(1.05);
}

/* Dot pattern decorativo */
.dot-pattern {
  background-image: radial-gradient(circle, rgba(196,169,154,.25) 1px, transparent 1px);
  background-size: 20px 20px;
}

/* Linha decorativa */
.divider-line {
  width: 48px;
  height: 1px;
  background: var(--primary);
  margin: 1rem 0 1.5rem;
}

/* Estrelas */
.stars {
  color: #E8B86D;
  font-size: 1rem;
  letter-spacing: .1em;
}

/* Tag pill */
.pill {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .35rem .9rem;
  background: rgba(196, 169, 154, 0.15);
  border: 1px solid rgba(196, 169, 154, 0.35);
  border-radius: 50px;
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .08em;
  color: var(--primary-deep);
}

/* Pulse suave em badge */
@keyframes badge-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: .7; }
}
