@charset "UTF-8";

.p-service-ourservice .c-page-section__copy {
  margin-top: 49px;
}
.p-service-ourservice .c-page-section__desc {
  letter-spacing: 0.05em;
  margin-top: 33px;
}
.p-service-ourservice .c-page-section__notes {
  margin-top: 50px;
}
.p-service-ourservice .c-page-section__slide {
  margin-top: 60px;
}

.p-service-product .c-page-section__boxs {
  margin-top: 60px;
}
.p-service-product .c-page-section__notes {
  margin-top: 80px;
  padding: 18px 20px 18px 20px;
}

.p-service-flow {
  padding-bottom: 100px;
}

.p-service-flow__boxs {
  display: flex;
  flex-direction: column;
  gap: 26px;
  margin-top: 60px;
}

.p-service-flow__box {
  -moz-column-gap: 10px;
       column-gap: 10px;
  display: grid;
  grid-template-columns: auto auto;
  position: relative;
  row-gap: 20px;
}
.p-service-flow__box:not(:last-child)::after {
  background-color: #c7c7c7;
  bottom: 0;
  content: "";
  height: calc(100% - 54px);
  left: 19px;
  position: absolute;
  width: 1px;
}

.p-service-flow__box-num {
  align-items: center;
  background-color: #129294;
  border-radius: 50%;
  color: #fff;
  display: inline-flex;
  flex-shrink: 0;
  font-size: 22px;
  font-weight: bold;
  height: 38px;
  justify-content: center;
  text-shadow: 0 3px 6px rgba(106, 156, 222, 0.12);
  width: 38px;
}

.p-service-flow__box-title {
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: calc(32 / 22);
}

.p-service-flow__box-desc {
  font-size: 15px;
  font-weight: 500;
  margin-top: 10px;
}

.p-service-flow__box-img {
  aspect-ratio: 350/280;
  border-radius: 20px;
  box-shadow: 0 3px 6px 0 rgba(114, 160, 223, 0.33);
  flex-shrink: 0;
  grid-column: 2/3;
  margin-bottom: 34px;
  overflow: hidden;
  width: 100%;
}

@media (min-width: 414px) {
  .p-service-flow__box {
    -moz-column-gap: 20px;
         column-gap: 20px;
  }
}

@media (min-width: 1024px) {
  .p-service-ourservice .c-page-section__slide {
    margin-top: 100px;
  }
  .p-service-product .c-page-section__notes {
    padding: 18px 45px 18px 20px;
  }
  .p-service-flow {
    padding-bottom: 135px;
  }
  .p-service-flow__box {
    align-items: flex-start;
    display: flex;
    gap: 0;
  }
  .p-service-flow__box-texts {
    margin-left: calc(40 / 1366 * 100vw);
    margin-right: calc(66 / 1366 * 100vw);
    margin-top: 3px;
  }
  .p-service-flow__box-desc {
    line-height: calc(33 / 15);
    margin-top: 28px;
  }
  .p-service-flow__box-img {
    max-width: 350px;
    width: calc(350 / 1366 * 100vw);
  }
}

@media (min-width: 1366px) {
  .p-service-ourservice .c-page-section__desc {
    letter-spacing: normal;
  }
  .p-service-flow__box-texts {
    margin-left: 40px;
    margin-right: 50px;
  }
}