.hero {
  padding: 28px 32px 18px;
}

.hero-inner {
  grid-template-columns: minmax(320px, 0.96fr) minmax(540px, 0.92fr);
  gap: 22px;
  align-items: center;
  max-width: 1280px;
}

.hero-visual {
  justify-content: flex-end;
}

.portrait-card {
  max-width: 580px;
  aspect-ratio: 1.1 / 1;
  overflow: hidden;
}

.portrait-image {
  width: 102%;
  height: 100%;
  max-width: none;
  object-fit: cover;
  object-position: center center;
  transform: translateX(0);
}

@media (max-width: 980px) {
  .hero-inner {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .hero-visual {
    justify-content: flex-start;
  }

  .portrait-card {
    max-width: 700px;
    aspect-ratio: 1.1 / 1;
  }

  .portrait-image {
    width: 100%;
    transform: none;
  }
}

@media (max-width: 640px) {
  .hero {
    padding: 24px 18px 30px;
  }

  .portrait-card {
    max-width: 100%;
    aspect-ratio: 1.05 / 1;
  }
}
