.sec-link {
  padding: 0 4.1666666667vw;
}
@media (max-width: 759px) {
  .sec-link {
    padding: 0 0;
  }
}

.main {
  margin-top: 0;
}

.top-head {
  position: relative;
  margin-top: 7.6388888889vw;
  margin-bottom: 10.4166666667vw;
}
@media (max-width: 759px) {
  .top-head {
    margin-top: 24vw;
    margin-top: 18vw;
    margin-bottom: 0;
  }
}
.top-head__title {
  font-size: 7.3611111111vw;
  font-weight: 600;
  color: #B12E2A;
  line-height: 1.188;
  mix-blend-mode: multiply;
  margin: 0 4.1666666667vw 1.5277777778vw;
}
@media (max-width: 759px) {
  .top-head__title {
    font-size: 12.2666666667vw;
    line-height: 1.304;
    margin: 0 8vw 3.7333333333vw;
  }
}
.top-head__text {
  color: #FFF;
  font-size: 1.9444444444vw;
  margin: 0 4.1666666667vw;
}
@media (max-width: 759px) {
  .top-head__text {
    font-size: 4.8vw;
    margin: 0 8vw;
  }
}
.top-head__text--small {
  font-size: 0.9722222222vw;
  margin: 0 -0.2083333333vw 0 -0.1388888889vw;
}
@media (max-width: 759px) {
  .top-head__text--small {
    font-size: 3.2vw;
    margin: 0;
  }
}
.top-head__scroll {
  transform: rotate(90deg);
  transform-origin: left center 0;
  position: absolute;
  left: 0;
  top: 0;
  margin: 24.7222222222vw 0 0 4.4444444444vw;
  width: 12.0833333333vw;
  font-size: 0.7638888889vw;
  color: #FFF;
  transition: 0.2s ease-in-out;
  font-family: "Josefin Sans", sans-serif;
}
@media (max-width: 759px) {
  .top-head__scroll {
    margin: 82.6666666667vw 0 0 5.3333333333vw;
    width: 36.2666666667vw;
    font-size: 2.4vw;
  }
}
.top-head__scroll::before {
  content: "";
  position: absolute;
  top: 30%;
  right: 0;
  width: 8.2638888889vw;
  height: 1px;
  background: #FFF;
  transition: 0.2s ease-in-out;
}
@media (max-width: 759px) {
  .top-head__scroll::before {
    width: 24vw;
  }
}
.top-head__scroll::after {
  content: "";
  position: absolute;
  transform: scale(0.7);
  top: 32%;
  right: -0.4166666667vw;
  transform: translateY(-50%);
  box-sizing: border-box;
  width: 0.5555555556vw;
  height: 0.5555555556vw;
  border: 0.4166666667vw solid transparent;
  border-left: 0.4166666667vw solid #FFF;
}
@media (max-width: 759px) {
  .top-head__scroll::after {
    right: -0.8vw;
    width: 1.0666666667vw;
    height: 1.0666666667vw;
    border: 0.8vw solid transparent;
    border-left: 0.8vw solid #FFF;
  }
}
@media (min-width: 760px) {
  .top-head__scroll:hover {
    width: 14.1666666667vw;
  }
  .top-head__scroll:hover::before {
    width: 10.3472222222vw;
    height: 1px;
    background: #FFF;
  }
}
.top-head__video {
  position: relative;
  margin-top: -7.4305555556vw;
  z-index: -1;
  height: 50vw;
  width: 100%;
}
@media (max-width: 759px) {
  .top-head__video {
    margin-top: -18.1333333333vw;
    height: 133.3333333333vw;
  }
}
.top-head__video::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(39, 56, 95, 0.5);
  mix-blend-mode: multiply;
}
.top-head__video video {
  object-fit: cover;
  position: absolute;
  height: 100%;
  width: 100%;
  top: 0;
  left: 0;
}

.about.sec {
  position: relative;
}
@media (min-width: 760px) {
  .about.sec {
    margin-bottom: 6.4583333333vw;
  }
}
@media (max-width: 759px) {
  .about.sec {
    margin-bottom: 21.3333333333vw;
  }
}
.about.sec .sec-head {
  margin-bottom: 0.6944444444vw;
}
@media (max-width: 759px) {
  .about.sec .sec-head__title {
    margin-top: 21.3333333333vw;
  }
}
@media (min-width: 760px) {
  .about.sec .sec-head__title__ja {
    font-size: 0.9027777778vw;
    font-weight: 600;
  }
}
@media (max-width: 759px) {
  .about.sec .sec-head__title__en {
    font-size: 10.6666666667vw;
  }
}
.about.sec .sec-slide {
  position: relative;
}
@media (max-width: 759px) {
  .about.sec .sec-slide {
    margin-top: 22.6666666667vw;
    padding-top: 0;
  }
}
.about.sec .sec-slide .swiper-slide .sec-inner {
  opacity: 0;
}
.about.sec .sec-slide .swiper-slide-active .sec-inner {
  opacity: 1;
}
.about.sec .sec-slide .swiper-slide:not(.swiper-slide-active) {
  height: 0;
}
.about.sec .sec-slide-wrap .sec-inner {
  min-height: 36.1111111111vw;
}
@media (max-width: 759px) {
  .about.sec .sec-slide-wrap .sec-inner {
    min-height: 71.4666666667vw;
  }
}
.about.sec .sec-slide-wrap .sec-inner__bg picture::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
}
@media (min-width: 760px) {
  .about.sec .sec-slide-wrap .sec-inner__link {
    padding-top: 2.0833333333vw;
    padding-left: 4.1666666667vw;
    width: fit-content;
  }
}
@media (max-width: 759px) {
  .about.sec .sec-slide-wrap .sec-inner__link {
    margin: 6.6666666667vw 0 11.2vw auto;
    height: 10.6666666667vw;
  }
  .about.sec .sec-slide-wrap .sec-inner__link .button {
    width: 48vw;
    height: 10.6666666667vw;
  }
  .about.sec .sec-slide-wrap .sec-inner__link .button a {
    font-size: 3.4666666667vw;
    padding: 3.2vw 0;
  }
  .about.sec .sec-slide-wrap .sec-inner__link .button .button__icon {
    width: 4.8vw;
    height: 4.8vw;
    right: 2.9333333333vw;
  }
}
.about.sec .sec-slide-wrap .sec-inner__thumb {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 16.3888888889vw;
  height: 6.9444444444vw;
  margin: 0 2.0833333333vw 2.0833333333vw 0;
}
@media (max-width: 759px) {
  .about.sec .sec-slide-wrap .sec-inner__thumb {
    width: 54.144vw;
    height: 22.9306666667vw;
    top: 0;
    left: 50%;
    right: unset;
    transform: translateX(-50%);
    margin: 43.2vw 0 0 0;
    margin: 56vw 0 0 0;
  }
}
.about.sec .sec-slide-wrap .sec-body {
  padding-top: 0;
  padding-bottom: 0;
}
@media (min-width: 760px) {
  .about.sec .sec-slide-wrap .sec-body {
    padding-top: 2.7777777778vw;
    padding-left: 4.1666666667vw;
    width: 55%;
  }
}
@media (max-width: 759px) {
  .about.sec .sec-slide-wrap .sec-body {
    padding: 12vw 0 0 0;
  }
}
.about.sec .sec-slide-wrap .sec-body__title {
  font-size: 2.0833333333vw;
  letter-spacing: 0.12em;
  font-weight: 600;
}
@media (min-width: 760px) {
  .about.sec .sec-slide-wrap .sec-body__title {
    color: #FFF;
  }
}
@media (max-width: 759px) {
  .about.sec .sec-slide-wrap .sec-body__title {
    font-size: 5.3333333333vw;
    letter-spacing: 0.06em;
    margin: 0 0 5.3333333333vw 0;
    font-weight: 600;
  }
}
.about.sec .sec-slide-wrap .sec-body__text {
  font-size: 1.1111111111vw;
  letter-spacing: 0.03em;
  line-height: 1.8;
  font-weight: 600;
}
@media (min-width: 760px) {
  .about.sec .sec-slide-wrap .sec-body__text {
    color: #FFF;
  }
}
@media (max-width: 759px) {
  .about.sec .sec-slide-wrap .sec-body__text {
    font-size: 4.2666666667vw;
    letter-spacing: 0.06em;
    font-weight: 600;
  }
}
.about.sec .sec-slide-wrap .sec-slide-item:nth-of-type(1) .sec-inner__bg picture::after {
  background-color: rgba(0, 0, 0, 0.3);
}
.about.sec .sec-slide-wrap .sec-slide-item:nth-of-type(2) .sec-inner__bg picture::after {
  background-color: rgba(0, 0, 0, 0.7);
}
.about.sec .sec-slide-wrap .sec-slide-item:nth-of-type(3) .sec-inner__bg picture::after {
  background-color: rgba(0, 0, 0, 0.3);
}
.about.sec .sec-slide-ctl {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  position: absolute;
  right: 0;
  top: 0;
  margin-top: -4.5833333333vw;
  margin-right: 4.2361111111vw;
}
@media (max-width: 759px) {
  .about.sec .sec-slide-ctl {
    left: 0;
    right: unset;
    margin-top: -17.6vw;
    margin: -17.6vw 0 0 -4.2666666667vw;
    width: 92vw;
    justify-content: center;
  }
}
.about.sec .sec-slide-ctl__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 8.75vw;
  height: 3.1944444444vw;
  position: relative;
  margin-left: 2.0833333333vw;
  cursor: default;
  font-size: 1.1111111111vw;
  letter-spacing: 0.06rem;
  font-weight: 600;
}
@media (max-width: 759px) {
  .about.sec .sec-slide-ctl__btn {
    width: 28vw;
    height: 12.2666666667vw;
    margin-left: 0;
    font-size: 4.2666666667vw;
  }
  .about.sec .sec-slide-ctl__btn + .sec-slide-ctl__btn {
    margin-left: 4vw;
  }
}
.about.sec .sec-slide-ctl__btn::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 0.1388888889vw;
  background-color: #040000;
}
@media (max-width: 759px) {
  .about.sec .sec-slide-ctl__btn::after {
    height: 0.5333333333vw;
  }
}
.about.sec .sec-slide-ctl__btn[data-is-ctl=active]::after {
  background-color: #B12E2A;
}
@media (min-width: 760px) {
  .about.sec .sec-slide-ctl__btn:hover::after {
    background-color: #B12E2A;
  }
}
@media (max-width: 759px) {
  .about.sec .sec-slide-lines {
    margin: 0;
  }
}

.service {
  margin-bottom: 6.25vw;
}
@media (max-width: 759px) {
  .service {
    margin-bottom: 22.9333333333vw;
  }
}
.service .sec-lower {
  margin-bottom: 1.3888888889vw;
}
@media (max-width: 759px) {
  .service .sec-lower {
    margin-bottom: 4.5333333333vw;
  }
}
.service .sec-head__title {
  margin-top: 0;
}
@media (max-width: 759px) {
  .service .sec-head__title {
    margin-top: 0;
  }
}
@media (min-width: 760px) {
  .service .sec-head__title__ja {
    font-size: 0.9722222222vw;
  }
}
@media (max-width: 759px) {
  .service .sec-head__title__en {
    font-size: 13.3333333333vw;
  }
}
.service .sec-head {
  margin-bottom: 1.3888888889vw;
}
@media (max-width: 759px) {
  .service .sec-head {
    margin-bottom: 3.7333333333vw;
  }
}
.service .sec-inner {
  min-height: inherit;
  height: 36.1111111111vw;
}
@media (max-width: 759px) {
  .service .sec-inner {
    margin: 0;
    max-width: 100%;
    height: 71.4666666667vw;
  }
}
.service .sec-inner__bg picture {
  position: relative;
  display: block;
  height: 36.1111111111vw;
}
@media (max-width: 759px) {
  .service .sec-inner__bg picture {
    height: 71.4666666667vw;
  }
}
.service .sec-inner__bg picture::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
  background-color: rgba(0, 0, 0, 0.3);
}
.service .sec-body {
  color: #fff;
  font-size: 1.2986111111vw;
  letter-spacing: 0.03em;
  text-align: center;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 0;
}
@media (max-width: 759px) {
  .service .sec-body {
    font-size: 3.2vw;
  }
}
.service .sec-body__title {
  justify-content: center;
  margin-bottom: -1.0416666667vw;
  margin-top: -1.7361111111vw;
}
@media (max-width: 759px) {
  .service .sec-body__title {
    margin-bottom: -2.6666666667vw;
    margin-top: -2.1333333333vw;
  }
}
@media (max-width: 759px) {
  .service .sec-body__text {
    font-size: 3.2vw;
  }
}
.service .sec-body img {
  max-width: 31.1805555556vw;
  height: 8.3333333333vw;
}
@media (max-width: 759px) {
  .service .sec-body img {
    max-width: 54.9333333333vw;
    height: 14.9333333333vw;
  }
}

.other {
  margin-bottom: 7.3611111111vw;
}
@media (max-width: 759px) {
  .other {
    margin-bottom: 21.8666666667vw;
  }
}
@media (min-width: 760px) {
  .other .sec-slide {
    margin-bottom: 0;
    padding-top: 0;
  }
}
@media (max-width: 759px) {
  .other .sec-slide {
    padding-top: 0;
    margin-bottom: 24.8vw;
  }
}
@media (min-width: 760px) {
  .other .sec-colum {
    gap: 16px;
  }
}
.other .sec-colum .sec-inner {
  min-height: 20.8333333333vw;
  width: calc((100% - 16px) / 2);
}
@media (max-width: 759px) {
  .other .sec-colum .sec-inner {
    min-height: 72vw;
    width: 100%;
  }
}
@media (min-width: 760px) {
  .other .sec-colum .sec-item {
    height: 20.8333333333vw;
  }
}
@media (max-width: 759px) {
  .other .sec-colum .sec-item {
    height: 71.4666666667vw;
  }
}
.other .sec-colum .sec-item .sec-item-head__subTitle {
  font-size: 2.7777777778vw;
  font-family: "Josefin Sans", sans-serif;
}
@media (max-width: 759px) {
  .other .sec-colum .sec-item .sec-item-head__subTitle {
    font-size: 8.5333333333vw;
  }
}
.other .sec-colum .sec-item .sec-item-head__subTitle .u-font-large {
  font-size: 3.1944444444vw;
}
@media (max-width: 759px) {
  .other .sec-colum .sec-item .sec-item-head__subTitle .u-font-large {
    font-size: 9.6vw;
  }
}
.other .sec-colum .sec-inner:nth-of-type(1) .sec-inner__bg picture::after {
  background-color: rgba(0, 0, 0, 0.3);
}
.other .sec-colum .sec-inner:nth-of-type(3) .sec-inner__bg picture::after {
  background-color: rgba(0, 0, 0, 0.4);
  mix-blend-mode: multiply;
}
.other .sec-colum .sec-inner:nth-of-type(3) a:hover .sec-inner__bg picture::after {
  background-color: rgba(0, 0, 0, 0.64);
}
.other .sec-colum .sec-inner:nth-of-type(4) .sec-inner__bg picture::after {
  background-color: rgba(0, 0, 0, 0.4);
  mix-blend-mode: multiply;
}
.other .sec-colum .sec-inner:nth-of-type(4) a:hover .sec-inner__bg picture::after {
  background-color: rgba(0, 0, 0, 0.7);
}
@media (max-width: 759px) {
  .other .ly_colum.sec {
    padding: 0;
  }
  .other .ly_colum.sec .sec-inner + .sec-inner {
    margin-top: 2.6666666667vw;
  }
}
.other .sec-item__text {
  margin-top: 0.7638888889vw;
  font-size: 0.9722222222vw;
  font-weight: 600;
}
.other .sec-item__text p {
  line-height: 1.8;
}
@media (max-width: 759px) {
  .other .sec-item__text {
    margin-top: 2.6666666667vw;
    font-size: 3.4666666667vw;
  }
}
.other .button {
  width: 18.75vw;
}
@media (max-width: 759px) {
  .other .button {
    width: 73.3333333333vw;
  }
}

.feature {
  margin-bottom: 6.25vw;
}
@media (max-width: 759px) {
  .feature {
    margin-bottom: 21.3333333333vw;
  }
}
.feature .sec-lower {
  margin-bottom: 1.3888888889vw;
}
@media (max-width: 759px) {
  .feature .sec-lower {
    margin-bottom: 4.5333333333vw;
  }
}
@media (max-width: 759px) {
  .feature .sec-head {
    margin-bottom: 3.7333333333vw;
  }
}
.feature .swiper-container-horizontal > .swiper-pagination-bullets {
  bottom: 15px;
}
@media (max-width: 759px) {
  .feature .swiper-container-horizontal > .swiper-pagination-bullets {
    bottom: -9.3333333333vw;
    margin: 0;
    width: 64vw !important;
  }
}
.feature .sec-slide-lines {
  margin: 0 0 -3.4722222222vw 4.1666666667vw;
}
.feature .ly_colum .sec-slide {
  padding-top: 0;
  position: relative;
}
.feature .swiper-button {
  position: absolute;
  bottom: -1.7361111111vw;
  left: 56.25vw;
}
@media (max-width: 759px) {
  .feature .swiper-button {
    left: unset;
    right: 0;
    bottom: -7.4666666667vw;
  }
}
.feature .swiper-button-next:after, .feature .swiper-button-prev:after {
  font-size: unset;
}
.feature .swiper-button-next, .feature .swiper-button-prev {
  position: absolute;
  top: 0;
  width: 0.5555555556vw;
  height: 1.1111111111vw;
  margin-top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #040000;
}
@media (max-width: 759px) {
  .feature .swiper-button-next, .feature .swiper-button-prev {
    width: 1.6vw;
    height: 3.2vw;
  }
}
.feature .swiper-button-next {
  right: -4.7222222222vw;
}
@media (max-width: 759px) {
  .feature .swiper-button-next {
    right: 0;
  }
}
@media (max-width: 759px) {
  .feature .swiper-button-prev {
    left: -9.3333333333vw;
  }
}
@media (max-width: 759px) {
  .feature .ly_colum .sec-slide .sec-inner {
    height: 66.6666666667vw;
  }
}
.feature .ly_right {
  margin-top: -7.2916666667vw;
}
@media (max-width: 759px) {
  .feature .ly_right {
    margin-top: 24vw;
  }
}

.top-news {
  margin-top: 0;
  margin-bottom: 7.5694444444vw;
}
@media (max-width: 759px) {
  .top-news {
    margin-top: 0vw;
    margin-bottom: 19.7333333333vw;
  }
}
.top-news .sec-head {
  margin-bottom: 1.5277777778vw;
}
@media (max-width: 759px) {
  .top-news .sec-head {
    margin-bottom: 4.2666666667vw;
  }
}
@media (min-width: 760px) {
  .top-news .sec-head__title {
    margin-top: 6.6666666667vw;
  }
}
@media (min-width: 760px) {
  .top-news .sec-item-head__subTitle {
    height: 5.2083333333vw;
  }
}
@media (min-width: 760px) {
  .top-news .news-list {
    margin: 0 auto 4.1666666667vw;
  }
}
@media (max-width: 759px) {
  .top-news .news-list {
    margin-bottom: 10.6666666667vw;
  }
}
@media (max-width: 759px) {
  .top-news .news-list__inner {
    width: 89.6vw;
    margin-left: -2.6666666667vw;
  }
}
.top-news .news-list__cate {
  width: 25vw;
  margin-right: 2.7777777778vw;
}
@media (max-width: 759px) {
  .top-news .news-list__cate {
    margin-bottom: 0;
  }
}
@media (max-width: 759px) {
  .top-news .news-list__date {
    margin-bottom: 0;
    width: 26%;
  }
}
.top-news .sec-link .button {
  width: 11.1111111111vw;
}
.top-news .sec-link .button a {
  padding: 0.8333333333vw 0;
  font-size: 0.9027777778vw;
}
.top-news .sec-link .button__icon {
  right: 0.9722222222vw;
}
.top-news .sec-link a:hover .button__icon {
  right: 0.6944444444vw;
}
@media (max-width: 759px) {
  .top-news .sec-link {
    width: 48vw;
    height: 10.6666666667vw;
  }
  .top-news .sec-link .button {
    width: 48vw;
    height: 10.6666666667vw;
    margin: 5.3333333333vw auto 0;
  }
  .top-news .sec-link .button a {
    font-size: 3.4666666667vw;
    padding: 3.2vw 0;
  }
  .top-news .sec-link .button .button__icon {
    width: 4.8vw;
    height: 4.8vw;
    right: 2.9333333333vw;
  }
}

@media (max-width: 759px) {
  .sdgs {
    margin-bottom: 21.6vw;
  }
}
.sdgs .sec-lower {
  margin-bottom: 1.3888888889vw;
}
@media (max-width: 759px) {
  .sdgs .sec-lower {
    margin-bottom: 4.5333333333vw;
  }
}
.sdgs .sec-head {
  margin-bottom: 0;
}
.sdgs .sec-head__title__en .u-font-small {
  font-size: 5.5555555556vw;
}
@media (max-width: 759px) {
  .sdgs .sec-head__title__en .u-font-small {
    font-size: 11.2vw;
  }
}
.sdgs .sec-colum {
  margin-top: 3.8194444444vw;
  margin-bottom: 4.8611111111vw;
  position: relative;
}
@media (max-width: 759px) {
  .sdgs .sec-colum {
    margin-top: 11.4666666667vw;
  }
}
.sdgs .sec-colum::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100%;
  background: #F5F6F8;
  margin-top: -3.125vw;
  margin-left: -4.1666666667vw;
  padding-bottom: 6.25vw;
  z-index: -1;
}
@media (max-width: 759px) {
  .sdgs .sec-colum::before {
    height: 64.8vw;
    margin-top: -5.6vw;
    margin-left: -8vw;
  }
}
.sdgs .sec-inner:nth-of-type(2) {
  width: auto;
}
.sdgs .sec-inner:nth-of-type(1) {
  width: 43.0555555556vw;
}
@media (min-width: 760px) {
  .sdgs .sec-inner {
    display: flex;
    align-items: center;
    min-height: 20.8333333333vw;
  }
}
@media (max-width: 759px) {
  .sdgs .sec-inner__bg {
    position: relative;
    width: 83.7333333333vw;
    height: 60vw;
  }
}
.sdgs .sec-body {
  padding-left: 4.1666666667vw;
}
@media (max-width: 759px) {
  .sdgs .sec-body {
    padding: 16.5333333333vw 0 0;
  }
}
.sdgs .sec-body__thumb {
  width: 16.2472222222vw;
  height: 2.3652777778vw;
  margin-bottom: 2.0833333333vw;
}
.sdgs .sec-body__thumb img {
  width: 100%;
}
@media (max-width: 759px) {
  .sdgs .sec-body__thumb {
    width: 53.344vw;
    height: 7.7653333333vw;
    margin-bottom: 3.4666666667vw;
  }
}
.sdgs .sec-body__title {
  font-size: 1.8055555556vw;
  letter-spacing: 0.03rem;
  margin-bottom: 0.6944444444vw;
  line-height: 1.6;
}
@media (max-width: 759px) {
  .sdgs .sec-body__title {
    font-size: 5.3333333333vw;
    letter-spacing: 0.06rem;
    margin-bottom: 4vw;
  }
}
.sdgs .sec-body__text {
  font-size: 1.1111111111vw;
  letter-spacing: 0.03em;
  line-height: 1.8;
  font-weight: 600;
}
@media (max-width: 759px) {
  .sdgs .sec-body__text {
    font-size: 4.2666666667vw;
  }
}

#sec-bottom .sec-head {
  margin-top: 0;
}
@media (min-width: 760px) {
  #sec-bottom .sec-head {
    padding: 0 8.125vw;
  }
}

.side-link {
  position: fixed;
  right: -9.7222222222vw;
  top: 18.4027777778vw;
  cursor: pointer;
  transition: 0.2s opacity ease-in-out;
  pointer-events: all;
  z-index: 5;
}
@media (max-width: 759px) {
  .side-link {
    right: -32vw;
    top: 37.3333333333vw;
  }
}
.side-link:hover .side-link__inner::before {
  background: #040000;
  border: 1px solid #777980;
  border-right: none;
}
.side-link.is-open {
  right: 0vw;
}
.side-link.is-open .button__icon {
  transform: rotate(0deg);
}
.side-link.is-open .side-link__inner::before {
  background: #040000;
  border: 1px solid #777980;
}
.side-link.is-close {
  opacity: 0;
  pointer-events: none;
}
.side-link .side-link__inner {
  box-sizing: border-box;
  display: flex;
  position: relative;
  width: 13.1944444444vw;
  width: 12.8472222222vw;
}
@media (max-width: 759px) {
  .side-link .side-link__inner {
    width: 42.6666666667vw;
  }
}
.side-link .side-link__inner::before {
  border-top-left-radius: 1.0416666667vw;
  border-bottom-left-radius: 1.0416666667vw;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  height: 100%;
  margin-top: -0.4166666667vw;
  padding-bottom: 0.4166666667vw;
  background: #BC0009;
  content: "";
  z-index: -1;
  transition: 0.2s ease-in-out;
}
@media (max-width: 759px) {
  .side-link .side-link__inner::before {
    border-top-left-radius: 2.6666666667vw;
    border-bottom-left-radius: 2.6666666667vw;
    margin-top: 0;
    padding-bottom: 0;
  }
}
.side-link .side-link__btn {
  writing-mode: vertical-rl;
  color: #FFF;
  width: 3.4722222222vw;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  font-size: 1.0416666667vw;
  margin-top: -0.9027777778vw;
  letter-spacing: 0.06rem;
}
@media (max-width: 759px) {
  .side-link .side-link__btn {
    width: 10.6666666667vw;
    font-size: 3.2vw;
  }
}
.side-link .side-link__item {
  padding: 1.0416666667vw 1.6666666667vw 1.0416666667vw 0.5555555556vw;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
@media (max-width: 759px) {
  .side-link .side-link__item {
    padding: 2.466667vw 6.6666666667vw 2.466667vw 0;
  }
}
.side-link .side-link__item picture {
  width: 5.9722222222vw;
  height: 8.1944444444vw;
  display: block;
  margin: 0 auto;
}
@media (max-width: 759px) {
  .side-link .side-link__item picture {
    width: 20.5333333333vw;
    height: 27.2vw;
  }
}
.side-link .side-link__item img {
  width: 100%;
  transition: 0.2s ease-in-out;
}
.side-link .side-link__item img:hover {
  opacity: 0.9;
}
.side-link .side-link__desc {
  text-align: center;
  font-size: 0.7638888889vw;
  color: #FFF;
  margin-top: 0.4861111111vw;
  letter-spacing: -0.01em;
  display: block;
}
@media (max-width: 759px) {
  .side-link .side-link__desc {
    font-size: 2.1333333333vw;
    margin-top: 1.8666666667vw;
    right: 0;
  }
}
.side-link .button__icon {
  content: "";
  display: block;
  width: 1.5277777778vw;
  height: 1.5277777778vw;
  border-radius: 50%;
  position: relative;
  top: 0.8333333333vw;
  left: 0;
  background: url(./../images/common/icon_button_arrow.svg) no-repeat;
  background-size: contain;
  transform: rotate(180deg);
}
@media (max-width: 759px) {
  .side-link .button__icon {
    top: 3.2vw;
    top: 2.2vw;
    width: 4.8vw;
    height: 4.8vw;
  }
}

.side-link__close {
  z-index: 5;
  position: fixed;
  right: 0;
  top: 17.7083333333vw;
  display: block;
  width: 1.8055555556vw;
  height: 1.8055555556vw;
  border-radius: 50%;
  background: url(./../images/common/icon_close.svg) no-repeat;
  background-size: contain;
  margin-right: 2.0833333333vw;
  opacity: 1;
  transition: 0.5s opacity ease-in-out;
  pointer-events: all;
}
@media (max-width: 759px) {
  .side-link__close {
    width: 6.9333333333vw;
    height: 6.9333333333vw;
    margin-right: 7.2vw;
    top: 33.6vw;
  }
}
.side-link__close.is-close {
  opacity: 0;
  pointer-events: none;
}
.side-link__close.is-open {
  opacity: 0;
  pointer-events: none;
}

.other .sec-colum .sec-inner:nth-of-type(4) a .sec-inner__bg picture::after {
  background-color: unset;
}

.other .sec-colum .sec-inner:nth-of-type(4) a:hover .sec-inner__bg picture::after {
  background-color: rgba(0, 0, 0, 0.3);
}

@media (min-width: 760px) {
  .sec-inner__link.btn-s03 {
    padding-top: 4.1666666667vw !important;
  }
}

@media (max-width: 759px) {
  .about .bl_fullMedia .sec-inner__bg {
    position: relative;
    width: 100vw;
    margin: 0 calc(50% - 50vw);
  }
}

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