/*====================================================================================
[TABLE OF CONTENT]

1. COMPONENT.
   1.1. TITLE.
   1.2. HEADING.
   1.3. TAG.
   1.4. ITEM.
   1.5. GALLERY.
   1.6. TABLE.
   1.7. BOX.
   1.8. STEP.
   1.9. CARD.
   1.10. GROUP.
   1.11. BANNER.
   1.12. VIDEO.
2. PROJECT.
   2.1. PAGE VISION.
   2.2. SECTION VISION.
   2.3. SECTION VISION ABOUT.
   2.4. SECTION VISION REPORT.
====================================================================================*/
@import url("https://fonts.googleapis.com/css2?family=Zen+Maru+Gothic:wght@900&display=swap");
@media (max-width: 767px) {
  .u-hide-max-md {
    display: none !important;
  }
}
@media (min-width: 768px) {
  .u-hide-min-md {
    display: none !important;
  }
}
/*====================================================================================
1. COMPONENT.
====================================================================================*/
/*------------------------------------------------------------------------------------
1.1. TITLE.
------------------------------------------------------------------------------------*/
/*---------- TITLE ----------*/
.c-title {
  position: relative;
  z-index: 2;
}
.c-title__text {
  display: block;
  text-align: center;
}
.c-title__text--xs {
  color: #00467F;
  line-height: 1.5;
  font-weight: 900;
  letter-spacing: 0.17em;
  text-transform: uppercase;
}
.c-title__text--md {
  line-height: 1.3;
  font-weight: 700;
}

@media (max-width: 767px) {
  .c-title__text--xs {
    margin-block-end: 7px;
    font-size: 15px;
  }
  .c-title__text--md {
    font-size: 23px;
  }
}
@media (min-width: 768px) and (max-width: 1299px) {
  .c-title__text--xs {
    margin-block-end: 10px;
    font-size: 22px;
  }
  .c-title__text--md {
    font-size: 37px;
  }
}
@media (min-width: 1300px) {
  .c-title__text--xs {
    font-size: 25px;
  }
  .c-title__text--md {
    font-size: 40px;
    letter-spacing: 0.1em;
  }
}
/*---------- TITLE SECTION ----------*/
.c-title-section {
  font-weight: 700;
  text-align: center;
}

@media (max-width: 767px) {
  .c-title-section {
    font-size: 25px;
  }
}
@media (min-width: 768px) {
  .c-title-section {
    font-size: 50px;
    letter-spacing: 0.1em;
  }
}
/*---------- TITLE SECTION BLUE ----------*/
.c-title-section--blue {
  color: #00467F;
}

/*---------- TITLE END ----------*/
.c-title-end {
  display: flex;
  justify-content: center;
}
.c-title-end__wrap {
  position: relative;
  padding: 15px 55px;
}
.c-title-end__deco {
  position: absolute;
  width: 46px;
  height: 46px;
}
.c-title-end__deco::before, .c-title-end__deco::after {
  position: absolute;
  content: "";
}
.c-title-end__deco::before {
  inset-block-start: 0;
  inset-inline-start: 0;
  width: 37px;
  height: 37px;
  background: url("./../recruit/vision/images/c-icon-star-sm.png") no-repeat center center/100% auto;
}
.c-title-end__deco::after {
  inset-block-end: 0;
  inset-inline-end: 0;
  width: 18px;
  height: 18px;
  background: url("./../recruit/vision/images/c-icon-star-xs.png") no-repeat center center/100% auto;
}
.c-title-end__deco--v1 {
  inset-block-end: -7px;
  inset-inline-start: -7px;
}
.c-title-end__deco--v2 {
  inset-block-start: 0;
  inset-inline-end: 0;
}
.c-title-end__text {
  padding: 0 10px 5px 15px;
  color: #00467F;
  font-size: 40px;
  font-weight: 700;
  letter-spacing: 0.09em;
  background: linear-gradient(0deg, #DFF2FC 40%, transparent 40%);
}

/*------------------------------------------------------------------------------------
1.2. HEADING.
------------------------------------------------------------------------------------*/
.c-heading {
  position: relative;
}
.c-heading::before {
  position: absolute;
  content: "";
  inset-block-start: -20px;
  inset-inline-start: 50%;
  transform: translateX(-50%);
}
.c-heading__wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin-inline: auto;
  padding-inline: 10px;
}
.c-heading__wrap::before, .c-heading__wrap::after {
  position: absolute;
  content: "";
  inset-block-start: 0;
  height: 100%;
}
.c-heading__wrap::before {
  inset-inline-start: 0;
  background: url("./../recruit/vision/images/c-heading-deco.png") no-repeat center center/100% 100%;
}
.c-heading__wrap::after {
  inset-inline-end: 0;
  background: url("./../recruit/vision/images/c-heading-deco2.png") no-repeat center center/100% 100%;
}

@media (max-width: 767px) {
  .c-heading::before {
    border-inline: 26px solid transparent;
    border-block-start: 20px solid #D9D9D9;
  }
  .c-heading__wrap {
    min-height: 125px;
  }
  .c-heading__wrap::before, .c-heading__wrap::after {
    width: 28px;
  }
}
@media (min-width: 768px) {
  .c-heading::before {
    border-inline: 30px solid transparent;
    border-block-start: 24px solid #D9D9D9;
  }
  .c-heading__wrap {
    max-width: 874px;
    min-height: 155px;
  }
  .c-heading__wrap::before, .c-heading__wrap::after {
    width: 36px;
  }
}
/*---------- HEADING NO ARROW ----------*/
.c-heading--no-arrow::before {
  content: none;
}

/*---------- HEADING SECTION ----------*/
.c-heading-section {
  display: grid;
  justify-content: center;
}
.c-heading-section__text, .c-heading-section__title {
  color: #00467F;
  font-weight: 700;
  text-align: center;
}
.c-heading-section__text {
  line-height: 1.5;
  letter-spacing: normal;
}
.c-heading-section__title {
  position: relative;
  padding-block-end: 5px;
  line-height: 1.3;
  border-block-end: 2px solid #000000;
}
.c-heading-section__title::before {
  position: absolute;
  content: "";
}

@media (max-width: 767px) {
  .c-heading-section {
    padding-inline: 20px;
  }
  .c-heading-section__text {
    margin-block-end: 6px;
    font-size: 18px;
  }
  .c-heading-section__title {
    font-size: 25px;
  }
  .c-heading-section__title::before {
    inset-inline-end: -35px;
    inset-block-end: -4px;
    width: 35px;
    height: 35px;
    background: url("./../recruit/vision/images/c-icon-pen.png") no-repeat center center/100% auto;
  }
}
@media (min-width: 768px) {
  .c-heading-section__text {
    margin-block-end: 10px;
    font-size: 36px;
  }
  .c-heading-section__title {
    font-size: 50px;
  }
  .c-heading-section__title::before {
    inset-inline-end: -63px;
    inset-block-end: -4px;
    width: 63px;
    height: 63px;
    background: url("./../recruit/vision/images/c-icon-pen.png") no-repeat center center/100% auto;
  }
}
/*---------- HEADING START ----------*/
.c-heading-start {
  position: relative;
}
.c-heading-start::before, .c-heading-start::after {
  position: absolute;
  content: "";
}
.c-heading-start::before {
  inset-block-start: 0;
  inset-inline-start: 50%;
  width: 12px;
  height: 100%;
  margin-inline-start: -6px;
  background-color: #00467F;
}
.c-heading-start::after {
  inset-inline-start: 50%;
  inset-block-end: -20px;
  transform: translateX(-50%);
  border-inline: 18px solid transparent;
  border-block-start: 21px solid #00467F;
}
.c-heading-start__title {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
}
.c-heading-start__title::before {
  position: absolute;
  content: "";
  z-index: -1;
  inset-inline: 0;
  background-color: #ffffff;
}
.c-heading-start__text {
  color: #00467F;
  font-weight: 700;
  letter-spacing: 0.09em;
  background: linear-gradient(0deg, #DFF2FC 40%, transparent 40%);
}

@media (max-width: 767px) {
  .c-heading-start {
    padding-block: 40px;
  }
  .c-heading-start__title {
    gap: 15px;
  }
  .c-heading-start__title::before {
    inset-block-start: 7px;
    height: calc(100% - 10px);
  }
  .c-heading-start__deco {
    width: 60px;
  }
  .c-heading-start__text {
    margin-block-end: 10px;
    padding-inline: 5px;
    font-size: 25px;
  }
}
@media (min-width: 768px) {
  .c-heading-start {
    padding-block: 40px;
  }
  .c-heading-start__title {
    gap: 40px;
  }
  .c-heading-start__title::before {
    inset-block-start: 15px;
    height: calc(100% - 30px);
  }
  .c-heading-start__text {
    margin-block-end: 20px;
    padding-inline: 15px;
    font-size: 40px;
  }
}
/*---------- HEADING QUOTE ----------*/
.c-heading-quote {
  position: relative;
  display: flex;
  justify-content: center;
}
.c-heading-quote::before {
  position: absolute;
  content: "";
  inset-block-start: 0;
  inset-inline-start: 50%;
  transform: translateX(-50%);
}
.c-heading-quote__wrap {
  position: relative;
}
.c-heading-quote__wrap::before, .c-heading-quote__wrap::after {
  position: absolute;
  content: "";
}
.c-heading-quote__wrap::before {
  inset-inline-start: 0;
  background: url("./../recruit/vision/images/c-icon-quote.png") no-repeat center center/100% 100%;
}
.c-heading-quote__wrap::after {
  inset-block-end: -17px;
  background: url("./../recruit/vision/images/c-icon-quote2.png") no-repeat center center/100% 100%;
}

@media (max-width: 767px) {
  .c-heading-quote {
    padding-block-start: 30px;
  }
  .c-heading-quote::before {
    border-inline: 26px solid transparent;
    border-block-start: 20px solid #D9D9D9;
  }
  .c-heading-quote__wrap {
    padding-inline: 0px;
  }
  .c-heading-quote__wrap::before, .c-heading-quote__wrap::after {
    width: 37px;
    height: 22px;
  }
  .c-heading-quote__wrap::before {
    inset-inline-start: -10px;
    inset-block-start: 5px;
  }
  .c-heading-quote__wrap::after {
    inset-inline-end: -10px;
    inset-block-end: -17px;
  }
}
@media (min-width: 768px) {
  .c-heading-quote {
    padding-block-start: 40px;
  }
  .c-heading-quote::before {
    border-inline: 30px solid transparent;
    border-block-start: 24px solid #D9D9D9;
  }
  .c-heading-quote__wrap {
    padding-inline: 50px;
  }
  .c-heading-quote__wrap::before, .c-heading-quote__wrap::after {
    width: 47px;
    height: 32px;
  }
  .c-heading-quote__wrap::before {
    inset-block-start: 25px;
  }
  .c-heading-quote__wrap::after {
    inset-inline-end: 22px;
  }
}
/*------------------------------------------------------------------------------------
1.3. TAG.
------------------------------------------------------------------------------------*/
/*---------- TAG STEP ----------*/
.c-tag-step {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background-color: #00467F;
}
.c-tag-step__text, .c-tag-step__num {
  display: block;
  color: #ffffff;
  text-align: center;
  line-height: 1.1;
  font-weight: 900;
  text-transform: uppercase;
}
.c-tag-step__text {
  letter-spacing: 0.15em;
}

@media (max-width: 767px) {
  .c-tag-step {
    width: 70px;
    height: 70px;
    padding-block-start: 5px;
  }
  .c-tag-step__text {
    font-size: 13px;
  }
  .c-tag-step__num {
    font-size: 25px;
  }
}
@media (min-width: 768px) {
  .c-tag-step {
    width: 100px;
    height: 100px;
    padding-block-start: 10px;
  }
  .c-tag-step__text {
    font-size: 22px;
  }
  .c-tag-step__num {
    font-size: 35px;
  }
}
/*------------------------------------------------------------------------------------
1.4. ITEM.
------------------------------------------------------------------------------------*/
/*---------- ITEM STEP ----------*/
.c-item-step:last-child .c-item-step__row::before {
  content: none;
}
.c-item-step img {
  height: auto;
  max-width: 100%;
}
.c-item-step__row {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.c-item-step__row::before {
  position: absolute;
  content: "";
  inset-inline-start: 50%;
  transform: translateX(-50%);
  background: url("./../recruit/vision/images/c-item-arrow.png") no-repeat center center/100% auto;
}
.c-item-step .c-tag-step, .c-item-step__icon {
  position: absolute;
}
.c-item-step__icon {
  padding-block: 5px;
  text-align: center;
  background-color: #ffffff;
}
.c-item-step__text {
  line-height: 1.5;
  font-weight: 700;
  text-align: center;
}

@media (max-width: 767px) {
  .c-item-step {
    padding-inline: 25px;
  }
  .c-item-step:not(:last-child) {
    margin-block-end: 25px;
  }
  .c-item-step__row {
    min-height: 100px;
    padding: 10px 40px;
    border: 4px solid #00467F;
  }
  .c-item-step__row::before {
    inset-block-end: -30px;
    width: 25px;
    height: 26px;
  }
  .c-item-step .c-tag-step {
    inset-inline-start: -35px;
  }
  .c-item-step__icon {
    inset-inline-end: -39px;
    width: 70px;
  }
  .c-item-step__icon img {
    width: auto;
    max-height: 60px;
  }
  .c-item-step__text {
    font-size: 18px;
  }
}
@media (min-width: 768px) {
  .c-item-step {
    padding-inline: 50px;
  }
  .c-item-step:not(:last-child) {
    margin-block-end: 36px;
  }
  .c-item-step__row {
    min-height: 134px;
    border: 5px solid #00467F;
  }
  .c-item-step__row::before {
    inset-block-end: -42px;
    width: 37px;
    height: 38px;
  }
  .c-item-step .c-tag-step {
    inset-inline-start: -50px;
  }
  .c-item-step__icon {
    inset-inline-end: -68px;
    width: 126px;
  }
  .c-item-step__text {
    font-size: 28px;
  }
}
/*---------- LIST ITEM STEP ----------*/
@media (min-width: 768px) {
  .c-list-item-step {
    max-width: 770px;
    margin-inline: auto;
  }
}
/*------------------------------------------------------------------------------------
1.5. GALLERY.
------------------------------------------------------------------------------------*/
/*---------- GALLERY STEP ----------*/
.c-gallery-step img {
  height: auto;
  max-width: 100%;
}

@media (max-width: 575px) {
  .c-gallery-step__item:not(:first-child) {
    margin-block-start: 3px;
  }
}
@media (min-width: 576px) {
  .c-gallery-step__list {
    display: flex;
    justify-content: center;
    gap: 3px;
  }
}
/*------------------------------------------------------------------------------------
1.6. TABLE.
------------------------------------------------------------------------------------*/
/*---------- TABLE STEP ----------*/
.c-table-step img {
  height: auto;
  max-width: 100%;
}
.c-table-step__title {
  margin-block-end: 20px;
  color: #00467F;
  font-weight: 700;
  text-align: center;
}

@media (max-width: 767px) {
  .c-table-step__title {
    font-size: 21px;
  }
}
@media (min-width: 768px) {
  .c-table-step__title {
    font-size: 33px;
  }
}
/*---------- TABLE VISION ----------*/
.c-table-vision img {
  height: auto;
  max-width: 100%;
}
.c-table-vision table {
  width: 100%;
  table-layout: fixed;
}
.c-table-vision__row {
  display: flex;
}
.c-table-vision__right {
  flex: 1;
  min-width: 1px;
}
.c-table-vision__line {
  position: relative;
  text-align: center;
}
.c-table-vision__line::before {
  position: absolute;
  content: "";
  inset-inline-start: 50%;
  transform: translateX(-50%);
}
.c-table-vision__deco {
  position: absolute;
}

@media (max-width: 767px) {
  .c-table-vision td {
    border: 2px solid #D9D9D9;
  }
  .c-table-vision__right {
    padding-block-start: 3.5vw;
  }
  .c-table-vision__text {
    width: auto;
  }
  .c-table-vision__text--1line {
    max-height: 4vw;
  }
  .c-table-vision__text--2line {
    max-height: 8vw;
  }
  .c-table-vision__text--3line {
    max-height: 12vw;
  }
  .c-table-vision__line {
    margin-block-start: 15px;
    padding: 10px;
    border: 2px solid #D9D9D9;
  }
  .c-table-vision__line::before {
    inset-block-start: -12px;
    border-inline: 50px solid transparent;
    border-block-start: 20px solid #D9D9D9;
  }
}
@media (min-width: 768px) {
  .c-table-vision td {
    border: 4px solid #D9D9D9;
  }
  .c-table-vision__right {
    padding-block-start: 20px;
  }
  .c-table-vision__line {
    margin-block-start: 17px;
    padding: 15px;
    border: 4px solid #D9D9D9;
  }
  .c-table-vision__line::before {
    inset-block-start: -15px;
    border-inline: 70px solid transparent;
    border-block-start: 29px solid #D9D9D9;
  }
}
@media (min-width: 768px) and (max-width: 1299px) {
  .c-table-vision td img {
    transform: scale(0.9);
  }
}
/*---------- TABLE VISION VERSION 1 ----------*/
.c-table-vision--v1 {
  position: relative;
}
.c-table-vision--v1 td {
  text-align: center;
}

@media (max-width: 767px) {
  .c-table-vision--v1 tr:first-child td {
    padding-block: 10px;
  }
  .c-table-vision--v1 tr:nth-child(2) td {
    padding-block: 10px;
  }
  .c-table-vision--v1 tr:nth-child(3) td {
    padding-block: 25px;
  }
  .c-table-vision--v1 tr td:first-child {
    width: 25%;
  }
  .c-table-vision--v1 .c-table-vision__deco {
    inset-block-start: 40px;
    inset-inline-end: -15px;
    width: 30px;
    height: 30px;
  }
}
@media (min-width: 768px) {
  .c-table-vision--v1 tr:first-child td {
    padding-block: 18px;
  }
  .c-table-vision--v1 tr:nth-child(2) td {
    padding-block: 25px;
  }
  .c-table-vision--v1 tr:nth-child(3) td {
    padding-block: 50px;
  }
  .c-table-vision--v1 tr td:first-child {
    width: 189px;
  }
  .c-table-vision--v1 .c-table-vision__deco {
    inset-block-start: 85px;
    inset-inline-end: -24px;
  }
}
/*---------- TABLE VISION VERSION 2 ----------*/
.c-table-vision--v2 td {
  vertical-align: top;
}

@media (max-width: 767px) {
  .c-table-vision--v2 .c-table-vision__row--v1 .c-table-vision__left {
    width: 25%;
  }
  .c-table-vision--v2 .c-table-vision__row--v2 .c-table-vision__left {
    width: 35%;
  }
  .c-table-vision--v2 .c-table-vision__row--v3 .c-table-vision__right {
    padding-inline-start: 5px;
  }
  .c-table-vision--v2 td {
    padding: 10px 0 10px 10px;
  }
}
@media (min-width: 768px) {
  .c-table-vision--v2 .c-table-vision__row--v1 .c-table-vision__left {
    width: 170px;
  }
  .c-table-vision--v2 .c-table-vision__row--v2 .c-table-vision__left {
    width: 120px;
  }
  .c-table-vision--v2 .c-table-vision__row--v3 .c-table-vision__right {
    padding-inline-start: 7px;
  }
  .c-table-vision--v2 td {
    padding: 20px 0 20px 15px;
  }
}
/*------------------------------------------------------------------------------------
1.7. BOX.
------------------------------------------------------------------------------------*/
/*---------- BOX VISION ----------*/
.c-box-vision {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
.c-box-vision p {
  color: #454545;
  line-height: 1.5;
  font-weight: 900;
  letter-spacing: normal;
  font-family: "Zen Maru Gothic", sans-serif;
}

@media (max-width: 767px) {
  .c-box-vision p {
    font-size: 3vw;
  }
}
@media (min-width: 768px) {
  .c-box-vision p {
    font-size: 27px;
  }
}
/*---------- LIST BOX VISION ----------*/
.c-list-box-vision {
  position: relative;
  display: flex;
  flex-wrap: wrap;
}

/*---------- LIST BOX VISION VERSION 1 ----------*/
.c-list-box-vision--v1 {
  justify-content: space-between;
}
.c-list-box-vision--v1 .c-box-vision--v1 {
  width: 46.5%;
  margin-inline-start: -1%;
  background-image: url("./../recruit/vision/images/c-box-bg.png");
}
.c-list-box-vision--v1 .c-box-vision--v2 {
  width: 48%;
  margin-inline-end: -4.5%;
  background-image: url("./../recruit/vision/images/c-box-bg2.png");
}

@media (max-width: 767px) {
  .c-list-box-vision--v1 {
    margin-block-start: -20px;
  }
  .c-list-box-vision--v1 .c-box-vision--v1 {
    height: 25vw;
    margin-block-start: 12px;
  }
  .c-list-box-vision--v1 .c-box-vision--v2 {
    height: 25vw;
    padding: 0 0 4.5vw 1vw;
  }
}
@media (min-width: 768px) {
  .c-list-box-vision--v1 {
    margin-block-start: -50px;
  }
  .c-list-box-vision--v1 .c-box-vision--v1 {
    height: 216px;
    margin-block-start: 12px;
    padding: 10px 0px 10px 10px;
  }
  .c-list-box-vision--v1 .c-box-vision--v2 {
    height: 181px;
    padding: 0 0 40px 10px;
  }
}
/*---------- LIST BOX VISION VERSION 2 ----------*/
.c-list-box-vision--v2 .c-box-vision--v1 {
  width: 41.5%;
  margin-inline-start: 6%;
  background-image: url("./../recruit/vision/images/c-box-bg3.png");
}
.c-list-box-vision--v2 .c-box-vision--v2 {
  width: 51%;
  background-image: url("./../recruit/vision/images/c-box-bg4.png");
}
.c-list-box-vision--v2 .c-box-vision--v3 {
  width: 60%;
  background-image: url("./../recruit/vision/images/c-box-bg5.png");
}
.c-list-box-vision--v2 .c-box-vision--v4 {
  width: 44.5%;
  padding: 5px 0 0 0;
  background-image: url("./../recruit/vision/images/c-box-bg6.png");
}
.c-list-box-vision--v2 .c-box-vision--v5 {
  width: 49%;
  background-image: url("./../recruit/vision/images/c-box-bg7.png");
}

@media (max-width: 767px) {
  .c-list-box-vision--v2 .c-box-vision--v1 {
    height: 23vw;
    padding: 1vw 0 3vw 1vw;
  }
  .c-list-box-vision--v2 .c-box-vision--v2 {
    height: 25vw;
    margin: 11vw 0 0 1%;
    padding: 0 0 4.5vw 0;
  }
  .c-list-box-vision--v2 .c-box-vision--v3 {
    height: 32vw;
    margin: -7.5vw 0 0 -1%;
    padding: 1vw 2vw 9vw 1vw;
  }
  .c-list-box-vision--v2 .c-box-vision--v4 {
    height: 30vw;
    margin: 10vw 0 0 -7.5%;
  }
  .c-list-box-vision--v2 .c-box-vision--v5 {
    height: 28vw;
    margin: -20vw 0 0 1.5%;
    padding: 1vw 0 1vw 1vw;
  }
}
@media (min-width: 768px) {
  .c-list-box-vision--v2 .c-box-vision--v1 {
    height: 190px;
    padding: 10px 0px 20px 15px;
  }
  .c-list-box-vision--v2 .c-box-vision--v2 {
    height: 195px;
    margin: 90px 0 0 1%;
    padding: 0 0 25px 10px;
  }
  .c-list-box-vision--v2 .c-box-vision--v3 {
    height: 290px;
    margin: -65px 0 0 -1%;
    padding: 10px 20px 70px 10px;
  }
  .c-list-box-vision--v2 .c-box-vision--v4 {
    height: 240px;
    margin: 120px 0 0 -7.5%;
  }
  .c-list-box-vision--v2 .c-box-vision--v5 {
    height: 265px;
    margin: -190px 0 0 1.5%;
    padding: 10px 0px 10px 10px;
  }
}
/*------------------------------------------------------------------------------------
1.8. STEP.
------------------------------------------------------------------------------------*/
/*---------- STEP VISION ----------*/
.c-step-vision img {
  height: auto;
  max-width: 100%;
}
.c-step-vision__desc {
  margin-block-end: 20px;
}
.c-step-vision__desc p {
  font-weight: 500;
  letter-spacing: normal;
}
.c-step-vision__imgs {
  display: flex;
  gap: 3px;
}

@media (max-width: 767px) {
  .c-step-vision .c-heading {
    margin-block-end: 40px;
  }
  .c-step-vision__left {
    margin-block-end: 25px;
  }
  .c-step-vision__desc p {
    font-size: 16px;
  }
  .c-step-vision__desc p:not(:first-child) {
    margin-block-start: 15px;
  }
}
@media (min-width: 768px) {
  .c-step-vision .c-heading {
    margin-block-end: 80px;
  }
  .c-step-vision__row {
    display: flex;
  }
  .c-step-vision__left {
    flex: 1;
    min-width: 1px;
    padding-inline-end: 65px;
  }
  .c-step-vision__right {
    width: 35.5%;
  }
  .c-step-vision__desc p {
    font-size: 27px;
  }
  .c-step-vision__desc p:not(:first-child) {
    margin-block-start: 50px;
  }
}
/*---------- STEP VISION VERSION 3 ----------*/
@media (min-width: 768px) {
  .c-step-vision--v3 .c-step-vision__right {
    padding-block-start: 70px;
  }
}
/*---------- LIST STEP VISION ----------*/
@media (max-width: 767px) {
  .c-list-step-vision .c-step-vision:not(:first-child) {
    margin-block-start: 50px;
  }
}
@media (min-width: 768px) {
  .c-list-step-vision .c-step-vision:not(:first-child) {
    margin-block-start: 100px;
  }
}
/*------------------------------------------------------------------------------------
1.9. CARD.
------------------------------------------------------------------------------------*/
/*---------- CARD VISION ----------*/
.c-card-vision__title {
  font-weight: 700;
  text-align: center;
}
.c-card-vision__img img {
  width: 100%;
}

@media (max-width: 767px) {
  .c-card-vision__title {
    margin-block-end: 15px;
    font-size: 20px;
  }
}
@media (min-width: 768px) {
  .c-card-vision__title {
    margin-block-end: 20px;
    font-size: 27px;
  }
}
/*---------- CARD VISION SHADOW ----------*/
.c-card-vision--shadow .c-card-vision__img {
  box-shadow: 0 4px 5px rgba(0, 0, 0, 0.5);
}

/*---------- LIST CARD VISION ----------*/
@media (max-width: 575px) {
  .c-list-card-vision .c-card-vision:not(:first-child) {
    margin-block-start: 35px;
  }
}
@media (min-width: 576px) {
  .c-list-card-vision {
    display: flex;
    gap: 15px;
  }
}
/*------------------------------------------------------------------------------------
1.10. GROUP.
------------------------------------------------------------------------------------*/
/*---------- GROUP VISION ----------*/
.c-group-vision img {
  height: auto;
  max-width: 100%;
}
.c-group-vision__desc p {
  font-weight: 400;
  text-align: center;
  letter-spacing: normal;
}

@media (max-width: 767px) {
  .c-group-vision .c-heading-quote {
    margin-block-end: 35px;
  }
  .c-group-vision__desc {
    margin-block-start: 25px;
  }
  .c-group-vision__desc p {
    font-size: 18px;
    line-height: 1.6;
  }
}
@media (min-width: 768px) {
  .c-group-vision .c-heading-quote {
    margin-block-end: 70px;
  }
  .c-group-vision__desc {
    margin-block-start: 50px;
  }
  .c-group-vision__desc p {
    font-size: 27px;
    line-height: 1.4;
  }
}
/*------------------------------------------------------------------------------------
1.11. BANNER.
------------------------------------------------------------------------------------*/
/*---------- BANNER VISION ----------*/
.c-bnr-vision {
  border: 1px solid #545454;
}
.c-bnr-vision img {
  height: auto;
  max-width: 100%;
}
.c-bnr-vision__outer {
  position: relative;
}
.c-bnr-vision__inner {
  position: absolute;
  inset: 0;
}
.c-bnr-vision__text p {
  line-height: 1.3;
  font-weight: 700;
  letter-spacing: normal;
}
.c-bnr-vision__btn {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  inset-block-start: 50%;
  inset-inline-start: 50%;
  padding: 10px;
  transform: translate(-50%, -50%);
  background-color: #FF0090;
  color: #ffffff;
  line-height: 1.5;
  font-weight: 900;
}

@media (max-width: 767px) {
  .c-bnr-vision {
    padding: 10px;
  }
  .c-bnr-vision__outer {
    overflow-x: auto;
  }
  .c-bnr-vision__img {
    width: 700px;
  }
  .c-bnr-vision__inner {
    padding: 20px 15px;
  }
  .c-bnr-vision__text p {
    font-size: 15px;
  }
  .c-bnr-vision__btn {
    width: 180px;
    height: 55px;
    font-size: 18px;
  }
}
@media (min-width: 768px) {
  .c-bnr-vision {
    padding: 20px;
  }
  .c-bnr-vision__inner {
    padding: 25px 36px;
  }
  .c-bnr-vision__text p {
    font-size: 24px;
  }
  .c-bnr-vision__btn {
    width: 224px;
    height: 64px;
    font-size: 24px;
  }
}
/*------------------------------------------------------------------------------------
1.12. VIDEO.
------------------------------------------------------------------------------------*/
/*---------- VIDEO VISION ----------*/
.c-video-vision__title {
  font-weight: 700;
  text-align: center;
}
.c-video-vision__body {
  position: relative;
  padding-bottom: 56.25%;
  overflow: hidden;
}
.c-video-vision iframe,
.c-video-vision img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

@media (max-width: 767px) {
  .c-video-vision__title {
    margin-block-end: 15px;
    font-size: 22px;
  }
}
@media (min-width: 768px) {
  .c-video-vision__title {
    margin-block-end: 20px;
    font-size: 36px;
  }
}
/*====================================================================================
2. PROJECT.
====================================================================================*/
/*------------------------------------------------------------------------------------
2.1. PAGE VISION.
------------------------------------------------------------------------------------*/
.p-vision {
  background-color: #e0e9f0;
}
.p-vision img {
  height: auto;
  max-width: 100%;
}
.p-vision .page-visual {
  background: url("../recruit/vision/images/page_img.jpg") no-repeat center center/cover;
}
.p-vision .crumb_list {
  padding: 14px 0;
}

/*------------------------------------------------------------------------------------
2.2. SECTION VISION.
------------------------------------------------------------------------------------*/
.s-vision-about,
.s-vision-report {
  overflow: hidden;
}
.s-vision-about__wrap,
.s-vision-report__wrap {
  background-color: #ffffff;
}

@media (max-width: 767px) {
  .s-vision-about__wrap,
  .s-vision-report__wrap {
    padding-block: 50px;
    border-radius: 25px;
  }
}
@media (min-width: 768px) {
  .s-vision-about__wrap,
  .s-vision-report__wrap {
    max-width: 1490px;
    margin-inline: auto;
    padding-block: 100px;
    border-radius: 52px;
  }
}
/*------------------------------------------------------------------------------------
2.3. SECTION VISION ABOUT.
------------------------------------------------------------------------------------*/
@media (max-width: 767px) {
  .s-vision-about {
    padding-block-start: 30px;
  }
  .s-vision-about .c-title-section {
    margin-block-end: 30px;
  }
  .s-vision-about .c-bnr-vision {
    margin-block-end: 35px;
  }
}
@media (min-width: 768px) {
  .s-vision-about {
    padding-block-start: 60px;
  }
  .s-vision-about .re-container {
    max-width: 1020px;
  }
  .s-vision-about .c-title-section {
    margin-block-end: 60px;
  }
  .s-vision-about .c-bnr-vision {
    margin-block-end: 70px;
  }
}
/*------------------------------------------------------------------------------------
2.4. SECTION VISION REPORT.
------------------------------------------------------------------------------------*/
.s-vision-report__desc p {
  text-align: center;
  letter-spacing: normal;
}

@media (max-width: 767px) {
  .s-vision-report {
    padding-block: 50px;
  }
  .s-vision-report .c-heading-section {
    margin-block-end: 35px;
  }
  .s-vision-report__desc {
    margin-block-end: 25px;
  }
  .s-vision-report__desc p {
    font-size: 16px;
    line-height: 1.7;
  }
  .s-vision-report .c-table-step {
    margin-block-end: 35px;
  }
  .s-vision-report .c-gallery-step {
    margin-block-end: 35px;
  }
  .s-vision-report .c-heading-start {
    margin-block-end: 50px;
  }
  .s-vision-report .c-list-step-vision {
    margin-block-end: 50px;
  }
  .s-vision-report__end {
    padding-block: 70px 50px;
  }
}
@media (min-width: 768px) {
  .s-vision-report {
    padding-block: 100px;
  }
  .s-vision-report .re-container {
    max-width: 1315px;
  }
  .s-vision-report .c-heading-section {
    margin-block-end: 65px;
  }
  .s-vision-report__desc {
    margin-block-end: 50px;
  }
  .s-vision-report__desc p {
    font-size: 27px;
    line-height: 1.4;
  }
  .s-vision-report .c-table-step {
    margin-block-end: 70px;
  }
  .s-vision-report .c-gallery-step {
    margin-block-end: 70px;
  }
  .s-vision-report .c-heading-start {
    margin-block-end: 100px;
  }
  .s-vision-report .c-list-step-vision {
    margin-block-end: 100px;
  }
  .s-vision-report__end {
    padding-block: 250px 200px;
  }
}