@charset "UTF-8";
/*--------------------
共通設定
--------------------*/
main h1 {
  margin: 40px 0;
  font-size: 30px;
  font-weight: bold;
  color: #E72F29;
  text-align: center;
  line-height: 1;
}
main h2 {
  margin-bottom: 20px;
  padding: 10px 10px 10px 24px;
  background: #E72F29;
  border-radius: 30px;
  font-size: clamp(1.25rem, 1vw + 1rem, 1.375rem);
  color: #fff;
  line-height: 1;
  position: relative;
}
main h2::before {
  content: "";
  width: 6px;
  height: 6px;
  background: #fff;
  border-radius: 100%;
  position: absolute;
  top: 50%;
  left: 10px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
main h3 {
  margin-bottom: 20px;
}

.btn {
  margin-top: 40px;
  text-align: center;
}
.btn__wrap {
  width: 80%;
  max-width: 600px;
  display: inline-block;
  position: relative;
}
.btn__wrap::after {
  content: "\f105";
  font-family: "Font Awesome 5 Free";
  color: #E72F29;
  position: absolute;
  top: 50%;
  right: 20px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
.btn__wrap a, .btn__wrap input, .btn__wrap button {
  width: 100%;
  padding: 10px;
  background: #fff;
  border: 3px solid #E72F29;
  border-radius: 40px;
  color: #E72F29;
  font-size: 16px;
  display: block;
  cursor: pointer;
}
.btn__wrap input:disabled {
  background: #dddddd;
  cursor: not-allowed;
}

.back-btn {
  margin-top: 20px;
  text-align: center;
}
.back-btn__wrap {
  width: 80%;
  max-width: 600px;
  display: inline-block;
  position: relative;
}
.back-btn__wrap::after {
  content: "\f105";
  font-family: "Font Awesome 5 Free";
  color: #808080;
  position: absolute;
  top: 50%;
  right: 20px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
.back-btn__wrap a, .back-btn__wrap input, .back-btn__wrap button {
  width: 100%;
  padding: 6px;
  background: #fff;
  border: 2px solid #808080;
  border-radius: 40px;
  color: #808080;
  font-size: 12px;
  display: block;
  cursor: pointer;
}

@media screen and (min-width: 900px) {
  .btn__wrap::after {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
  .btn__wrap:hover::after {
    right: 10px;
    color: #fff;
    -webkit-transition-delay: 0.1s;
            transition-delay: 0.1s;
  }
  .btn__wrap:hover a, .btn__wrap:hover input, .btn__wrap:hover button {
    background: #E72F29;
    color: #fff;
  }
  .btn__wrap a, .btn__wrap input, .btn__wrap button {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
}
.error {
  padding: 10px;
  border: 1px solid #E72F29;
  color: #E72F29;
}
.error strong {
  padding-left: 14px;
  position: relative;
}
.error strong::before {
  content: "！";
  font-size: 14px;
  color: #E72F29;
  position: absolute;
  top: 0;
  left: 0;
}

.ui-dialog {
  width: 80% !important;
  max-width: 800px !important;
  height: auto !important;
  position: fixed !important;
  top: 50% !important;
  left: 50% !important;
  z-index: 101 !important;
  -webkit-transform: translate(-50%, -50%) !important;
          transform: translate(-50%, -50%) !important;
}
.ui-dialog .ui-dialog-content {
  padding: 0 !important;
}

.ui-widget.ui-widget-content {
  padding: 10px !important;
}

.ui-widget-overlay {
  background-color: rgba(0, 0, 0, 0.6);
  background-image: radial-gradient(rgba(0, 0, 0, 0.5) 20%, transparent 20%), radial-gradient(rgba(0, 0, 0, 0.5) 20%, transparent 20%);
  background-size: 8px 8px;
  background-position: 0 0, 4px 4px;
  opacity: 1;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

#discription {
  overflow: auto;
  margin-top: 10px;
  padding: 10px;
  height: 200px;
  background-color: #ffe;
  border: 1px solid #ccc;
  text-align: left;
}
#discription h2 {
  padding: 0;
  background: none;
  color: #000;
  font-size: 16px;
}
#discription h3 {
  color: #000;
  font-size: 14px;
}
#discription p {
  font-size: 12px;
}

.flow {
  margin-bottom: 20px;
}

/*--------------------
メールアドレス入力
--------------------*/
#member__regist--01 {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 40px;
}
#member__regist--01 > div {
  padding: 20px 10px;
  border: 2px solid #E72F29;
  border-radius: 4px;
  background: #fff;
}
#member__regist--01 .regist-container__left p:not(.example) {
  font-size: 14px;
}
#member__regist--01 .regist-container__left .member_mail,
#member__regist--01 .regist-container__left .gazou {
  font-size: 14px;
}
#member__regist--01 .regist-container__left input#member_mail,
#member__regist--01 .regist-container__left input#gazou {
  width: 100%;
  height: 40px;
  margin: 2px;
  padding-left: 8px;
  outline: 1px solid #D0D0D0;
  border-radius: 4px;
}
#member__regist--01 .regist-container__left input#member_mail:focus,
#member__regist--01 .regist-container__left input#gazou:focus {
  outline: 2px solid #808080;
}
#member__regist--01 .regist-container__left input#member_mail:focus::-webkit-input-placeholder, #member__regist--01 .regist-container__left input#gazou:focus::-webkit-input-placeholder {
  opacity: 0.35;
}
#member__regist--01 .regist-container__left input#member_mail:focus::-moz-placeholder, #member__regist--01 .regist-container__left input#gazou:focus::-moz-placeholder {
  opacity: 0.35;
}
#member__regist--01 .regist-container__left input#member_mail:focus:-ms-input-placeholder, #member__regist--01 .regist-container__left input#gazou:focus:-ms-input-placeholder {
  opacity: 0.35;
}
#member__regist--01 .regist-container__left input#member_mail:focus::-ms-input-placeholder, #member__regist--01 .regist-container__left input#gazou:focus::-ms-input-placeholder {
  opacity: 0.35;
}
#member__regist--01 .regist-container__left input#member_mail:focus::placeholder,
#member__regist--01 .regist-container__left input#gazou:focus::placeholder {
  opacity: 0.35;
}

@media screen and (min-width: 600px) {
  #member__regist--01 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  #member__regist--01 > div {
    padding: 20px;
  }
}
@media screen and (min-width: 900px) {
  #member__regist--01 > div {
    padding: 40px;
  }
}
/*--------------------
メールアドレス確認
--------------------*/
#member__regist--02 .attention {
  margin-top: 20px;
  border: 2px solid #E72F29;
}
#member__regist--02 .attention h2 {
  margin-bottom: 0;
  padding: 10px !important;
  border-radius: 0 !important;
}
#member__regist--02 .attention h2::before {
  display: none;
}
#member__regist--02 .attention p {
  padding: 10px;
  font-size: 12px;
  background: #fff;
}

/*--------------------
会員情報入力
--------------------*/
#member__regist--03 .small {
  margin-top: 6px;
}
#member__regist--03 .small p {
  margin-bottom: 0;
  padding-left: 12px;
  font-size: 12px;
  position: relative;
}
#member__regist--03 .small p::before {
  content: "※";
  font-size: 12px;
  position: absolute;
  top: 0;
  left: 0;
}
#member__regist--03 .errorlist {
  margin-bottom: 20px;
  border: 2px solid #E72F29;
  padding: 10px;
  background: #fff;
}
#member__regist--03 .errorlist li {
  color: #E72F29;
  font-size: 14px;
}
#member__regist--03 .form-container__wrap--list {
  margin-bottom: 40px;
}
#member__regist--03 .form-container__wrap--list .list-item:not(:last-of-type) {
  margin-bottom: 20px;
}
#member__regist--03 .form-container__wrap--list .list-item__name {
  margin-bottom: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  font-size: 14px;
  line-height: 1;
}
#member__regist--03 .form-container__wrap--list .list-item__name span {
  display: inline-block;
  margin-left: 4px;
  font-size: 11px;
  color: #E72F29;
}
#member__regist--03 .form-container__wrap--list .list-item__form.birthday {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
#member__regist--03 .form-container__wrap--list .list-item__form.birthday > div {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#member__regist--03 .form-container__wrap--list .list-item__form.birthday > div:first-of-type p {
  margin-left: 4px;
}
#member__regist--03 .form-container__wrap--list .list-item__form.birthday > div .select {
  width: 100%;
  position: relative;
}
#member__regist--03 .form-container__wrap--list .list-item__form.birthday > div .select::after {
  content: "\f105";
  font-family: "Font Awesome 5 Free";
  padding: 0px 6px;
  font-size: 16px;
  border-bottom: 1px solid #D0D0D0;
  color: #D0D0D0;
  position: absolute;
  top: 50%;
  right: 4px;
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
#member__regist--03 .form-container__wrap--list .list-item__form.birthday > div p {
  margin-left: 8px;
}
#member__regist--03 .form-container__wrap--list .list-item__form.prefecture {
  position: relative;
}
#member__regist--03 .form-container__wrap--list .list-item__form.prefecture::after {
  content: "\f105";
  font-family: "Font Awesome 5 Free";
  padding: 0px 6px;
  font-size: 16px;
  border-bottom: 1px solid #D0D0D0;
  color: #D0D0D0;
  position: absolute;
  top: 50%;
  right: 4px;
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
  pointer-events: none;
}
#member__regist--03 .form-container__wrap--list .list-item__form.grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
#member__regist--03 .form-container__wrap--list .list-item__form input,
#member__regist--03 .form-container__wrap--list .list-item__form select {
  height: 40px;
  width: 100%;
  margin: 2px;
  padding-left: 4px;
  outline: 1px solid #D0D0D0;
  border-radius: 4px;
}
#member__regist--03 .form-container__wrap--list .list-item__form input:focus,
#member__regist--03 .form-container__wrap--list .list-item__form select:focus {
  outline: 2px solid #808080;
}
#member__regist--03 .form-container__wrap--list .list-item__form input::-webkit-input-placeholder, #member__regist--03 .form-container__wrap--list .list-item__form select::-webkit-input-placeholder {
  color: #D0D0D0;
  font-size: 14px;
  font-weight: 500;
}
#member__regist--03 .form-container__wrap--list .list-item__form input::-moz-placeholder, #member__regist--03 .form-container__wrap--list .list-item__form select::-moz-placeholder {
  color: #D0D0D0;
  font-size: 14px;
  font-weight: 500;
}
#member__regist--03 .form-container__wrap--list .list-item__form input:-ms-input-placeholder, #member__regist--03 .form-container__wrap--list .list-item__form select:-ms-input-placeholder {
  color: #D0D0D0;
  font-size: 14px;
  font-weight: 500;
}
#member__regist--03 .form-container__wrap--list .list-item__form input::-ms-input-placeholder, #member__regist--03 .form-container__wrap--list .list-item__form select::-ms-input-placeholder {
  color: #D0D0D0;
  font-size: 14px;
  font-weight: 500;
}
#member__regist--03 .form-container__wrap--list .list-item__form input::placeholder,
#member__regist--03 .form-container__wrap--list .list-item__form select::placeholder {
  color: #D0D0D0;
  font-size: 14px;
  font-weight: 500;
}
#member__regist--03 .form-container__wrap--list .small {
  margin-top: 14px;
}
#member__regist--03 .form-container__wrap--list .form-magazine {
  margin-top: 20px;
}
#member__regist--03 .form-container__wrap--list .form-magazine__head {
  margin-bottom: 4px;
  color: #E72F29;
}
#member__regist--03 .form-container__wrap--list .form-magazine__btn {
  border: 1px solid #D0D0D0;
  border-radius: 4px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: #fff;
}
#member__regist--03 .form-container__wrap--list .form-magazine__btn input[type=checkbox] {
  opacity: 0;
  position: absolute;
}
#member__regist--03 .form-container__wrap--list .form-magazine__btn input[type=checkbox] + label {
  padding: 20px 20px 20px 48px;
  display: block;
  position: relative;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
#member__regist--03 .form-container__wrap--list .form-magazine__btn input[type=checkbox] + label::before {
  content: "";
  width: 22px;
  height: 22px;
  display: inline-block;
  background: #fff;
  border-radius: 100%;
  border: 1px solid #D0D0D0;
  text-align: center;
  position: absolute;
  top: 50%;
  left: 20px;
  -webkit-transform: translateY(-51%);
          transform: translateY(-51%);
  cursor: pointer;
  -webkit-transition: all 250ms ease;
  transition: all 250ms ease;
}
#member__regist--03 .form-container__wrap--list .form-magazine__btn input[type=checkbox]:checked + label::before {
  background-color: #E72F29;
  -webkit-box-shadow: inset 0 0 0 4px #fff;
          box-shadow: inset 0 0 0 4px #fff;
  border-color: #E72F29;
}
#member__regist--03 .form-container__wrap--list .form-magazine__btn input[type=checkbox]:focus::before {
  outline: none;
  border-color: #E72F29;
}
#member__regist--03 .form-container__wrap--list .form-magazine__btn label {
  padding-left: 26px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#member__regist--03 .form-container__wrap--list .form-magazine__btn > span {
  height: 100%;
  padding-top: 2px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 12px;
}

@media screen and (min-width: 600px) {
  #member__regist--03 .form-container__wrap--list .list-item {
    display: grid;
    grid-template-columns: 180px 1fr;
  }
  #member__regist--03 .form-container__wrap--list .list-item__name {
    margin-bottom: 10px;
    padding-top: 14px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    font-size: 14px;
    line-height: 1;
  }
  #member__regist--03 .form-container__wrap--list .list-item__name span {
    margin-bottom: 0;
  }
  #member__regist--03 .form-container__wrap--list .list-item__name span span {
    margin-left: 6px;
    font-size: 12px;
  }
}
/*--------------------
確認
--------------------*/
#member__regist--04 .form-container__wrap--list {
  display: grid;
  gap: 20px;
}
#member__regist--04 .form-container__wrap--list .list-item__head {
  color: #E72F29;
  font-size: 14px;
}

/*--------------------
完了画面
--------------------*/
#member__regist--05 .done-container__wrap {
  margin-top: 40px;
  padding: 20px 10px;
  border: 2px solid #E72F29;
  border-radius: 8px;
}
#member__regist--05 .done-container__wrap h1 {
  margin-bottom: 40px;
  margin-top: 20px;
  font-size: 32px;
  color: #E72F29;
  text-align: center;
  line-height: 1;
}
#member__regist--05 .done-container__wrap .attention h2 {
  margin-bottom: 20px;
  padding: 10px;
  background: red;
  text-align: center;
  color: #fff;
  line-height: 1;
}
#member__regist--05 .done-container__wrap .attention p {
  font-size: 12px;
  color: #E72F29;
}