@charset "UTF-8";
/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/* 変数の定義
--------------------------------------------------*/
/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/*-----------------------------------------

※このスタイルシートはSCSSで生成されています。
cssへの直記入はなさらないようにしてください。

-----------------------------------------*/
/* 色の定義
--------------------------------------------------*/
/* フォントの定義
--------------------------------------------------*/
html,
body,
ul,
ol,
dl,
li,
dt,
dd,
a,
p,
div,
img,
svg,
table,
tr,
th,
td,
figure {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.6;
  color: #1C1C1C;
  font-feature-settings: "palt";
}

body,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
img,
svg,
a,
table,
tr,
th,
td,
figure {
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  body,
  ul,
  ol,
  dl,
  li,
  dt,
  dd,
  p,
  div,
  img,
  svg,
  a,
  table,
  tr,
  th,
  td,
  figure {
    font-size: 1.4rem;
  }
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  letter-spacing: 0.04em;
  line-height: 1.5;
  font-weight: 800;
  font-feature-settings: "palt";
}

.en {
  font-family: "Inter Tight", sans-serif;
  font-style: italic;
  letter-spacing: 0;
  line-height: 1;
  font-weight: 700;
  display: inline-block;
}

/* エントリー
--------------------------------------------------*/
#entry_form {
  padding: 80px 0 120px;
}
@media screen and (max-width: 999px) {
  #entry_form {
    padding: 60px 0 80px;
  }
}

.entry_form_txt {
  text-align: center;
  margin-bottom: 60px;
}
@media screen and (max-width: 999px) {
  .entry_form_txt {
    margin-bottom: 40px;
  }
}

.form_inner {
  background-color: #fff;
  border-radius: 8px;
  padding: clamp(30px, 4vw, 60px) clamp(20px, 4vw, 60px);
}

.form_wrap {
  margin-bottom: 50px;
}
@media screen and (max-width: 999px) {
  .form_wrap {
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 768px) {
  .form_wrap {
    margin-bottom: 30px;
  }
}

.js-school-info-wrap {
  display: none;
}

.js-school-info-wrap.is-show {
  display: block;
}

.js-job-select-wrap {
  display: none;
}

.js-job-select-wrap.is-show {
  display: block;
}

.form_ttl {
  margin-bottom: 15px;
}
@media screen and (max-width: 768px) {
  .form_ttl {
    margin-bottom: 10px;
  }
}
.form_ttl .required {
  color: #CE1B21;
}

.form_box {
  position: relative;
}
.form_box select, .form_box input, .form_box textarea {
  width: 100%;
  padding: 20px;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.6;
  font-size: 1.6rem;
  color: #1C1C1C;
  background-color: #f6f6f6;
  border: solid 1px transparent;
  transition: border-color 0.4s ease;
}
@media screen and (max-width: 449px) {
  .form_box select, .form_box input, .form_box textarea {
    font-size: 1.4rem;
    padding: 10px;
  }
}
.form_box select::-moz-placeholder, .form_box input::-moz-placeholder, .form_box textarea::-moz-placeholder {
  color: #888484;
}
.form_box select::placeholder, .form_box input::placeholder, .form_box textarea::placeholder {
  color: #888484;
}
.form_box select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background: url("data:image/svg+xml,%3Csvg width='10' height='8' viewBox='0 0 10 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5 8L0 0H10L5 8Z' fill='%23CE1B21'/%3E%3C/svg%3E") no-repeat right 16px center/10px auto;
  background-color: #f6f6f6;
  padding-right: 40px;
}
.form_box textarea {
  height: 200px;
}
.form_box {
  /* フォーカス時の共通 */
}
.form_box select:focus,
.form_box input:focus,
.form_box textarea:focus {
  border-color: #CE1B21;
}

.wpcf7-form-control-wrap .wpcf7-radio {
  display: flex;
  flex-wrap: wrap;
  gap: 20px 25px;
}
.wpcf7-form-control-wrap .wpcf7-radio .wpcf7-list-item {
  margin: 0;
  line-height: 1;
}
.wpcf7-form-control-wrap .wpcf7-radio .wpcf7-list-item > label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}
.wpcf7-form-control-wrap .wpcf7-radio .wpcf7-list-item input[type=radio] {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  margin: 0;
  padding: 0;
  border: 1px solid #BDBDBD;
  border-radius: 50%;
  background-color: #fff;
  cursor: pointer;
}
.wpcf7-form-control-wrap .wpcf7-radio .wpcf7-list-item input[type=radio]:checked {
  border-color: #CE1B21;
  background: radial-gradient(circle, #CE1B21 0 45%, transparent 46% 100%);
  background-color: #fff;
}

.agree_wrap .wrap_txt {
  padding: 30px;
  border: solid 1px #DFDFDF;
  margin-bottom: 30px;
  font-size: 1.4rem;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  .agree_wrap .wrap_txt {
    padding: 20px;
  }
}
.agree_wrap .wrap_txt .link_txt {
  font-size: 1.4rem;
  font-weight: 500;
  color: #CE1B21;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: opacity 0.3s ease;
}
.agree_wrap .wrap_txt .link_txt .simple_arrow {
  display: inline-block;
  -webkit-mask: var(--arrow) no-repeat center/contain;
  mask: var(--arrow) no-repeat center/contain;
  background: #CE1B21;
  width: 14px;
  height: 11px;
  transform: rotate(-45deg);
}
.agree_wrap .wrap_txt .link_txt:hover {
  opacity: 0.6;
}
.agree_wrap .wrap_checkbox {
  text-align: center;
  margin-bottom: 30px;
}
.agree_wrap .wrap_checkbox .wpcf7-list-item {
  margin-top: 15px;
}

.confirm_wrap {
  margin: 0 auto 20px;
  width: -moz-fit-content;
  width: fit-content;
}

.agree_wrap .wpcf7-list-item,
.confirm_wrap .wpcf7-list-item {
  margin: 0;
}
.agree_wrap .wpcf7-list-item label,
.confirm_wrap .wpcf7-list-item label {
  display: inline-flex;
  align-items: center;
  -moz-column-gap: 15px;
       column-gap: 15px;
  cursor: pointer;
}
@media screen and (max-width: 768px) {
  .agree_wrap .wpcf7-list-item label,
  .confirm_wrap .wpcf7-list-item label {
    -moz-column-gap: 10px;
         column-gap: 10px;
  }
}
.agree_wrap .wpcf7-list-item input[type=checkbox],
.confirm_wrap .wpcf7-list-item input[type=checkbox] {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  margin: 0;
  padding: 0;
  width: 24px;
  height: 24px;
  border: solid 1px #1C1C1C;
  position: relative;
  cursor: pointer;
  transition: background 0.3s ease, border-color 0.3s ease;
  flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .agree_wrap .wpcf7-list-item input[type=checkbox],
  .confirm_wrap .wpcf7-list-item input[type=checkbox] {
    width: 20px;
    height: 20px;
  }
}
.agree_wrap .wpcf7-list-item input[type=checkbox]:checked,
.confirm_wrap .wpcf7-list-item input[type=checkbox]:checked {
  background: #CE1B21;
  border-color: #CE1B21;
}
.agree_wrap .wpcf7-list-item input[type=checkbox]:checked::after,
.confirm_wrap .wpcf7-list-item input[type=checkbox]:checked::after {
  content: "";
  position: absolute;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='9' viewBox='0 0 12 9' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4.19632 9L0 4.73389L1.04908 3.66736L4.19632 6.86694L10.9509 0L12 1.06653L4.19632 9Z' fill='%23FFFFFF'/%3E%3C/svg%3E");
  width: 12px;
  height: 9px;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}

.btn_wrap .entry_btn {
  margin: 0 auto;
  width: 100%;
  max-width: 320px;
  height: 70px;
  background: #fff;
  border-radius: 100vh;
  overflow: hidden;
  position: relative;
  color: #fff;
}
.btn_wrap .entry_btn input {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background: none;
  border: none;
  outline: none;
  padding: 0;
  margin: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  cursor: pointer;
  width: 100%;
  text-align: left;
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  padding-left: 30px;
}
.btn_wrap .entry_btn input:disabled {
  cursor: not-allowed;
}
.btn_wrap .entry_btn::before {
  content: "";
  position: absolute;
  opacity: 1;
  inset: 0px;
  background: linear-gradient(to right, #BA0F15, #E72A31);
  transition: opacity 0.3s;
}
.btn_wrap .entry_btn::after {
  content: "";
  position: absolute;
  -webkit-mask: var(--arrow) no-repeat center/contain;
  mask: var(--arrow) no-repeat center/contain;
  background: #fff;
  width: 16px;
  height: 12px;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
}
.btn_wrap .entry_btn:hover {
  border: solid 1px #CE1B21;
}
.btn_wrap .entry_btn:hover::before {
  opacity: 0;
}
.btn_wrap .entry_btn:hover::after {
  background: #CE1B21;
}
.btn_wrap .entry_btn:hover input {
  color: #CE1B21;
}
.btn_wrap .entry_btn.is-disabled {
  border: solid 1px #BDBDBD;
}
.btn_wrap .entry_btn.is-disabled::before {
  opacity: 1;
  background: #BDBDBD;
}
.btn_wrap .entry_btn.is-disabled::after {
  background: #fff;
}
.btn_wrap .entry_btn.is-disabled input {
  color: #fff;
}
.btn_wrap .entry_btn.is-disabled:hover {
  border: solid 1px #BDBDBD;
}
.btn_wrap .entry_btn.is-disabled:hover::before {
  opacity: 1;
  background: #BDBDBD;
}
.btn_wrap .entry_btn.is-disabled:hover::after {
  background: #fff;
}
.btn_wrap .entry_btn.is-disabled:hover input {
  color: #fff;
}
.btn_wrap .entry_btn .wpcf7-spinner {
  display: none;
}

.wpcf7-form-control-wrap > .wpcf7-not-valid-tip {
  color: #CE1B21;
  font-size: 1.4rem;
  font-weight: 500;
  margin-top: 4px;
}

.wpcf7-response-output {
  display: none;
}

.txt_error {
  display: none;
}
.txt_error.is-show {
  display: block;
  text-align: center;
  color: #CE1B21;
  margin-bottom: 40px;
}

/* エントリー完了
--------------------------------------------------*/
#entry_complete {
  padding: 80px 0 100px;
}
@media screen and (max-width: 999px) {
  #entry_complete {
    padding: 60px 0 80px;
  }
}
#entry_complete .wrap_content {
  background-color: #fff;
  border-radius: 8px;
  padding: clamp(25px, 4vw, 50px);
  margin-bottom: 50px;
  text-align: center;
}
@media screen and (max-width: 999px) {
  #entry_complete .wrap_content {
    margin-bottom: 40px;
  }
}
#entry_complete .wrap_content .wrap_icon {
  margin-bottom: 25px;
}
@media screen and (max-width: 768px) {
  #entry_complete .wrap_content .wrap_icon {
    margin-bottom: 15px;
  }
}
#entry_complete .wrap_content .wrap_icon svg {
  width: 50px;
  height: 50px;
  margin-bottom: 4px;
}
#entry_complete .wrap_content .wrap_icon .ttl {
  font-size: 2.4rem;
}
#entry_complete .btn {
  margin-inline: auto;
}/*# sourceMappingURL=entry.css.map */