.gear-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: 80svh !important;
  min-height: 80dvh !important;
  background:
    linear-gradient(180deg, transparent 0%, transparent 68%, var(--bg, #0f0f13) 100%),
    var(--hero-gradient) !important;
}

.gear-hero::before,
.gear-hero::after {
  content: "";
  position: absolute;
  left: 100%;
  top: 58%;
  width: min(clamp(360px, 42vw, 680px), 58dvh);
  aspect-ratio: 1;
  background: #050707;
  opacity: 0.42;
  pointer-events: none;
  z-index: 0;
  transform: translate(-50%, -50%) rotate(0deg);
  transform-origin: center;
}

.gear-hero::before {
  -webkit-mask: url("/img/minigear-globe.svg") center / contain no-repeat;
  mask: url("/img/minigear-globe.svg") center / contain no-repeat;
}

.gear-hero::after {
  -webkit-mask: url("/img/minigear-gear.svg") center / contain no-repeat;
  mask: url("/img/minigear-gear.svg") center / contain no-repeat;
  animation: heroGearSpin 80s linear infinite;
}

.gear-hero > * {
  position: relative;
  z-index: 1;
}

@keyframes heroGearSpin {
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}

@media (max-width: 768px) {
  .gear-hero::before,
  .gear-hero::after {
    left: 86%;
    top: 66%;
    width: min(76vw, 42dvh);
    opacity: 0.24;
  }
}

@media (prefers-reduced-motion: reduce) {
  .gear-hero::after {
    animation: none;
  }
}
