@charset "utf-8";

.sub-mv {
  border-bottom: none;
}

.sec-ttl strong {
  letter-spacing: -0.01em;
}

.sec-vision {
  position: relative;
  padding-top: var(--space-140);
}

.sec-vision .mission-txt {
  max-width: 28.125rem;
  margin-inline: auto;
}

.sec-vision .mission-txt p {
  line-height: 2.5;
}

.sec-vision .mission-content {
  position: relative;
  z-index: 1;
}

.sec-vision .bg-logo {
  position: absolute;
  top: 40%;
  left: 50%;
  max-width: 18.75rem;
  z-index: 0;
  transform: translate(-50%, -50%);
}

.sec-overview .info-wrap {
  list-style-type: none;
  display: flex;
  flex-direction: column;
  gap: var(--space-40);
  padding-inline-start: 0;
}

.sec-overview .info-wrap .info-card {
  padding: var(--space-25) var(--space-50);
  border-radius: 20px;
  background-color: var(--clr-neutral-100);
  backdrop-filter: blur(12px);
}

.sec-overview .info-card .info-item {
  display: flex;
  padding-block: 2rem;
}

.sec-overview .info-card .info-item .map-link {
  width: 100%;
}

.sec-overview .info-card .info-item:not(:first-child) {
  border-top: 1px solid #aaa;
}

.sec-overview .info-wrap .info-card .info-ttl {
  font-size: var(--fs-20);
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: var(--space-10);
  width: 30%;
  flex-shrink: 0;
}

.sec-overview .info-wrap .info-card .info-text {
  font-family: var(--font-secondary);
  font-size: var(--fs-18);
  font-weight: 500;
}

.info-card a {
  color: currentColor;
  text-decoration: none;
}

.info-map {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
}

.info-map .map-content {
  display: flex;
  gap: 20px;
}

.info-map .btn-map {
  position: relative;
  background: url(../img/svg/ico_map_circle.svg) no-repeat center / contain;
  width: 2.25rem;
  height: 2.25rem;
  display: block;
  cursor: pointer;
  transition: background .3s ease;
  flex-shrink: 0;
}

.info-map:hover .btn-map {
  scale: 1.2;
  background: url(../img/svg/ico_map_circle_hover.svg) no-repeat center / contain;
  transition: all 0.6s;
}

.sec-mission {
  position: relative;
  overflow: visible;
  background-color: var(--clr-background);
}

.sec-mission .circle-canvas {
  position: absolute;
  top: 55%;
  left: 50%;
  z-index: 0;
  transform: translate(-50%, -50%);
  z-index: 0;
}

.sec-mission .sec-mission-card {
  gap: var(--space-20);
  row-gap: var(--space-70);
  margin-inline: var(--space-30);
  flex-wrap: wrap;
}

/* .sec-mission .card {
  width: 48%;
} */

.sec-mission .sec-mission-card .mission-card {
  display: flex;
  max-width: 27.5rem;
  height: 100%;
  padding: 1.7188rem .8438rem;
  border-radius: 20px;
  border: 2px solid var(--clr-neutral-500);
  backdrop-filter: blur(12px);
  flex-direction: column;
  gap: var(--space-20);
  box-shadow: 0 2px 5px rgba(51, 51, 51, 0.2);
}

.sec-mission .mission-card .sec-ttl strong {
  line-height: 1.1;
  font-size: var(--fs-24);
  letter-spacing: -0.01em;
}

.sec-overview .overview-info {
  display: flex;
  margin-bottom: var(--space-55);
  justify-content: space-between;
  gap: var(--space-80);
}

.sec-overview .overview-info .sec-info {
  max-width: 43.75rem;
}

.sec-overview .overview-info .sec-info p {
  line-height: 1.5;
  font-family: var(--font-secondary);
  font-size: var(--fs-18);
  font-weight: 400;
  letter-spacing: 0;
}

.sec-overview .overview-img-wrap {
  display: grid;
  grid-template-columns: auto 23.4375rem;
  grid-template-rows: auto auto;
  gap: 1.25rem;
  max-height: 29.375rem;
}

.sec-overview .overview-img-wrap .overview-img.img-lg {
  grid-row: 1 / span 2;
  grid-column: 1;
}

.overview-swiper-container {
  max-width: 100%;
  position: relative;
}

.overview-swiper {
  width: 100%;
  max-height: 35rem;
  border-radius: 20px;
  overflow: hidden;
  aspect-ratio: 16 / 9;
}

.overview-swiper-wrap {
  border-radius: 20px;
}

.overview-slide {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 20px;
  overflow: hidden;
}

.overview-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

@media (max-width: 64em) {
  .overview-swiper-container {
    padding-bottom: 50px;
  }

  .overview-swiper-wrap {
    max-width: 100%;
  }

  .swiper-pagination-vertical.swiper-pagination-bullets,
  .swiper-vertical>.swiper-pagination-bullets {
    top: unset;
    right: unset;
    width: 100%;
    height: auto;
    margin-top: 30px;
    bottom: 0;
  }

  .sec-mission .sec-mission-card {
    justify-content: center;
  }
}

@media (max-width: 48em) {
  .sub-mv {
    padding-block: 3rem var(--space-40);
  }

  .sub-mv-inner .sub-mv-txt {
    margin-top: 0;
  }

  .sub-mv .sub-mv-inner,
  .sec-mission h2,
  .sec-overview .sec-overview-inner {
    padding-inline: var(--space-15);
  }

  .sec-wrap {
    --max-width: 600px;
    --padding: var(--space-30);
  }

  .sec-ttl small {
    font-size: var(--fs-14);
  }

  .sec-ttl strong {
    font-size: var(--fs-32);
  }

  .sec-vision .mission-txt p {
    line-height: 1.8;
  }

  .sec-overview .info-wrap .info-card {
    padding: var(--space-20);
  }

  .sec-overview .info-wrap .info-card .info-ttl {
    font-size: var(--fs-18);
  }

  .sec-overview .info-wrap .info-card .info-text {
    font-size: var(--fs-16);
  }

  .sec-overview .info-card .info-item {
    flex-direction: column;
    padding-block: 1.5rem;
  }

  .sec-overview .info-wrap .info-card .info-ttl {
    width: 100%;
  }

  .sec-overview .info-wrap .info-map {
    flex-direction: column;
    align-items: flex-start;
  }

  .info-map .map-content {
    align-items: center;
  }

  .sec-overview.sec-padding {
    padding-block: var(--space-80);
  }

  .sec-overview .overview-info {
    margin-bottom: var(--space-40);
    flex-direction: column;
    gap: var(--space-45);
  }

  .sec-overview .overview-info .sec-info {
    max-width: 100%;
  }

  .sec-overview .overview-info .sec-info p,
  .sec-overview .info-box small {
    font-size: var(--fs-16);
  }

  .sec-overview .overview-img {
    gap: var(--space-40);
  }

  .sec-overview .overview-img img {
    border-radius: 1.25rem;
  }

  .overview-swiper {
    min-height: unset;
  }

  .sec-mission .mission-card .sec-ttl strong {
    font-size: var(--fs-20);
    font-weight: 600;
  }

  .sec-mission .card {
    max-width: 25rem;
    margin-inline: auto;
  }

  .sec-mission .circle-canvas {
    position: sticky;
    top: 5rem;
    transform: unset;
    width: 100%;
    height: 100%;
  }

  .sec-mission .sec-wrap {
    margin-top: -100%;
  }
}