:root{
  --gold:#d4af37;
  --gold-dark:#b8962e;
  --dark:#0f172a;
  --white:#ffffff;
  --gray:#cbd5e1;
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

body{
  font-family:'Poppins',sans-serif;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  background:
    linear-gradient(rgba(0,0,0,.7), rgba(0,0,0,.7)),
    url("hero-banner.jpg") center/cover no-repeat;
  padding:40px 15px;
}

/* ================= MAIN CONTAINER ================= */

.container{
  width:100%;
  max-width:600px;
  background:rgba(255,255,255,.08);
  backdrop-filter:blur(18px);
  border-radius:22px;
  padding:40px 35px;
  box-shadow:0 30px 60px rgba(0,0,0,.45);
  color:#fff;
  animation:fadeIn .6s ease;
}

@keyframes fadeIn{
  from{opacity:0; transform:translateY(20px);}
  to{opacity:1; transform:translateY(0);}
}

.container h2{
  text-align:center;
  margin-bottom:25px;
  font-weight:600;
}

.container h2::after{
  content:"";
  display:block;
  width:60px;
  height:3px;
  background:var(--gold);
  margin:12px auto 0;
  border-radius:4px;
}

.container h3{
  margin-bottom:15px;
  font-size:16px;
  font-weight:500;
  color:var(--gray);
}

/* ================= FORM STEPS ================= */

.form-step{
  display:none;
}

.form-step.active{
  display:block;
  animation:slide .4s ease;
}

@keyframes slide{
  from{opacity:0; transform:translateX(20px);}
  to{opacity:1; transform:translateX(0);}
}

/* ================= INPUT ================= */

.container input{
  width:100%;
  padding:13px 15px;
  margin-bottom:14px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(255,255,255,.12);
  color:#fff;
  font-size:14px;
  outline:none;
  transition:.3s ease;
}

.container input::placeholder{
  color:#d1d5db;
}

.container input:focus{
  border-color:var(--gold);
  background:rgba(255,255,255,.18);
}

/* ================= BUTTONS ================= */

button{
  padding:12px 22px;
  border:none;
  border-radius:14px;
  font-weight:600;
  font-size:14px;
  cursor:pointer;
  margin-top:5px;
  transition:.3s ease;
}

/* Primary Gold Button */
button:not(.secondary){
  background:linear-gradient(135deg,var(--gold),var(--gold-dark));
  color:#000;
  box-shadow:0 10px 30px rgba(212,175,55,.35);
}

button:not(.secondary):hover{
  transform:translateY(-2px);
  box-shadow:0 18px 45px rgba(212,175,55,.55);
}

/* Back Button */
.secondary{
  background:transparent;
  border:1px solid var(--gold);
  color:var(--gold);
  margin-right:10px;
}

.secondary:hover{
  background:var(--gold);
  color:#000;
}

/* ================= SUCCESS MESSAGE ================= */

#successMessage{
  margin-top:18px;
  padding:12px;
  border-radius:10px;
  text-align:center;
  font-weight:500;
  background:rgba(34,197,94,.15);
  color:#4ade80;
}

.hidden{
  display:none;
}

/* ================= STATUS SECTION ================= */

hr{
  margin:35px 0 25px;
  border:none;
  height:1px;
  background:rgba(255,255,255,.15);
}

#statusResult{
  margin-top:15px;
  font-weight:500;
}

/* ================= MOBILE ================= */

@media(max-width:480px){
  .container{
    padding:30px 22px;
  }

  button{
    width:100%;
    margin-top:10px;
  }
}
.back-btn {
  position: absolute;
  top: 20px;
  left: 20px;
  background: transparent;
  border: none;
  font-size: 26px;
  cursor: pointer;
  color: #333;
}

.back-btn:hover {
  color: #000;
}
.container {
  position: relative;
}


/* ================= EXTRA MOBILE RESPONSIVE ================= */

/* Small Phones (320px – 480px) */
@media (max-width:480px){

  body{
    padding:20px 10px;
    align-items:flex-start;
  }

  .container{
    max-width:100%;
    padding:25px 18px;
    border-radius:18px;
  }

  .container h2{
    font-size:20px;
  }

  .container h3{
    font-size:14px;
  }

  .container input{
    padding:12px;
    font-size:13px;
  }

  button{
    width:100%;
    font-size:14px;
    padding:12px;
  }

  .secondary{
    margin-right:0;
    margin-bottom:8px;
  }

  #successMessage{
    font-size:13px;
  }

  hr{
    margin:25px 0 18px;
  }

  /* Back Button Mobile Fix */
  .back-btn{
    top:12px;
    left:12px;
    font-size:22px;
    color:#fff;
  }
}


/* Medium Phones & Small Tablets */
@media (min-width:481px) and (max-width:768px){

  .container{
    max-width:90%;
    padding:35px 25px;
  }

  .container h2{
    font-size:22px;
  }

  button{
    font-size:15px;
  }

  .back-btn{
    color:#fff;
  }
}
.terms{
  margin-top:15px;
}

.terms label{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:14px;
}

.terms input{
  width:16px;
  height:16px;
}




.container{
  position:relative;
  overflow:hidden;
}

.seo-bg-text{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  font-size:12px;
  line-height:1.8;
  color:#999;
  width:90%;
  text-align:center;
  filter:blur(1.5px);
  opacity:0.35;
  pointer-events:none;
  user-select:none;
}