@charset "UTF-8";
/*アニメーション
----------------------------*/
@keyframes fadeInSimple {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes sliderPagination {
  0% {
    transform: scaleX(0);
    opacity: 0;
  }
  100% {
    transform: scaleX(1);
    opacity: 1;
  }
}
/*共通
----------------------------*/
.l-container {
  width: 100%;
}

.pc-header-main.is-fixed {
  position: static !important;
}

.l-footer {
  padding: 0;
}

.pc-footer {
  margin: 0;
}

#feature {
  width: 100%;
  margin: 0 auto;
  color: #000;
  box-sizing: border-box;
  text-align: center;
  font-family: "Times New Roman", serif;
  font-weight: 400;
  font-style: normal;
  font-feature-settings: "palt";
  position: relative;
  overflow: clip;
  opacity: 0;
  transition: 0.3s;
}
#feature.is_show {
  opacity: 1;
}
#feature * {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}
#feature a {
  width: 100%;
  height: auto;
  display: block;
  color: #000;
  transition: 0.3s;
}
#feature a:hover {
  text-decoration: none;
  opacity: 0.7;
}
#feature img {
  width: 100%;
  height: auto;
  display: block;
}
#feature figure {
  background-color: #fff;
}
#feature .fadeimg {
  transition: 0.3s;
}
#feature .js_anime.is_fade figure {
  opacity: 0;
  transition: 1s;
}
#feature .js_anime.is_fadetop figure {
  opacity: 0;
  transform: translateY(-30px);
  transition: 1s;
}
#feature .js_anime.is_fadebottom figure {
  opacity: 0;
  transform: translateY(30px);
  transition: 1s;
}
#feature .js_anime.is_fadeleft figure {
  opacity: 0;
  transform: translateX(-30px);
  transition: 1s;
}
#feature .js_anime.is_faderight figure {
  opacity: 0;
  transform: translateX(30px);
  transition: 1s;
}
#feature .js_anime.is_show.is_fade figure {
  opacity: 1;
}
#feature .js_anime.is_show.is_fadetop figure {
  opacity: 1;
  transform: translateY(0);
}
#feature .js_anime.is_show.is_fadebottom figure {
  opacity: 1;
  transform: translateY(0);
}
#feature .js_anime.is_show.is_fadeleft figure {
  opacity: 1;
  transform: translateX(0);
}
#feature .js_anime.is_show.is_faderight figure {
  opacity: 1;
  transform: translateX(0);
}

#feature {
  /*メインビジュアル（.hero)
  ----------------------------*/
}
#feature .hero {
  padding-bottom: calc(160 * (var(--vw) / 2100));
  position: sticky;
  top: 0;
  z-index: 1;
}
#feature .hero .hero__img {
  width: 100%;
}
#feature .hero .hero__txt {
  width: calc(510 * (var(--vw) / 2100));
  margin: calc(119 * (var(--vw) / 2100)) auto 0;
}
#feature .sec {
  padding: calc(120 * (var(--vw) / 2100)) 0 calc(263 * (var(--vw) / 2100));
  margin-top: calc(200 * (var(--vw) / 2100));
  background-color: #fff;
  position: relative;
  z-index: 2;
}
#feature .sec .sec__credit {
  position: absolute;
}
#feature .sec .sec__credit .credit .item {
  width: fit-content;
}
#feature .sec .sec__credit .credit .item .link {
  display: flex;
  flex-wrap: nowrap;
  transition: 0.3s;
}
#feature .sec .sec__credit .credit .item .link:hover {
  opacity: 0.7;
}
#feature .sec .sec__credit .credit .item .link span {
  font-size: calc(18 * (var(--vw) / 2100));
  line-height: calc(29.7 * (var(--vw) / 2100));
  letter-spacing: 0.04em;
  white-space: nowrap;
}
#feature .sec .sec__credit.sec__credit01 {
  top: calc(100% + calc(26 * (var(--vw) / 2100)));
  right: 0;
}
#feature .sec .sec__credit.sec__credit01 .credit .item {
  margin-left: auto;
}
#feature .sec .sec__credit.sec__credit02 {
  bottom: calc(-7 * (var(--vw) / 2100));
  right: calc(100% + calc(29 * (var(--vw) / 2100)));
}
#feature .sec .sec__credit.sec__credit02 .credit .item {
  margin-left: auto;
}
#feature .sec .sec__credit.sec__credit03 {
  bottom: calc(-7 * (var(--vw) / 2100));
  left: calc(100% + calc(30 * (var(--vw) / 2100)));
}
#feature .sec .sec__credit.sec__credit04 {
  bottom: calc(-7 * (var(--vw) / 2100));
  left: calc(100% + calc(30 * (var(--vw) / 2100)));
}
#feature .sec .sec__credit.sec__credit05 {
  bottom: calc(-7 * (var(--vw) / 2100));
  right: calc(100% + calc(30 * (var(--vw) / 2100)));
}
#feature .sec .sec__credit.sec__credit05 .credit .item {
  margin-left: auto;
}
#feature .sec .sec__credit.sec__credit06 {
  top: calc(100% + calc(26 * (var(--vw) / 2100)));
  right: 0;
}
#feature .sec .sec__credit.sec__credit06 .credit .item {
  margin-left: auto;
}
#feature .sec .sec__flex {
  display: flex;
  position: relative;
}
#feature .sec .sec__flex.is_reverse {
  flex-direction: row-reverse;
}
#feature .sec .sec__ttl {
  width: calc(490 * (var(--vw) / 2100));
  margin: 0 auto;
}
#feature .sec .sec__img {
  position: relative;
}
#feature .sec .sec__img.sec__img01 {
  width: calc(800 * (var(--vw) / 2100));
  margin: calc(139 * (var(--vw) / 2100)) 0 0 calc(280 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img02 {
  width: calc(500 * (var(--vw) / 2100));
  margin: calc(919 * (var(--vw) / 2100)) 0 0 calc(260 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img03 {
  width: calc(760 * (var(--vw) / 2100));
  margin: calc(320 * (var(--vw) / 2100)) auto 0;
}
#feature .sec .sec__img.sec__img04 {
  width: calc(460 * (var(--vw) / 2100));
  margin: calc(120 * (var(--vw) / 2100)) 0 0 calc(200 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img05 {
  width: calc(600 * (var(--vw) / 2100));
  margin: calc(616 * (var(--vw) / 2100)) 0 0 calc(460 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img06 {
  width: calc(780 * (var(--vw) / 2100));
  margin: calc(299 * (var(--vw) / 2100)) 0 0 calc(380 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img07 {
  width: calc(460 * (var(--vw) / 2100));
  margin: calc(1154 * (var(--vw) / 2100)) 0 0 calc(240 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img08 {
  width: calc(520 * (var(--vw) / 2100));
  margin: calc(355 * (var(--vw) / 2100)) 0 0 calc(120 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img09 {
  width: 100%;
  margin: calc(321 * (var(--vw) / 2100)) 0 0 0;
}
#feature .sec .sec__img.sec__img10 {
  width: calc(480 * (var(--vw) / 2100));
  margin: calc(120 * (var(--vw) / 2100)) 0 0 calc(140 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img11 {
  width: calc(640 * (var(--vw) / 2100));
  margin: calc(560 * (var(--vw) / 2100)) 0 0 calc(380 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img12 {
  width: calc(600 * (var(--vw) / 2100));
  margin: calc(319 * (var(--vw) / 2100)) 0 0 calc(1180 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img13 {
  width: calc(800 * (var(--vw) / 2100));
  margin: calc(120 * (var(--vw) / 2100)) auto 0;
}
#feature .sec .sec__img.sec__img14 {
  width: calc(460 * (var(--vw) / 2100));
  margin: calc(320 * (var(--vw) / 2100)) 0 0 calc(440 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img15 {
  width: calc(740 * (var(--vw) / 2100));
  margin: calc(735 * (var(--vw) / 2100)) 0 0 calc(160 * (var(--vw) / 2100));
}
#feature .sec .sec__img.sec__img16 {
  width: calc(520 * (var(--vw) / 2100));
  margin: calc(229 * (var(--vw) / 2100)) auto 0;
}
#feature .allitemarea {
  padding: 0 0 calc(285 * (var(--vw) / 2100));
  background-color: #fff;
  position: relative;
  z-index: 2;
}
#feature .allitemarea .allitem {
  width: calc(220 * (var(--vw) / 2100));
  margin: 0 auto;
  position: relative;
}
#feature .allitemarea .allitem::before {
  content: "";
  width: calc(65 * (var(--vw) / 2100));
  height: 1px;
  background-color: #000;
  position: absolute;
  bottom: calc(-23 * (var(--vw) / 2100));
  left: calc(50% - calc(65 / 2 * (var(--vw) / 2100)));
  transform: translateX(-50%) scale(0, 1);
  transform-origin: right;
  transition: 1s;
}
#feature .allitemarea .allitem::after {
  content: "";
  width: calc(65 * (var(--vw) / 2100));
  height: 1px;
  background-color: #000;
  position: absolute;
  bottom: calc(-23 * (var(--vw) / 2100));
  left: calc(50% + calc(65 / 2 * (var(--vw) / 2100)));
  transform: translateX(-50%) scale(0, 1);
  transform-origin: left;
  transition: 1s;
}
#feature .allitemarea .allitem.is_show::before {
  transform: translateX(-50%) scale(1, 1);
}
#feature .allitemarea .allitem.is_show::after {
  transform: translateX(-50%) scale(1, 1);
}
