@charset "UTF-8";
body {
  color: #000;
  overflow-x: hidden;
}

.l-container {
  width: 100%;
}

.feature {
  background: #eaeaea;
  color: #000;
  font-feature-settings: "palt";
  font-family: "hiragino-kaku-gothic-pron", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
  font-weight: 300;
  font-style: normal;
  margin: 0 auto;
  padding: 0 0 162px;
}
.feature a {
  display: block;
  text-decoration: none;
}
.feature a:link, .feature a:visited {
  color: #fff;
}
.feature a:hover {
  opacity: 0.8;
  transition: all 0.3s ease-in-out;
}

.feature .default-img{
  height: auto;
  width: 100%;
}

.feature .sp-only{
  display: none !important;
}

.feature .js-inview{
  opacity: 0;
  transition: opacity 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.feature .js-inview.is-active{
  opacity: 1;
}

.feature .js-fade{
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.8s 0.2s;
}
.feature .js-fade.is-active{
  opacity: 1;
  transform: translateY(0);
}

.feature .js-hero{
  opacity: 0;
  left: 0;
  top: 0;
  transform: translateY(8%);
  transition: all 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  position: absolute;
  pointer-events: none;
  height: 750px;
  width: 100%;
}
.feature .js-hero.is-active{
  opacity: 1;
  transform: translateY(0);
}

.feature .sec .js-fadeUp span{
  display: block;
  transform: translateY(100%) skewX(12deg);
  transition: all 0.5s cubic-bezier(0.36, 0.14, 0, 1);
}
.feature .sec .js-fadeUp span.fade{
  transform: translateY(0) skewX(0deg);
}

.feature .delay{
  transition-delay: 1s;
}

/* credit */

.feature .creditContainer{
  margin: 42px auto 0;
}

.feature .credit {
  display: flex;
  flex-wrap: wrap;
  gap: 14px 13px;
  justify-content: center;
}

.feature .credit li{
  font-family: "nimbus-sans", sans-serif;
  font-size: 12px;
  font-weight: 400;
  letter-spacing: 0.005em;
  line-height: 1;
  position: relative;
}
.feature .credit li::before{
  background: #000;
  content: "";
  bottom: 0;
  left: 0;
  position: absolute;
  height: 1px;
  width: 100%;
}
.feature .credit li a {
  color: #000;
}

.feature .credit .price {
  letter-spacing: 0;
}

.feature .credit01{
  margin: 42px auto 0 -67px;
}

.feature .credit02{
  margin: 39px auto 0;
}

.feature .credit03{
  margin: 38px auto 0;
}

.feature .credit04{
  margin: 38px auto 0;
}

/* hero */

.feature .hero {
  margin: 0 auto;
  padding: 0 0 53px;
  position: relative;
  width: 100%;
}

.feature .hero__mv{
  background: #fff;
  left: -7px;
  margin: 0 auto;
  position: relative;
  width: 1200px;
}

.feature .hero__mv .hero__mv-img{
  display: flex;
  justify-content: space-between;
  width: 100%;
}
.feature .hero__mv .hero__mv-img figure:nth-of-type(1){
  padding: 97px 0 0 66px;
  width: 470px;
}
.feature .hero__mv .hero__mv-img figure:nth-of-type(2){
  width: 600px;
}

.feature .hero__mv-ttl{
  font-family: "trajan-pro-3", serif;
  font-weight: 600;
  font-size: 46px;
  letter-spacing: 0.03em;
  line-height: 1;
  margin: auto;
  top: 359px;
  left: 0;
  right: 0;
  position: absolute;
  pointer-events: all;
  width: fit-content;
}
.feature .hero__mv .hero__mv-text{
  font-feature-settings: initial;
  font-size: 19px;
  letter-spacing: 0.21em;
  position: absolute;
  pointer-events: all;
}
.feature .hero__mv .hero__mv-text:nth-of-type(1){
  top: 62px;
  left: 73px;
}
.feature .hero__mv .hero__mv-text:nth-of-type(2){
  letter-spacing: 0.3em;
  top: 104px;
  left: 547px;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}

.feature .hero__read{
  font-size: 14px;
  left: -7px;
  letter-spacing: 0.1em;
  line-height: 2.0714;
  margin: 107.5px auto 0;
  position: relative;
  text-align: center;
}

/* main */

.feature .sec{
  position: relative;
  width: 100%;
}
.feature .sec .inner{
  margin: 0 auto;
  position: relative;
  width: 100%;
}

.feature .sec .sec__ttl{
  display: flex;
  font-family: "trajan-pro-3", serif;
  font-weight: 600;
  font-size: 50px;
  letter-spacing: 0.02em;
  line-height: 1;
  margin: 17px auto 0;
  overflow: hidden;
  text-align: center;
  height: 190%;
  width: fit-content;
}
.feature .sec .sec__read{
  display: flex;
  font-feature-settings: initial;
  font-weight: 400;
  font-size: 18px;
  letter-spacing: 0.1em;
  line-height: 1;
  margin: 34px auto 0;
  overflow: hidden;
  text-align: center;
  height: 100%;
  width: fit-content;
}

.feature .sec .sec__text{
  margin: 32px auto 0;
}
.feature .sec .sec__text-ttl{
  font-family: "trajan-pro-3", serif;
  font-weight: 600;
  font-size: 30px;
  letter-spacing: 0.065em;
  text-align: center;
}
.feature .sec .sec__text-read{
  font-feature-settings: initial;
  font-weight: 400;
  font-size: 13px;
  letter-spacing: -0.04em;
  line-height: 2.0769;
  margin: 7px auto 0;
  text-align: justify;
  width: 600px;
}

.feature .sec .sec__detail{
  position: relative;
}

.feature .sec .sec__detail-right{
  position: absolute;
  width: 410px;
  z-index: 2;
}
.feature .sec .sec__detail-left{
  position: absolute;
  width: 262.16px;
  z-index: 2;
}

.feature .sec .sec__item{
  margin: 0 auto;
  width: 560px;
}

.feature .sec .sec__chart{
  position: absolute;
  width: 304.16px;
}

.feature .sec .sec__point{
  font-feature-settings: initial;
  font-size: 17px;
  letter-spacing: 0.016em;
  line-height: 1.7647;
  position: absolute;
}

.feature .sec .sec__point span{
  background: #000;
  display: block;
  top: 0;
  left: -19px;
  position: absolute;
  transition: .8s ease;
  height: 1px;
  width: 1.9215px;
}

.feature .sec .sec__point.is-active span{
  height: 120px;
}

/* sec01 */

.feature .sec01{
  margin: 89px auto 0;
}

.feature .sec01 .sec__detail{
  margin: 22px auto 0;
  width: 1178px;
}

.feature .sec01 .sec__detail-right{
  top: 18px;
  right: 0;
}
.feature .sec01 .sec__detail-left{
  top: 468px;
  left: 60px;
}
.feature .sec01 .sec__detail-left a{
  transform: rotate(-5deg);
}

.feature .sec01 .sec__chart{
  top: 640px;
  right: 91px;
}

.feature .sec01 .sec__point{
  top: 305px;
  left: 130px;
}

.feature .sec01 .img03{
  width: 560px;
}

/* sec02 */

.feature .sec02{
  margin: 174px auto 0;
}

.feature .sec02 .sec__ttl{
  letter-spacing: 0em;
}

.feature .sec02 .sec__detail{
  margin: 26px auto 0;
  width: 1187px;
}

.feature .sec02 .sec__detail-right{
  top: 21px;
  left: 0;
}
.feature .sec02 .sec__detail-left{
  top: 476px;
  right: 68px;
}
.feature .sec02 .sec__detail-left a{
  transform: rotate(5deg);
}

.feature .sec02 .sec__chart{
  top: 647px;
  left: 38px;
}

.feature .sec02 .sec__point{
  top: 299px;
  right: 63px;
}

.feature .sec02 .sec__text{
  margin: 33px auto 0;
}
.feature .sec02 .sec__text-ttl{
  left: -5px;
  position: relative;
}

.feature .sec02 .img06{
  width: 560px;
}

/* sec03 */

.feature .sec03{
  margin: 177px auto 0;
}

.feature .sec03 .sec__ttl{
  letter-spacing: 0;
}

.feature .sec03 .sec__detail{
  margin: 27px auto 0;
  width: 1198px;
}

.feature .sec03 .sec__detail-right{
  top: 18px;
  right: 0;
}
.feature .sec03 .sec__detail-left{
  top: 458px;
  left: 68px;
}
.feature .sec03 .sec__detail-left a{
  transform: rotate(-5deg);
}

.feature .sec03 .sec__text-ttl{
  letter-spacing: 0.05em;
}

.feature .sec03 .sec__chart{
  margin: 32px auto 0;
  position: relative;
}

.feature .sec03 .sec__point{
  top: 307px;
  left: 92px;
}

.feature .sec03 .img09{
  width: 560px;
}

/* sec04 */

.feature .sec04{
  margin: 40px auto 0;
}

.feature .sec04 .sec__ttl{
  letter-spacing: 0em;
}

.feature .sec04 .sec__detail{
  margin: 0 auto;
  width: 1228px;
}

.feature .sec04 .sec__detail-right{
  top: 21px;
  left: 0;
}
.feature .sec04 .sec__detail-left{
  top: 496px;
  right: 110px;
}
.feature .sec04 .sec__detail-left a{
  transform: rotate(5deg);
}

.feature .sec04 .sec__chart{
  top: 647px;
  left: 38px;
}

.feature .sec04 .sec__point{
  top: 324px;
  right: 97px;
}

.feature .sec04 .sec__text{
  margin: 33px auto 0;
}
.feature .sec04 .sec__text-ttl{
  letter-spacing: 0.05em;
}

.feature .sec04 .img12{
  width: 560px;
}

.feature .sec__btn {
  border-bottom: solid #000 1px;
  font-family: "nimbus-sans", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  letter-spacing: 0.03em;
  margin: 157px auto 0;
  position: relative;
  text-align: center;
  width: 90px;
}
.feature .sec__btn a {
  color: #000;
  display: inline-block;
}

.l-footer {
  padding-top: 0;
}

.pc-footer {
  margin-top: 0;
}