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

.l-container {
  width: 100%;
}

.feature {
  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 170px;
}
.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-hero {
  opacity: 0;
  transform: translateY(10px);
  transition: .8s ease 1.3s;
}
.feature .js-hero.is-active {
  opacity: 1;
  transform: translateY(0);
}

.feature .js-inview{
  opacity: 0;
  transform: translateY(50px);
  transition: all 0.8s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.feature .js-inview.is-active{
  opacity: 1;
  transform: translateY(0px);
}

/* credit */

.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: #231815;
  content: "";
  bottom: 0;
  left: 0;
  position: absolute;
  height: 1px;
  width: 100%;
}
.feature .credit li a {
  color: #231815;
}

.feature .credit .txt {
  margin-right: 3px;
}
.feature .credit .price {
  letter-spacing: 0.02em;
}

.feature .credit01{
  margin: 33px 0 0;
  width: fit-content;
}

.feature .credit02{
  margin: 30px 0 0;
  width: fit-content;
}

.feature .credit03{
  margin: 39px auto 0;
  width: 60%;
}

.feature .credit04{
  margin: 37px auto 0 58px;
  width: 60%;
}
.feature .credit04 li a{
  color: #fff;
}
.feature .credit04 li::before{
  background: #fff;
}
.feature .credit04 .txt{
  margin: 0;
}

.feature .credit05{
  margin: 39px auto 0;
  width: 100%;
}

.feature .credit06{
  margin: 33px 0 0;
  width: fit-content;
}

.feature .credit07{
  margin: 29px 0 0 auto;
  width: fit-content;
}


/* hero */

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

.feature .hero__mv{
  align-items: flex-start;
  display: flex;
  width: 100%;
}

.feature .hero__mv .hero__mv-img:nth-of-type(1){
  animation: hero01 .8s ease .5s;
  overflow: hidden;
  height: 60.71vw;
  width: 50vw;
}
.feature .hero__mv .hero__mv-img:nth-of-type(2){
  animation: hero02 .8s ease .5s;
  margin: 7.5vw 0 0;
  overflow: hidden;
  height: 46.43vw;
  width: 40.43vw;
}
.feature .hero__mv .hero__mv-img figure{
  animation: scale .8s ease .5s;
}

.feature .hero__ttl{
  color: #fff;
  font-family: "nimbus-sans", sans-serif;
  font-weight: 700;
  font-size: 4.64vw;
  letter-spacing: 0.03em;
  margin: auto;
  top: 46.1vw;
  left: 0;
  right: 0.14vw;
  position: absolute;
  width: fit-content;
}
.feature .hero__text{
  color: #fff;
  font-size: 14px;
  letter-spacing: 0.1em;
  line-height: 2.0714;
  margin: 52px auto 0;
  text-align: center;
}

@keyframes hero01{
  from {clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);}
  to {clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);}
}
@keyframes hero02{
  from {clip-path: polygon(100% 0, 100% 0, 100% 100%, 100% 100%);}
  to {clip-path: polygon(100% 0, 0 0, 0 100%, 100% 100%);}
}
@keyframes scale{
  from {transform: scale(1.13);}
  to {transform: scale(1);}
}

/* main */

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

.feature .sec .sec__detail{
  align-items: flex-start;
  display: flex;
  justify-content: space-between;
  margin: 0 auto;
  position: relative;
  width: 1030px;
}
.feature .sec .sec__detail *{
  position: relative;
  z-index: 2;
}
.feature .sec .sec__detail::before{
  background: #2e83a0;
  content: "";
  top: 58px;
  left: 266px;
  position: absolute;
  pointer-events: none;
  height: 500px;
  width: 500px;
  z-index: 1;
}

.feature .sec .sec__text{
  margin: 114px 0 0;
  position: relative;
  width: fit-content;
}

.feature .sec .sec__text-device{
  color: #fff;
  font-family: "nimbus-sans", sans-serif;
  font-weight: 700;
  font-size: 20px;
  letter-spacing: 0.03em;
  line-height: 1.925;
  position: relative;
  width: fit-content;
}
.feature .sec .sec__text-device::before{
  background: #fff;
  content: "";
  bottom: -15px;
  left: 2px;
  position: absolute;
  height: 1px;
  width: 20px;
}
.feature .sec .sec__text-ttl{
  color: #fff;
  font-feature-settings: initial;
  font-weight: 600;
  font-size: 30px;
  letter-spacing: 0.055em;
  line-height: 1;
  margin: 37px 0 0;
}
.feature .sec .sec__text-read{
  color: #000;
  font-weight: 400;
  font-size: 13px;
  letter-spacing: 0.1em;
  line-height: 2.0769;
  margin: 34px 0 0;
  text-align: justify;
  width: 440px;
}

.feature .sec .sec__slide{
  display: flex;
  margin: 178px auto 0;
  width: 1400px;
}

/* sec01 */

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

.feature .sec01 .sec__detail{
  left: 1px;
}

.feature .sec01 .sec__text-read span{
  letter-spacing: 0.13em;
}

.feature .sec01 .img01{
  width: 500px;
}

/* sec02 */

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

.feature .sec02 .sec__detail{
  flex-direction: row-reverse;
  left: 25px;
}
.feature .sec02 .sec__detail::before{
  left: 240px;
}

.feature .sec02 .sec__text-device{
  margin: 0 0 0 auto;
}
.feature .sec02 .sec__text-device::before{
  left: initial;
  right: 2px;
}

.feature .sec02 .sec__text-ttl{
  margin: 45px 0 0;
}

.feature .sec02 .sec__text-read{
  letter-spacing: 0.055em;
}

.feature .sec02 .sec__text{
  text-align: right;
  margin: 97px 0 0;
}

.feature .sec02 .img05{
  width: 500px;
}

/* sec03 */

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

.feature .sec03 .inner::before{
  background: #2e83a0;
  content: "";
  top: 270px;
  left: 0;
  position: absolute;
  height: 400px;
  width: 100%;
}

.feature .sec03 .sec__detail{
  align-items: flex-start;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  margin: auto;
  width: 1400px;
}
.feature .sec03 .sec__detail::before{
  content: none;
}

.feature .sec03 .sec__device{
  color: #000;
  font-family: "nimbus-sans", sans-serif;
  font-weight: 700;
  font-size: 70px;
  letter-spacing: 0.045em;
  line-height: 1;
  top: 227px;
  left: 208px;
  position: absolute;
}
.feature .sec03 .sec__ttl{
  color: #fff;
  font-family: "nimbus-sans", sans-serif;
  font-weight: 700;
  font-size: 50px;
  letter-spacing: 0.055em;
  line-height: 1;
  top: 291px;
  left: 208px;
  position: absolute;
}

.feature .sec03 .sec__read{
  color: #000;
  font-weight: 400;
  font-size: 14px;
  letter-spacing: 0.075em;
  line-height: 1.857;
  margin: -170px 0 0 552px;
  text-align: justify;
  width: 502px;
}

.feature .sec03 .sec__detail .sec__item:nth-of-type(1){
  margin: 404px 0 0;
}
.feature .sec03 .sec__detail .sec__item:nth-of-type(2){
  margin: 0 0 0 45px;
}
.feature .sec03 .sec__detail .sec__item:nth-of-type(3){
  margin: 165px 0 0 -154px;
}
.feature .sec03 .img09{
  width: 500px;
}
.feature .sec03 .img10{
  width: 425px;
}
.feature .sec03 .img11{
  width: 425px;
}

/* sec04 */

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

.feature .sec04 .sec__detail{
  left: 4px;
  width: 1034px;
}
.feature .sec04 .sec__detail::before{
  top: 66px;
}

.feature .sec04 .sec__text-read{
  letter-spacing: 0.11em;
  width: 444px;
}
.feature .sec04 .sec__text-read span{
  letter-spacing: 0.13em;
}

.feature .sec04 .sec__slide{
  margin: 183px auto 0;
}

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

/* sec05 */

.feature .sec05{
  margin: 222px auto 0;
}

.feature .sec05 .sec__detail{
  flex-direction: row-reverse;
  left: 23px;
  width: 1035px;
}
.feature .sec05 .sec__detail::before{
  left: 246px;
}

.feature .sec05 .sec__text-device{
  margin: 0 0 0 auto;
}
.feature .sec05 .sec__text-device::before{
  left: initial;
  right: 2px;
}

.feature .sec05 .sec__text-ttl{
  margin: 45px 0 0;
}

.feature .sec05 .sec__text-read{
  letter-spacing: 0.055em;
  width: 444px;
}

.feature .sec05 .sec__text{
  text-align: right;
  margin: 97px 0 0;
}

.feature .sec05 .img16{
  width: 500px;
}


.feature .sec__btn {
  border-bottom: solid #000 1px;
  font-family: "nimbus-sans", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 400;
  left: 1px;
  letter-spacing: 0.03em;
  margin: 193px 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;
}