@charset "UTF-8";
@media screen and (max-width: 767px) {
  .vision-section-main__body,
  .vision-Mission {
    font-size: 16px;
  }
}

/* ---------------------------------------------
*   vision-page-title
--------------------------------------------- */
.c-ttl-border-bottom::after {
  content: none;
}
@media screen and (min-width: 360px) {
  .c-ttl-border-bottom__sub-txt {
    margin: 4px 0;
    font-size: 16px;
    letter-spacing: 0.05em;
  }
}

.vision-visual {
  overflow: hidden;
}
.vision-visual img {
  position: relative;
  left: 50%;
  width: auto;
  max-width: none;
  height: 300px;
  transform: translateX(-50%);
}
@media screen and (min-width: 1477px) {
  .vision-visual img {
    max-width: 100%;
    height: auto;
  }
}

/* ---------------------------------------------
*   vision-section
--------------------------------------------- */
.vision-section {
  padding-top: 115px;
}
@media screen and (max-width: 767px) {
  .vision-section {
    padding-top: 55px;
  }
}
.vision-section__ttl {
  position: relative;
  padding-bottom: 18px;
  font-size: 32px;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .vision-section__ttl {
    font-size: 24px;
  }
}
.vision-section__ttl::before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 60px;
  height: 2px;
  background-color: var(--color-red-1);
}
.vision-section__ttl--center {
  text-align: center;
  /*			z-index: 100;*/
}
.vision-section__ttl--center::before {
  left: 50%;
  transform: translateX(-50%);
}

/* ---------------------------------------------
*   vision-anchor
--------------------------------------------- */
.vision-anchor__list {
  display: flex;
  justify-content: space-between;
  gap: 1px;
  border-radius: 8px;
  box-shadow: 0 0 12px 0 rgba(0, 0, 0, 0.12);
}
@media screen and (max-width: 1024px) {
  .vision-anchor__list {
    display: block;
  }
}
.vision-anchor__item {
  position: relative;
  flex: 1;
}
.vision-anchor__item:not(:last-child)::before {
  position: absolute;
  content: "";
  background-color: var(--color-gray-2);
  bottom: 50%;
  right: 0;
  width: 1px;
  height: 30px;
  transform: translateY(50%);
}
@media screen and (max-width: 1024px) {
  .vision-anchor__item:not(:last-child)::before {
    background-color: var(--color-gray-1);
    bottom: 0;
    width: 100%;
    height: 1px;
    transform: none;
  }
}
.vision-anchor__link {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 90px;
}
@media (hover: hover) and (pointer: fine) {
  .vision-anchor__link {
    transition: color 0.3s;
  }
  .vision-anchor__link:hover {
    color: var(--color-red-1);
  }
}
@media screen and (max-width: 1024px) {
  .vision-anchor__link {
    justify-content: start;
    height: 54px;
  }
}
.vision-anchor__link::before {
  content: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="10" height="7" viewBox="0 0 10 7"><path d="M5,6.71L.29,2C-.1,1.61-.1.98.29.59S1.32.2,1.71.59l3.29,3.29,3.29-3.29c.39-.39,1.02-.39,1.41,0s.39,1.02,0,1.41l-4.71,4.71Z" style="fill: %23b5031d;"/></svg>');
  position: absolute;
  display: block;
  width: 10px;
  height: 7px;
  bottom: 10px;
  right: 50%;
  transform: translate(50%, 0);
  font-size: 0;
}
@media screen and (max-width: 1024px) {
  .vision-anchor__link::before {
    bottom: 50%;
    transform: translate(0, 50%);
    right: 18px;
  }
}
.vision-anchor__txt {
  display: block;
  line-height: 1.3;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 1024px) {
  .vision-anchor__txt {
    padding-left: 18px;
  }
  .vision-anchor__txt br {
    display: none;
  }
}

/* ---------------------------------------------
*   vision-icon-link
--------------------------------------------- */
.vision-iconlink__txt {
  display: inline-flex;
  justify-content: end;
  align-items: center;
  gap: 8px;
  font-weight: bold;
  transition: color 0.3s;
}
.vision-iconlink__txt:hover {
  color: var(--color-red-1);
  --vico-arr1: var(--color-white-1);
  --vico-arr0: var(--color-red-1);
}
.vision-iconlink__button {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  width: 390px;
  max-width: 100%;
  height: 56px;
  margin: 0 auto;
  color: var(--color-white-1);
  font-weight: bold;
  border: 1px solid var(--color-red-1);
  background-color: var(--color-red-1);
  border-radius: 100vw;
  --vico-arr1: var(--color-white-1);
  --vico-arr0: var(--color-red-1);
  transition: color 0.3s, background-color 0.3s;
}
.vision-iconlink__button:not([target])::before {
  content: "";
}
.vision-iconlink__button:hover {
  color: var(--color-red-1);
  background-color: var(--color-white-1);
  --vico-arr1: var(--color-red-1);
  --vico-arr0: var(--color-white-1);
}
.vision-iconlink--size1 {
  width: 13px;
  height: 13px;
  flex: 0 0 13px;
}
.vision-iconlink--size2 {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
}
.vision-iconlink--size3 {
  width: 24px;
  height: 24px;
  flex: 0 0 24px;
}

/* ---------------------------------------------
*   vision-number
--------------------------------------------- */
.vision__txt--num {
  color: var(--color-red-1);
}
.vision__txt--num em {
  font-size: 48px;
}
@media screen and (max-width: 1024px) {
  .vision__txt--num em {
    font-size: 40px;
  }
}
.vision__txt--num span {
  font-size: 20px;
}
@media screen and (max-width: 1024px) {
  .vision__txt--num span {
    font-size: 18px;
  }
}
.vision__txt--num-note {
  display: block;
  font-size: 15px;
}

/* ---------------------------------------------
*   モビリティで世界中の人に安全と自由を
--------------------------------------------- */
.vision-header {
  display: flex;
  justify-content: space-between;
  gap: 55px;
  max-width: 1052px;
  margin: 80px auto 0;
  margin: min(4.6vw + 33px, 80px) auto 0;
}
@media screen and (max-width: 1024px) {
  .vision-header {
    display: block;
  }
}
.vision-header__fig {
  max-width: 423px;
  flex-shrink: 0;
}
.vision-header__fig img {
  border-radius: 8px;
}
@media screen and (max-width: 1024px) {
  .vision-header__col {
    margin-top: 35px;
  }
}
.vision-header__ttl {
  font-size: 32px;
  line-height: 1.3;
  font-weight: bold;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .vision-header__ttl {
    font-size: 27px;
    letter-spacing: 0;
  }
}
.vision-header__txt {
  line-height: 1.6;
  margin-top: 25px;
}

/* ---------------------------------------------
*   数字で見るAstemo
--------------------------------------------- */
.vision-Number__list {
  padding: 40px 0 0 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 min(7vw - 42px, 56px);
  /*@media screen and (max-width: 1024px) {*/
}
@media screen and (max-width: 1280px) {
  .vision-Number__list {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.vision-Number__item {
  min-height: 145px;
  padding: 30px 12px 36px 12px;
}
@media screen and (max-width: 767px) {
  .vision-Number__item {
    min-height: 0;
    padding: 24px 12px;
  }
}
.vision-Number__item {
  flex: 1;
  display: flex;
  justify-content: space-between;
  border-top: solid 1px var(--color-gray-1);
}
.vision-Number__item:nth-last-child(-n+2) {
  min-height: 125px;
  border-bottom: solid 1px var(--color-gray-1);
}
@media screen and (max-width: 560px) {
  .vision-Number__item {
    display: block;
  }
}
.vision-Number__item--wrap {
  flex-wrap: wrap;
}
.vision-Number__target {
  font-size: 18px;
  line-height: 1.3;
  font-weight: bold;
}
.vision-Number__period {
  display: block;
  padding-top: 6px;
  font-size: 12px;
  line-height: 1.3;
  color: var(--color-black-3);
}
.vision-Number__period span {
  position: relative;
  display: block;
  padding: 1px 0 0 20px;
}
.vision-Number__period span::before {
  position: absolute;
  content: "";
  top: 50%;
  left: 8px;
  width: 4px;
  height: 4px;
  background-color: #3d3d3d;
  border-radius: 2px;
  transform: translate(0, -50%);
}
.vision-Number__period span:last-child {
  margin-bottom: -10px;
}
.vision-Number__number {
  flex: 0 0 auto;
  display: flex;
  justify-content: end;
  padding: 8px 0 0 0;
}
.vision-Number__number div {
  /* 連結売上収益 */
  display: flex;
  justify-content: space-between;
  align-items: end;
}
.vision-Number__number div + div {
  padding-top: 15px;
}
.vision-Number__label {
  /* 連結売上収益 */
  margin: 0 8px 4px 0;
  font-size: clamp(14px, 1.6vw - 2.4px, 16px);
}
.vision-Number__value {
  line-height: 1;
  text-align: right;
  white-space: nowrap;
}
.vision-Number__value em {
  margin: 0 5px;
  font-size: clamp(40px, 6.4vw - 25px, 48px);
}
.vision-Number__value em[class] {
  font-size: 32px;
  font-size: clamp(28px, 3.2vw + 32px, 32px);
}
.vision-Number__value em > span {
  font-size: 0.75em;
}
.vision-Number__value > span {
  font-size: clamp(18px, 1.6vw + 1.6px, 20px);
}
.vision-Number__value i {
  margin-top: 0.5em;
  font-size: 15px;
  text-align: right;
}
.vision-Number__value--column {
  display: block;
  margin-top: 0.5em;
  text-align: right;
}
.vision-Number__link {
  flex: 0 0 100%;
  display: flex;
  flex-direction: column;
  align-items: end;
  padding-top: 12px;
}
.vision-Number__link span {
  font-size: clamp(14px, 1.6vw - 2.4px, 16px);
}

/* ---------------------------------------------
*  事業構成
--------------------------------------------- */
.vision-Composition__column {
  display: flex;
  justify-content: space-between;
  padding: 40px 0 46px 0;
}
@media screen and (max-width: 1024px) {
  .vision-Composition__column {
    display: block;
  }
}
.vision-Composition__txt-group {
  flex: 0 0 31%;
}
.vision-Composition__ttl {
  font-size: min(1vw + 16px, 24px);
  line-height: 1.3;
  font-weight: bold;
}
.vision-Composition p {
  line-height: 1.6;
}
.vision-Composition__txt {
  padding: 20px 0 18px 0;
}
.vision-Composition__txt em {
  position: relative;
  display: block;
  margin: 3px 0 0 15px;
  font-weight: bold;
}
.vision-Composition__txt em:first-child {
  margin-top: 12px;
}
.vision-Composition__txt em:last-child {
  margin-bottom: 12px;
}
.vision-Composition__txt em::before {
  position: absolute;
  content: "";
  top: 50%;
  left: -15px;
  width: 8px;
  height: 1px;
  background-color: var(--color-red-1);
  transform: translate(0, -50%);
}
.vision-Composition__figure {
  flex: 0 0 65.2%;
  padding: 0;
}
@media screen and (max-width: 1024px) {
  .vision-Composition__figure {
    padding: 45px 0 0 0;
  }
}
@media screen and (max-width: 767px) {
  .vision-Composition__figure {
    padding: 35px 0 0 0;
  }
}
.vision-Composition__figtxt {
  position: relative;
}
@media screen and (max-width: 1024px) {
  .vision-Composition__figtxt {
    width: 640px;
    max-width: 100%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .vision-Composition__figtxt {
    width: 346px;
  }
}
.vision-Composition__figtxt img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .vision-Composition__figtxt img {
    padding: 20px 0 0;
  }
}
.vision-Composition__grid {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-areas: "b a c" "d a e";
  grid-template-columns: 0.67fr 1fr 0.77fr;
  grid-template-rows: 0.84fr 1fr;
  gap: 10px;
}
.vision-Composition__grid > div:nth-child(1) {
  grid-area: b;
}
.vision-Composition__grid > div:nth-child(2) {
  grid-area: c;
}
.vision-Composition__grid > div:nth-child(3) {
  grid-area: d;
}
.vision-Composition__grid > div:nth-child(4) {
  grid-area: e;
}
@media screen and (max-width: 767px) {
  .vision-Composition__grid > div:nth-child(4) {
    align-self: end;
  }
}
.vision-Composition__grid > div:nth-child(5) {
  grid-area: a;
}
@media screen and (max-width: 767px) {
  .vision-Composition__grid > div:nth-child(5) {
    align-self: center;
  }
}
@media screen and (max-width: 767px) {
  .vision-Composition__grid {
    grid-template-areas: "b c" "a a" "d e";
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1fr 1fr 1fr;
  }
}
.vision-Composition__grid > div {
  padding-top: min(4.5vw - 28px, 35px);
}
@media screen and (max-width: 1024px) {
  .vision-Composition__grid > div {
    padding-top: 25px;
  }
}
@media screen and (max-width: 767px) {
  .vision-Composition__grid > div {
    padding-top: 0;
  }
}
.vision-Composition__item--biz .vision__txt--num em {
  font-size: min(4vw - 2px, 54px);
  line-height: 1.3;
}
@media screen and (max-width: 1024px) {
  .vision-Composition__item--biz .vision__txt--num em {
    font-size: 44px;
  }
}
@media screen and (max-width: 767px) {
  .vision-Composition__item--biz .vision__txt--num em {
    font-size: 30px;
  }
}
.vision-Composition__item--biz .vision__txt--num span {
  font-size: min(1.6vw - 2.4px, 20px);
  line-height: 1.3;
}
@media screen and (max-width: 1024px) {
  .vision-Composition__item--biz .vision__txt--num span {
    font-size: 14.5px;
  }
}
@media screen and (max-width: 767px) {
  .vision-Composition__item--biz .vision__txt--num span {
    font-size: 13px;
  }
}
.vision-Composition__item--biz .vision-iconlink__txt span {
  font-size: min(1.1vw + 1px, 16px);
  white-space: nowrap;
}
@media screen and (max-width: 1024px) {
  .vision-Composition__item--biz .vision-iconlink__txt span {
    font-size: 13px;
  }
}
@media screen and (max-width: 767px) {
  .vision-Composition__item--biz .vision-iconlink__txt span {
    font-size: 13px;
    line-height: 1.3;
    text-align: left;
    white-space: nowrap;
  }
}
@media screen and (min-width: 768px) {
  .vision-Composition__item--biz .vision-iconlink__txt span br {
    display: none;
  }
}
.vision-Composition__item--biz .vision-iconlink__txt .vision-iconlink--size3 {
  width: clamp(17px, 1.75vw - 0.5px, 24px);
  height: clamp(17px, 1.75vw - 0.5px, 24px);
  flex: 0 0 clamp(17px, 1.75vw - 0.5px, 24px);
  margin-top: -3px;
}
@media screen and (max-width: 1400px) {
  .vision-Composition__item--biz .vision-iconlink__txt .vision-iconlink--size3 {
    width: 24px;
    height: 24px;
    flex: 0 0 24px;
  }
}
@media screen and (max-width: 1300px) {
  .vision-Composition__item--biz .vision-iconlink__txt .vision-iconlink--size3 {
    width: 22px;
    height: 22px;
    flex: 0 0 22px;
  }
}
@media screen and (max-width: 1200px) {
  .vision-Composition__item--biz .vision-iconlink__txt .vision-iconlink--size3 {
    width: 20px;
    height: 20px;
    flex: 0 0 20px;
  }
}
@media screen and (max-width: 1100px) {
  .vision-Composition__item--biz .vision-iconlink__txt .vision-iconlink--size3 {
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
  }
}
@media screen and (max-width: 1024px) {
  .vision-Composition__item--biz .vision-iconlink__txt .vision-iconlink--size3 {
    width: 17px;
    height: 17px;
    flex: 0 0 17px;
  }
}
.vision-Composition__item--r {
  display: flex;
  justify-content: end;
}
.vision-Composition__item--color1 {
  color: #41010A;
}
.vision-Composition__item--color1 button {
  color: #41010A;
}
.vision-Composition__item--color1 .vision-iconlink__txt {
  --vico-arr1: #41010A;
  --vico-arr2: #41010A;
}
.vision-Composition__item--color1 .vision-iconlink__txt:hover {
  --vico-arr1: var(--color-white-1);
  --vico-arr2: var(--color-red-1);
}
.vision-Composition__item--color2 {
  color: var(--color-red-1);
}
.vision-Composition__item--color2 button {
  color: var(--color-red-1);
}
.vision-Composition__item--color3 {
  color: #8A0216;
}
.vision-Composition__item--color3 button {
  color: #8A0216;
}
.vision-Composition__item--color3 .vision-iconlink__txt {
  --vico-arr1: #8A0216;
  --vico-arr2: #8A0216;
}
.vision-Composition__item--color3 .vision-iconlink__txt:hover {
  --vico-arr1: var(--color-white-1);
  --vico-arr2: var(--color-red-1);
}
.vision-Composition__fig {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
.vision-Composition__fig::before {
  content: "";
  flex: 0 0 29%;
}
@media screen and (max-width: 767px) {
  .vision-Composition__fig::before {
    flex: 0 0 20px;
  }
}
.vision-Composition__fig--ttl {
  font-size: min(0.8vw + 6.8px, 18px);
  flex: 0 0 8%;
}
@media screen and (max-width: 1024px) {
  .vision-Composition__fig--ttl {
    flex: 0 0 28px;
    font-size: 16px;
  }
}
@media screen and (max-width: 767px) {
  .vision-Composition__fig--ttl {
    flex: 0 0 28px;
    font-size: 16px;
  }
}
.vision-Composition__fig--num {
  flex: 0 0 19%;
  color: var(--color-red-1);
  text-align: center;
}
.vision-Composition__fig--num em {
  font-size: min(2.667vw + 10.667px, 48px);
  line-height: 1;
  letter-spacing: -0.03em;
}
@media screen and (max-width: 1024px) {
  .vision-Composition__fig--num em {
    font-size: 38px;
  }
}
@media screen and (max-width: 767px) {
  .vision-Composition__fig--num em {
    font-size: 32px;
  }
}
.vision-Composition__fig--num em > span {
  font-size: min(2.5vw, 36px);
}
.vision-Composition__fig--num > span {
  font-size: min(0.267vw + 10.267px, 14px);
  line-height: 1;
}
@media screen and (max-width: 1024px) {
  .vision-Composition__fig--num > span {
    font-size: 14px;
  }
}
@media screen and (max-width: 767px) {
  .vision-Composition__fig--num > span {
    font-size: 12px;
  }
}
.vision-Composition__fig--note {
  flex: 1 0 auto;
  font-size: min(0.8vw + 4.8px, 16px);
}
@media screen and (max-width: 1024px) {
  .vision-Composition__fig--note {
    font-size: 14px;
  }
}
@media screen and (max-width: 767px) {
  .vision-Composition__fig--note {
    font-size: 12px;
  }
}
.vision-Composition__fig {
  /* item */
}
@media screen and (max-width: 1024px) {
  .vision-Composition__fig {
    font-size: 14px;
  }
}

/* Modal
--------------------------------------------- */
.c-modal__close {
  width: 26px;
  right: 0;
  background: url('data:image/svg+xml;utf-8, <svg xmlns="http://www.w3.org/2000/svg" width="26" height="26" viewBox="0 0 26 26"> <polygon points="26 24.63 14.37 13 26 1.37 24.63 0 13 11.63 1.37 0 0 1.37 11.64 13 0 24.63 1.37 26 13 14.37 24.63 25.99 26 24.63" fill="%23b5031d" fill-rule="evenodd"/></svg>');
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .c-modal__close {
    width: 20px;
    height: 20px;
  }
}

.c-modal__inner {
  padding: 55px 40px;
}
@media screen and (max-width: 767px) {
  .c-modal__inner {
    padding: 50px min(6vw - 8px, 40px);
  }
}
.c-modal__inner .c-modal__container {
  padding: 0 min(5.4vw - 40px, 30px);
}

.vision-modal__ttl {
  margin: 0 0 30px 0;
  font-size: 24px;
  font-weight: bold;
}
.vision-modal__column {
  display: flex;
  justify-content: space-between;
  gap: 40px;
}
@media screen and (max-width: 767px) {
  .vision-modal__column {
    display: block;
  }
}
.vision-modal__fig {
  flex: 1;
}
.vision-modal__fig img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .vision-modal__fig {
    margin: 0 0 25px 0;
  }
}
.vision-modal__body {
  flex: 1;
}
.vision-modal__txt {
  margin: 0;
  line-height: 1.6;
}
.vision-modal__list-ttl {
  position: relative;
  margin: 1.4em 0 0.4em 0;
  padding: 0 0 0 20px;
  font-weight: bold;
}
.vision-modal__list-ttl::before {
  position: absolute;
  content: "";
  top: 50%;
  left: 0;
  width: 8px;
  height: 1px;
  background-color: var(--color-red-1);
  transform: translate(0, -50%);
}
.vision-modal__list-ttl a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: color 0.3s;
}
.vision-modal__list-ttl a:hover {
  color: var(--color-red-1);
  --vico-arr1: var(--color-white-1);
  --vico-arr0: var(--color-red-1);
}
.vision-modal__list-ttl a svg {
  margin-top: -3px;
}
.vision-modal__list--sub {
  list-style-type: "・";
}
.vision-modal__list--sub li {
  margin: 0.1em 0 5px 15px;
  font-size: 14px;
}

/* ---------------------------------------------
*  MISSION
--------------------------------------------- */
.vision-Mission__visual {
  position: relative;
  margin: 0 0 100px;
}
@media screen and (max-width: 767px) {
  .vision-Mission__visual {
    margin: 5px 0 60px;
  }
}
.vision-Mission__visual.show figure::before,
.vision-Mission__visual.show figure::after {
  height: 0;
  transition: height 0.5s ease-in-out 0s;
}
.vision-Mission__visual.show p {
  opacity: 1;
}
.vision-Mission__visual-fig {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.vision-Mission__visual-fig img {
  position: relative;
  z-index: 1;
  left: 50%;
  width: auto;
  max-width: none;
  height: 300px;
  transform: translateX(-50%);
}
@media screen and (min-width: 1477px) {
  .vision-Mission__visual-fig img {
    max-width: 100%;
    height: auto;
  }
}
.vision-Mission__visual-fig::before, .vision-Mission__visual-fig::after {
  position: absolute;
  z-index: 2;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 50%;
  background: #fff;
}
.vision-Mission__visual-fig::before {
  top: auto;
  bottom: 0;
}
.vision-Mission__visual-txt {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
.vision-Mission__visual-ttl {
  color: #fff;
  font-weight: bold;
  text-align: center;
  opacity: 0;
  transition: opacity 0.5s ease-in-out 0.2s;
}
.vision-Mission__visual-ttl--small {
  display: block;
  font-size: 24px;
  letter-spacing: 0.14em;
}
@media screen and (max-width: 767px) {
  .vision-Mission__visual-ttl--small {
    font-size: 20px;
  }
}
.vision-Mission__visual-ttl--main {
  display: block;
  padding: 0.3em 0;
  font-size: 32px;
}
@media screen and (max-width: 1024px) {
  .vision-Mission__visual-ttl--main {
    font-size: 29px;
  }
}
@media screen and (max-width: 767px) {
  .vision-Mission__visual-ttl--main {
    font-size: 26px;
    line-height: 1.4;
  }
}
@media screen and (min-width: 768px) {
  .vision-Mission__visual-ttl--main br {
    display: none;
  }
}
.vision-Mission__txt {
  max-width: 46em;
  margin: 35px auto -40px;
  padding-inline: calc(var(--shared-contents-side-padding) * 1px);
  font-size: 26px;
  line-height: 1.6;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .vision-Mission__txt {
    font-size: 20px;
  }
}
@media screen and (min-width: 768px) {
  .vision-Mission__txt br {
    display: none;
  }
}

/* ---------------------------------------------
*  主な先進技術
--------------------------------------------- */
.vision-Advanced__fig {
  text-align: center;
}

.vision-Advanced-header {
  padding-top: 40px;
}
.vision-Advanced-header__txt {
  margin: 20px auto 20px;
  font-size: 18px;
  line-height: 1.6;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .vision-Advanced-header__txt {
    font-size: 16px;
    text-align: left;
  }
  .vision-Advanced-header__txt br {
    display: none;
  }
}

.vision-Advanced-field--first {
  padding: 60px 0 0 0;
}
.vision-Advanced-field--second {
  padding: 125px 0 0 0;
}
@media screen and (max-width: 767px) {
  .vision-Advanced-field--second {
    padding: 60px 0 0 0;
  }
}
.vision-Advanced-field--third {
  padding: 100px 0 0 0;
}
@media screen and (max-width: 767px) {
  .vision-Advanced-field--third {
    padding: 60px 0 0 0;
  }
}
.vision-Advanced-field__ttl {
  font-size: 28px;
  font-weight: bold;
  text-align: center;
}
.vision-Advanced-field__ttl img {
  display: block;
  margin: 0 auto 15px;
}
.vision-Advanced-field__lead {
  text-align: center;
}
.vision-Advanced-field__lead span {
  display: inline-block;
}
.vision-Advanced-field {
  /*  簡易カード型リンク  */
}
.vision-Advanced-field__list {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 40px;
  padding: 55px 0 0 12px;
}
@media screen and (max-width: 1024px) {
  .vision-Advanced-field__list {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (max-width: 767px) {
  .vision-Advanced-field__list {
    padding: 35px 0 0 12px;
    grid-template-columns: 1fr;
    gap: 25px;
  }
}
.vision-Advanced-field__item {
  position: relative;
  display: flex;
  flex-direction: column;
}
.vision-Advanced-field__item::before {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 2px;
  height: calc(100% - 5px);
  background-color: var(--color-gray-1);
}
.vision-Advanced-field__cttl {
  position: relative;
  padding: 0 0 0 25px;
  font-size: 16px;
  line-height: 1.3;
  color: var(--color-red-1);
  font-weight: bold;
}
.vision-Advanced-field__cttl::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 2px;
  height: 1.1em;
  background-color: var(--color-red-1);
  transition: width 0.3s;
}
.vision-Advanced-field__txt {
  position: relative;
  flex-grow: 1;
  display: flex;
  justify-content: space-between;
  flex-direction: column;
  padding: 15px 20px 0 25px;
  line-height: 1.7;
}
@media screen and (max-width: 767px) {
  .vision-Advanced-field__txt {
    padding: 15px 0 0 25px;
  }
}
.vision-Advanced-field__link {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 138px;
  height: 46px;
  margin: 12px 0 0 0;
  padding: 2px 0 0 0;
  font-size: 16px;
  font-weight: bold;
  color: var(--color-red-1);
  border: solid 1px var(--color-red-1);
  border-radius: 200px;
  transition: color 0.3s, background-color 0.3s;
}
.vision-Advanced-field__link:hover {
  color: var(--color-white-1);
  background: var(--color-red-1);
  --vico-arr1: var(--color-white-1);
}
.vision-Advanced-field__link svg {
  display: inline-block;
  margin-left: 8px;
  vertical-align: top;
}
.vision-Advanced-field__fig {
  padding: 45px 0 60px;
}
@media screen and (max-width: 767px) {
  .vision-Advanced-field__fig {
    padding: 45px 0;
  }
}
@media screen and (max-width: 767px) {
  .vision-Advanced-field__fig--first picture {
    display: block;
    overflow-x: auto;
  }
}
.vision-Advanced-field__fig--first img {
  min-width: 596px;
}
.vision-Advanced-field__button {
  margin-bottom: 0px;
}

.vision-Advanced-box {
  display: flex;
  justify-content: space-between;
  margin: 60px 12px 15px;
  padding: 20px 30px;
  background: var(--color-gray-3);
  border: solid 1px var(--color-gray-3);
  transition: border-color 0.3s ease-in-out 0s;
}
@media screen and (max-width: 767px) {
  .vision-Advanced-box {
    margin: 40px 0 0 12px;
    padding: 15px 20px 10px;
    line-height: 1.6;
  }
}
.vision-Advanced-box:hover {
  border-color: var(--color-red-1);
}
.vision-Advanced-box__ttl {
  display: block;
  color: var(--color-red-1);
}
.vision-Advanced-box__txt {
  display: block;
  margin: 10px 20px 8px 0;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .vision-Advanced-box__txt {
    margin: 5px 20px 8px 0;
  }
}
.vision-Advanced-box__txt {
  color: var(--color-base-1);
  font-weight: normal;
}
.vision-Advanced-box:hover __txt {
  color: var(--color-base-1);
}

/* ---------------------------------------------
*  サステナビリティ
--------------------------------------------- */
@media screen and (max-width: 767px) {
  .vision-Sustainability {
    padding-top: 100px;
  }
}
.vision-Sustainability__column {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 55px;
  padding: 40px 0 55px;
}
@media screen and (max-width: 1024px) {
  .vision-Sustainability__column {
    grid-template-columns: 1fr;
    gap: 15px;
  }
}
.vision-Sustainability__item {
  padding: 15px 15px 0 0;
  border-top: solid 1px var(--color-gray-1);
}
.vision-Sustainability__link {
  display: flex;
  justify-content: space-between;
  gap: 25px;
}
.vision-Sustainability__link--thumb {
  flex: 0 0 166px;
  border-radius: 8px;
  overflow: hidden;
}
@media screen and (max-width: 1024px) {
  .vision-Sustainability__link--thumb {
    flex: 0 0 115px;
  }
}
.vision-Sustainability__link--txt {
  flex: 1 1 auto;
}

/*# sourceMappingURL=vision.css.map */