.page-subtitle {
  font-size: 22px;
  font-weight: 700;
  line-height: 33px;
  margin-bottom: 27px;
}
@media screen and (min-width: 768px) {
  .page-subtitle {
    font-size: 26px;
    line-height: 39px;
    margin-bottom: 30px;
  }
}

.page-sub2title {
  font-size: 22px;
  font-weight: 700;
  line-height: 33px;
  margin-bottom: 33px;
}
@media screen and (max-width: 767.98px) {
  .page-sub2title {
    margin-bottom: 13px;
  }
}

@media screen and (max-width: 767.98px) {
  .sp-negative {
    margin-right: -15px;
    margin-left: -15px;
  }
}

@media screen and (min-width: 768px) {
  .detailed-contents {
    margin-bottom: 100px;
  }
}
@media screen and (max-width: 767.98px) {
  .detailed-contents {
    margin-bottom: 60px;
  }
}
.detailed-contents > h2 {
  font-size: 18px;
  line-height: 27px;
}
@media screen and (min-width: 768px) {
  .detailed-contents > h2 {
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 767.98px) {
  .detailed-contents > h2 {
    margin-bottom: 15px;
  }
}
.detailed-contents > h3:not([class]) {
  display: block;
  font-size: 16px;
  line-height: 24px;
  margin-bottom: 10px;
}
.detailed-contents > p:not([class]) {
  margin-bottom: 20px;
}

.table-confirmation {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .table-confirmation {
    border: 1px solid #C0C5CB;
  }
}
@media screen and (max-width: 767.98px) {
  .table-confirmation {
    border-top: 1px solid #C0C5CB;
    border-bottom: 1px solid #C0C5CB;
  }
}
@media screen and (min-width: 768px) {
  .table-confirmation tr:not(:last-child) {
    border-bottom: 1px solid #C0C5CB;
  }
}
@media screen and (max-width: 767.98px) {
  .table-confirmation tr {
    display: flex;
    flex-direction: column;
  }
}
@media screen and (max-width: 767.98px) {
  .table-confirmation tr:not(:first-child) {
    border-top: 1px solid #C0C5CB;
  }
}
.table-confirmation th {
  background-color: #F5F8FB;
  padding: 10px 20px;
  text-align: left;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .table-confirmation th {
    padding: 23px 20px;
    width: 310px;
  }
}
.table-confirmation td {
  padding: 10px 20px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .table-confirmation td {
    padding: 23px 20px;
    width: calc(100% - 310px);
  }
}
@media screen and (min-width: 768px) {
  .table-confirmation.ol-table {
    border: none;
    display: flex;
  }
}
@media screen and (min-width: 768px) {
  .table-confirmation.ol-table tbody {
    display: flex;
    gap: 30px;
  }
}
@media screen and (min-width: 768px) {
  .table-confirmation.ol-table tbody tr {
    border: none;
    display: flex;
    flex-direction: column;
    width: 33.3333333333%;
  }
}
@media screen and (min-width: 768px) {
  .table-confirmation.ol-table tbody th, .table-confirmation.ol-table tbody td {
    width: 100%;
  }
}
@media screen and (min-width: 768px) {
  .table-confirmation.ol-table tbody th {
    border: 1px solid #C0C5CB;
    padding: 8px 15px;
  }
}
@media screen and (min-width: 768px) {
  .table-confirmation.ol-table tbody td {
    padding: 20px 0;
  }
}
.table-confirmation.ol-table tbody .gap-10 {
  display: flex;
  align-items: flex-start;
  justify-content: center;
}
.table-confirmation.ol-table tbody .gap-10 .bg-g500 {
  display: flex;
  justify-content: center;
  padding: 10px;
}
.table-confirmation.ol-table tbody .gap-10 > div:first-child {
  width: 45%;
}
.table-confirmation.ol-table tbody .gap-10 > div:last-child {
  width: 55%;
}
.table-confirmation .bg-info {
  display: flex;
  align-items: center;
}

.stack {
  gap: 20px;
  position: relative;
}
.stack .link-color.fs-14 {
  font-weight: 700;
  position: relative;
}
@media screen and (max-width: 767.98px) {
  .stack .link-color.fs-14 {
    margin-top: 10px;
  }
}
@media screen and (min-width: 768px) {
  .stack .btn ~ .link-color.fs-14 {
    position: absolute;
    left: 0;
  }
}
.stack .ic-arrow-back {
  margin-right: 10px;
  height: 14px;
  width: 14px;
}
.stack .ic-arrow-back::after {
  height: 14px;
  width: 14px;
}
.stack .btn {
  height: 54px;
  max-width: 320px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .stack .btn {
    height: 54px;
  }
}

.qalist > li {
  padding-top: 50px;
}
.qalist > li p.flex {
  width: 100%;
}
@media screen and (max-width: 767.98px) {
  .qalist > li p.flex {
    display: inline;
  }
}
.qalist > li > dl > dt {
  background-color: #F5F8FB;
  border: 1px solid #C0C5CB;
  font-weight: 700;
  margin-bottom: 15px;
  padding: 12px 15px;
}
@media screen and (min-width: 768px) {
  .qalist > li > dl > dt {
    margin-bottom: 20px;
  }
}
@media screen and (min-width: 768px) {
  .qalist > li > dl > dd {
    padding-left: 40px;
  }
}
.qalist > li > dl > dd > div {
  display: block;
  margin-top: 5px;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .qalist > li > dl > dd > div {
    padding-left: 23px;
  }
}
.qalist > li .q {
  color: #3498DB;
  padding-right: 5px;
}
.qalist > li .a {
  color: #3498DB;
  font-weight: 700;
  padding-right: 5px;
}

.helpmenu {
  display: flex;
}
@media screen and (max-width: 767.98px) {
  .helpmenu {
    flex-direction: column;
  }
}
@media screen and (min-width: 768px) {
  .helpmenu {
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
.helpmenu li {
  background-image: url("data:image/svg+xml, %3csvg width='14' height='14' viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.5977 4.19971L6.99766 9.79971L1.39766 4.19971' stroke='%23989BA1' stroke-width='2'/%3e%3c/svg%3e");
  background-size: 14px 14px;
  background-repeat: no-repeat;
  background-position: right 12px center;
  border-bottom: 1px solid #C0C5CB;
  padding: 20px 30px 20px 0;
}
@media screen and (min-width: 768px) {
  .helpmenu li {
    width: calc(50% - 15px);
  }
}
.helpmenu li:first-child {
  border-top: 1px solid #C0C5CB;
}
@media screen and (min-width: 768px) {
  .helpmenu li:nth-child(2) {
    border-top: 1px solid #C0C5CB;
  }
}

.dl-table {
  border: 1px solid #C0C5CB;
  display: inline-flex;
  flex-wrap: wrap;
  margin: 20px 0;
}
.dl-table dt {
  background-color: #F5F8FB;
  border-bottom: 1px solid #C0C5CB;
  font-weight: 700;
  padding: 8px 10px;
  width: 100%;
}
.dl-table dd {
  padding: 8px 10px;
  width: 33.3333333333%;
}
.dl-table dd:not(:last-child) {
  border-right: 1px solid #C0C5CB;
}/*# sourceMappingURL=detailed.css.map */