.elementor-52753 .elementor-element.elementor-element-c7c43e8:not(.elementor-motion-effects-element-type-background), .elementor-52753 .elementor-element.elementor-element-c7c43e8 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#000000;}.elementor-52753 .elementor-element.elementor-element-c7c43e8 > .elementor-container{max-width:635px;}.elementor-52753 .elementor-element.elementor-element-c7c43e8{border-style:none;transition:background 0.3s, border 0.2s, border-radius 0.2s, box-shadow 0.2s;}.elementor-52753 .elementor-element.elementor-element-c7c43e8 > .elementor-background-overlay{transition:background 0.3s, border-radius 0.2s, opacity 0.3s;}.elementor-52753 .elementor-element.elementor-element-89b06de > .elementor-element-populated{border-style:none;}.elementor-52753 .elementor-element.elementor-element-89b06de > .elementor-element-populated, .elementor-52753 .elementor-element.elementor-element-89b06de > .elementor-element-populated > .elementor-background-overlay, .elementor-52753 .elementor-element.elementor-element-89b06de > .elementor-background-slideshow{border-radius:11px 11px 11px 11px;}.elementor-52753 .elementor-element.elementor-element-3c92679{--spacer-size:50px;}.elementor-52753 .elementor-element.elementor-element-125ba19 img{max-width:46%;}.elementor-52753 .elementor-element.elementor-element-8e5c4a7{--spacer-size:50px;}.elementor-52753 .elementor-element.elementor-element-c929450:not(.elementor-motion-effects-element-type-background), .elementor-52753 .elementor-element.elementor-element-c929450 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#00030A;}.elementor-52753 .elementor-element.elementor-element-c929450{transition:background 0.3s, border 0.3s, border-radius 0.3s, box-shadow 0.3s;}.elementor-52753 .elementor-element.elementor-element-c929450 > .elementor-background-overlay{transition:background 0.3s, border-radius 0.3s, opacity 0.3s;}@media(max-width:1024px){.elementor-52753 .elementor-element.elementor-element-125ba19 img{max-width:61%;}}@media(max-width:767px){.elementor-52753 .elementor-element.elementor-element-125ba19 img{max-width:83%;}.elementor-52753 .elementor-element.elementor-element-8e5c4a7{--spacer-size:90px;}}/* Start custom CSS for section, class: .elementor-element-165346b *//* Turnstyle Access Gate — make the TOP access box match the v0.4 UI */
.ts-access{
  max-width: 820px !important;
  margin: 0 auto !important;
  padding: 22px 22px !important;

  background: rgba(0,0,0,0.22) !important;
  border: 1px solid rgba(255,255,255,0.14) !important;
  border-radius: 18px !important;

  color: #ffffff !important;
  font-family: Nunito, Arial, sans-serif !important;

  box-shadow: 0 30px 80px rgba(0,0,0,.35) !important;
}

/* Title */
.ts-access > div:first-child{
  font-size: 20px !important;
  font-weight: 800 !important;
  margin: 0 0 12px 0 !important;
  color: #ffffff !important;
  letter-spacing: .01em !important;
}

/* Form layout */
.ts-access form{
  display: flex !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  align-items: center !important;
}

/* Input */
.ts-access input[name="access_key"]{
  flex: 1 1 360px !important;
  min-width: 280px !important;

  background: rgba(0,0,0,0.28) !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
  border-radius: 12px !important;

  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;

  font-size: 16px !important;
  line-height: 1.3 !important;
  padding: 12px 14px !important;

  box-shadow: none !important;
  outline: none !important;
}

.ts-access input[name="access_key"]::placeholder{
  color: rgba(255,255,255,0.45) !important;
}

/* Focus glow (purple) */
.ts-access input[name="access_key"]:focus{
  border-color: rgba(168, 85, 247, 0.70) !important;
  box-shadow: 0 0 0 4px rgba(168, 85, 247, 0.18) !important;
  background: rgba(0,0,0,0.32) !important;
}

/* Continue button (purple glow) */
.ts-access button[type="submit"]{
  padding: 12px 16px !important;
  border-radius: 12px !important;

  border: 1px solid rgba(255,255,255,0.18) !important;
  background: rgba(168, 85, 247, 0.95) !important;

  color: #ffffff !important;
  font-weight: 800 !important;
  cursor: pointer !important;

  box-shadow: 0 10px 24px rgba(168, 85, 247, 0.25) !important;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease !important;
}

.ts-access button[type="submit"]:hover{
  transform: translateY(-1px) !important;
  box-shadow: 0 14px 34px rgba(168, 85, 247, 0.32) !important;
  background: rgba(168, 85, 247, 1) !important;
}

/* Hint text */
.ts-access > div:last-child{
  margin-top: 10px !important;
  font-size: 12.5px !important;
  opacity: .70 !important;
  color: rgba(255,255,255,0.80) !important;
}

/* Mobile tighten */
@media (max-width: 640px){
  .ts-access{
    padding: 18px !important;
  }
  .ts-access input[name="access_key"]{
    min-width: 0 !important;
    flex: 1 1 100% !important;
  }
  .ts-access button[type="submit"]{
    width: 100% !important;
    justify-content: center !important;
  }
}
/* Turnstyle Access: FORCE Email + PIN to stack (one per line) */
.ts-access .ts-access-form{
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
}

.ts-access .ts-access-form > label{
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
}

.ts-access .ts-access-form input[type="email"],
.ts-access .ts-access-form input[type="password"],
.ts-access .ts-access-form input[type="text"]{
  display: block !important;
  width: 100% !important;
  max-width: 360px !important; /* email */
}

.ts-access .ts-access-form input[name="ts_pin"]{
  max-width: 200px !important; /* pin */
}

/* If anything wrapped the two labels in a row/flex, kill it */
.ts-access .ts-access-form .ts-access-row,
.ts-access .ts-access-form .row,
.ts-access .ts-access-form .fields,
.ts-access .ts-access-form .field-row{
  display: contents !important;
}
 =========================================================
   Turnstyle Access – keep fields dark + text white ALWAYS
   ========================================================= */

/* Base input */
.ts-access input[type="email"],
.ts-access input[type="password"],
.ts-access input[type="text"]{
  background: rgba(0,0,0,0.28) !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  border: 1px solid rgba(255,255,255,0.18) !important;
}

/* Focus state (kills white flash) */
.ts-access input[type="email"]:focus,
.ts-access input[type="password"]:focus,
.ts-access input[type="text"]:focus{
  background: rgba(0,0,0,0.32) !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  box-shadow: 0 0 0 4px rgba(124,58,237,0.18) !important;
  outline: none !important;
}

/* Autofill (Chrome / Safari / Edge) */
.ts-access input:-webkit-autofill,
.ts-access input:-webkit-autofill:hover,
.ts-access input:-webkit-autofill:focus,
.ts-access input:-webkit-autofill:active{
  -webkit-text-fill-color: #ffffff !important;
  caret-color: #ffffff !important;
  box-shadow: 0 0 0 1000px rgba(0,0,0,0.28) inset !important;
  transition: background-color 9999s ease-in-out 0s;
}

/* Placeholder */
.ts-access input::placeholder{
  color: rgba(255,255,255,0.45) !important;
}/* End custom CSS */
/* Start custom CSS for column, class: .elementor-element-89b06de *//* =========================================================
   Subtle glowing pulse – form container
   ========================================================= */

/* Base form container (make sure this matches your form wrapper) */
.ts-stepform{
  position: relative;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 18px;
  animation: tsFormGlow 6.5s ease-in-out infinite;
}

/* Glow animation */
@keyframes tsFormGlow{
  0%{
    box-shadow:
      0 0 0 rgba(110,224,255,0),
      0 0 0 rgba(160,120,255,0);
  }
  40%{
    box-shadow:
      0 0 22px rgba(110,224,255,0.18),
      0 0 34px rgba(160,120,255,0.12);
  }
  70%{
    box-shadow:
      0 0 26px rgba(160,120,255,0.18),
      0 0 40px rgba(110,224,255,0.10);
  }
  100%{
    box-shadow:
      0 0 0 rgba(110,224,255,0),
      0 0 0 rgba(160,120,255,0);
  }
}/* End custom CSS */
/* Start custom CSS for section, class: .elementor-element-c7c43e8 */.elementor-52753 .elementor-element.elementor-element-c7c43e8.ts-hero{
  position: relative;
  overflow: hidden;
  isolation: isolate;          /* KEY: creates a stacking context */
  background: #0b1022 !important; /* or your dark base */
}

/* blobs behind */
.elementor-52753 .elementor-element.elementor-element-c7c43e8.ts-hero::before{
  content:"";
  position:absolute;
  inset:-200px;
  z-index:-1;                  /* KEY: behind content */
  background:
    radial-gradient(600px 400px at 20% 20%, rgba(120,140,255,.25), transparent 60%),
    radial-gradient(700px 450px at 80% 30%, rgba(110,220,255,.22), transparent 60%),
    radial-gradient(600px 500px at 60% 90%, rgba(160,120,255,.18), transparent 60%);
  filter: blur(2px);
  pointer-events:none;
}

/* dots behind */
.elementor-52753 .elementor-element.elementor-element-c7c43e8.ts-hero::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;                  /* KEY: behind content */
  background-image: radial-gradient(rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 18px 18px;
  opacity: .35;
  pointer-events:none;
}/* End custom CSS */