/* Shared hero photography — extends style.css */

.hero,
.page-hero,
.landing-hero {
  position: relative;
  overflow: hidden;
  background-color: var(--black-1);
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.hero-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: var(--hero-focal, center center);
}

.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    180deg,
    rgba(0, 0, 0, 0.55) 0%,
    rgba(0, 0, 0, 0.72) 45%,
    rgba(0, 0, 0, 0.88) 100%
  );
  pointer-events: none;
}

.hero-fade {
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: clamp(80px, 12vw, 140px);
  z-index: 2;
  background: linear-gradient(
    to bottom,
    transparent,
    var(--hero-fade-color, var(--black-2))
  );
  pointer-events: none;
}

.hero .hero-content,
.hero .container,
.page-hero .container,
.page-hero-inner,
.landing-hero-inner {
  position: relative;
  z-index: 3;
}

.hero {
  min-height: 100vh;
  display: flex;
  align-items: center;
  padding-top: 6rem;
}

.page-hero {
  min-height: clamp(52vh, 68vh, 72vh);
  display: flex;
  align-items: center;
  padding: 9rem 0 5rem;
}

.landing-hero {
  min-height: clamp(68vh, 82vh, 85vh);
  display: flex;
  align-items: center;
  padding: 9rem 0 6rem;
}

@media (max-width: 860px) {
  .hero {
    min-height: 88vh;
    padding-top: 5.5rem;
  }

  .page-hero {
    min-height: auto;
    padding: 7.5rem 0 4rem;
  }

  .landing-hero {
    min-height: 75vh;
    padding: 8rem 0 4rem;
  }
}

@media (max-width: 480px) {
  .page-hero {
    padding: 6.5rem 0 3rem;
  }

  .landing-hero {
    padding: 7rem 0 3.5rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .hero-bg img {
    transform: none !important;
  }
}
