/* ======================================================
   REGISTER PAGE
====================================================== */

.mjv2-register-page{
  padding-top:12px;
}

/* ======================================================
   AUTH SHELL
====================================================== */

.mjv2-auth-shell{
  max-width:520px;
  margin:0 auto;
}

/* ======================================================
   AUTH CARD
====================================================== */

.mjv2-auth-card{
  position:relative;
  padding:24px;
  border-radius:26px;
  background:
    linear-gradient(180deg, rgba(14,22,38,.96), rgba(12,19,33,.98));
  border:1px solid rgba(80,120,190,.18);
  box-shadow:
    0 16px 36px rgba(0,0,0,.20),
    inset 0 1px 0 rgba(255,255,255,.03);
}

.mjv2-auth-card::before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,0));
}

/* ======================================================
   AUTH HEADER
====================================================== */

.mjv2-auth-head{
  margin-bottom:20px;
}

.mjv2-auth-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:26px;
  padding:0 12px;
  border-radius:999px;
  font-size:11px;
  font-weight:700;
  color:var(--mjv2-primary);
  background:rgba(42,171,238,.12);
  border:1px solid rgba(42,171,238,.20);
  margin-bottom:10px;
}

.mjv2-auth-title{
  margin:0;
}

.mjv2-auth-subtitle{
  margin-top:8px;
  font-size:14px;
  line-height:1.6;
  color:var(--mjv2-muted);
}

/* ======================================================
   FORM
====================================================== */

.mjv2-auth-form{
  display:flex;
  flex-direction:column;
  gap:14px;
}

/* ======================================================
   FORM GROUP
====================================================== */

.mjv2-form-group{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.mjv2-form-group label{
  font-size:13px;
  font-weight:600;
  color:var(--mjv2-muted);
}

.mjv2-form-group input{
  height:44px;
  padding:0 14px;
  border-radius:14px;
  border:1px solid var(--mjv2-border);
  background:rgba(0,0,0,.20);
  color:var(--mjv2-text);
  font-size:14px;
  transition:
    border .15s ease,
    box-shadow .15s ease;
}

.mjv2-form-group input:focus{
  outline:none;
  border-color:var(--mjv2-primary);
  box-shadow:0 0 0 2px rgba(42,171,238,.18);
}

/* ======================================================
   PASSWORD WRAP
====================================================== */

.mjv2-auth-password-wrap{
  position:relative;
  display:flex;
  align-items:center;
}

.mjv2-auth-password-wrap input{
  width:100%;
  padding-right:42px;
}

.mjv2-auth-password-toggle{
  position:absolute;
  right:10px;
  width:28px;
  height:28px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:none;
  background:none;
  color:var(--mjv2-muted);
  cursor:pointer;
  opacity:.8;
}

.mjv2-auth-password-toggle:hover{
  opacity:1;
}

.mjv2-auth-password-toggle svg{
  width:18px;
  height:18px;
}

/* ======================================================
   SUBMIT BUTTON
====================================================== */

.mjv2-auth-submit{
  margin-top:6px;
  width:100%;
}

/* ======================================================
   LINKS
====================================================== */

.mjv2-auth-links{
  margin-top:14px;
  display:flex;
  justify-content:flex-start;
  font-size:13px;
}

.mjv2-auth-links a{
  color:var(--mjv2-primary);
  text-decoration:none;
}

.mjv2-auth-links a:hover{
  text-decoration:underline;
}

/* ======================================================
   LOGIN STATE
====================================================== */

.mjv2-auth-state{
  margin-top:10px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.mjv2-auth-state-text{
  font-size:14px;
  color:var(--mjv2-text);
}

/* ======================================================
   ALERT
====================================================== */

.mjv2-auth-alert{
  margin-bottom:12px;
  padding:10px 14px;
  border-radius:12px;
  font-size:13px;
  background:rgba(255,80,80,.10);
  border:1px solid rgba(255,80,80,.25);
  color:#ff9a9a;
}

/* ======================================================
   MOBILE
====================================================== */

@media (max-width:640px){

  .mjv2-auth-card{
    padding:20px;
    border-radius:22px;
  }

  .mjv2-auth-title{
    font-size:22px;
  }

  .mjv2-auth-subtitle{
    font-size:13px;
  }
}