/* body {
  font-size: 1.8rem;
} */

.-fs-s {
  font-size: 1.4rem;
}

.-fs-r {
  font-size: 1.6rem;
}

.-fs-m {
  font-size: 1.8rem;
}

.-fs-l {
  font-size: 2.4rem;
  line-height: 1.5;
}

.-fs-xl {
  font-size: 3.2rem;
  line-height: 1.5;
}

.-lh15 {
  line-height: 1.5;
}

.-ta-l {
  text-align: left;
}

.-ta-c {
  text-align: center;
}

.-ta-r {
  text-align: right;
}

.-va-t {
  vertical-align: top;
}

.-va-m {
  vertical-align: middle;
}

.-va-b {
  vertical-align: bottom;
}

.-va-bl {
  vertical-align: baseline;
}

.-w-s {
  max-width: 455px;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}

.-w-m {
  max-width: 455px;
  width: 100%;
  margin-right: auto;
  margin-left: auto;
}

:is(.-git00>*+*) {
  margin-top: 0;
}

:is(.-git10>*+*) {
  margin-top: 10px;
}

:is(.-git20>*+*) {
  margin-top: 20px;
}

:is(.-git30>*+*) {
  margin-top: 30px;
}

:is(.-git40>*+*) {
  margin-top: 40px;
}

:is(.-git60>*+*) {
  margin-top: 60px;
}

:is(.-git-main>*+*) {
  margin-top: 10rem;
}

.content {
  padding: 0 20px;
}

.content__inner {
  width: 1100px;
  margin-right: auto;
  margin-left: auto;
}

.content__inner.-full {
  width: 100%;
}

.content__inner.-narrow {
  width: 720px;
}

.content__header {
  text-align: center;
}

:is(.content__header>*+*) {
  margin-top: 20px;
}

.content__label.-img {
  line-height: 1;
}

.content__label.-img img {
  height: initial;
}

.content__label.-ruby {
  margin-top: 2rem;
  line-height: 1;
}

.content__img img {
  display: block;
  margin-right: auto;
  margin-left: auto;
}

.content__row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 40px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}

.content__row.-gap30 {
  gap: 30px;
}

.content__row.-gap20 {
  gap: 20px;
}

.content__row.-gap10 {
  gap: 10px;
}

.content__row.-gap00 {
  gap: 0px;
}

.content__row.-ai-s {
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.content__row.-ai-c {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}

.content__row.-ai-e {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.content__row.-wrap {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.content__row__item {
  -webkit-box-flex: 1;
  -ms-flex: 1 1 100%;
  flex: 1 1 100%;
  overflow: hidden;
}

.content__row.-flow .content__row__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
}

.content__row.-item2 .content__row__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 1 calc( 100% / 2 );
  flex: 0 1 calc( 100% / 2 );
}

.content__row.-item3 .content__row__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 calc( 100% / 3 );
  flex: 0 0 calc( 100% / 3 );
}

.content__row.-item4 .content__row__item {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 calc( 100% / 4 );
  flex: 0 0 calc( 100% / 4 );
}

.slide {
  max-width: 100%;
  width: 100%;
}

.slide img {
  width: 100%;
  height: auto;
}

.hero {
  position: relative;
}

.hero-slide__item__body {
  color: #fff;
  position: absolute;
  /* bottom: 8rem;
  left: 8rem; */
  top: calc( 50% + 4rem );
  transform: translateY(-50%);
  left: 12rem;
  filter: drop-shadow(0px 0px 2px rgba(0,0,0,.5));
}

.hero-slide__item__body.-r {
  left: auto;
  right: 8rem;
  text-align: right;
}

.hero-slide__item__header {
  font-size: 1.8rem;
}

.hero-slide__item__header>*+* {
  margin-top: 1.6rem;
}

.hero-slide__item__label {
  line-height: 0;
}

.hero-slide__item__txt {
  font-size: 2.4rem;
  margin-top: 3.6rem;
}

.slick-initialized+.hero-slide__item__body {
  opacity: 1;
}

.hero-slide {
  overflow: hidden;
  background-color: #ddd;
}

[data-inview] {
  opacity: 0;
  -webkit-transition: opacity .5s;
  transition: opacity .5s;
}

[data-inview].-inview {
  opacity: 1;
}

.hero-slide__item__img {
  position: relative;
  width: 100%;
  max-height: 800px;
  aspect-ratio: 16/9;
}


.hero-slide__item__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-slide__item__img .-pc {
  display: block;
}

.hero-slide__item__img .-sp {
  display: none;
}

.slick-dots {
	position: absolute;
	bottom: 20px;
	right: 0;
	left: 0;
	width: 100%;
	font-size: 0;
	text-align: center;
}

.slick-dots li {
	display: inline-block;
	font-size: 0;
	padding: 0;
	cursor: pointer;
}

.slick-dots li:only-child {
	display: none;
}

.slick-dots li+li {
	margin-left: 8px;
}

.slick-dots li:before {
	content: '';
	display: block;
	width: 8px;
	height: 8px;
	background-color: #fff;
	border-radius: 100px;
}

.slick-dots li.slick-active:before {
	background-color: #000;
}

.slick-dots button {
	display: none;
}


.intro {
  text-align: center;
}

.intro__title {
  display: none;
}

.intro__txt {
  font-size: 2.4rem;
}

.intro__txt>*+* {
  margin-top: 2.8rem;;
}

.feature__row {
  margin-right: -2rem;
  margin-left: -2rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0;
} 

.feature__row__item {
  position: relative;
  flex: 0 0 33.33%;
}

.feature__item01 {
  flex: 0 0 100%;
}

.feature__row__item__img {
  aspect-ratio: 4/3;
}

.feature__item01 .feature__row__item__img {
  aspect-ratio: 10/3;
}

.feature__item02 .feature__row__item__body {
  color: #fff;
}

.feature__row__item__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.feature__row__item__body {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  top: 0;
  padding: 2rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  line-height: 1;
}



.feature__row__item__title {
  margin-top: 2rem;
  font-size: 3.2rem;
}

.feature__row__item__title sup {
  font-size: 1.4rem;
  margin-left: 1rem;
  position: relative;
  top: -.5rem;
}

.feature__row__item__txt {
  margin-top: 4rem;
  font-size: 2.4rem;
}

.feature__row__item__txt>li + li {
  margin-top: 2rem;
}

.feature__item01 .feature__row__item__body {
  right: auto;
  left: 19rem;
  justify-content: center;
}

.feature__item01 .feature__row__item__lead {
  font-size: 2rem;
}

.feature__item01 .feature__row__item__title {
  font-size: 3.6rem;
}

.feature__caption {
  display: flex;
  justify-content: center;
  gap: 1em;
  font-size: 1.4rem;
  margin-top: 2rem;
  line-height: 1.57;
  color: rgba(77, 77, 77, 1);
}


.setting__row {
  gap: 20px;
}

.setting__row__item__img {
  aspect-ratio: 3/4;
}

.setting__row__item__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.setting__title {
  font-size: 24px;
}

.setting__title:has(.setting__badge__new) {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0 1rem;
}

.setting__badge__new {
  display: block;
  width: 38px;
  height: 18px;
  flex: 0 0 38px;
  background: url(../images/setting_badge_new.svg) no-repeat center /contain;
}

.setting__caption {
  display: block;
  font-size: 1.4rem;
  line-height: 1.2;
  margin-top: 1rem;
}

.slick-dots>li::before {
  -webkit-transition: background-color .5s;
  transition: background-color .5s;
}

.variation__row {
  display: flex;
  margin: 0 -2rem;
}

.variation__row__sep {
  flex: 0 0 .1rem;
  background-color: #000;
} 

.variation__row__item__wrapper {
  flex: 1 1 100%;
}

.variation__row__item__wrapper + .variation__row__item__wrapper {
  border-left: .1rem solid #000;
}

.variation__row__item {
  display: flex;
  flex-direction: column;
  gap: 4rem;
  padding: 0 2rem;
}

.variation__row__title {
  text-align: center;
  font-size: 2.4rem;
  line-height: 1;
}

.variation__row__types {
  display: flex;
  flex-wrap: wrap;
  margin: 0 4rem;
  justify-content: center;
  height: 5.6rem;
}

.variation__row__types>li:not(:last-child):after {
  content: '／';
}

.variation__row__item__ex {
  text-align: center;
  padding: 3.2rem 1.6rem;
  background-color: rgba(242, 242, 242, 1);
  max-width: 43.5rem;
  width: 100%;
  margin-inline: auto;
}

.variation__row__item__ex__title {
  line-height: 1;
}

.variation__row__item__ex__body {
  display: flex;
  justify-content: center;
  margin-top: 3.2rem;
  font-size: 1.4rem;
  gap: 1rem;
}


.variation__row__item__ex__item img {
  aspect-ratio: 1/1;
  max-width: 10.2rem;
  width: 100%;
  margin-inline: auto;
  display: block;

}

.variation__row__item__ex__item figcaption {
  margin-top: 1rem;
}

.variation__row__item__ex__name {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.variation__row__item__img {
  display: flex;
  justify-content: center;
  gap: 0 2rem;
}

.variation__row__item__img figcaption {
  margin-bottom: 1rem;
  text-align: center;
}

.variation__row__item__style {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 2rem;
}

.variation__row__item__style figure {
  aspect-ratio: 1/1;
  width: 10.2rem;
}

.variation__row__item__style figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.variation__row__item__links {
  max-width: 43.5rem;
  width: 100%;
  margin-inline: auto;
}

.variation__row__item__links__title {
  line-height: 1;
  font-size: 1.8rem;
  text-align: center;
}

.variation__row__item__links__body {
  margin-top: 4rem;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.variation__row__item__links__item {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  padding: 2rem;
  height: 10rem;
  text-align: center;
  background-color: rgba(34, 34, 34, 1);
  color: #fff!important;
}

.variation__slide__function {
  display: flex;
  justify-content: center;
  gap: .2rem;
}

.variation__slide__btn {
  display: none;
}



.pagetop {
  display: none;
}

.cta-btn {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  left: 2rem;
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  height: 0;
  transition: opacity .25s;
}

.cta-btn.-hide {
  opacity: 0;
}

.cta-btn__item[href] {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1;
  height: 6rem;
  border-radius: 3rem;
  background-color: rgba(34, 34, 34, 1);
  color: #fff;
  width: 34rem;
}



@media screen and (max-width: 480px) {
  :is(.-git-main>*+*) {
    margin-top: 8rem;
  }

  .content__inner {
    width: 100%;
  }

  .content__inner.-narrow {
    width: 100%;
  }

  .content__row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  .hero-slide__item__body,
  .hero-slide__item__body.-r {
    top: auto;
    left: 2rem;
    right: 2rem;
    bottom: 6.8rem;
    text-align: center;
    transform: translateY(0);
  }

  .hero-slide__item__header>*+* {
    margin-top: .8rem;
  }

  .hero-slide__item__img {
    aspect-ratio: 3/4;
  }

  .hero-slide__item__img .-pc {
    display: none;
  }
  
  .hero-slide__item__img .-sp {
    display: block;
  }


  .hero-slide__item__txt {
    display: none;
  }

  .feature-interview__chart__face__icon {
    margin-top: 5px;
    margin-bottom: -55px;
  }



  .intro__title {
    display: block;
    text-align: center;
    font-size: 2rem;
    margin-bottom: 4rem;
  }

  .intro__txt {
    font-size: 1.6rem;
  }
  
  .intro__txt>*+* {
    margin-top: 2rem;
  }

  .setting__row {
    gap: 40px;
  }

  .feature__row {
    flex-direction: column;
    flex-wrap: nowrap;
  }

  .feature__row__item__title {
    margin-top: 1rem;
    font-size: 2.8rem;
  }

  .feature__row__item__txt {
    margin-top: 2rem;
    font-size: 1.6rem;
  }

  .feature__row__item__txt>li + li {
    margin-top: 1rem;
  }

  .feature__caption {
    display: block;
  }


  .feature__item01 .feature__row__item__img {
    aspect-ratio: 1/1;
  }

  .feature__item01 .feature__row__item__body {
    left: 0;
    right: 0;
    justify-content: flex-end;
  }

  .feature__item01 .feature__row__item__lead {
    font-size: 1.6rem;
  }

  .feature__item01 .feature__row__item__title {
    font-size: 2.4rem;
  }

  .setting__row__item__img {
    aspect-ratio: 3/2;
  }

  .variation__row {
    display: block;

  }

  .variation__row__item__wrapper + .variation__row__item__wrapper {
    border-left: none;
  }

  .variation__row__item {

  }

  .variation__row__title {
    display: none;
  }

  .variation__row__types {
    margin: 0;
    height: auto;
  }

  .variation__row__item__ex__body {
    margin-top: 1.6rem;
  }

  .variation__row__item__ex__item {
    flex: 0 0 10.2rem;
  }

  .variation__slide__btn {
    flex: 0 1 16.7rem;
    height: 4rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border: .1rem solid rgba(128, 128, 128, 1);
    font-size: 1.8rem;
    line-height: 1;
    margin-bottom: 2.4rem;
    color: #fff;
    background-color: #c0c0c0;
    transition: background-color .25s, color .25s;
  }

  .variation__slide__btn:hover {
    opacity: 1;
  }

  .variation__slide__btn.-current {
    background-color:#fff;
    color: #000;
    opacity: 1;
  }

  .variation__slide__btn.-m {
    border-radius: 2rem 0 0 2rem;
    padding-left: .8rem;
  }
  
  .variation__slide__btn.-l {
    border-radius: 0 2rem 2rem 0;
    padding-right: .8rem;
  }

  .variation__row__item__ex {
    max-width: 100%;
  }

  .variation__row__item__links {
    max-width: 100%;
  }

  .cta-btn__item[href] {
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    line-height: 1;
    height: 6rem;
    border-radius: 3rem;
    background-color: rgba(34, 34, 34, 1);
    color: #fff;
    width: 100%;
  }

  .siteFooter {
    padding-bottom: 12rem;
  }


}