/**
 * @file
 * Login-Seite (Gin Login) – getrennt von custom.css, um Admin-Styles nicht zu mischen.
 */

body.gin-login .user-form-page__user-form img {
  max-width: 100%;
  max-height: 115px !important;
  margin-bottom: 7px;
}

.gin-helper-login-slogan {
  text-transform: uppercase;
  color: #666;
  font-size: 21px;
}

/* Gin nutzt flex-wrap auf __user-form – Layout nicht überschreiben. */
body.gin-login .user-form-page__user-form:has(.gin-helper-login-legal) {
  position: relative;
  padding-bottom: 2.75rem;
}

.gin-helper-login-legal {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  box-sizing: border-box;
  padding: 0.75rem 24px 1.25rem;
  text-align: center;
  background: var(--gin-bg-layer, #fff);
}

@media (min-width: 800px) {
  .gin-helper-login-legal {
    padding-right: 48px;
    padding-left: 48px;
  }
}

.gin-helper-login-legal__nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.5rem;
  align-items: center;
  justify-content: center;
  max-width: 560px;
  margin: 0 auto;
  font-size: 0.875rem;
}

.gin-helper-login-legal__nav a {
  color: var(--gin-color-text, #555);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

.gin-helper-login-legal__nav a:hover,
.gin-helper-login-legal__nav a:focus {
  color: var(--gin-color-primary, #003ecc);
}

.gin-helper-login-legal__sep {
  color: var(--gin-color-text-light, #999);
  user-select: none;
}

/* Subtle Ken Burns loop for Gin Login wallpaper. */
body.gin-login .user-form-page__wallpaper {
  position: relative;
  overflow: hidden;
}

body.gin-login .user-form-page__wallpaper::before {
  content: "";
  position: absolute;
  inset: -12%;
  z-index: 2;
  pointer-events: none;
  background:
    radial-gradient(
      circle at 88% 8%,
      rgba(255, 191, 102, 0.5) 0%,
      rgba(255, 160, 84, 0.36) 22%,
      rgba(255, 124, 64, 0.2) 42%,
      rgba(255, 124, 64, 0) 68%
    );
  mix-blend-mode: screen;
  will-change: transform, opacity;
  animation:
    gin-helper-login-wallpaper-motion 28s ease-in-out infinite alternate,
    gin-helper-light-sweep 12s ease-in-out infinite alternate;
}

body.gin-login .user-form-page__wallpaper > img {
  opacity: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform-origin: center center;
  will-change: transform;
  animation: gin-helper-login-wallpaper-motion 28s ease-in-out infinite alternate;
  transition: transform 1.4s ease;
}

body.gin-login .user-form-page__wallpaper .gin-helper-cloud-layer {
  position: absolute;
  inset: 0;
  z-index: 3;
  overflow: hidden;
  pointer-events: none;
}

body.gin-login .user-form-page__wallpaper .gin-helper-cloud {
  position: absolute;
  right: 0;
  height: auto;
  max-width: none;
  transform: translate3d(calc(100% + var(--gin-helper-cloud-width, 220px)), 0, 0) scaleX(var(--gin-helper-cloud-scale-x, 1));
  will-change: transform, opacity;
  filter: blur(8px) drop-shadow(0 4px 10px rgba(0, 0, 0, 0.15));
  animation-name: gin-helper-cloud-drift;
  animation-timing-function: linear;
  animation-fill-mode: forwards;
}

@keyframes gin-helper-login-wallpaper-motion {
  0% {
    transform: scale(1) translate3d(0, 0, 0);
  }
  35% {
    transform: scale(1.06) translate3d(-1.2%, -0.8%, 0);
  }
  70% {
    transform: scale(1.1) translate3d(1.4%, 0.9%, 0);
  }
  100% {
    transform: scale(1.14) translate3d(-0.8%, 1.2%, 0);
  }
}

@keyframes gin-helper-cloud-drift {
  0% {
    transform: translate3d(calc(100% + var(--gin-helper-cloud-width, 220px)), 0, 0) scaleX(var(--gin-helper-cloud-scale-x, 1));
    opacity: 0;
  }
  8% {
    opacity: inherit;
  }
  88% {
    opacity: inherit;
  }
  100% {
    transform: translate3d(calc(-100vw - var(--gin-helper-cloud-width, 220px)), 0, 0) scaleX(var(--gin-helper-cloud-scale-x, 1));
    opacity: 0;
  }
}

@keyframes gin-helper-light-sweep {
  0% {
    opacity: 0.72;
  }
  50% {
    opacity: 0.9;
  }
  100% {
    opacity: 0.76;
  }
}

@media (prefers-reduced-motion: reduce) {
  body.gin-login .user-form-page__wallpaper > img {
    animation: none;
    transform: none;
  }

  body.gin-login .user-form-page__wallpaper::before {
    animation: none;
  }

  body.gin-login .user-form-page__wallpaper .gin-helper-cloud-layer {
    display: none;
  }
}
