@charset "UTF-8";
:root {
  --vw: (100vw / 1400) * var(--ratio);
  --ratio: calc(var(--pc-width) / 750);
  --pc-width: 450;
}

/*アニメーション 
----------------------------*/
.fadeImg {
  opacity: 0;
  transform: translate3d(0px, 5%, 0px);
}
.fadeImg.is-show {
  opacity: 1;
  transform: translate3d(0px, 0px, 0px);
  filter: none;
  transition: opacity 580ms cubic-bezier(0.455, 0.03, 0.515, 0.955), transform 1080ms cubic-bezier(0.12, 0.45, 0, 1.025);
}

.fadeTxt {
  opacity: 0;
  -webkit-transform: translateY(20px);
  transform: translateY(20px);
  -webkit-transition: 1s ease-out;
  transition: 1s ease-out;
}
.fadeTxt.is-show {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

/*共通
----------------------------*/
.l-container {
  width: 100%;
}

.l-header {
  padding: 0;
  position: relative;
  z-index: 999;
  background-color: #fff;
  overflow-x: clip;
}

.l-footer {
  padding: 0;
  position: relative;
  z-index: 999;
  background-color: #fff;
  overflow-x: clip;
}

.pc-footer {
  margin: 0;
}

#feature {
  width: 100%;
  margin: 0 auto;
  color: #000;
  background-color: #fff;
  box-sizing: border-box;
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-feature-settings: "palt";
  position: relative;
  overflow: clip;
}
#feature * {
  box-sizing: border-box;
  padding: 0;
  margin: 0;
  margin-block-start: 0;
  margin-block-end: 0;
}
#feature a {
  width: 100%;
  height: auto;
  display: block;
  color: #000;
  text-decoration: none;
}
#feature a:hover {
  opacity: 1;
}
#feature img, #feature svg {
  width: 100%;
  height: auto;
  display: block;
}
#feature .inner {
  width: 100%;
  margin: 0 auto;
  position: relative;
}

/*Wrap
----------------------------*/
#feature .contentsWrap {
  display: flex;
  width: 100vw;
  position: relative;
}
#feature .leftWrap {
  position: sticky;
  top: 80px;
  height: calc(100vh - 80px);
  width: 50vw;
}
#feature .leftWrap .hero {
  position: relative;
  width: 100%;
}
#feature .leftWrap .hero .hero__img {
  width: 100%;
  opacity: 0;
}
#feature .leftWrap .hero .hero__img.is-show {
  opacity: 1;
  filter: none;
  transition: opacity 880ms 440ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
#feature .leftWrap .hero .hero__img img {
  -o-object-fit: cover;
  object-fit: cover;
  height: calc(100vh - 80px);
  -o-object-position: center;
  object-position: center;
}
#feature .leftWrap .hero .hero__txt {
  width: 17.5714285714vw;
  position: absolute;
  top: 48%;
  left: 50%;
  transform: translate(-50%, -50%);
}
#feature .leftWrap .hero .hero__txt img {
  opacity: 0;
  filter: alpha(opacity=0);
  transform: translate3d(0px, 2%, 0px);
}
#feature .leftWrap .hero .hero__txt.is-show img {
  opacity: 1;
  filter: none;
  transform: translate3d(0px, 0px, 0px);
  transition: opacity 380ms 1220ms cubic-bezier(0.25, 0.46, 0.45, 0.94), transform 380ms 1220ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
#feature .mainWrap {
  width: 50vw;
  opacity: 0;
}
#feature .mainWrap.is-show {
  opacity: 1;
  filter: none;
  transition: opacity 880ms 440ms cubic-bezier(0.25, 0.46, 0.45, 0.94);
  transition-delay: 1500ms;
}
#feature .mainWrap .inner {
  margin: 0 auto;
  position: relative;
  overflow: clip;
  z-index: 2;
}

/*メインビジュアル（.hero) Wrapに記載
----------------------------*/
/*.sec
----------------------------*/
#feature .sec {
  position: relative;
}
#feature .sec .sec__img, #feature .sec .sec__box {
  position: relative;
  z-index: 1;
}
#feature .sec .sec__txt {
  font-family: "hiragino-kaku-gothic-pron", sans-serif;
  font-weight: 600;
  font-style: normal;
  font-size: calc(23 * var(--vw));
  letter-spacing: 0.05em;
  line-height: 1.87;
  text-align: center;
}
#feature .sec01 .txt01 {
  margin: calc(120 * var(--vw)) auto;
}
#feature .sec01 .box01 {
  width: calc(700 * var(--vw));
  margin: 0 auto calc(70 * var(--vw));
}
#feature .sec01 .txt02 {
  margin: 0 auto calc(60 * var(--vw));
}
#feature .sec01 .box02 {
  width: calc(650 * var(--vw));
  margin: 0 auto calc(168 * var(--vw));
}
#feature .sec01 .txt03 {
  margin: 0 auto calc(70 * var(--vw));
  line-height: 1.739;
}
#feature .sec01 .box03 {
  width: calc(700 * var(--vw));
  margin: 0 auto calc(180 * var(--vw));
}
#feature .sec01 .box04 {
  width: calc(750 * var(--vw));
  margin: 0 auto calc(170 * var(--vw));
}
#feature .sec01 .txt04 {
  margin: 0 auto calc(62 * var(--vw));
  line-height: 1.913;
}
#feature .sec01 .box05 {
  width: calc(700 * var(--vw));
  margin: 0 auto calc(172 * var(--vw));
}
#feature .sec01 .box06 {
  width: calc(650 * var(--vw));
  margin: 0 auto calc(70 * var(--vw));
}
#feature .sec01 .txt05 {
  margin: 0 auto calc(64 * var(--vw));
}
#feature .sec01 .box07 {
  width: calc(700 * var(--vw));
  margin: 0 auto calc(82 * var(--vw));
}
#feature .sec01 .box08 {
  width: calc(600 * var(--vw));
  margin: 0 auto;
}
#feature .sec01 .box09 {
  margin: calc(280 * var(--vw)) 0 calc(290 * var(--vw));
  text-align: center;
}
#feature .sec01 .box09 .sec__all-btn {
  position: relative;
  font-family: "nimbus-sans", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: calc(30 * var(--vw));
  letter-spacing: 0.057em;
  display: inline-block;
  width: fit-content;
  margin: 0 auto;
}
#feature .sec01 .box09 .sec__all-btn::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-color: #000;
  display: inline-block;
}

/*.credit
----------------------------*/
#feature .sec__credit {
  position: absolute;
  left: 50%;
  bottom: calc(50 * var(--vw));
  transform: translateX(-50%);
  z-index: 2;
}
#feature .sec__credit.credit02 {
  bottom: calc(46 * var(--vw));
}
#feature .sec__credit.credit03 {
  bottom: calc(54 * var(--vw));
}
#feature .sec__credit.credit04 a {
  color: #fff;
  border-bottom: 1px solid #fff;
}
#feature .sec__credit.credit05 {
  bottom: calc(46 * var(--vw));
}
#feature .sec__credit.credit06 a {
  color: #fff;
  border-bottom: 1px solid #fff;
}
#feature .sec__credit.credit07 a {
  color: #fff;
  border-bottom: 1px solid #fff;
}
#feature .sec__credit.credit07 .credit {
  letter-spacing: -0.035em;
  gap: calc(10 * var(--vw));
}
#feature .credit {
  display: flex;
  justify-content: center;
  gap: calc(14 * var(--vw));
  font-family: "nimbus-sans", sans-serif;
  font-weight: 500;
  font-style: normal;
  font-size: calc(19.69 * var(--vw));
  letter-spacing: 0.005em;
  line-height: 1;
}
#feature .credit a {
  border-bottom: 1px solid #000;
}

/*1400px以上
----------------------------*/
@media screen and (min-width: 1401px) {
  :root {
    --vw: 1px * var(--ratio);
  }
}