/* Smooth synchronized animations */
.hero{
  display:flex;gap:32px;align-items:center;justify-content:center;flex-wrap:wrap;padding:40px 20px;
  opacity:1;
}

.photo-card{
  width:min(90vw, 340px);aspect-ratio:1/1;border-radius:16px;overflow:hidden;
  background:linear-gradient(45deg, rgba(244,114,182,.25), rgba(239,68,68,.25));
  padding:8px;box-shadow:0 10px 30px rgba(0,0,0,.35);
  opacity:0;
  transform:scale(0.3);
  animation:zoomIn 0.8s cubic-bezier(.34,1.56,.64,1) 0.2s forwards;
  position:relative;
}

@keyframes zoomIn{
  0%{opacity:0;transform:scale(0.3)}
  60%{opacity:0.8;transform:scale(1.1)}
  100%{opacity:1;transform:scale(1)}
}

.photo-card img{
  width:100%;height:100%;object-fit:cover;border-radius:12px;display:block;
}
.photo-card img.img-missing{object-fit:contain;padding:24px;filter:grayscale(100%);}

.hero-text{
  min-width:260px;max-width:520px;
  opacity:1;
}

.hero-text h1{
  margin:0 0 8px 0;font-size:clamp(1.6rem, 6vw, 2.3rem);
  opacity:0;
  transform:translateY(30px);
  animation:ascendSmooth 0.7s cubic-bezier(.25,.46,.45,.94) 0.4s forwards;
}

.tag{
  margin:0;color:var(--accent);font-weight:600;
  opacity:0;
  transform:translateY(30px);
  animation:ascendSmooth 0.7s cubic-bezier(.25,.46,.45,.94) 0.6s forwards;
}

.age-line{
  font-size:clamp(1.1rem, 4.2vw, 1.4rem);
  margin:16px 0;
  font-weight:800;
  position:relative;
  padding:20px 24px;
  border-radius:16px;
  background:
    linear-gradient(45deg, rgba(244,114,182,.15), rgba(239,68,68,.15)),
    linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(8px);
  box-shadow:
    0 8px 32px rgba(244,114,182,.2),
    inset 0 1px 0 rgba(255,255,255,.1);
  overflow:hidden;
  opacity:0;
  transform:translateY(30px);
  animation:ascendSmooth 0.7s cubic-bezier(.25,.46,.45,.94) 0.8s forwards;
}

.age-line .counter{
  position:relative;
  z-index:1;
  background:linear-gradient(90deg, var(--accent), var(--accent-2));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  text-shadow:0 0 20px rgba(244,114,182,.3);
}

.sub{
  color:var(--muted);margin-top:0;
  opacity:0;
  transform:translateY(30px);
  animation:ascendSmooth 0.7s cubic-bezier(.25,.46,.45,.94) 1.0s forwards;
}

@keyframes ascendSmooth{
  0%{opacity:0;transform:translateY(30px)}
  100%{opacity:1;transform:translateY(0)}
}

@media (max-width:640px){
  .age-line{font-size:1.1rem}
}
