:root {
  --sds-typography-weight-semibold: 600;
}

.our-concept {
  background: #000005;
  color: #FFF;
}
.our-concept .inner {
  padding-block: 38px 145px;
}
@media screen and (max-width: 960px) {
  .our-concept .inner {
    padding-block: 40px;
  }
}

.our-concept__box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 100px;
}
@media screen and (max-width: 1366px) {
  .our-concept__box {
    gap: 7.3206442167vw;
  }
}
@media screen and (max-width: 960px) {
  .our-concept__box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.our-concept .section-title {
  margin-top: 100px;
}
@media screen and (max-width: 1366px) {
  .our-concept .section-title {
    margin-top: 7.3206442167vw;
  }
}
@media screen and (max-width: 1366px) and (min-width: 961px) {
  .our-concept .section-title .section-title--jp {
    padding-left: 9.663250366vw;
    font-size: 1.4641288433vw;
  }
  .our-concept .section-title .section-title--jp::before {
    width: 8.4919472914vw;
    height: 0.1464128843vw;
  }
}
.our-concept .section-title svg {
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}
@media screen and (max-width: 1366px) {
  .our-concept .section-title svg {
    max-width: 31.4787701318vw;
  }
}
@media screen and (max-width: 960px) {
  .our-concept .section-title svg {
    max-width: 200px;
  }
}
.our-concept .section-title .small {
  display: block;
  font-family: "Roboto Slab";
  font-size: 62px;
  font-style: normal;
  font-weight: 700;
  line-height: normal;
}
@media screen and (max-width: 1366px) {
  .our-concept .section-title .small {
    font-size: 4.5387994143vw;
  }
}
@media screen and (max-width: 960px) {
  .our-concept .section-title .small {
    font-size: 25px;
  }
}
.our-concept .section-title--jp::before {
  background: #fff;
}

.our-concept__emphasis {
  font-size: 31px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.1290322581;
}
@media screen and (max-width: 1366px) {
  .our-concept__emphasis {
    font-size: 2.2693997072vw;
  }
}
@media screen and (max-width: 960px) {
  .our-concept__emphasis {
    font-size: 20px;
  }
}
.our-concept__emphasis .bg-red {
  margin-top: 15px;
  padding: 7px 0 7px 16px;
  display: inline-block;
  background: #A32C00;
  font-size: 54px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.5555555556;
}
@media screen and (max-width: 1366px) {
  .our-concept__emphasis .bg-red {
    margin-top: 1.0980966325vw;
    padding: 0.5124450952vw 0 0.5124450952vw 1.1713030747vw;
    font-size: 3.953147877vw;
    white-space: nowrap;
  }
}
@media screen and (max-width: 960px) {
  .our-concept__emphasis .bg-red {
    margin-top: 15px;
    padding: 5px 0 5px 5px;
    font-size: 25px;
  }
}
.our-concept__emphasis .letter-spacing {
  letter-spacing: -20px;
}
@media screen and (max-width: 1366px) {
  .our-concept__emphasis .letter-spacing {
    letter-spacing: -1.4641288433vw;
  }
}
.our-concept__text {
  margin-top: 15px;
  line-height: 2.3125;
}
@media screen and (max-width: 1366px) {
  .our-concept__text {
    margin-top: 1.0980966325vw;
  }
}
@media screen and (max-width: 960px) {
  .our-concept__text {
    margin-top: 15px;
    line-height: 1.8;
  }
}

.our-concept__img {
  margin-top: 50px;
}
@media screen and (max-width: 1366px) {
  .our-concept__img {
    margin-top: 3.6603221083vw;
  }
}
@media screen and (max-width: 960px) {
  .our-concept__img {
    margin-top: 30px;
  }
}

.concept-intro {
  background: #fff;
}
.concept-intro .inner {
  padding-block: 127px 185px;
}
@media screen and (max-width: 1366px) {
  .concept-intro .inner {
    padding-block: 9.2972181552vw 13.5431918009vw;
  }
}
.concept-intro__logo {
  text-align: center;
}
@media screen and (max-width: 960px) {
  .concept-intro__logo {
    margin: auto;
    max-width: 80%;
  }
}

.concept-intro__content {
  margin: auto;
  max-width: 1020px;
}
@media screen and (max-width: 1366px) {
  .concept-intro__content {
    max-width: 74.6705710102vw;
  }
}
@media screen and (max-width: 960px) {
  .concept-intro__content {
    max-width: 100%;
  }
}

.concept-intro__emphasis {
  margin: 5px auto 0;
  padding: 16px 40px;
  color: #FFF;
  background: #000005;
  font-size: 62px;
  font-style: normal;
  font-weight: 900;
  line-height: normal;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 1366px) {
  .concept-intro__emphasis {
    margin: 0.3660322108vw auto 0;
    padding: 1.1713030747vw 2.9282576867vw;
    font-size: 4.5387994143vw;
  }
}
@media screen and (max-width: 960px) {
  .concept-intro__emphasis {
    margin-top: 5px;
    padding: 10px 20px;
    font-size: 30px;
    text-align: center;
  }
}

.concept-intro__text {
  margin-top: 20px;
  line-height: 2.3125;
}
@media screen and (max-width: 1366px) {
  .concept-intro__text {
    margin-top: 1.4641288433vw;
  }
}
@media screen and (max-width: 960px) {
  .concept-intro__text {
    margin-top: 20px;
    line-height: 1.8;
  }
}

.strength {
  background: url("../img/service/strength-bg.webp") no-repeat center center;
}
@media screen and (min-width: 961px) {
  .strength .inner {
    padding-block: 0;
  }
}

.strength__box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 50px;
}
@media screen and (max-width: 1366px) {
  .strength__box {
    gap: 3.6603221083vw;
  }
}
@media screen and (max-width: 960px) {
  .strength__box {
    gap: 40px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.strength__title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.strength__title-num {
  color: #A32C00;
  font-size: 171px;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 1366px) {
  .strength__title-num {
    font-size: 12.5183016105vw;
  }
}
@media screen and (max-width: 960px) {
  .strength__title-num {
    font-size: 140px;
  }
}

.strength__title-text {
  font-size: 72px;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 1366px) {
  .strength__title-text {
    font-size: 5.270863836vw;
  }
}
@media screen and (max-width: 960px) {
  .strength__title-text {
    font-size: 50px;
  }
}
.strength__title-text img {
  display: block;
}
@media screen and (max-width: 1366px) {
  .strength__title-text img {
    max-width: 21.7423133236vw;
  }
}
@media screen and (max-width: 960px) {
  .strength__title-text img {
    max-width: 240px;
  }
}
.strength__title-text .red {
  color: #A32C00;
}

.strength__list {
  margin: -70px 0;
}
@media screen and (max-width: 1366px) {
  .strength__list {
    margin: -5.1244509517vw 0;
  }
}
@media screen and (max-width: 960px) {
  .strength__list {
    margin: 0;
  }
}

.strength__item {
  padding: 18px 30px 25px;
  background: #A32C00;
  color: #fff;
}
@media screen and (max-width: 1366px) {
  .strength__item {
    padding: 1.317715959vw 2.196193265vw 1.8301610542vw;
  }
}
@media screen and (max-width: 960px) {
  .strength__item {
    padding: 15px 20px;
  }
}
.strength__item + .strength__item {
  margin-top: 20px;
}
@media screen and (max-width: 1366px) {
  .strength__item + .strength__item {
    margin-top: 1.4641288433vw;
  }
}
@media screen and (max-width: 960px) {
  .strength__item + .strength__item {
    margin-top: 40px;
  }
}

.strength__item-title {
  font-size: 36px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.5;
  border-bottom: 2px solid #FFF;
}
@media screen and (max-width: 1366px) {
  .strength__item-title {
    font-size: 2.635431918vw;
    border-bottom: 0.1464128843vw solid #FFF;
  }
}
@media screen and (max-width: 960px) {
  .strength__item-title {
    padding-bottom: 10px;
    font-size: 24px;
  }
}
.strength__item-title .emphasis {
  font-size: 46px;
  line-height: 1.1739130435;
}
@media screen and (max-width: 1366px) {
  .strength__item-title .emphasis {
    font-size: 3.3674963397vw;
  }
}
@media screen and (max-width: 960px) {
  .strength__item-title .emphasis {
    font-size: 30px;
    display: block;
  }
}

.strength__description {
  margin-top: 15px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 4px;
}
@media screen and (max-width: 1366px) {
  .strength__description {
    margin-top: 1.0980966325vw;
    gap: 0.2928257687vw;
  }
}
@media screen and (max-width: 960px) {
  .strength__description {
    margin-top: 15px;
    padding-left: 5px;
    gap: 4px;
  }
}
.strength__description li {
  padding-left: 10px;
  position: relative;
  font-weight: 500;
  line-height: 1.5;
}
@media screen and (max-width: 1366px) {
  .strength__description li {
    padding-left: 0.7320644217vw;
  }
}
@media screen and (max-width: 960px) {
  .strength__description li {
    padding-left: 0;
  }
}
.strength__description li::before {
  background: #FFF;
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 4px;
  height: 4px;
  border-radius: 50%;
}
@media screen and (max-width: 960px) {
  .strength__description li::before {
    left: -10px;
    top: 9px;
    -webkit-transform: none;
            transform: none;
  }
}

.strength__result {
  margin-top: 14px;
  padding: 3px 10px 2px 5px;
  background: #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 1366px) {
  .strength__result {
    margin-top: 1.0248901903vw;
    padding: 0.2196193265vw 0.7320644217vw 0.1464128843vw 0.3660322108vw;
  }
}
@media screen and (max-width: 960px) {
  .strength__result {
    margin-top: 15px;
    padding: 3px 10px 2px 5px;
  }
}

@media screen and (max-width: 960px) {
  .strength__result-icon {
    min-width: 30px;
    max-width: 30px;
  }
}

.strength__result-text {
  color: #A32C00;
  font-weight: 500;
  line-height: 1.5;
}
.phase {
  margin-top: 200px;
  background: #080808;
}
@media screen and (max-width: 1366px) {
  .phase {
    margin-top: 14.6412884334vw;
  }
}
@media screen and (max-width: 960px) {
  .phase {
    margin-top: 60px;
  }
}

.phase__title {
  margin: auto;
  padding: 15px;
  font-size: 62px;
  font-style: normal;
  font-weight: 900;
  line-height: normal;
  text-align: center;
  background: #FFF;
  max-width: 1020px;
}
@media screen and (max-width: 1366px) {
  .phase__title {
    padding: 1.0980966325vw;
    font-size: 4.5387994143vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__title {
    padding: 10px;
    font-size: 30px;
  }
}

.phase__list {
  margin-top: 140px;
}
@media screen and (max-width: 1366px) {
  .phase__list {
    margin-top: 10.2489019034vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__list {
    margin-top: 40px;
  }
}

.phase__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
}
@media screen and (max-width: 1366px) {
  .phase__item {
    gap: 2.9282576867vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px;
  }
}
.phase__item + .phase__item {
  margin-top: 40px;
}
@media screen and (max-width: 1366px) {
  .phase__item + .phase__item {
    margin-top: 2.9282576867vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__item + .phase__item {
    margin-top: 20px;
  }
}

.phase__head {
  padding-top: 40px;
  width: 34.91%;
}
@media screen and (max-width: 1366px) {
  .phase__head {
    padding-top: 2.9282576867vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__head {
    width: 100%;
    padding-top: 20px;
  }
}

.phase__item-label {
  color: #D9D9D9;
  font-size: 28px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.3214285714;
  font-family: "Roboto Slab";
  border-bottom: 1px solid #D9D9D9;
  text-align: center;
}
@media screen and (max-width: 1366px) {
  .phase__item-label {
    font-size: 2.0497803807vw;
    border-bottom: 0.0732064422vw solid #D9D9D9;
  }
}
@media screen and (max-width: 960px) {
  .phase__item-label {
    font-size: 20px;
    border-bottom: 1px solid #D9D9D9;
  }
}

.phase__num {
  color: #D9D9D9;
  font-size: 46px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.3214285714;
}
@media screen and (max-width: 1366px) {
  .phase__num {
    font-size: 3.3674963397vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__num {
    font-size: 30px;
  }
}

.phase__item-title {
  margin-top: 30px;
  text-align: center;
  color: #FFF;
}
@media screen and (max-width: 1366px) {
  .phase__item-title {
    margin-top: 2.196193265vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__item-title {
    margin-top: 20px;
  }
}

.phase__item-name {
  font-size: 54px;
  font-style: normal;
  font-weight: 700;
  line-height: 0.6851851852;
}
@media screen and (max-width: 1366px) {
  .phase__item-name {
    font-size: 3.953147877vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__item-name {
    font-size: 30px;
  }
}

.phase__item-subtitle {
  margin-top: 20px;
  font-size: 28px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.3214285714;
}
@media screen and (max-width: 1366px) {
  .phase__item-subtitle {
    margin-top: 1.4641288433vw;
    font-size: 2.0497803807vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__item-subtitle {
    margin-top: 10px;
    font-size: 20px;
  }
}

.phase__body {
  padding: 45px 30px;
  border: 20px solid #D9D9D9;
  background: #fff;
  width: calc(65.09% - 40px);
}
@media screen and (max-width: 1366px) {
  .phase__body {
    padding: 3.2942898975vw 2.196193265vw;
    border: 1.4641288433vw solid #D9D9D9;
    width: calc(65.09% - 2.9282576867vw);
  }
}
@media screen and (max-width: 960px) {
  .phase__body {
    padding: 20px 25px;
    width: 100%;
  }
}

.phase__description {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 12px;
}
@media screen and (max-width: 1366px) {
  .phase__description {
    gap: 0.878477306vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__description {
    gap: 10px;
  }
}
.phase__description li {
  padding-left: 10px;
  font-size: 20px;
  font-style: normal;
  font-weight: 400;
  line-height: 1.3;
  position: relative;
}
@media screen and (max-width: 1366px) {
  .phase__description li {
    padding-left: 0.7320644217vw;
    font-size: 1.4641288433vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__description li {
    padding-left: 0;
    font-size: 16px;
  }
}
.phase__description li::before {
  content: "";
  position: absolute;
  background: #D9D9D9;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  width: 3px;
  height: 16px;
}
@media screen and (max-width: 1366px) {
  .phase__description li::before {
    width: 0.2196193265vw;
    height: 1.1713030747vw;
  }
}
@media screen and (max-width: 960px) {
  .phase__description li::before {
    left: -10px;
    top: 9px;
    width: 3px;
    height: 16px;
    -webkit-transform: none;
            transform: none;
  }
}

.service {
  background: url("../img/service/service-bg.webp") no-repeat center center;
}
.service .inner {
  padding-inline: 0;
}
.service__box {
  margin-left: auto;
  background: #fff;
  width: 91%;
}
@media screen and (max-width: 960px) {
  .service__box {
    margin-left: auto;
    width: 98%;
  }
}
.service__box + .service__box {
  margin-top: 140px;
}
@media screen and (max-width: 1366px) {
  .service__box + .service__box {
    margin-top: 10.2489019034vw;
  }
}
@media screen and (max-width: 960px) {
  .service__box + .service__box {
    margin-top: 40px;
  }
}

.service__block {
  padding: 64px 60px 64px 0;
  background: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
}
@media screen and (max-width: 1366px) {
  .service__block {
    padding: 4.6852122987vw 4.39238653vw 4.6852122987vw 0;
  }
}
@media screen and (max-width: 960px) {
  .service__block {
    padding: 20px 0 20px 20px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.service__img {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-left: calc((100vw - 100%) / 2 * -1 - 10%);
  margin-right: -13.9092240117vw;
}
@media screen and (max-width: 960px) {
  .service__img {
    margin-top: 2px;
    margin-left: 0;
    margin-right: 0;
    left: 0;
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}
.service__img img {
  width: 100%;
}

.service__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 960px) {
  .service__content {
    display: contents;
  }
}

.service__title {
  margin-left: auto;
  font-family: "Roboto Slab";
  font-size: 84px;
  font-style: normal;
  font-weight: 700;
  line-height: 0.8571428571;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
@media screen and (max-width: 1366px) {
  .service__title {
    font-size: 6.149341142vw;
  }
}
@media screen and (max-width: 960px) {
  .service__title {
    margin-right: auto;
    font-size: 34px;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
.service__title .bg-black {
  margin-left: auto;
  background: #000005;
  color: #FFF;
  padding: 14px 18px;
  display: inline-block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  text-align: right;
  font-family: "Roboto Slab";
}
@media screen and (max-width: 1366px) {
  .service__title .bg-black {
    padding: 1.0248901903vw 1.317715959vw;
  }
}
@media screen and (min-width: 961px) {
  .service__title .bg-black {
    white-space: nowrap;
  }
}
.service__title .section-title--jp {
  margin-left: auto;
  max-width: 511px;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
@media screen and (max-width: 1366px) {
  .service__title .section-title--jp {
    max-width: 37.4084919473vw;
  }
}
@media screen and (min-width: 961px) {
  .service__title .section-title--jp {
    white-space: nowrap;
  }
}
@media screen and (max-width: 960px) {
  .service__title .section-title--jp {
    margin-left: 0;
    max-width: 100%;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
  }
}

.service__title--en {
  margin-top: 30px;
  text-align: right;
}
@media screen and (max-width: 1366px) {
  .service__title--en {
    margin-top: 2.196193265vw;
  }
}
@media screen and (max-width: 960px) {
  .service__title--en {
    margin-top: 10px;
    text-align: left;
  }
}

.service__title-sub {
  font-size: 42px;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: var(--sds-typography-weight-semibold);
  line-height: normal;
  text-align: right;
}
@media screen and (max-width: 1366px) {
  .service__title-sub {
    font-size: 3.074670571vw;
  }
}
@media screen and (max-width: 960px) {
  .service__title-sub {
    font-size: 18px;
    text-align: left;
  }
}

.service__description {
  margin: 40px 0 0 auto;
  max-width: 573px;
}
@media screen and (max-width: 1366px) {
  .service__description {
    margin: 2.9282576867vw 0 0 auto;
    max-width: 41.9472913616vw;
  }
}
@media screen and (max-width: 960px) {
  .service__description {
    margin-top: 20px;
    padding-right: 20px;
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
    max-width: 100%;
  }
}

.service__block--reverse {
  padding: 64px 0 64px 40px;
}
@media screen and (max-width: 1366px) {
  .service__block--reverse {
    padding: 4.6852122987vw 0 4.6852122987vw 2.9282576867vw;
  }
}
@media screen and (max-width: 960px) {
  .service__block--reverse {
    padding: 20px 0 20px 20px;
  }
}
.service__block--reverse .service__sub-title--en {
  font-family: "Roboto Slab";
  font-size: 65px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.3692307692;
}
@media screen and (max-width: 1366px) {
  .service__block--reverse .service__sub-title--en {
    font-size: 4.7584187408vw;
  }
}
@media screen and (max-width: 960px) {
  .service__block--reverse .service__sub-title--en {
    font-size: 30px;
  }
}

.service__sub-emphasis {
  margin-top: 20px;
  padding: 15px;
  background: #D9D9D9;
  text-align: center;
  font-size: 35px;
  font-style: normal;
  font-weight: var(--sds-typography-weight-semibold);
  line-height: normal;
}
@media screen and (max-width: 1366px) {
  .service__sub-emphasis {
    margin-top: 1.4641288433vw;
    padding: 1.0980966325vw;
    font-size: 2.5622254758vw;
  }
}
@media screen and (max-width: 960px) {
  .service__sub-emphasis {
    margin-top: 20px;
    padding: 10px;
    font-size: 20px;
  }
}

.service__sub-description {
  margin-top: 25px;
}
@media screen and (max-width: 1366px) {
  .service__sub-description {
    margin-top: 1.8301610542vw;
  }
}
@media screen and (max-width: 960px) {
  .service__sub-description {
    padding-right: 20px;
    margin-top: 20px;
    -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
            order: 3;
  }
}
@media screen and (max-width: 960px) {
  .service__sub-description .btn__wrapper {
    padding-right: 20px;
  }
}

.service__block--reverse .service__img {
  margin-left: 4.39238653vw;
  margin-right: calc((100vw - 100%) / 2 * -1 + 6%);
  left: auto;
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
@media screen and (max-width: 960px) {
  .service__block--reverse .service__img {
    margin-top: 20px;
    margin-left: 0;
    margin-right: 0;
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
.service__block--reverse .service__content {
  margin-top: 120px;
  min-width: 565px;
}
@media screen and (max-width: 1366px) {
  .service__block--reverse .service__content {
    margin-top: 8.78477306vw;
    min-width: 41.3616398243vw;
  }
}
@media screen and (max-width: 960px) {
  .service__block--reverse .service__content {
    margin-top: 20px;
    min-width: 100%;
  }
}

.service__box:nth-child(2) {
  margin-left: 0;
  margin-right: auto;
}
.service__box:nth-child(2) .service__block {
  padding: 64px 0 64px 60px;
}
@media screen and (max-width: 1366px) {
  .service__box:nth-child(2) .service__block {
    padding: 4.6852122987vw 0 4.6852122987vw 4.39238653vw;
  }
}
@media screen and (max-width: 960px) {
  .service__box:nth-child(2) .service__block {
    padding: 20px 20px 20px 0;
  }
}
.service__box:nth-child(2) .service__img {
  margin-top: 50px;
  margin-right: calc((100vw - 100%) / 2 * -1 - 40px);
  margin-left: -9.5168374817vw;
}
@media screen and (max-width: 1366px) {
  .service__box:nth-child(2) .service__img {
    margin-top: 3.6603221083vw;
  }
}
@media screen and (max-width: 960px) {
  .service__box:nth-child(2) .service__img {
    margin-left: 0;
    margin-top: 20px;
    margin-right: 0;
  }
}
.service__box:nth-child(2) .service__content {
  margin-top: 30px;
}
@media screen and (max-width: 1366px) {
  .service__box:nth-child(2) .service__content {
    margin-top: 2.196193265vw;
  }
}
@media screen and (max-width: 960px) {
  .service__box:nth-child(2) .service__content {
    margin-top: 20px;
  }
}
@media screen and (max-width: 960px) {
  .service__box:nth-child(2) .service__title {
    margin-right: 0;
  }
}
.service__box:nth-child(2) .section-title--jp {
  max-width: 100%;
}
@media screen and (max-width: 960px) {
  .service__box:nth-child(2) .section-title--jp {
    margin-left: auto;
  }
}
.service__box:nth-child(2) .service__title--en {
  text-align: left;
}
@media screen and (max-width: 960px) {
  .service__box:nth-child(2) .service__title--en {
    text-align: right;
  }
}
.service__box:nth-child(2) .service__title-sub {
  white-space: nowrap;
  text-align: left;
}
.service__box:nth-child(2) .service__description {
  margin-left: 0;
  max-width: 572px;
}
@media screen and (max-width: 1366px) {
  .service__box:nth-child(2) .service__description {
    max-width: 41.8740849195vw;
  }
}
@media screen and (max-width: 960px) {
  .service__box:nth-child(2) .service__description {
    padding-left: 20px;
    max-width: 100%;
  }
}

@media screen and (max-width: 960px) {
  .service .btn__wrapper {
    padding-right: 20px;
    margin-top: 20px;
    -webkit-box-ordinal-group: 5;
        -ms-flex-order: 4;
            order: 4;
  }
}