:root{
  --black:#000000;
  --white:#eeeeee;
  --rose-red:#8e1616;
  --blue:#0078ab;
  --sky-blue:#68c5db;

  --glass: rgba(255,255,255,0.06);
  --stroke: rgba(255,255,255,0.18);
  --stroke2: rgba(255,255,255,0.28);
  --muted: rgba(255,255,255,0.78);
}

*{ margin:0; padding:0; box-sizing:border-box; }

body{
  min-height:100vh;
  background-color: var(--black);
  overflow-x:hidden;
  overflow-y:auto;
  background-image: url("../images/bg-pattern.png");
  background-repeat: repeat;
  background-position: top left;
  background-size: auto;
  background-attachment: scroll;
  padding-top: 120px;
}

/* wrapper card */
.auth-wrapper{
  width: 420px;
  max-width: 92%;
  margin: 0 auto 40px;
  padding: 30px;

  border-radius: 10px;
  border: 1px solid var(--stroke);
  background: var(--glass);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);

  box-shadow: 0 18px 55px rgba(0,0,0,.50);
  text-align: center;
}

.auth-wrapper .brand{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin-bottom: 8px;
  color: #fff;
  text-decoration:none;
}
.auth-wrapper .brand i{
  color: var(--sky-blue);
}
.auth-wrapper .sub{
  color: var(--muted);
  font-size: 13px;
  margin-bottom: 18px;
  line-height: 1.45;
}

.auth-wrapper h2{
  font-size: 2rem;
  margin-bottom: 18px;
  color:#fff;
}

/* messages */
.messages{
  display:grid;
  gap:10px;
  margin-bottom: 14px;
  text-align:left;
}
.messages p{
  padding: 10px 12px;
  border-radius: 8px;
  border: 1px solid var(--stroke2);
  background: rgba(255,255,255,0.06);
  color: #fff;
  font-size: 13px;
}
.messages p.error{
  border-color: rgba(255,70,70,0.35);
  background: rgba(255,70,70,0.10);
}

/* form */
.auth-wrapper form{
  display:flex;
  flex-direction:column;
}

.input-field{
  position:relative;
  border-bottom: 2px solid rgba(255,255,255,0.35);
  margin: 15px 0;
  text-align:left;
}

.input-field input{
  width:100%;
  height: 42px;
  background: transparent;
  border: none;
  outline: none;
  font-size: 15px;
  color:#fff;
  padding-right: 38px; /* space for eye icon if present */
}

/* floating label */
.input-field label{
  position:absolute;
  top:50%;
  left:0;
  transform: translateY(-50%);
  color:#fff;
  opacity:.9;
  font-size: 15px;
  pointer-events:none;
  transition: 0.15s ease;
}

.input-field input:focus ~ label,
.input-field input:not(:placeholder-shown) ~ label{
  font-size: 0.8rem;
  top: 10px;
  transform: translateY(-120%);
  opacity: .85;
}

/* eye toggle button */
.pass-toggle{
  position:absolute;
  right:0;
  top:50%;
  transform: translateY(-50%);
  width: 34px;
  height: 34px;
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.20);
  background: rgba(255,255,255,0.06);
  color:#fff;
  cursor:pointer;
}

.form-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin: 18px 0 26px 0;
  color:#fff;
  gap: 10px;
}

.remember{
  display:flex;
  align-items:center;
  gap:8px;
  font-size: 13px;
  color:#fff;
}
.remember input{ accent-color:#fff; }

.auth-wrapper a{
  color: #efefef;
  text-decoration:none;
}
.auth-wrapper a:hover{ text-decoration:underline; }

/* primary button */
.btn{
  background: var(--blue);
  color: var(--white);
  font-weight: 600;
  border: none;
  padding: 12px 20px;
  cursor: pointer;
  border-radius: 4px;
  font-size: 16px;
  border: 2px solid transparent;
  transition: 0.3s ease;
}
.btn:hover{
  border-color: var(--rose-red);
  background: var(--rose-red);
}

/* google button */
.btn-google{
  margin-top: 12px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.22);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 20px;
  border-radius: 4px;
}
.btn-google:hover{
  border-color: rgba(255,255,255,0.35);
  background: rgba(255,255,255,0.12);
}

.divider{
  margin: 16px 0 6px;
  height: 1px;
  background: rgba(255,255,255,0.15);
  position:relative;
}
.divider span{
  position:absolute;
  left:50%;
  top:50%;
  transform: translate(-50%,-50%);
  background: rgba(0,0,0,0.55);
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  color: var(--muted);
  border: 1px solid rgba(255,255,255,0.12);
}

.bottom{
  text-align:center;
  margin-top: 18px;
  color:#fff;
  font-size: 14px;
}
.note{
  margin-top: 10px;
  color: var(--muted);
  font-size: 12.5px;
  line-height: 1.4;
}

/* errors */
.field-error, .form-errors{
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 8px;
  background: rgba(255,70,70,0.10);
  border: 1px solid rgba(255,70,70,0.25);
  color: #fff;
  font-size: 13px;
  text-align:left;
}
.field-error ul, .form-errors ul{
  margin:0;
  padding-left: 18px;
}

/* Fix Chrome autofill */
input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active{
  -webkit-box-shadow: 0 0 0 1000px transparent inset !important;
  -webkit-text-fill-color:#fff !important;
  transition: background-color 9999s ease-in-out 0s;
}

/* Responsive */
@media (max-width: 992px){
  .auth-wrapper{ padding: 26px; }
  .auth-wrapper h2{ font-size: 1.8rem; }
}
@media (max-width: 768px){
  body{ padding-top: 105px; }
  .auth-wrapper h2{ font-size: 1.6rem; }
  .form-row{ flex-direction:column; align-items:flex-start; margin: 14px 0 18px; }
}
@media (max-width: 480px){
  .auth-wrapper{ padding: 18px; margin-bottom: 20px; }
  .auth-wrapper h2{ font-size: 1.4rem; }
}
