*{
  box-sizing:border-box;
  font-family:system-ui,-apple-system;
}

html,body{
  margin:0;
  height:100%;
}

/* 🌱 Strong Green Background */
.bg{
  position:fixed;
  inset:0;
  background:linear-gradient(120deg,#047857,#22c55e);
  animation:bgMove 10s ease-in-out infinite alternate;
}
@keyframes bgMove{
  0%{filter:hue-rotate(0deg)}
  100%{filter:hue-rotate(18deg)}
}

/* Layout */
.wrapper{
  min-height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:20px;
}

/* Card */
.card{
  width:100%;
  max-width:420px;
  background:rgba(255,255,255,.2);
  backdrop-filter:blur(22px);
  border-radius:26px;
  padding:34px 28px;
  box-shadow:0 35px 90px rgba(0,0,0,.35);
  color:#F0FDF4;
  animation:fadeUp .7s ease;
}

@keyframes fadeUp{
  from{opacity:0;transform:translateY(35px)}
  to{opacity:1;transform:none}
}

/* Brand */
.brand{
  text-align:center;
  margin-bottom:22px;
}
.brand img{
  width:58px;
  height:58px;
}
.brand h1{
  margin:10px 0 6px;
  font-size:28px;
  font-weight:900;
  color:#FFFFFF;
  letter-spacing:.5px;
}
.brand p{
  font-size:15px;
  font-weight:700;
  opacity:1;
}

/* 🔴 Error Banner */
.error-banner{
  display:none;
  margin:18px 0 10px;
  padding:14px 16px;
  border-radius:14px;
  background:#7f1d1d;
  color:#FEE2E2;
  font-size:17px;
  font-weight:900;
  text-align:center;
  box-shadow:0 0 0 2px rgba(255,255,255,.2);
  animation:shake .35s;
}
@keyframes shake{
  0%{transform:translateX(0)}
  25%{transform:translateX(-6px)}
  50%{transform:translateX(6px)}
  75%{transform:translateX(-6px)}
  100%{transform:translateX(0)}
}

/* Fields */
.field{
  position:relative;
  margin-top:24px;
}
.field input{
  width:100%;
  padding:18px 48px 18px 16px;
  border-radius:14px;
  border:2.5px solid rgba(255,255,255,.7);
  background:rgba(255,255,255,.18);
  color:#FFFFFF;
  font-size:18px;
  font-weight:700;
}
.field label{
  position:absolute;
  left:16px;
  top:-10px;
  background:#16a34a;
  padding:3px 10px;
  font-size:14px;
  font-weight:900;
  color:#FFFFFF;
  border-radius:10px;
}
.toggle{
  position:absolute;
  right:16px;
  top:50%;
  transform:translateY(-50%);
  font-size:18px;
  cursor:pointer;
}

/* Button */
button{
  width:100%;
  margin-top:34px;
  padding:18px;
  border:none;
  border-radius:36px;
  background:#00ff99;
  color:#064E3B;
  font-size:18px;
  font-weight:900;
  letter-spacing:1px;
  cursor:pointer;
  transition:.3s;
}
button:hover{transform:scale(1.05)}
button:disabled{opacity:.6}

/* Links */
.links{
  margin-top:26px;
  display:flex;
  justify-content:space-between;
  font-size:15px;
  font-weight:800;
}
.links a{
  color:#F0FDF4;
  text-decoration:none;
}

/* Mobile */
@media(max-width:420px){
  .card{padding:28px 22px}
  .brand h1{font-size:26px}
}