@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700;900&display=swap");

:where(.user_id_guid) a {
  text-decoration: none;
  -webkit-transition: 0.4s opacity;
  transition: 0.4s opacity;
}

:where(.user_id_guid) a:hover {
  opacity: 0.7;
}

:where(.user_id_guid) *,
:where(.user_id_guid) ::before,
:where(.user_id_guid) ::after {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border-style: solid;
  border-width: 0;
}

:where(.user_id_guid) p,
:where(.user_id_guid) table,
:where(.user_id_guid) blockquote,
:where(.user_id_guid) address,
:where(.user_id_guid) pre,
:where(.user_id_guid) iframe,
:where(.user_id_guid) form,
:where(.user_id_guid) figure,
:where(.user_id_guid) dl {
  margin: 0;
}

:where(.user_id_guid) h1,
:where(.user_id_guid) h2,
:where(.user_id_guid) h3,
:where(.user_id_guid) h4,
:where(.user_id_guid) h5,
:where(.user_id_guid) h6 {
  font-size: inherit;
  font-weight: inherit;
  margin: 0;
}

:where(.user_id_guid) ul,
:where(.user_id_guid) ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

:where(.user_id_guid) picture {
  vertical-align: middle;
}

:where(.user_id_guid) picture,
:where(.user_id_guid) img,
:where(.user_id_guid) figure,
:where(.user_id_guid) a img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

:where(.user_id_guid) em,
:where(.user_id_guid) address {
  font-style: normal;
}

body {
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.75;
  margin: 0;
}

.l-contents {
  min-width: 1280px;
}

.question-block_wrap {
  background-color: #f4f4f9;
  padding-bottom: 6rem;
}

/* sp_contents */
.sp_contents {
  display: none;
}

.sp_mv {
  background-color: #f4f4f9;
}

.sp_mv_title {
  background-color: #fff;
  border-top: 4px solid #0078c7;
  color: #0078c7;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.4;
  padding: 2rem 1rem;
  text-align: center;
}

.sp_mv__message-block {
  padding: 5rem 1rem;
  text-align: center;
}

.sp_mv__message-block .mv_image {
  margin: 0 auto;
  width: 200px;
}

.sp_mv__message-block .sp_mv__message {
  color: #0078c7;
  font-size: 1.8rem;
  font-weight: 700;
  margin-top: 3rem;
}

/* mv */
.mv {
  background-color: #fff;
  border-top: 4px solid #0078c7;
  padding: 80px 0;
}

.mv_inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 64px;
  margin: 0 auto;
  max-width: 1110px;
  width: 80%;
}

.mv_image__block {
  width: 340px;
}

.contents_description {
  width: calc(100% - 340px - 64px);
}

.contents_description .contents_title {
  color: #0078c7;
  font-size: 44px;
  font-weight: 700;
  line-height: 1.4;
}

.contents_description .contents_text {
  margin-top: 30px;
}

.contents_description .contents_text.note {
  font-size: 13px;
}

/* question-block_wrap */
.question-block {
  background-color: #fff;
  -webkit-box-shadow: 3px 3px 20px rgba(0, 0, 0, 0.1);
  box-shadow: 3px 3px 20px rgba(0, 0, 0, 0.1);
  border-radius: 12px;
  overflow: hidden;
  margin: 0 auto;
  max-width: 980px;
  width: 70%;
}

.question-block .question-block_text+.question-block_text {
  margin-top: 6rem;
}

.question-block {
  display: none;
}

.question-block.active {
  display: block;
}

.sub-question-block {
  background-color: #f4f4f9;
  border-right: 1px solid #dcf0ff;
  border-bottom: 1px solid #dcf0ff;
  border-left: 1px solid #dcf0ff;
  display: none;
  padding: 6rem 0 7rem;
}

.question-block__note {
  font-size: 1.3rem;
  font-weight: 700;
  padding: 0 6rem 2rem;
}

.question-block__text {
  padding: 0 6rem 4rem;
}

/* qb01 */
.qb01 {
  background-color: transparent;
  -webkit-box-shadow: none;
  box-shadow: none;
  border: none;
  padding: 6rem 0;
}

.qb01_inner {
  margin-top: 3rem;
}

.qb01_serects {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 20px;
}

.serectbox-wrap {
  position: relative;
}

.serectbox-wrap::after {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  background: #0078c7;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
  pointer-events: none;
  position: absolute;
  top: 50%;
  right: 20px;
  -webkit-transform: translate(0, -10%);
  transform: translate(0, -10%);
}

.serectbox-wrap select {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.serectbox-wrap:has(select:disabled)::after {
  background: #969698;
}

.qb01_serectbox {
  color: #0078c7;
  font-size: 1.8rem;
  margin-top: 1rem;
  width: 240px;
}

.qb01_serectbox:disabled {
  background-color: #e1e1e1;
  color: #969698;
}

.qb01_text__item {
  margin-top: 2rem;
}

.organization_field {
  font-size: 1.8rem;
  width: 100%;
}

.organization_field::-webkit-input-placeholder {
  color: #969698;
  font-size: 1.8rem;
}

.organization_field::-moz-placeholder {
  color: #969698;
  font-size: 1.8rem;
}

.organization_field:-ms-input-placeholder {
  color: #969698;
  font-size: 1.8rem;
}

.organization_field::-ms-input-placeholder {
  color: #969698;
  font-size: 1.8rem;
}

.organization_field::placeholder {
  color: #969698;
  font-size: 1.8rem;
}

/* checklist_form */
.checklist_form .question-block+.question-block {
  margin-top: 4rem;
}

.question-block_title {
  background-color: #0078c7;
  color: #fff;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 4rem;
  padding: 2.5rem 6rem;
  width: 100%;
}

.question-block__fieldset {
  padding-bottom: 6rem;
}

.choice_label {
  border-radius: 4px;
  display: block;
  border: 1px solid #f4f4f9;
  padding: 1.8rem 2rem 1.8rem 5.2rem;
  position: relative;
  cursor: pointer;
  -webkit-transition: background-color 0.3s, border-color 0.3s;
  transition: background-color 0.3s, border-color 0.3s;
}

.choice_label:hover {
  color: #0078c7;
  background-color: #dcf0ff;
}

.choice_label::before {
  content: "";
  position: absolute;
  left: 26px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  border: 1px solid #333;
  border-radius: 50%;
  background: #fff;
  -webkit-transition: border-color 0.2s;
  transition: border-color 0.2s;
}

.choice {
  font-size: 1.8rem;
  padding: 0 6rem;
  position: relative;
}

.choice input[type=radio] {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.choice input[type=radio]:checked+.choice_label,
.choice input[type=radio]:checked+.sub-choice_label {
  color: #0078c7;
  background-color: #dcf0ff;
}

.choice input[type=radio]:checked+.choice_label::before,
.choice input[type=radio]:checked+.sub-choice_label::before {
  border-color: #0078c7;
}

.choice input[type=radio]:checked+.choice_label::after,
.choice input[type=radio]:checked+.sub-choice_label::after {
  content: "";
  position: absolute;
  left: 30px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #0078c7;
}

.choice+.choice {
  margin-top: 1rem;
}

.choice:has(.sub-question-block) input[type=radio]:checked+.choice_label {
  border-radius: 4px 4px 0 0;
}

.choice_label__note {
  display: block;
  font-size: 1.3rem;
  line-height: 1.4;
}

.sub-question-block_title {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.4;
  padding: 0 6rem 4rem;
  width: 100%;
}

.sub-choice_label {
  background-color: #fff;
  border: 1px solid #f4f4f9;
  border-radius: 4px;
  display: block;
  font-size: 1.6rem;
  padding: 1.6rem 2rem 1.6rem 5.2rem;
  position: relative;
  cursor: pointer;
  -webkit-transition: background-color 0.3s, border-color 0.3s;
  transition: background-color 0.3s, border-color 0.3s;
}

.sub-choice_label:hover {
  background-color: #dcf0ff;
}

.sub-choice_label::before {
  content: "";
  position: absolute;
  left: 26px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  border: 1px solid #333;
  border-radius: 50%;
  background: #fff;
  -webkit-transition: border-color 0.2s;
  transition: border-color 0.2s;
}

/* results-block */
.results-block {
  background-color: #0078c7;
  margin-top: 8rem;
  padding: 8rem 0 5rem;
}

.results-title {
  color: #fff;
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
}

.results-title small {
  display: block;
  font-size: 1.6rem;
  font-weight: 400;
  margin-top: 1rem;
}

/* task-container */
.task-container {
  background-color: #fff;
  -webkit-box-shadow: 3px 3px 20px rgba(0, 0, 0, 0.1);
  box-shadow: 3px 3px 20px rgba(0, 0, 0, 0.1);
  border-radius: 12px;
  overflow: hidden;
  margin: 6rem auto 0;
  padding: 4rem 0 1rem;
  max-width: 980px;
  width: 70%;
}

.result-content {
  padding: 0 7rem 4rem;
}

.task-label {
  border: 1px solid #0078c7;
  border-radius: 4px;
  color: #0078c7;
  display: block;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1;
  padding: 1.2rem 2.2rem;
  width: 8rem;
}

.task-timing {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 25px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0 7rem 4rem;
}

.task-timing .task-timing__content {
  width: calc(100% - 80px - 25px);
}

.result-category_title {
  background-color: #0078c7;
  border-radius: calc(infinity * 1px);
  color: #fff;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.3;
  padding: 1rem 3rem;
  position: relative;
  margin: 0 auto 3rem;
  width: calc(100% - 80px);
}

.result-category_title .result-category_number {
  background-color: #fff;
  border-radius: calc(infinity * 1px);
  color: #0078c7;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
  padding: 0.2rem 1rem 0.4rem;
  position: absolute;
  top: 50%;
  right: 3rem;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
}

.release-date {
  font-size: 2rem;
  font-weight: 700;
}

.attention {
  font-size: 1.3rem;
}

.inner-block {
  background-color: #f4f4f9;
  border-radius: 2rem;
  margin-top: 3rem;
  padding: 3rem;
}

.link-block {
  margin-top: 3rem;
  text-align: right;
}

.link-block a {
  border-bottom: 1px solid #0078c7;
  color: #0078c7;
  display: inline-block;
  padding: 0 2.4rem 0.3rem 0;
  position: relative;
}

.link-block a::after {
  content: "";
  display: inline-block;
  border-right: 2px solid #0078c7;
  border-bottom: 2px solid #0078c7;
  height: 12px;
  width: 12px;
  position: absolute;
  top: 50%;
  right: 5px;
  -webkit-transform: translateY(-55%) rotate(-45deg);
  transform: translateY(-55%) rotate(-45deg);
}

.link-block+.link-block {
  margin-top: 2rem;
}

.result-content__sub-title {
  border-bottom: 2px solid #0078c7;
  color: #0078c7;
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 3rem;
  padding: 0 0 0.5rem;
}

/* button */
.button {
  background-color: #f4f4f9;
  -webkit-box-shadow: 0 4px 0 0 #0078c7;
  box-shadow: 0 4px 0 0 #0078c7;
  border-radius: calc(infinity * 1px);
  color: #969698;
  cursor: pointer;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.3;
  opacity: 1;
  padding: 0.8em 1em;
  text-align: center;
  -webkit-transition: 0.4s ease;
  transition: 0.4s ease;
  width: 100%;
}

.button:hover {
  opacity: 0.7;
}

.button:disabled {
  background-color: #e1e1e1;
  color: #969698;
  -webkit-box-shadow: 0 4px 0 0 #969698;
  box-shadow: 0 4px 0 0 #969698;
  cursor: default;
}

.button:disabled:hover {
  opacity: 1;
}

.button_reset {
  background-color: #dcf0ff;
  color: #0078c7;
}

.button_submit {
  background-color: #ffff00;
  color: #333;
}

.icon_reset,
.icon_submit {
  position: relative;
  padding-right: 3rem;
}

.icon_reset::after,
.icon_submit::after {
  background-size: contain;
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
}

.icon_reset::after {
  background: url(../img/icon_reset.svg) no-repeat center top;
  height: 24px;
  width: 24px;
}

.icon_submit::after {
  background: url(../img/icon_save.svg) no-repeat center top;
  height: 25px;
  width: 20px;
}

.button:disabled .icon_submit::after {
  background: url(../img/icon_save_gray.svg) no-repeat center top;
}

/* submission-block */
.submission-block {
  background-color: #0078c7;
  padding: 0 0 6rem;
}

.submission-button-block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 0 40px;
  padding: 5rem 5rem 2rem;
}

.submission-button-item {
  width: calc((100% - 40px) / 2);
}

.submission-status {
  margin-top: 2rem;
  padding: 0 5rem;
  text-align: center;
  width: 100%;
}

.submission-text {
  color: #0078c7;
  padding: 0 5rem 5rem;
  text-align: center;
}

.submit_error {
  text-align: center;
}

/* form settings */
.mark_required {
  background-color: #ff0000;
  border-radius: 6px;
  color: #fff;
  display: block;
  line-height: 1;
  font-size: 1.4rem;
  font-weight: 700;
  padding: 0.5rem;
  text-align: center;
  width: 48px;
}

.error_message {
  color: #ff0000;
  font-size: 13px;
  margin-top: 1rem;
}

select {
  background-color: #fff;
  border: 1px solid #e1e1e1;
  border-radius: 12px;
  padding: 1.2rem 1.8rem;
}

fieldset {
  border: none;
  padding: 0;
  margin: 0;
}

input[type=text] {
  background-color: #fff;
  border: 1px solid #e1e1e1;
  border-radius: 12px;
  padding: 1.2rem 1.8rem;
}

input[type=text]::-webkit-input-placeholder {
  color: #969698;
}

input[type=text]::-moz-placeholder {
  color: #969698;
}

input[type=text]:-ms-input-placeholder {
  color: #969698;
}

input[type=text]::-ms-input-placeholder {
  color: #969698;
}

input[type=text]::placeholder {
  color: #969698;
}

/* screen-reader */
.sr-only {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
}

/* Utility */
.color_blue {
  color: #0078c7;
}

.mt-10 {
  margin-top: 10px;
}

.mt-20 {
  margin-top: 20px;
}

.mt-30 {
  margin-top: 30px;
}

.mt-40 {
  margin-top: 40px;
}

.text-indent {
  padding-left: 1em;
}

/* print */

@media screen and (orientation: landscape) and (max-width: 1000px) {
  .question-block_wrap {
    display: none;
  }

  .sp_contents {
    display: block;
  }
}

@media screen and (max-width: 767px) {
  .l-contents {
    min-width: auto;
    width: 100%;
  }

  .question-block_wrap {
    display: none;
  }

  .sp_contents {
    display: block;
  }
}

@media print {

  .l-header,
  .l-footer {
    display: none;
  }

  body>*:not(.printable) {
    display: block;
  }

  body>.printable,
  body>.printable * {
    visibility: hidden;
  }

  .printable {
    display: none !important;
    width: 100%;
    margin: 0;
    padding: 0;
    border: none;
  }

  @page {
    margin: 0 5%;
    /* すべての余白を1インチに設定 */
  }

  .l-contents {
    position: absolute;
    top: 0;
    min-width: 100%;
  }

  .question-block_wrap {
    /* background-color: #fff; */
    padding-bottom: 0;
  }

  .question-block {
    width: 90%;
    margin: 0 auto;
  }

  .task-container {
    /* background-color: #fff; */
    /* -webkit-box-shadow: none; */
    /* box-shadow: none; */
    overflow: hidden;
    margin: 2rem auto;
    padding: 4rem 0 1rem;
    max-width: 100%;
    width: 90%;
  }

  /* .results-block {
    background-color: transparent;
  } */

  /* .results-title {
    color: #333;
  } */
  /* .result-category_title {
    background-color: transparent;
    border: 1px solid #333;
    color: #333;
  } */
  /* .inner-block {
    background-color: transparent;
    border: 1px solid #ccc;
  } */
}

/* ============================================
   以下、index.cssからの非重複スタイル
   ============================================ */

:where(.info) {
    font-family: "Noto Sans JP", sans-serif;
    font-size: 62.5%;
    font-weight: 500;
    color: #2a3054;
}
:where(.info) a {
    text-decoration: none;
    -webkit-transition: 0.4s opacity;
    transition: 0.4s opacity;
}
:where(.info) a:hover {
    opacity: 0.7;
}
:where(.info) *,:where(.info):after,:where(.info):before {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    border-style: solid;
    border-width: 0;
}
:where(.info) address,:where(.info) blockquote,:where(.info) dl,:where(.info) figure,:where(.info) form,:where(.info) iframe,:where(.info) p,:where(.info) pre,:where(.info) table {
    margin: 0;
}
:where(.info) h1,:where(.info) h2,:where(.info) h3,:where(.info) h4,:where(.info) h5,:where(.info) h6 {
    font-size: inherit;
    font-weight: inherit;
    margin: 0;
}
:where(.info) ol,:where(.info) ul {
    margin: 0;
    padding: 0;
    list-style: none;
}
:where(.info) picture {
    vertical-align: middle;
}
:where(.info) a img,:where(.info) figure,:where(.info) img,:where(.info) picture {
    max-width: 100%;
    height: auto;
    vertical-align: top;
}
:where(.info) address,:where(.info) em {
    font-style: normal;
}

.info {
    width: 100%;
    max-width: min(calc(1600 / 750 * 100vw),160rem);
    margin: 0 auto;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
    color: #2a3054;
    text-align: center;
    overflow: hidden;
}
.info .pc {
    display: inline-block;
}
.info .sp {
    display: none;
}
.info .palt {
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
}

/*KeyVisual部*/
.KV {
    position: relative;
}
.KV .pc {
    display: inline-block;
}
.KV .sp {
    display: none;
}
.KV_CTA_pc {
    position: absolute;
    bottom: 17.5%;
    left: 53.5%;
    transform: translateX(-50%);
    z-index: 1;
}
.KV_CTA_pc img {
    width: min(27.31vw,43.7rem);
    box-sizing: border-box;
}

/*フローティングバナー部*/
.mv__label {
    margin: 14.3rem auto 0;
    width: 54.8rem;
}
.mv__label__title {
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.4;
}
.mv__label__title .mvlogo {
    margin-bottom: 0.8rem;
}
.mv__detail {
    width: 54.8rem;
    margin: 2.4rem auto 0;
}
.mv__detail__ttl {
    padding: 0 0 0.3em;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.5;
}
.mv__detail__lead {
    padding: 0 0 1.5em;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.5;
}
.mv__detail__ft {
    padding: 1.2rem 21.1rem 0;
}
.mv__join {
    position: fixed;
    right: 12rem;
    bottom: 6rem;
    z-index: 2;
    width: 18.8rem;
}
@media screen and (min-width:767px) and (max-width:1280px) {
    .mv__join {
        right: 5vw;
    }
}
.mv__join__btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    height: 18.8rem;
    padding: 1.6rem 0.8rem 0.5em 0;
    background: #eaf330;
    border-radius: 50%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-box-shadow: 0.8rem 0.8rem 0.5rem rgba(0, 0, 0, 0.3);
    box-shadow: 0.8rem 0.8rem 0.5rem rgba(0, 0, 0, 0.3);
    color: #2a3054;
    -webkit-transition: 0.4s all;
    transition: 0.4s all;
}
.mv__join__btn span {
    font-size: 2.26rem;
    font-weight: 900;
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
    line-height: 1.277;
}
.mv__join__btn span b {
    font-size: 2.82rem;
    font-weight: 900;
}
.mv__join__btn:after {
    content: "";
    position: absolute;
    display: block;
    right: 1.8rem;
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
    width: 1.4rem;
    height: 1.4rem;
    border-top: 0.2rem solid #2a3054;
    border-right: 0.2rem solid #2a3054;
}
.mv__join__btn:hover {
    background: #fa4ea5;
    color: #fff;
    opacity: 1;
    -webkit-transition: 0.4s all;
    transition: 0.4s all;
}
.mv__join__btn:hover:after {
    border-top-color: #fff;
    border-right-color: #fff;
}
.mv__join__btn .label {
    display: inline-block;
    position: absolute;
    left: 50%;
    top: 1.4rem;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    min-width: 15rem;
    height: 3rem;
    background: #2a3054;
    border-radius: 0.83em;
    font-size: 1.8rem;
    font-weight: 900;
    line-height: 1.5;
    color: #fff;
}

.section.pc .arar{
    background: url(../img/arar_bg_pc.jpg) repeat-y center top;
    background-size: 100% auto;
    width: 100%;
    height: 100%;
    min-height: 100vh;
    max-width: 160rem;
    margin: 0 auto;
}

.section.pc .arar .arar__title,
.section.pc .arar .arar__item{
    margin: 13rem auto 0;
}
.section.pc .arar .arar__item:last-of-type{
    margin-bottom: 17rem;
}
.section.pc .arar .arar__item img {
    width: 90%;
    max-width: 111.1rem;
    margin: 0 auto;
}

.section.faq{
    background: url(../img/FAQ_bg.jpg) repeat-y center top;
    background-size: 100% auto;
    width: 100%;
    height: 100%;
    min-height: 100vh;
    max-width: 160rem;
    margin: 0 auto;
}

/* FAQ list */
.section.faq .faq_container{
    padding: 8rem 0 12rem;
    font-family: "Zen Maru Gothic", sans-serif;
}
.section.faq .faq_title img{
    width: 90%;
    margin: 0 auto;
}
.section.faq .faq_list{
    width: 90%;
    max-width: 120rem;
    margin: 4rem auto 0;
    text-align: left;
}
.section.faq .faq_list details{
    background: #fff;
    border: none;
    border-radius: 0.4rem;
    box-shadow: 0.5rem 0.5rem 0 0 rgba(0, 0, 0, 0.2);
}
.section.faq .faq_list details + details{ 
    margin-top: 2.4rem; 
}
.section.faq .faq_list summary{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    gap: 1.6rem;
    padding: 2.4rem 10rem 2.4rem 2.4rem;
    cursor: pointer;
    list-style: none;
    position: relative;
    overflow: hidden;
}
.section.faq .faq_list summary::-webkit-details-marker{ display: none; }
.section.faq .faq_list .faq_question{
    display: inline-block;
    position: relative;
    padding-left: 10rem;
    line-height: 1.7;
}
.section.faq .faq_list .faq_question::before{
    content: "";
    position: absolute;
    left: -2.4rem;
    top: -2.4rem;
    bottom: -2.4rem;
    width: 8.58rem;
    height: auto;
    border-radius: 0.4rem 0 0 0.4rem;
    background: #000000;
    font-size: 1.1rem;
}
.section.faq .faq_list .faq_question::after{
    content: "Q";
    position: absolute;
    left: -2.5rem;
    top: 42.5%;
    width: 8.58rem;
    text-align: center;
    -webkit-transform: translateY(-50%) scale(4.5);
    transform: translateY(-50%) scale(4.5);
    -webkit-transform-origin: center;
    transform-origin: center;
    color: #fff;
    font-weight: 700;
}
.section.faq .faq_list summary::after{
    content: "+";
    position: absolute;
    right: 2.0rem;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 4.2rem;
    height: 4.2rem;
    border-radius: 0;
    background: transparent;
    color: #2a3054;
    font-weight: 900;
    font-size: 4.2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}
.section.faq .faq_list details[open] summary::after{ content: "−"; }
.section.faq .faq_list .faq_question_text{
    font-size: 3.2rem;
    font-weight: 700;
    color: #2a3054;
    line-height: 1.3;
    font-feature-settings: "palt" 1;
}
.section.faq .faq_list .faq_answer{
    max-height: 0;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    padding: 0 2.4rem 0;
    position: relative;
    will-change: max-height, opacity, padding, border-top-color, visibility;
    -webkit-transition: max-height 0.35s ease, opacity 0.25s ease, padding 0.35s ease, border-top-color 0.35s ease, visibility 0s linear 0.35s;
    transition: max-height 0.35s ease, opacity 0.25s ease, padding 0.35s ease, border-top-color 0.35s ease, visibility 0s linear 0.35s;
}
.section.faq .faq_list details[open] .faq_answer{
    max-height: 100rem;
    opacity: 1;
    visibility: visible;
    padding: 2.4rem 16rem 2.4rem 3.2rem;
    box-shadow: inset 0px 0.3rem 0.5rem 0px rgba(0, 0, 0, 0.3);
}
.section.faq .faq_list .faq_answer p{
    margin: 0;
    padding-left: 9.5rem;
    font-size: 2rem;
    line-height: 1.55;
    font-feature-settings: "palt" 1;
}
.section.faq .faq_list .faq_answer::before{
    content: "A";
    position: absolute;
    left: 3rem;
    top: 2.4rem;
    width: auto;
    height: auto;
    border-radius: 0;
    background: transparent;
    color: #2a3054;
    font-weight: 700;
    -webkit-transform: scale(4.5);
    transform: scale(4.5);
    -webkit-transform-origin: left top;
    transform-origin: left top;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

/* SP用スタイル (index.cssからの非重複分) */
@media screen and (max-width:767px) {

    .info {
        max-width: 100%;
    }
    .info .sp {
        display: inline-block;
    }
    .info .pc {
        display: none;
    }

    /*KeyVisual部*/
    .KV .pc {
        display: none;
    }
    .KV .sp {
        display: inline-block;
    }
    .KV_CTA_sp {
        position: absolute;
        bottom: 8%;
        left: 20%;
        transform: translateX(-12.5%);
        z-index: 1;
    }
    .KV_CTA_sp img {
        width: min(82.67vw,62rem);
        box-sizing: border-box;
    }
    
    /*フローティングバナー部*/
    .mv__label {
        margin: 17.0666666667vw auto 0;
        width: 41.8666666667vw;
        height: 105.8666666667vw;
    }
    .mv__label__title {
        font-size: 3.4666666667vw;
        line-height: 1.19;
    }
    .mv__label__title .mvlogo {
        margin-bottom: 1em;
    }
    .mv__detail {
        width: auto;
        margin: 0;
        padding: 8.2666666667vw 11.0666666667vw 0;
        background: url('https://bso.benesse.ne.jp/miraiseed/fansite/summit/assets/img/bg09_sp.png') no-repeat center top/100% auto
    }
    .mv__detail__ttl {
        padding: 0 0 0.8em;
        font-size: 4.8vw;
    }
    .mv__detail__lead {
        padding: 0 0 1.3em;
        font-size: 3.4666666667vw;
        font-weight: 700;
        line-height: 1.76;
    }
    .mv__detail__ft {
        position: relative;
        padding: 2.4vw 29.3333333333vw 0;
    }
    .mv__detail__ft:before {
        content: "";
        position: absolute;
        display: block;
        left: 0;
        top: 0;
        width: 100%;
        height: 0.2666666667vw;
        background: -webkit-gradient(linear,left top,right top,from(#e47c00),to(#ff86d4));
        background: linear-gradient(to right,#e47c00,#ff86d4)
    }
    .mv__join {
        right: 2.6666666667vw;
        bottom: 6.6666666667vw;
        width: 32vw;
    }
    .mv__join__btn {
        height: 32vw;
        padding: 2.6666666667vw 1.3333333333vw 0 0;
        -webkit-box-shadow: 1.3333333333vw 1.3333333333vw 0.8vw rgba(0, 0, 0, 0.3);
        box-shadow: 1.3333333333vw 1.3333333333vw 0.8vw rgba(0, 0, 0, 0.3);
    }
    .mv__join__btn span {
        font-size: 3.7333333333vw;
    }
    .mv__join__btn span b {
        font-size: 4.8vw;
    }
    .mv__join__btn:after {
        right: 3.7333333333vw;
        width: 2.2666666667vw;
        height: 2.2666666667vw;
        border-top-width: 0.3376vw;
        border-right-width: 0.3376vw;
    }
    .mv__join__btn .label {
        top: 2.4vw;
        min-width: 25.52vw;
        height: 5.1066666667vw;
        font-size: 3.0666666667vw;
    }

    .section.sp .arar{
        padding: 0;
    }
    .section.sp .arar .arar_CTA{
        position: relative;
    }
    .section.sp .arar .arar_CTA a{
        position: absolute;
        z-index: 1;
        width: 90%;
        top: 0;
        left: 5%;
    }

    /* FAQ list (SP) */
    .section.faq .faq_container{
        padding: 8vw 0 16vw; 
    }

    .section.faq .faq_list{
        width: 90%;
        max-width: 65.9rem;
        margin: 6.4vw auto 0;
    }
    .section.faq .faq_list summary{ 
        padding: 4.8vw 17.2vw 4.8vw 4.8vw;
    }
    .section.faq .faq_list .faq_question{
        padding-left: 10vw;
        line-height: 1.4;
    }
    .section.faq .faq_list .faq_question::before{
        width: 9.36vw;
        height: auto;
        top: -4.8vw;
        bottom: -4.8vw;
        left: -4.8vw;
        border-radius: 0.4rem 0 0 0.4rem;
    }
    .section.faq .faq_list .faq_question::after{
        left: -4.68vw;
        width: 9.36vw;
        -webkit-transform: translateY(-50%) scale(3.25);
        transform: translateY(-50%) scale(3.25);
    }
    .section.faq .faq_list summary::after{
        right: 4.0vw;
        width: 9.0vw;
        height: 9.0vw;
        background: transparent;
        border-radius: 0;
        font-size: 9.0vw;
    }
    .section.faq .faq_list .faq_question_text{
        font-size: 4.2666666667vw;
    }
    .section.faq .faq_list details[open] .faq_answer{
        padding: 4.8vw;
    }
    .section.faq .faq_list .faq_answer p{
        padding-left: 10vw;
        font-size: 3.6vw;
    }
    .section.faq .faq_list .faq_answer::before{
        left: 3.3vw;
        top: 4.8vw;
        width: auto;
        height: auto;
        -webkit-transform: scale(4);
        transform: scale(4);
        background: transparent;
        border-radius: 0;
    }

    /* FAQ list (SP) */
    .section.faq{
        max-width: 75rem;
    }
}
