@charset "utf-8";
.l-contents {
  padding-bottom: 50px;
}
.l-inner-wrap > section + section {
  margin-top: 60px;
}

.l-inner-wrap > .home-about {
  margin-top: 50px;
}

.home-intro {
  padding: 50px 0 0;
}
.home-intro .home-intro-row {
  display: flex;
  flex-wrap: nowrap;
  gap: 0 16px;
}
.home-intro .home-hero {
  width: 68%;
  max-width: 640px;
}
.home-intro .home-hero img {
  width: 100%;
}
.home-intro .home-hero picture {
  display: block;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid #e4e5e5;
}
.home-intro .home-link {
  flex: 1;
}
.home-intro .home-link-list > li + li {
  margin-top: 16px;
}
.home-intro .home-link-box {
  display: flex;
  flex-wrap: nowrap;
  padding: 20px 16px 16px 20px;
  border-radius: 10px;
  overflow: hidden;
  background-color: #eef0fd;
  border: 1px solid #c7cdf7;
}
.home-intro .home-link-box-img {
  width: 33%;
  max-width: 94px;
  border-radius: 2px;
  overflow: hidden;
}
.home-intro .home-link-box-img img {
  width: 100%;
}
.home-intro .home-link-box-desc {
  flex: 1;
  padding-left: 18px;
}
.home-intro .home-link-box-ttl {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.44;
  position: relative;
  top: -4px;
  color: #485cc7;
}
.home-intro .home-link-box-txt {
  font-size: 1.4rem;
  line-height: 1.57;
  color: #333;
}
.home-intro .home-link-box.is-sche {
  background-color: #fbe9e9;
  border-color: #f2bebe;
}
.home-intro .home-link-box.is-sche .home-link-box-ttl {
  color: #f67979;
}

.home-heading-v2 {
  position: relative;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.2;
  color: #333;
  margin-bottom: 30px;
  padding-bottom: 22px;
  border-bottom: 4px solid #00bce3;
}
.home-heading-v2::after {
  content: "";
  position: absolute;
  bottom: 4px;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #00bce3;
}

.home-section-inner {
  width: 100%;
  max-width: 940px;
  margin: 0 auto;
  border-radius: 10px;
}

.home-section-inner.is-bg {
  border: 1px solid #e4e5e5;
  background-color: #fff;
}

.home-about .home-section-inner {
  padding: 28px 36px 30px 40px;
}

.home-about-ttl {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  color: #ff8f1c;
  margin-bottom: 21px;
}

.home-about-list-pc {
  display: flex;
  flex-wrap: wrap;
  gap: 30px 28px;
  width: 100%;
  font-size: 1.6rem;
  line-height: 1.625;
}
.home-about-list-pc > li:nth-child(2n-1) {
  width: calc(50% - 14px - 1%);
}
.home-about-list-pc > li:nth-child(2n) {
  width: calc(50% - 14px);
}
.home-about-list-sp {
  display: none;
}
.home-list-check {
  position: relative;
  padding-left: 34px;
}

.home-list-check::before {
  content: "";
  position: absolute;
  top: 0.3em;
  left: 0;
  width: 22px;
  height: 24px;
  background: url(/assets/img/common/ico-check.png) 0 0 no-repeat;
  background-size: contain;
}

.home-list-note {
  font-size: 1.3rem;
  line-height: 1.57;
  margin-top: 5px;
}

.home-flow-list > li {
  position: relative;
}
.home-flow-list > li + li {
  margin-top: 64px;
}
.home-flow-list > li + li::before {
  content: "";
  position: absolute;
  top: -44px;
  left: 0;
  right: 0;
  margin: auto;
  width: 48px;
  height: 25px;
  background: url(/assets/img/common/obj-arrow.png) 0 0 no-repeat;
  background-size: contain;
}

.home-flow-unit {
  display: flex;
  flex-wrap: nowrap;
}
.home-flow-unit > dt {
  border-radius: 10px 0 0 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  width: 60px;
  font-size: 3.2rem;
  font-weight: 500;
  color: #fff;
  background-color: #485cc7;
}
.home-flow-unit > dd {
  border-radius: 0 10px 10px 0;
  flex: 1;
  padding: 21px 30px 20px 34px;
  background-color: #fff;
  border: 1px solid #e4e5e5;
  border-left: none;
}
.home-flow-unit .home-flow-unit-row {
  display: flex;
  flex-wrap: nowrap;
  width: 100%;
}
.home-flow-unit .home-flow-unit-body {
  flex: 1;
}
.home-flow-unit .home-flow-unit-pic {
  width: 197px;
  padding-left: 5.1%;
}
.home-flow-unit .home-flow-unit-ttl {
  font-size: 2.2rem;
  font-weight: 700;
  padding-bottom: 16px;
  margin-bottom: 18px;
  color: #485cc7;
  border-bottom: 1px solid #485cc7;
}
.home-flow-unit .home-flow-unit-txt {
  font-size: 1.6rem;
  line-height: 1.75;
}
.home-flow-unit .home-flow-unit-note {
  font-size: 1.4rem;
  margin-top: 5px;
}

.home-flow-unit .home-flow-unit-img img {
  max-width: 140px;
  width: 100%;
}

.home-flow-unit.is-unit2 .home-flow-unit-img {
  padding-top: 10px;
}

.home-flow-unit.is-unit4 .home-flow-unit-img {
  padding-top: 10px;
  padding-left: 22px;
}

.home-flow-unit.is-unit2 > dt {
  background-color: #f2b737;
}

.home-flow-unit.is-unit2 .home-flow-unit-ttl {
  color: #f2b737;
  border-color: #f2b737;
}

.home-flow-unit.is-unit3 > dt {
  background-color: #f67979;
}

.home-flow-unit.is-unit3 .home-flow-unit-ttl {
  color: #f67979;
  border-color: #f67979;
}

.home-flow-unit.is-unit4 > dt {
  background-color: #00bce3;
}

.home-flow-unit.is-unit4 .home-flow-unit-ttl {
  color: #00bce3;
  border-color: #00bce3;
}

.home-qa .home-section-inner {
  padding: 39px;
}
.home-qa .home-qa-row {
  display: flex;
  flex-wrap: nowrap;
}
.home-qa .home-qa-main {
  width: 50%;
  padding-right: 3.3%;
  border-right: 1px solid #d6d8d9;
}
.home-qa .home-qa-other {
  width: 50%;
  padding-left: 3.3%;
}
.home-qa .home-qa-question {
  position: relative;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.625;
  text-align: left;
  padding-left: 40px;
  color: #ff8f1c;
}
.home-qa .home-qa-question::before {
  position: absolute;
  top: 0;
  bottom: 0.2em;
  left: 0;
  margin: auto;
  content: "Q";
  height: 4rem;
  font-size: 4rem;
  font-weight: 500;
  line-height: 1;
  color: #ff8f1c;
}
.home-qa .home-qa-other .home-qa-question {
  font-size: 1.6rem;
  max-width: 290px;
}
.home-qa .home-qa-answer {
  margin-top: 30px;
  position: relative;
  font-size: 1.6rem;
  line-height: 1.75;
  text-align: left;
  padding-left: 40px;
}
.home-qa .home-qa-answer::before {
  position: absolute;
  top: -0.15em;
  left: 0;
  content: "A";
  height: 4rem;
  font-size: 4rem;
  font-weight: 500;
  line-height: 1;
  color: #f7d4af;
}
.home-qa .home-qa-note {
  font-size: 1.4rem;
}
.home-qa .home-qa-other-ttl {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1;
  padding-top: 7px;
}
.home-qa .home-qa-other-list > li {
  padding: 20px 0;
}
.home-qa .home-qa-other-list > li + li {
  border-top: 1px dashed #d6d8d9;
}
.home-qa .home-qa-other-btn {
  position: relative;
}
.home-qa .home-qa-other-btn-ico {
  position: absolute;
  top: 0.7em;
  bottom: 0;
  right: 0;
  margin: auto;
  display: block;
  width: 16%;
  max-width: 70px;
  height: 1px;
  background-color: #485cc7;
}
.home-qa .home-qa-other-btn-ico::before {
  position: absolute;
  right: -1px;
  bottom: 4px;
  content: "";
  display: block;
  width: 11px;
  height: 1px;
  background-color: #485cc7;
  transform: rotate(45deg);
}

.home-support .home-support-list {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
}
.home-support .home-support-list > li {
  width: calc(50% - 15px);
}
.home-support .home-support-list a {
  cursor: pointer;
}
.home-support .home-support-bnr {
  border-radius: 10px;
  overflow: hidden;
}
.home-support .home-support-bnr img {
  width: 100%;
}
.home-support .home-support-bnr.is-border {
  border: 1px solid #e4e5e5;
}

@media screen and (min-width: 769px) and (max-width: 920px) {
  .home-intro .home-intro-row {
    display: block;
  }
  .home-intro .home-hero {
    width: 100%;
    max-width: 100%;
    margin-bottom: 16px;
  }
  .home-intro .home-link-list {
    display: flex;
    flex-wrap: nowrap;
    gap: 16px;
  }
  .home-intro .home-link-list > li + li {
    margin-top: 0;
  }
  .home-intro .home-link-list > li {
    display: flex;
    width: 50%;
  }
  .home-intro .home-link-list > li > a {
    display: flex;
  }
}
@media screen and (max-width: 768px) {
  .l-contents {
    padding-bottom: 40px;
  }
  .l-inner-wrap > section + section {
    margin-top: 50px;
  }
  .l-inner-wrap > .home-about {
    margin-top: 25px;
  }
  .home-intro {
    padding: 15px 0 0;
  }
  .home-intro .home-intro-row {
    display: block;
  }
  .home-intro .home-hero {
    width: 100%;
    max-width: none;
  }
  .home-intro .home-hero picture {
    border-radius: 5px;
  }
  .home-intro .home-link-list {
    margin-top: 15px;
  }
  .home-intro .home-link-list > li + li {
    margin-top: 15px;
  }
  .home-intro .home-link-list a {
    cursor: pointer;
  }
  .home-intro .home-link-box {
    padding: 14px;
    border-radius: 5px;
  }
  .home-intro .home-link-box-img {
    width: 30%;
    max-width: 190px;
  }
  .home-intro .home-link-box-desc {
    padding-left: 15px;
  }
  .home-intro .home-link-box-ttl {
    font-size: 1.5rem;
  }
  .home-heading-v2 {
    font-size: 1.9rem;
    margin-bottom: 20px;
    padding-bottom: 15px;
  }
  .home-section-inner {
    max-width: 100%;
    border-radius: 5px;
  }
  .home-about .home-section-inner {
    padding: 15px 15px 20px;
  }
  .home-about-ttl {
    font-size: 1.6rem;
    line-height: 1.625;
  }
  .home-about-list-pc {
    display: none;
  }
  .home-about-list-sp {
    display: block;
    font-size: 1.4rem;
    line-height: 1.71;
  }
  .home-about-list-sp > li + li {
    margin-top: 20px;
  }
  .home-list-check {
    position: relative;
    padding-left: 30px;
  }
  .home-list-check::before {
    top: 0;
  }
  .home-list-note {
    font-size: 1.2rem;
  }
  .home-flow-list > li + li {
    margin-top: 55px;
  }
  .home-flow-list > li + li::before {
    top: -38px;
  }
  .home-flow-unit > dt {
    border-radius: 5px 0 0 5px;
    width: 40px;
    font-size: 2.4rem;
    font-weight: 500;
  }
  .home-flow-unit > dd {
    border-radius: 0 5px 5px 0;
    padding: 13px 15px 20px 15px;
  }
  .home-flow-unit .home-flow-unit-row {
    display: block;
  }
  .home-flow-unit .home-flow-unit-pic {
    width: 100%;
    padding-left: 0;
  }
  .home-flow-unit .home-flow-unit-ttl {
    font-size: 1.7rem;
    padding-bottom: 8px;
    margin-bottom: 8px;
  }
  .home-flow-unit .home-flow-unit-txt {
    font-size: 1.4rem;
    line-height: 1.71;
  }
  .home-flow-unit .home-flow-unit-note {
    font-size: 1.2rem;
    line-height: 1.9;
  }
  .home-flow-unit .home-flow-unit-img {
    padding: 0 28% 0 22%;
  }
  .home-flow-unit .home-flow-unit-img img {
    max-width: 100%;
    width: 100%;
  }
  .home-flow-unit.is-unit2 .home-flow-unit-img {
    padding-top: 0;
  }
  .home-flow-unit.is-unit4 .home-flow-unit-img {
    padding-top: 0;
    padding-left: 22%;
  }
  .home-qa .home-section-inner {
    padding: 15px 15px 0;
  }
  .home-qa .home-qa-row {
    display: block;
  }
  .home-qa .home-qa-main {
    width: 100%;
    padding-right: 0;
    border-right: none;
  }
  .home-qa .home-qa-other {
    border-top: 1px solid #d6d8d9;
    width: 100%;
    padding-left: 0;
    margin-top: 20px;
  }
  .home-qa .home-qa-question {
    font-size: 1.6rem;
    line-height: 1.71;
    padding-left: 3.2rem;
  }
  .home-qa .home-qa-question::before {
    height: 3.2rem;
    font-size: 3.2rem;
  }
  .home-qa .home-qa-other .home-qa-question {
    font-size: 1.4rem;
    max-width: 100%;
  }
  .home-qa .home-qa-answer {
    margin-top: 20px;
    font-size: 1.4rem;
    line-height: 1.71;
    padding-left: 3.2rem;
  }
  .home-qa .home-qa-answer::before {
    top: -0.23em;
    height: 3.2rem;
    font-size: 3.2rem;
  }
  .home-qa .home-qa-note {
    font-size: 1.2rem;
  }
  .home-qa .home-qa-other-ttl {
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1;
    padding-top: 20px;
  }
  .home-qa .home-qa-other-btn {
    padding-bottom: 10px;
    min-height: 44px;
  }
  .home-qa .home-qa-other-btn-ico {
    top: auto;
    bottom: 0;
    width: 22%;
    max-width: 130px;
  }
  .home-support .home-support-list {
    display: block;
  }
  .home-support .home-support-list > li {
    width: 100%;
  }
  .home-support .home-support-list > li + li {
    margin-top: 15px;
  }
  .home-support .home-support-bnr {
    border-radius: 5px;
  }
}