/* Creative login composition over the existing access-gate background. */

.access-gate {
  place-items: stretch !important;
  padding: clamp(18px, 3vw, 42px) !important;
  overflow: hidden !important;
}

.access-gate-showcase {
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  pointer-events: none !important;
  overflow: hidden !important;
}

.access-gate-showcase::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 9vh !important;
  width: min(74vw, 1120px) !important;
  height: min(74vh, 700px) !important;
  transform: translateX(-50%) !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  border-bottom: 0 !important;
  border-radius: 50% 50% 0 0 / 58% 58% 0 0 !important;
  box-shadow:
    0 0 0 8px rgba(114, 133, 116, 0.08),
    0 0 82px rgba(114, 133, 116, 0.18),
    inset 0 0 72px rgba(255, 255, 255, 0.08) !important;
}

.access-gate-showcase::after {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  height: 34vh !important;
  background: transparent !important;
  filter: none !important;
}

.access-gate-showcase-title {
  position: absolute !important;
  left: 50% !important;
  top: clamp(30px, 5vh, 58px) !important;
  z-index: 2 !important;
  width: min(720px, 82vw) !important;
  transform: translateX(-50%) !important;
  color: #fff !important;
  text-align: center !important;
  font-weight: 820 !important;
  line-height: 0.98 !important;
  letter-spacing: 0 !important;
  text-shadow: 0 18px 42px rgba(0, 0, 0, 0.22) !important;
}

.access-gate-showcase-title span,
.access-gate-showcase-title strong {
  display: block !important;
}

.access-gate-showcase-title span {
  font-size: clamp(31px, 3.85vw, 56px) !important;
}

.access-gate-showcase-title strong {
  margin-top: 6px !important;
  color: #dce8dd !important;
  font-size: clamp(28px, 3.35vw, 51px) !important;
  white-space: nowrap !important;
}

.access-gate-person-stage {
  position: absolute !important;
  left: clamp(72px, 10vw, 160px) !important;
  bottom: clamp(0px, 1vh, 10px) !important;
  z-index: 3 !important;
  width: min(58vw, 910px) !important;
  height: min(92vh, 910px) !important;
  display: flex !important;
  align-items: flex-end !important;
  justify-content: center !important;
}

.access-gate-person-stage::before {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 22% !important;
  width: 68% !important;
  height: 58% !important;
  transform: translate(-50%, -50%) !important;
  border-radius: 50% !important;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.06) 0%, rgba(114, 133, 116, 0.05) 38%, transparent 72%) !important;
  filter: blur(24px) !important;
  opacity: 0.45 !important;
  z-index: 0 !important;
}

.access-gate-podium {
  position: absolute !important;
  left: 50% !important;
  bottom: clamp(62px, 8.8vh, 104px) !important;
  width: min(64vw, 980px) !important;
  height: clamp(132px, 18vh, 198px) !important;
  transform: translateX(-50%) perspective(760px) rotateX(58deg) !important;
  border-radius: 50% !important;
  background:
    radial-gradient(ellipse at 50% 28%, rgba(255,255,255,0.96) 0 35%, rgba(238,242,235,0.82) 58%, rgba(114,133,116,0.34) 78%, transparent 100%) !important;
  box-shadow:
    0 -8px 0 rgba(255,255,255,0.64),
    0 -20px 42px rgba(255,255,255,0.24),
    0 16px 54px rgba(230, 244, 225, 0.18),
    0 44px 90px rgba(0,0,0,0.34),
    inset 0 10px 18px rgba(255,255,255,0.18),
    inset 0 -22px 32px rgba(31,55,48,0.3) !important;
}

.access-gate-podium::before {
  content: "" !important;
  position: absolute !important;
  left: 12% !important;
  right: 12% !important;
  bottom: 20% !important;
  height: 15px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, transparent, rgba(237, 255, 232, 0.9), rgba(255,255,255,0.95), rgba(237, 255, 232, 0.9), transparent) !important;
  filter: blur(4px) !important;
  box-shadow: 0 0 28px rgba(237, 255, 232, 0.48) !important;
}

.access-gate-podium::after {
  content: "" !important;
  position: absolute !important;
  left: 9% !important;
  right: 9% !important;
  top: 17% !important;
  height: 24% !important;
  border-radius: 50% !important;
  border-top: 1px solid rgba(255, 255, 255, 0.62) !important;
  box-shadow: 0 -5px 12px rgba(255, 255, 255, 0.12) !important;
  opacity: 0.84 !important;
}

.access-gate-person {
  position: relative !important;
  z-index: 2 !important;
  display: block !important;
  max-width: 100% !important;
  height: min(92vh, 910px) !important;
  width: auto !important;
  object-fit: contain !important;
  object-position: bottom center !important;
  background: transparent !important;
  filter: drop-shadow(0 28px 42px rgba(0, 0, 0, 0.26)) !important;
}

.access-gate-card {
  position: absolute !important;
  z-index: 4 !important;
  left: 60% !important;
  top: 52% !important;
  width: min(100%, 560px) !important;
  margin: 0 !important;
  padding: 54px 48px 44px !important;
  border-radius: 46px !important;
  border: 1px solid rgba(255, 255, 255, 0.58) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.94) 0%, rgba(255,255,255,0.86) 54%, rgba(238,245,239,0.82) 100%) !important;
  backdrop-filter: blur(8px) saturate(1.08) !important;
  -webkit-backdrop-filter: blur(8px) saturate(1.08) !important;
  box-shadow:
    0 58px 124px rgba(0, 0, 0, 0.44),
    0 24px 58px rgba(31, 55, 48, 0.24),
    -18px 18px 54px rgba(255,255,255,0.08),
    0 0 0 1px rgba(255,255,255,0.26),
    inset 0 2px 0 rgba(255,255,255,0.98),
    inset 0 24px 44px rgba(255,255,255,0.5),
    inset 0 -34px 56px rgba(31,55,48,0.12) !important;
  transform: translate(-50%, -50%) perspective(950px) rotateY(-8deg) rotateX(2deg) translateZ(18px) !important;
}

.access-gate-card::before {
  content: "" !important;
  position: absolute !important;
  inset: -1px !important;
  z-index: -1 !important;
  border-radius: inherit !important;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.6), rgba(114,133,116,0.12), rgba(255,255,255,0.18)),
    radial-gradient(ellipse at 50% 100%, rgba(31,55,48,0.22), transparent 62%) !important;
  transform: translate(13px, 18px) scale(0.985) !important;
  filter: blur(22px) !important;
}

.access-gate-card::after {
  content: "" !important;
  position: absolute !important;
  left: 22px !important;
  right: 22px !important;
  bottom: 10px !important;
  height: 1px !important;
  border-radius: 999px !important;
  background: linear-gradient(90deg, transparent, rgba(31,55,48,0.22), transparent) !important;
  opacity: 0.75 !important;
}

.access-gate-copy h1 {
  color: #1f3730 !important;
  font-size: clamp(46px, 3.7vw, 68px) !important;
  line-height: 1.04 !important;
}

.access-gate-copy p,
.access-gate-hint {
  color: rgba(20, 32, 27, 0.78) !important;
}

.access-gate-copy p {
  font-size: clamp(16px, 1.2vw, 20px) !important;
}

.access-gate-inputs {
  gap: 18px !important;
}

.access-gate-input {
  width: clamp(82px, 6vw, 98px) !important;
  height: clamp(82px, 6vw, 98px) !important;
  border-radius: 22px !important;
  font-size: clamp(34px, 2.8vw, 44px) !important;
  border-color: rgba(31,55,48,0.16) !important;
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(246,249,246,0.96)) !important;
  box-shadow:
    0 20px 36px rgba(31,55,48,0.18),
    0 7px 16px rgba(255,255,255,0.25),
    inset 0 2px 0 rgba(255,255,255,0.98),
    inset 0 -14px 24px rgba(114,133,116,0.12) !important;
}

.access-gate-input:focus-visible {
  border-color: rgba(31,111,74,0.72) !important;
  box-shadow:
    0 16px 30px rgba(31,111,74,0.18),
    0 0 0 4px rgba(31,111,74,0.16),
    inset 0 2px 0 rgba(255,255,255,1),
    inset 0 -9px 18px rgba(114,133,116,0.08) !important;
}

.access-gate-submit {
  min-height: 72px !important;
  border-radius: 24px !important;
  font-size: clamp(19px, 1.35vw, 23px) !important;
  background: linear-gradient(180deg, #1F6F4A 0%, #1F3730 100%) !important;
  color: #ffffff !important;
  box-shadow:
    0 18px 34px rgba(31,55,48,0.3),
    0 7px 14px rgba(0,0,0,0.18),
    inset 0 1px 0 rgba(255,255,255,0.28),
    inset 0 -10px 20px rgba(0,0,0,0.12) !important;
}

.access-gate-submit:not(:disabled):hover,
.access-gate-submit:not(:disabled):focus-visible {
  background: linear-gradient(180deg, #237d54 0%, #1F3730 100%) !important;
  box-shadow:
    0 20px 38px rgba(31,55,48,0.34),
    0 8px 16px rgba(0,0,0,0.2),
    inset 0 1px 0 rgba(255,255,255,0.32),
    inset 0 -10px 20px rgba(0,0,0,0.12) !important;
}

.access-gate-orb {
  position: absolute !important;
  z-index: 1 !important;
  display: block !important;
  border-radius: 50% !important;
  background:
    radial-gradient(circle at 30% 24%, #fff, rgba(255,255,255,0.82) 34%, rgba(114,133,116,0.3) 78%, rgba(255,255,255,0.06)) !important;
  box-shadow:
    inset -12px -14px 22px rgba(31,55,48,0.12),
    inset 10px 12px 20px rgba(255,255,255,0.9),
    0 22px 38px rgba(0,0,0,0.18) !important;
}

.access-gate-orb-one { left: 6vw !important; top: 18vh !important; width: 58px !important; height: 58px !important; opacity: 0.52 !important; }
.access-gate-orb-two { right: 7vw !important; top: 17vh !important; width: 74px !important; height: 74px !important; opacity: 0.5 !important; }
.access-gate-orb-three { right: 12vw !important; bottom: 9vh !important; width: 46px !important; height: 46px !important; opacity: 0.46 !important; }

.access-gate-glint {
  position: absolute !important;
  z-index: 1 !important;
  display: block !important;
  width: 42px !important;
  height: 42px !important;
  filter: drop-shadow(0 0 16px rgba(255,255,255,0.72)) !important;
}

.access-gate-glint::before,
.access-gate-glint::after {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  top: 50% !important;
  transform: translate(-50%, -50%) !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,0.9) !important;
}

.access-gate-glint::before { width: 4px !important; height: 100% !important; }
.access-gate-glint::after { width: 100% !important; height: 4px !important; }
.access-gate-glint {
  width: 18px !important;
  height: 18px !important;
  opacity: 0.52 !important;
}

.access-gate-glint::before { width: 2px !important; height: 100% !important; }
.access-gate-glint::after { width: 100% !important; height: 2px !important; }
.access-gate-glint-one { right: 31vw !important; top: 20vh !important; transform: scale(0.72) !important; }
.access-gate-glint-two { right: 23vw !important; top: 40vh !important; transform: scale(0.58) !important; opacity: 0.36 !important; }

@media (max-width: 1100px) {
  .access-gate-person-stage {
    left: 1vw !important;
    width: 50vw !important;
    height: min(84vh, 760px) !important;
  }

  .access-gate-person {
    height: min(84vh, 760px) !important;
  }

  .access-gate-podium {
    width: min(58vw, 780px) !important;
    height: clamp(118px, 16vh, 174px) !important;
  }

  .access-gate-card {
    left: 60% !important;
    top: 52% !important;
    width: min(100%, 540px) !important;
  }
}

@media (max-width: 760px) {
  .access-gate {
    place-items: start center !important;
    min-height: 100svh !important;
    width: 100% !important;
    padding: max(12px, env(safe-area-inset-top)) 0 max(14px, env(safe-area-inset-bottom)) !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }

  .access-gate-showcase::before {
    top: 86px !important;
    width: 124vw !important;
    height: 360px !important;
    opacity: 0.42 !important;
  }

  .access-gate-showcase::after {
    height: 28vh !important;
    opacity: 0 !important;
  }

  .access-gate-showcase-title {
    position: relative !important;
    top: auto !important;
    left: auto !important;
    width: min(100% - 28px, 430px) !important;
    transform: none !important;
    margin: 14px auto 0 !important;
  }

  .access-gate-showcase-title span {
    font-size: clamp(38px, 11vw, 52px) !important;
    line-height: 0.95 !important;
  }

  .access-gate-showcase-title strong {
    margin-top: 3px !important;
    font-size: clamp(34px, 10vw, 48px) !important;
    line-height: 0.95 !important;
    white-space: normal !important;
  }

  .access-gate-person-stage {
    left: 50% !important;
    top: 128px !important;
    bottom: auto !important;
    width: min(78vw, 330px) !important;
    height: 210px !important;
    transform: translateX(-50%) !important;
    opacity: 0.95 !important;
  }

  .access-gate-person {
    max-height: 190px !important;
    height: 190px !important;
    width: auto !important;
  }

  .access-gate-podium {
    bottom: 12px !important;
    width: min(84vw, 340px) !important;
    height: 72px !important;
  }

  .access-gate-card {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    width: calc(100% - 32px) !important;
    max-width: 390px !important;
    margin: 300px auto 18px !important;
    padding: 32px 24px 28px !important;
    transform: none !important;
    border-radius: 28px !important;
    box-shadow:
      0 28px 64px rgba(0, 0, 0, 0.36),
      0 12px 28px rgba(31, 55, 48, 0.22),
      inset 0 2px 0 rgba(255,255,255,0.96),
      inset 0 -20px 34px rgba(31,55,48,0.1) !important;
  }

  .access-gate-copy h1 {
    font-size: clamp(30px, 8vw, 38px) !important;
    line-height: 1.08 !important;
    margin-bottom: 8px !important;
  }

  .access-gate-copy p {
    font-size: 16px !important;
    line-height: 1.35 !important;
    margin-bottom: 22px !important;
  }

  .access-gate-inputs {
    gap: 8px !important;
    justify-content: center !important;
  }

  .access-gate-input {
    width: 64px !important;
    height: 64px !important;
    border-radius: 18px !important;
    font-size: 28px !important;
  }

  .access-gate-hint {
    width: fit-content !important;
    max-width: 100% !important;
    margin: 16px auto 18px !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    line-height: 1.25 !important;
  }

  .access-gate-hint-kangaroo {
    width: 26px !important;
    height: 26px !important;
  }

  .access-gate-submit {
    min-height: 64px !important;
    border-radius: 22px !important;
    font-size: 20px !important;
    margin-top: 8px !important;
  }

  .access-gate-orb-two,
  .access-gate-orb-three,
  .access-gate-glint-two {
    display: none !important;
  }

  .access-gate-orb-one {
    left: 7vw !important;
    top: 18vh !important;
    width: 42px !important;
    height: 42px !important;
    opacity: 0.28 !important;
  }
}

@media (max-width: 390px) {
  .access-gate-card {
    width: calc(100% - 24px) !important;
    padding: 30px 20px 26px !important;
  }

  .access-gate-inputs {
    gap: 6px !important;
  }

  .access-gate-input {
    width: 60px !important;
    height: 60px !important;
  }
}
