Почему при переключении на регистрацию атрибут required срабатывает на скрытых полях формы?

кто может подсказать, почему у меня данный код никак не хочет при развороте на регистрацию использовать required для проверки заполнения, он пишет Заполните поле на какой то не существующей строке.

Я пробовал изменять типы у строк, но безуспешно.

Источник

* {
  margin: 0;
  padding: 0;
}

@import url('https://fonts.googleapis.com/css2?family=Roboto:wght@700&family=Sansation:wght@700&display=swap');

/* Задний фон страницы */
body {
  background-color: #e9e3e3;
}

.pagewrap {
  width: 1920px;
  margin: 0 auto;
}

header {
  /* Шапка сайта */
  border-bottom: 3px solid #000;
  height: 70px;
}

/* Делаем блоком */
header .login-box .sign-in .sign-up .sign-in-htm .sign-up-htm .user-box {
  display: block;
}

/* Логотип */
#logo {
  height: 70px;
}

/* Название сайта */
#text {
  font-size: 40px;
  color: #258818;
  font-family: "Sansation", sans-serif;
  font-weight: 700;
  font-style: normal;
  text-decoration: underline;
  text-underline-offset: 10px;
  text-decoration-color: #ff0000;
}

/* Логотип и название сайта */
.logo-name {
  display: flex;
  justify-content: center;
  align-items: center;
}

.login-box {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 400px;
  padding: 30px;
  transform: translate(-50%, -50%);
  background: rgba(206, 198, 198, 0.712);
  box-sizing: border-box;
  box-shadow: 0 15px 25px rgba(0, 0, 0, .6);
  border-radius: 10px;
}

/* Убирает кружочки */
.login-box .sign-in,
.login-box .sign-up {
  display: none;
}

/* Настройка текста Вход и Регистрация */
.login-box .tab {
  font-size: 25px;
  margin: 0 15px 10px 0;
  display: inline-block;
  color: #001bb3;
  text-transform: uppercase;
}

/* Выделяет цветом и подчеркивает */
.login-box .sign-in:checked+.tab,
.login-box .sign-up:checked+.tab {
  color: #ff0000;
  border-bottom: 2px solid#001bb3;
}

.login-box .user-box {
  position: relative;
}

/* Вводимый текст */
.login-box .user-box input {
  width: 100%;
  padding: 10px 0;
  font-size: 19px;
  color: #000;
  margin-bottom: 10px;
  border: none;
  border-bottom: 2px solid #001bb3;
  outline: none;
  background: transparent;
}

/* Название строк */
.login-box .user-box .box-login {
  position: absolute;
  top: 0;
  left: 0;
  padding: 10px 0;
  font-size: 20px;
  color: #001bb3;
  pointer-events: none;
  transition: .5s;
}

/* Название при нажатии на строку */
.login-box .user-box input:focus~.box-login,
.login-box .user-box input:valid~.box-login {
  top: -20px;
  left: 0;
  color: #001bb3;
  font-size: 15px;
}

/* Кнопка войти */
.login-box form button {
  position: relative;
  display: inline-block;
  background: none;
  border: none;
  padding: 10px 20px;
  /* Размер кнопки */
  color: #001bb3;
  font-size: 20px;
  /* Размер текста */
  text-decoration: none;
  text-transform: uppercase;
  overflow: hidden;
  transition: .5s;
  margin-top: 10px;
  /* Расстояние от строк */
  margin-right: 35px;
  letter-spacing: 4px
}

/* Кнопка при наведении */
.login-box button:hover {
  background: #001bb3;
  color: #fff;
  border-radius: 5px;
  box-shadow: 0 0 5px #001bb3,
    0 0 25px #001bb3,
    0 0 50px #001bb3,
    0 0 100px #001bb3;
  cursor: pointer;
}

/* Без этого не будет движения у кнопок*/
.login-box button span {
  position: absolute;
  display: block;
}

/* Начало движущейся кнопки */
.login-box button span:nth-child(1) {
  top: 0;
  left: -100%;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, transparent, #001bb3);
  animation: btn-anim1 1s linear infinite;
}

@keyframes btn-anim1 {
  0% {
    left: -100%;
  }

  50%,
  100% {
    left: 100%;
  }
}

.login-box button span:nth-child(2) {
  top: -100%;
  right: 0;
  width: 2px;
  height: 100%;
  background: linear-gradient(180deg, transparent, #001bb3);
  animation: btn-anim2 1s linear infinite;
  animation-delay: .25s
}

@keyframes btn-anim2 {
  0% {
    top: -100%;
  }

  50%,
  100% {
    top: 100%;
  }
}

.login-box button span:nth-child(3) {
  bottom: 0;
  right: -100%;
  width: 100%;
  height: 2px;
  background: linear-gradient(270deg, transparent, #001bb3);
  animation: btn-anim3 1s linear infinite;
  animation-delay: .5s
}

@keyframes btn-anim3 {
  0% {
    right: -100%;
  }

  50%,
  100% {
    right: 100%;
  }
}

.login-box button span:nth-child(4) {
  bottom: -100%;
  left: 0;
  width: 2px;
  height: 100%;
  background: linear-gradient(360deg, transparent, #001bb3);
  animation: btn-anim4 1s linear infinite;
  animation-delay: .75s
}

@keyframes btn-anim4 {
  0% {
    bottom: -100%;
  }

  50%,
  100% {
    bottom: 100%;
  }
}

/* Конец движущейся кнопки */
/* Начало кнопки глазок */
.password-control {
  position: absolute;
  top: 11px;
  right: 6px;
  display: inline-block;
  /* Размер кнопки начало*/
  width: 20px;
  height: 20px;
  /* Размер кнопки конец*/
  background: url(../images/view.svg) 0 0 no-repeat;
}

.password-control.view {
  background: url(../images/no-view.svg) 0 0 no-repeat;
}

/* Конец кнопки глазок */
/* Номер телефона */
.contact {
  display: flex;
  justify-content: center;
  margin-top: 10px;
  font-size: 23px;
  text-decoration: underline;
  text-underline-offset: 5px;
}

/* Версия */
.ver {
  display: flex;
  justify-content: right;
  margin-top: 20px;
  color: #000000;
}

/* Делает 2 формы в 1 */
.login-box .sign-in-htm,
.login-box .sign-up-htm {
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  position: absolute;
  transform: rotateY(180deg);
  /* Поворот на 180гр */
  backface-visibility: hidden;
  /* После поворота задняя часть не будет видна */
  transition: all .4s linear;
}

/* Показывает формы */
.login-box .sign-in:checked+.tab+.sign-up+.tab+.login-form .sign-in-htm {
  transform: rotate(0);
  position: relative;
}

.login-box .sign-up:checked+.tab+.login-form .sign-up-htm {
  transform: rotate(0);
  position: relative;
}
<div class="login-box">
  <form method="post">
    <input id="tab-1" type="radio" name="tab" class="sign-in" checked><label for="tab-1" class="tab">Вход</label>
    <input id="tab-2" type="radio" name="tab" class="sign-up"><label for="tab-2" class="tab">Регистрация</label>
    <div class="login-form">
      <!--Форма авторизации-->
      <div class="sign-in-htm">
        <div class="user-box">
          <input type="login" name="login" required="">
          <label class="box-login">Логин</label>
        </div>
        <div class="user-box">
          <input type="password" name="password" id="password-input" required="">
          <label class="box-login">Пароль</label>
          <a href="#" class="password-control" onclick="return show_hide_password(this)"></a>
        </div>
        <button href="#" type="submit">
                        <span class="button"></span>
                        <span class="button"></span>
                        <span class="button"></span>
                        <span class="button"></span>
                        Войти
                    </button>
        <div class="contact">Диспетчерская служба: </div>
        <div class="ver">Версия: 0.4.1</div>
      </div>

      <!--Форма регистрации-->
      <div class="sign-up-htm">
        <div class="user-box">
          <input type="text" name="first-name" autocomplete="off" required="">
          <label class="box-login">Фамилия</label>
        </div>
        <div class="user-box">
          <input type="text" name="last-name" autocomplete="off" required="">
          <label class="box-login">Имя</label>
        </div>
        <div class="user-box">
          <input type="text" name="middle-name" autocomplete="off" required="">
          <label class="box-login">Отчество</label>
        </div>
        <div class="user-box">
          <input type="Email" name="Email" autocomplete="off" required="">
          <label class="box-login">Почта</label>
        </div>
        <div class="user-box">
          <input type="password" name="password" autocomplete="off" required="">
          <label class="box-login">Пароль</label>
          <a href="#" class="password-control" onclick="return show_hide_password(this)"></a>
        </div>
        <div class="user-box">
          <input type="password" name="password" autocomplete="off" required="">
          <label class="box-login">Подтверждение пароля</label>
          <a href="#" class="password-control" onclick="return show_hide_password(this)"></a>
        </div>
        <button href="#" type="submit">
                        <span class="button"></span>
                        <span class="button"></span>
                        <span class="button"></span>
                        <span class="button"></span>
                        Зарегистрировать
                    </button>
        <div class="hr"></div>
        <div class="foot-lnk">
          <label for="tab-1">Зарегистрованы?</a>
                    </div>
                    <div class="ver">Версия: 0.4.1</div>
                </div>
            </div>
        </form>
    </div>


Ответы (1 шт):

Автор решения: Andrey Tabakov

Вам нужно разделить формы авторизации и регистрации.

Сейчас вы используете один и тот же элемент <form> и для логина и для регистрации. При действии submit вы отправите всю форму целиком, т.е. на странице входа, отправятся все поля, включая поля регистрации.

Поля регистрации (ФИО) у вас помечены как required из-за этого, форма не может быть отправлена, так как эти поля не заполнены.

→ Ссылка