@charset "UTF-8";
/* CSS Document */
h2 {
  font-size: 5rem;
  font-weight: 700;
  line-height: 1.2;
  color: #353B5B;
}
h2 span {
  font-size: 2.8rem;
  font-weight: 400;
}
h2 .left {
  padding-left: 5px;
}

.catch {
  text-align: end;
  font-size: 2.6rem;
  font-weight: 700;
  color: #353B5B;
  padding-bottom: 10px;
}

.sp-br {
  display: none;
}

.page-link {
  margin: 120px auto;
}
.page-link ul {
  display: flex;
  justify-content: space-between;
}
.page-link li {
  width: 30%;
}
.page-link p {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  position: relative;
  color: #353B5B;
  font-size: 2rem;
  font-weight: 700;
  border-bottom: solid 1px #F9CED9;
  width: 85%;
  line-height: 1.8;
}
.page-link p::after {
  content: "";
  display: inline-block;
  width: 35px;
  height: 35px;
  background-image: url(../../images/btn__more.webp);
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  right: -40px;
}
.page-link.under {
  width: 90%;
  max-width: 1060px;
}

@media screen and (max-width: 767px) {
  h2 {
    font-size: max(5vw, 2.8rem);
  }
  h2 span {
    font-size: max(2.6vw, 1.2rem);
  }
  .catch {
    font-size: 1.8rem;
  }
  .sp-br {
    display: inline-block;
  }
  .page-link {
    margin: 60px auto;
  }
  .page-link ul {
    flex-direction: column;
    gap: 15px;
  }
  .page-link li {
    width: 100%;
    gap: 0;
  }
  .page-link p {
    font-size: 1.4rem;
    width: 87%;
    line-height: 2;
  }
  h3 {
    font-size: 2.6rem;
  }
}
.top {
  margin: 150px auto 0;
  width: 90%;
  max-width: 1060px;
}

@media screen and (max-width: 767px) {
  .top {
    margin: 80px auto 0;
    max-width: 500px;
  }
}
.section-wrap {
  width: 100%;
  margin: 70px auto 150px;
  background: linear-gradient(90deg, #fff 0%, #fff 50%, #f9ced9 50%, #f9ced9 100%);
  overflow: hidden;
}
.section-wrap .background {
  background-color: #F9CED9;
  width: 90%;
  max-width: 1300px;
  margin: 0 auto;
  border-radius: 100px 0 0 100px;
}
.section-wrap .inner {
  width: 80%;
  max-width: 950px;
  margin: 0 auto;
  padding: 100px 0;
}
.section-wrap .topwrap {
  margin: 100px auto 80px;
}
.section-wrap .under_wrap {
  background-color: #fff;
  border-radius: 20px;
}
.section-wrap .under_wrap.second {
  margin-top: 100px;
}
.section-wrap .under_wrap_inner {
  width: 90%;
  margin: 0 auto;
  padding: 80px 0;
}
.section-wrap h4 {
  font-size: 2.6rem;
  font-weight: 700;
  color: #353B5B;
  margin-bottom: 40px;
  display: flex;
  align-items: center;
  gap: 10px;
  border-bottom: solid 2px #f5f5f5;
}
.section-wrap h4::before {
  content: "";
  display: inline-block;
  width: 15px;
  height: 15px;
  background-color: #F9CED9;
  border-radius: 100px;
}
.section-wrap .exsample {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 40px;
}
.section-wrap .exsample ul {
  display: flex;
  width: 90%;
  flex-wrap: wrap;
  gap: 35px;
  row-gap: 10px;
}
.section-wrap .exsample li {
  background-color: #F9CED9;
  border-radius: 50px;
  color: #353B5B;
  padding: 5px 10px;
}
.section-wrap .exsample p {
  font-weight: 700;
  color: #353B5B;
}
.section-wrap .img-wrap {
  display: flex;
  justify-content: center;
  align-items: end;
  flex-wrap: wrap;
  margin-top: 80px;
}
.section-wrap .img-wrap img {
  -o-object-fit: contain;
     object-fit: contain;
  width: 60%;
}
.section-wrap .area-wrap {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  max-width: 320px;
}
.section-wrap .area-wrap .list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 210px;
}
.section-wrap .area-wrap .parent {
  font-weight: 700;
}
.section-wrap .area-wrap p {
  width: 50px;
  height: 50px;
  border-radius: 100px;
  font-size: 1.4rem;
  font-weight: 600;
  text-align: center;
  color: #fff;
  background-color: #353B5B;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: 20px;
}
.section-wrap .area-wrap p span {
  font-size: 1.2rem;
}
.section-wrap .child {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.section-wrap .child li {
  font-weight: 400;
}
.section-wrap .vehicle {
  margin-top: 80px;
}
.section-wrap .vehicle h5 {
  font-size: 1.8rem;
  font-weight: 700;
  color: #353B5B;
}
.section-wrap .vehicle .img-wrap {
  flex-wrap: unset;
  justify-content: space-between;
  margin-top: 50px;
}
.section-wrap .vehicle .img-wrap img {
  aspect-ratio: 3/2;
  -o-object-fit: cover;
     object-fit: cover;
  width: 48%;
}
.section-wrap .vehicle .vehicle-list {
  width: 50%;
  margin: 50px 0 0 auto;
}
.section-wrap .vehicle ul {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.section-wrap .vehicle li {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.section-wrap .vehicle li span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 60%;
}
.section-wrap .vehicle li span::before {
  content: "";
  display: block;
  width: 80%;
  height: 1px;
  border-bottom: 1px dashed #333333;
}
.section-wrap .iron-img img {
  margin-top: 40px;
}

#iron {
  scroll-margin-top: 100px;
}

@media screen and (max-width: 767px) {
  .section-wrap {
    margin: 60px auto;
    background: unset;
    overflow: unset;
  }
  .section-wrap .background {
    width: 100%;
    border-radius: 30px 0 0 30px;
  }
  .section-wrap .inner {
    width: 100%;
    max-width: 500px;
    padding: 80px 0;
  }
  .section-wrap .sp-top {
    width: 90%;
    margin: 0 auto;
  }
  .section-wrap .topwrap {
    margin: 50px auto 70px;
  }
  .section-wrap .under_wrap {
    border-radius: 20px 20px 0 0;
  }
  .section-wrap .under_wrap.second {
    margin-top: 70px;
  }
  .section-wrap .under_wrap_inner {
    padding: 50px 0;
  }
  .section-wrap h4 {
    font-size: 1.8rem;
  }
  .section-wrap h4::before {
    width: 10px;
    height: 10px;
  }
  .section-wrap .exsample {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
  .section-wrap .exsample ul {
    width: 100%;
    flex-wrap: wrap;
    -moz-column-gap: 25px;
         column-gap: 25px;
  }
  .section-wrap .img-wrap {
    align-items: center;
    margin-top: 50px;
  }
  .section-wrap .img-wrap img {
    width: 100%;
  }
  .section-wrap .vehicle {
    width: 90%;
    margin: 50px auto 0;
  }
  .section-wrap .vehicle h5 {
    font-size: 1.4rem;
  }
  .section-wrap .vehicle .sp-flex {
    display: flex;
    flex-direction: column-reverse;
  }
  .section-wrap .vehicle .img-wrap {
    flex-direction: column;
    gap: 20px;
    margin-top: 30px;
  }
  .section-wrap .vehicle .img-wrap img {
    width: 100%;
  }
  .section-wrap .vehicle .vehicle-list {
    width: 100%;
    margin: 30px 0 0 auto;
  }
  .section-wrap .iron-img img {
    margin-top: 40px;
  }
  #iron {
    scroll-margin-top: 70px;
  }
}
.system {
  margin: 70px auto 100px;
}

.trouble {
  margin-bottom: 80px;
  padding-top: 70px;
}
.trouble .ttl-wrap {
  width: 570px;
  margin: 0 auto;
}
.trouble h4 {
  text-align: center;
  border-bottom: unset;
  display: block;
  margin-bottom: 20px;
}
.trouble h4::before {
  content: unset;
}
.trouble .trouble-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  row-gap: 30px;
  margin: 50px 0;
}
.trouble .trouble-wrap div {
  width: 47%;
  display: flex;
  align-items: center;
  gap: 10px;
  border-radius: 10px;
  border: solid 3px #fff;
  padding: 20px 35px;
}
.trouble .trouble-wrap img {
  width: 30%;
}
.trouble .label {
  width: 565px;
  border-radius: 50px;
  background-color: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
  font-size: 2rem;
  text-align: center;
  padding: 15px 0;
  margin: 0 auto 40px;
  color: #353B5B;
}
.trouble .label span {
  color: #95A5FF;
}
.trouble .b-txt {
  font-size: 2.4rem;
  text-align: center;
  color: #353B5B;
}
.trouble .b-txt span {
  font-size: 3.2rem;
  font-weight: 700;
}

@media screen and (max-width: 767px) {
  .trouble {
    padding-top: 0;
    margin-bottom: 60px;
  }
  .trouble .ttl-wrap {
    width: 90%;
    max-width: 500px;
  }
  .trouble .trouble-wrap {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: center;
    row-gap: 15px;
    margin: 30px 0 50px;
  }
  .trouble .trouble-wrap div {
    width: 90%;
  }
  .trouble .label {
    width: 275px;
    font-size: 1.2rem;
    padding: 10px 0;
    margin: 0 auto 30px;
  }
  .trouble .b-txt {
    font-size: 1.8rem;
  }
  .trouble .b-txt span {
    font-size: 1.8rem;
  }
}
.under_wrap .des {
  margin-top: 30px;
}
.under_wrap .checklist {
  width: 90%;
  margin: 40px auto 0;
  font-size: min(2.3vw, 2.4rem);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  row-gap: 20px;
  font-weight: 700;
}
.under_wrap .checklist p {
  width: 47%;
  display: flex;
  align-items: center;
}
.under_wrap .checklist p::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  background-image: url("../../images/check.png");
  background-size: contain;
  background-repeat: no-repeat;
  margin-right: 10px;
}

@media screen and (max-width: 767px) {
  .under_wrap .des {
    margin-top: 30px;
  }
  .under_wrap .checklist {
    width: 100%;
    flex-wrap: nowrap;
    flex-direction: column;
    font-size: 1.4rem;
    font-weight: 400;
  }
  .under_wrap .checklist p {
    width: 100%;
  }
}
.reason {
  width: 100%;
  background-color: #F8F8FF;
  padding: 50px 0 30px;
  position: relative;
}
.reason .polygon {
  display: block;
  width: 80%;
  max-width: 1060px;
}
.reason .reason-inner {
  width: 90%;
  max-width: 885px;
  margin: 70px auto 0;
}
.reason h3 {
  display: flex;
  align-items: end;
  justify-content: center;
  width: 100%;
  background-image: url("../../images/reason-line.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: bottom;
  margin-bottom: 60px;
}
.reason h3 span {
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
.reason h3 .flex {
  display: flex;
  flex-direction: column;
  padding-bottom: 6px;
}
.reason h3 .b {
  font-size: 4rem;
}
.reason h3 .s {
  font-size: 1.6rem;
}
.reason .three {
  font-size: 12.8rem;
  font-weight: 700;
  color: #95A5FF;
  line-height: 0;
  letter-spacing: 0;
  padding: 0 5px;
}
.reason .point-ttl {
  display: flex;
  align-items: flex-end;
  justify-content: space-evenly;
  background-image: url("../../images/Union.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: bottom;
  padding-bottom: 15px;
}
.reason .point-ttl h5 {
  font-size: 2.6rem;
  font-weight: 700;
  color: #353B5B;
}
.reason .point-ttl div {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.reason .point-ttl .pink {
  background-color: #F9CED9;
  border-radius: 50px;
  font-size: 2rem;
  font-weight: 700;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.reason ol {
  display: flex;
  justify-content: space-between;
}
.reason li {
  width: 30%;
}
.reason li p {
  margin-top: 25px;
}
.reason .pink-wrap {
  background-image: url("../../images/back.webp");
  background-size: contain;
  background-repeat: no-repeat;
  width: 720px;
  aspect-ratio: 5/1;
  margin: 70px auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.reason .pink-wrap p {
  width: -moz-fit-content;
  width: fit-content;
  font-size: 2.4rem;
}
.reason .bold {
  font-weight: 700;
}

@media screen and (max-width: 767px) {
  .reason {
    width: 100%;
    background-color: #F8F8FF;
    padding: 50px 0 30px;
    position: relative;
  }
  .reason .polygon {
    display: block;
    width: 80%;
    max-width: 1060px;
  }
  .reason .reason-inner {
    width: 90%;
    max-width: 500px;
    margin: 70px auto 0;
  }
  .reason h3 {
    margin-bottom: 50px;
  }
  .reason h3 span {
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 0.1em;
  }
  .reason h3 .flex {
    padding-bottom: 2px;
  }
  .reason h3 .b {
    font-size: 2.2rem;
  }
  .reason h3 .s {
    font-size: 1.2rem;
  }
  .reason .three {
    font-size: 5.4rem;
  }
  .reason .point-ttl {
    justify-content: flex-start;
    gap: 20px;
    padding: 0 10px 15px;
    background-image: url(../../images/Union_sp.png);
  }
  .reason .point-ttl h5 {
    font-size: 1.8rem;
  }
  .reason .point-ttl div {
    flex-direction: row;
    font-size: 1.2rem;
    padding-left: 10px;
    align-items: end;
    position: relative;
    z-index: 0;
  }
  .reason .point-ttl div::before {
    content: "";
    position: absolute;
    background-color: #F9CED9;
    border-radius: 50px;
    font-weight: 400;
    width: 30px;
    height: 30px;
    z-index: -1;
    left: 0;
  }
  .reason .point-ttl .pink {
    background-color: unset;
    font-size: 1.4rem;
    font-weight: 700;
    width: auto;
    height: auto;
    line-height: 1.3;
    padding-left: 2px;
  }
  .reason ol {
    flex-direction: column;
    gap: 40px;
  }
  .reason li {
    width: 100%;
  }
  .reason li p {
    width: -moz-fit-content;
    width: fit-content;
    margin: 15px auto 0;
  }
  .reason .pink-wrap {
    width: 100%;
    max-width: 500px;
    margin: 50px auto 0;
  }
  .reason .pink-wrap p {
    font-size: 1.4rem;
  }
}
.result {
  display: flex;
  justify-content: center;
  gap: 50px;
  width: 90%;
  margin: 150px auto 70px;
}
.result .navy {
  background-color: #353B5B;
  border-radius: 10px;
  padding: 5px 30px;
  color: #fff;
  text-align: center;
  width: 55%;
  max-width: 250px;
}
.result .percnt {
  font-size: 6.4rem;
  color: #95A5FF;
  line-height: 1;
  margin-top: 20px;
}
.result .percnt span {
  font-size: 12.8rem;
  font-weight: 700;
}
.result div p {
  text-align: center;
}
.result div p:nth-child(3) {
  font-size: 3.2rem;
  margin-bottom: 30px;
}
.result div p:nth-child(3) span {
  font-size: 1.4rem;
}
.result .bubble {
  position: relative;
}
.result .bubble::after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-color: transparent transparent #353B5B transparent;
  border-width: 0px 10px 14.43px 10px;
  position: absolute;
  top: -12px;
  left: 46%;
}
.result .circle-back {
  background-image: url("../../images/system-circle.webp");
  background-size: contain;
  background-repeat: no-repeat;
  width: 50%;
  aspect-ratio: 1/1;
  max-width: 500px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

@media screen and (max-width: 767px) {
  .result {
    width: 100%;
    max-width: 500px;
    margin: 80px auto 50px;
    gap: 5px;
  }
  .result .navy {
    width: 80%;
    max-width: 100%;
    padding: 5px 0;
  }
  .result .percnt {
    font-size: 3.2rem;
    margin-top: 10px;
  }
  .result .percnt span {
    font-size: 6.4rem;
  }
  .result div p:nth-child(3) {
    font-size: 2.6rem;
    margin-bottom: 15px;
  }
  .result div p:nth-child(3) span {
    font-size: 1.4rem;
  }
  .result .circle-back {
    background-size: cover;
    width: 50%;
    aspect-ratio: unset;
  }
}
.system-accordion {
  background: unset;
  overflow: unset;
}
.system-accordion .under_wrap {
  background-color: #F8F8FF;
  border-radius: 60px;
  max-width: 1300px;
  margin: 0 auto;
}
.system-accordion .under_wrap_inner {
  width: 90%;
  max-width: 1060px;
  padding: 80px 0;
}
.system-accordion h4 {
  border-bottom: unset;
}
.system-accordion .accordion-area {
  display: flex;
  flex-wrap: wrap;
  row-gap: 50px;
  justify-content: space-between;
}
.system-accordion .accordion-area .accordion {
  width: 45%;
}
.system-accordion .ttl-wrap {
  border: solid #353B5B;
  border-width: 2px 2px 2px 10px;
}
.system-accordion .ttl-wrap .title {
  font-size: 3.2rem;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px;
}
.system-accordion .ttl-wrap .title::after {
  position: absolute;
  right: 10px;
  content: "+";
  font-size: 2.8rem;
  font-weight: 400;
  color: #353B5B;
  width: 40px;
  height: 40px;
  border-radius: 50px;
  background-color: #F9CED9;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 5px;
}
.system-accordion .ttl-wrap.close .title::after {
  content: "－";
  padding-bottom: 0;
}
.system-accordion .box {
  display: none;
  padding: 10px 10px 10px 20px;
  border: dotted 1px #d9d9d9;
}
.system-accordion .box li {
  line-height: 2;
}
.system-accordion .box li::before {
  content: "・";
}
.system-accordion .under-des {
  margin-top: 50px;
}
.system-accordion .under-des span {
  font-weight: 700;
}

@media screen and (max-width: 767px) {
  .system-accordion {
    margin-bottom: 80px;
  }
  .system-accordion .under_wrap {
    border-radius: 0;
  }
  .system-accordion .under_wrap_inner {
    width: 90%;
    max-width: 500px;
    padding: 50px 0;
  }
  .system-accordion .accordion-area {
    flex-direction: column;
    flex-wrap: nowrap;
  }
  .system-accordion .accordion-area .accordion {
    width: 100%;
  }
  .system-accordion .ttl-wrap .title {
    font-size: 2.2rem;
  }
}
.system-line {
  width: 95%;
  max-width: 1060px;
  margin: 0 auto 250px;
}
.system-line h4 {
  font-size: 2.2rem;
  font-weight: 700;
  width: 95%;
  margin: 0 auto 70px;
  color: #353B5B;
}
.system-line ol {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-image: url("../../images/Rectangle.png");
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
}
.system-line li {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2%;
  border: solid 2px #353B5B;
  border-radius: 200px;
  width: 19%;
  aspect-ratio: 1/1;
  padding: 5px;
  background-color: #fff;
}
.system-line li p {
  font-weight: 700;
  font-size: min(2.1vw, 2.2rem);
  text-align: center;
}
.system-line li .number {
  font-size: min(2vw, 2.2rem);
  color: #95A5FF;
}
.system-line li img {
  height: 42%;
}
.system-line li:nth-child(2) {
  gap: 0;
}
.system-line .under-des {
  width: 95%;
  margin: 50px auto 0;
}

@media screen and (max-width: 767px) {
  .system-line {
    width: 90%;
    max-width: 500px;
    margin: 0 auto 150px;
  }
  .system-line h4 {
    font-size: 2.2rem;
    text-align: center;
    width: 100%;
    margin: 0 auto 30px;
  }
  .system-line ol {
    flex-direction: column;
    gap: 10px;
    background-image: url("../../images/Rectangle_sp.png");
  }
  .system-line li {
    gap: 5%;
    width: 210px;
    height: 210px;
  }
  .system-line li p {
    font-size: 1.8rem;
  }
  .system-line li .number {
    font-size: 2.4rem;
  }
  .system-line li img {
    height: 45%;
  }
  .system-line li:nth-child(2) {
    gap: 0;
  }
  .system-line .under-des {
    width: 95%;
    margin: 50px auto 0;
  }
}/*# sourceMappingURL=service.css.map */