@charset "UTF-8";

html {
  font-size: 10px;
}

@media screen and (max-width: 1400px) {
  html {
    font-size: calc(10 * (100vw / 1400));
  }
}

/*-------------------------
 font
-------------------------*/
#feature .hero h2,
#feature .list_area h2,
#feature .bg03 .point_area__block p {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 400;
}

#feature .bg02 p, #feature .ttl_set, #feature .accordion_content__block p,#feature .bg03 p.hide-text__text {
    font-family: gill-sans-nova,ryo-gothic-plusn, sans-serif;
  font-style: normal;
  font-weight: 400;
}

#feature .flex_area__box p, #feature .bg02 h2, #feature .bg02 .readmore, #feature .item_detail h2, #feature .item_detail__product, #feature .item_detail__btn, #feature .bg03 .point_area h2, #feature .bg03 .point_area__block .readmore, #feature .fixedMenu__inner a {
  font-family: "gill-sans-nova", sans-serif;
  font-style: normal;
  font-weight: 400;
}

#feature p span {
  font-family: "gill-sans-nova", sans-serif!important;
}


/*-------------------------
 fade
-------------------------*/
#feature .fadeIn {
  opacity: 0;
  transition: opacity 1s;
}

#feature .fadeIn.is_show {
  opacity: 1;
}

@keyframes float {
  0% {
    transform: translatey(0px);
  }

  50% {
    transform: translatey(-20px);
  }

  100% {
    transform: translatey(0px);
  }
}

#feature .float {
  animation: float 5s ease-in-out infinite;
}

#feature .float--2 {
  animation-delay: 0.3s;
}

#feature .float--3 {
  animation-delay: 0.6s;
}

#feature .float--4 {
  animation-delay: 0.9s;
}

#feature .float--5 {
  animation-delay: 1.2s;
}

/*-------------------------
 common
-------------------------*/
.l-header {
  position: relative;
  z-index: 20;
}
.l-footer {
  padding: 0;
  position: relative;
  z-index: 30;
  background: #fff;
}

.pc-footer {
  margin: 0;
}

.l-container {
  width: 100%;
  margin: auto;
}

#feature {
  box-sizing: border-box;
  margin: 0 auto;
  font-feature-settings: "palt";
  text-align: center;
  overflow: clip;
  font-family: "gill-sans-nova","ryo-gothic-plusn", sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #1F1F1F;
  width: 100%;
  position: relative;
}

/**
#feature :lang(en) {
  font-family: "gill-sans-nova", sans-serif;
}

#feature :lang(ja) {
  font-family: "ryo-gothic-plusn", sans-serif;
}
**/

#feature .feature-inner {
  max-width: 46.8rem;
  width: 100%;
  height: auto;
  margin: auto;
  position: relative;
  top: 0;
  left: 0;
  right: 0;
}

#feature figure {
  position: relative;
  height: fit-content;
}

#feature a {
  text-decoration: none;
  transition: all 0.3s ease-in-out;
  color: #000;
}

#feature img {
  width: 100%;
  height: auto;
  display: block;
}

#feature a:hover {
  opacity: 0.7;
  transition: 0.4s;
}

#feature figure a {
  background: #fff;
}

/*-------------------------
 background
-------------------------*/
#feature .pc_bg {
  background-image: url(../img/bg_pc_1.jpg);
  background-position: top center;
  background-size: cover;
  width: 100vw;
  background-attachment: fixed;
  position: absolute;
  transition: background-image 1s ease-in-out;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0 auto;
}

#feature .pc_bg.change-bg {
  background-image: url(../img/bg_pc_2.jpg);
}

#feature .bg01 {
  background-image: url(../img/bg01.jpg);
  background-position: bottom center;
  background-size: cover;
  height: 56.64rem;
}

#feature .bg02 {
  background-image: url(../img/bg02.png);
  background-position: bottom center;
  background-size: cover;
  height: auto;
  padding-bottom: 7.2rem;
}

#feature .bg03 {
  width: 100%;
  height: auto;
  position: relative;
  clip-path: inset(0);
  background-repeat: no-repeat;
  background-image: url(../img/bg03.jpg);
  background-size: cover;
}

#feature .bg03.--2 {
  width: 100%;
  height: auto;
  position: relative;
  clip-path: inset(0);
  background-repeat: no-repeat;
  background-image: url(../img/bg04.jpg);
  background-size: cover;
}

/*-------------------------
  content
-------------------------*/
#feature .fixed_area {
  position: fixed;
  top: 0;
  left: 50%;
  translate: -50% 0;
  z-index: 3;
  display: flex;
  justify-content: space-between;
  width: 100%;
  height: 100%;
  margin: 0 auto;
  pointer-events: none;
}

#feature .left_fixed,
#feature .right_fixed {
  display: flex;
  justify-content: center;
  align-items: center;
  width: calc((100% - 46.8rem) / 2);
  /* max-width: 46.8rem; */
  height: 100%;
  pointer-events: all;
}

#feature .left_fixed figure {
  width: 32rem;
}

#feature .right_fixed__box {
    width: 24.4rem;
}

#feature .right_fixed a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: 100%;
  text-align: left;
  gap: 1vw;
}

#feature .right_fixed a p {
  font-size: 1.6rem;
  letter-spacing: 0.075em;
  font-family: gill-sans-nova, sans-serif;
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  margin-top: 0;
  width: 16rem;
  color: #1f1f1f;
}

#feature .right_fixed a:last-child {
  margin-top: 1vw;
}

#feature .right_fixed figure {
  width: 3rem;
}

#feature .right_fixed .arrow {
  width: 2rem;
}

#feature .hero__img {
  width: 100%;
  height: 60rem;
  position: relative;
}

#feature .hero .ripples {
  background-image: url(../img/hero.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 60rem;
  overflow: hidden;
}

#feature .hero__img figure:last-child {
  width: 27.84rem;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2.4rem;
  margin: auto;
}

#feature .hero h2 {
  color: #EAB158;
  font-size: 2.76rem;
  letter-spacing: 0.03em;
  line-height: 1;
  padding-top: 6rem;
}

#feature .hero p {
  font-size: 1.8rem;
  letter-spacing: 0.12em;
  line-height: 2.42;
  padding-top: 2.58rem;
  margin: 0;
}

#feature .hero span {
  font-size: 1.2rem;
  margin: auto;
  position: relative;
  vertical-align: top;
  display: inline-block;
  margin-top: 0.48rem;
  color: #1f1f1f;
}

#feature .hero .flex_area {
  display: flex;
  justify-content: center;
  margin-top: 4.5rem;
}

#feature .flex_area__box {
  width: 37%;
}

#feature .flex_area__box figure {
  width: 6.48rem;
  margin: auto;
}

#feature .flex_area__box p {
  font-size: 1.56rem;
  letter-spacing: 0.1em;
  line-height: 1.8;
  margin-top: 1.62rem;
  padding: 0;
}

#feature .flex_area__box .arrow {
  width: 2.4rem;
  margin-top: 1.32rem;
}

#feature .bg01 .note {
  font-size: 1.08rem;
  text-align: right;
  letter-spacing: 0.125em;
  line-height: 1;
  color: #828282;
  margin: 4.68rem 1.08rem 0 0;
  padding: 0;
}

#feature .bg02 h2 {
  font-size: 3.96rem;
  letter-spacing: 0.075em;
  line-height: 1;
  color: #EB7DA2;
  padding-top: 6.9rem;
  font-weight: 500;
}

#feature .bg02 p {
  font-size: 1.44rem;
  letter-spacing: 0.125em;
  line-height: 1;
  color: #1F1F1F;
  margin-top: 2.1rem;
  padding: 0;
}

#feature .bg02 .content {
  position: relative;
  height: 41.64rem;
  margin: auto;
}

#feature .bg02 .content__box h2 {
  font-size: 2.04rem;
  letter-spacing: 0.075em;
  padding-top: 3.48rem;
}

#feature .content__box h3 {
  font-size: 2.28rem;
  letter-spacing: 0.075em;
  padding-top: 0.96rem;
  font-weight: 400;
}

#feature .content__box h4 {
  font-size: 1.32rem;
  padding-top: 0.9rem;
  letter-spacing: 0.125em;
  font-weight: 400;
}

#feature .content__box p {
  font-size: 1.2rem;
  line-height: 2.05;
  letter-spacing: 0.125em;
  text-align: center;
  margin-top: 0.6rem;
  color: #1F1F1F;
  align-items: center;
  vertical-align: initial;
}

#feature .content__box.--4 h2 span {
  font-size: 0.84rem;
  line-height: 0;
  display: inline-block;
  margin-top: 1.2rem;
  vertical-align: top;
  color: #EAB158;
}

#feature .content__box p span {
  font-size: 0.84rem;
  line-height: 0;
  display: inline-block;
  margin-top: 1rem;
  vertical-align: top;
  color: #1f1f1f;
}

#feature .bg02 .content__box.--1 {
  background-image: url(../img/circle01-1.svg);
  background-repeat: no-repeat;
  background-size: 20.52rem;
  width: 20.52rem;
  height: 20.52rem;
  position: absolute;
  top: 3.9rem;
  left: 4.32rem;
}

#feature .content__box.--1 h3 {
  color: #EAB158;
}

#feature .bg02 .content__box.--2 {
  background-image: url(../img/circle01-2.svg);
  background-repeat: no-repeat;
  background-size: 20.52rem;
  width: 20.52rem;
  height: 20.52rem;
  position: absolute;
  top: 9rem;
  left: 21.9rem;
}

#feature .bg03 .content__box.--2 p span {
  
}

#feature .bg02 .content__box.--2 h3 {
  color: #78C7B9;
  padding-top: 3.78rem;
  letter-spacing: 0.125em;
}

#feature .bg02 .content__box.--2 h4 {
  color: #78C7B9;
  padding: 0.36rem 0 0.3rem;
  margin: 0;
}

#feature .bg02 .content__box.--3 {
  background-image: url(../img/circle01-3.svg);
  background-repeat: no-repeat;
  background-size: 20.52rem;
  width: 20.52rem;
  height: 20.52rem;
  position: absolute;
  top: 21.48rem;
  left: 7.68rem;
}

#feature .bg02 .content__box.--3 h3 {
  color: #A0A6B3;
  padding-top: 3rem;
  letter-spacing: 0.065em;
}

#feature .bg02 .content__box.--3 h4 {
  color: #A0A6B3;
  padding: 0.42rem 0;
  margin: 0;
}

#feature .bg02 .readmore {
  margin-top: 3.12rem;
  color: #EB7DA2;
  text-decoration: underline 1px #EB7DA2;
  text-underline-offset: 1rem;
  padding: 0;
  font-weight: 400;
}

#feature .bg02 .readmore .open,
#feature .bg02 .readmore .close {
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  color: #EB7DA2;
}

#feature .bg03 p {
  font-size: 1.8rem;
  letter-spacing: 0.12em;
  line-height: 2.42;
  padding-top: 4.8rem;
  margin: 0;
}

#feature .bg03 .bg03__lead span {
  font-size: 1.2rem;
  margin: auto;
  position: relative;
  vertical-align: top;
  display: inline-block;
  margin-top: 0.6rem;
}

#feature .list_area {
  background-image: url(../img/frame01.svg);
  background-repeat: no-repeat;
  background-size: 42rem;
  width: 42rem;
  height: 32.4rem;
  margin: 3.42rem auto 0;
}

#feature .list_area h2 {
  font-size: 2.76rem;
  letter-spacing: 0.0075em;
  line-height: 1;
  padding-top: 5.28rem;
  color: #EAB158;
}

#feature .list_area ul {
  text-align: left;
  list-style: none;
  margin: 3.9rem auto 0;
  padding: 0;
  width: 28.32rem;
}

#feature .list_area li {
  font-size: 1.56rem;
  letter-spacing: 0.12em;
  margin-top: 1.5rem;
  vertical-align: middle;
  align-items: center;
  display: flex;
}

#feature .list_area li:before {
  content: "";
  display: inline-block;
  width: 2.4rem;
  height: 2.4rem;
  background-image: url(../img/icon01.svg);
  background-size: contain;
  background-repeat: no-repeat;
  margin-right: 1.2rem;
  vertical-align: middle;
}

#feature .sec02 .list_area li:nth-child(2):before,
#feature .sec02 .list_area li:nth-child(3):before,
#feature .sec02 .list_area li:nth-child(4):before {
  margin-top: -2.7rem;
}

#feature .sec01 .ripples {
  background-image: url(../img/img02.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 60rem;
  overflow: hidden;
}

#feature .bg03 .content {
  position: relative;
  height: 51.6rem;
}

#feature .content__box.--4 h2 span {
    font-size: 0.84rem;
    line-height: 0;
    display: inline-block;
    margin-top: 1.2rem;
    vertical-align: top;
    color: #EAB158;
}

#feature .bg03 .content__box h2 {
  font-size: 1.56rem;
  letter-spacing: 0.2em;
  color: #EAB158;
  letter-spacing: 0.085em;
  line-height: 1.5;
  font-weight: 400;
}

#feature .bg03 .content__box p {
  font-size: 1.2rem;
  letter-spacing: 0.125em;
  line-height: 1.8;
  padding-top: 0;
  margin-top: 0.5rem;
  /* font-weight: 300; */
}

#feature .bg03 .content__box {
  display: flex;
  justify-content: center;
  align-items: center;
}

#feature .bg03 .content__box.--1 {
  background-image: url(../img/circle02-1.png);
  background-repeat: no-repeat;
  background-size: 16.2rem;
  width: 16.2rem;
  height: 16.2rem;
  position: absolute;
  top: 4.92rem;
  left: 12rem;
  pointer-events: none;
  display: flex;
  justify-content: center;
  align-items: center;
  vertical-align: middle;
}

#feature .bg03 .content__box.--2 {
  background-image: url(../img/circle02-2.png);
  background-repeat: no-repeat;
  background-size: 10.8rem;
  width: 10.8rem;
  height: 10.8rem;
  position: absolute;
  top: 16.8rem;
  left: 2.4rem;
  display: flex;
  justify-content: center;
  align-items: center;
  vertical-align: middle;
}

#feature .bg03 .content__box.--2 h2 {
  letter-spacing: 0.17em;
  font-weight: 300;
  line-height: 1.9;
  margin-top: 0.54rem;
}

/**#feature .bg03 .content__box.--2 h2 span {
  font-size: 1.56rem;
  letter-spacing: 0.125em;
  color: #EAB158;
}**/

#feature .bg03 .content__box.--3 {
  background-image: url(../img/circle02-3.png);
  background-repeat: no-repeat;
  background-size: 14.4rem;
  width: 14.4rem;
  height: 14.4rem;
  position: absolute;
  top: 23.7rem;
  left: 12rem;
  display: flex;
  justify-content: center;
  align-items: center;
  vertical-align: middle;
}

#feature .bg03 .content__box.--3 h2 {
  letter-spacing: 0.17em;
  /* margin-top: 0.3rem; */
  font-weight: 300;
  line-height: 1.5;
}

#feature .bg03 .content__box.--3 p {
  margin-top: 0.5rem;
}

#feature .bg03 .content__box.--4 {
  background-image: url(../img/circle02-4.png);
  background-repeat: no-repeat;
  background-size: 15rem;
  width: 15rem;
  height: 15rem;
  position: absolute;
  top: 36.6rem;
  left: 1.8rem;
  display: flex;
  justify-content: center;
  align-items: center;
  vertical-align: middle;
}

#feature .bg03 .content__box.--4 h2 {
  font-size: 1.44rem;
  line-height: 2;
  margin-top: 0.3rem;
  letter-spacing: 0.125em;
  font-weight: 400;
}

#feature .bg03 .item01 {
  width: 16.8rem;
  height: 34.8rem;
  position: absolute;
  top: 16.8rem;
  right: 1.2rem;
}

#feature .bg03 .item_detail {
  margin-top: 4.98rem;
}

#feature .bg03 .item_detail h2 {
  font-size: 3.12rem;
  letter-spacing: 0.075em;
  color: #1F1F1F;
  line-height: 1.5;
  font-weight: 500;
}

#feature .bg03 .item_detail__name {
  font-size: 1.56rem;
  letter-spacing: 0.125em;
  color: #EEB475;
  line-height: 1.5;
  margin-top: -3.3rem;
}

#feature .bg03 .item_detail__product {
  margin-top: -3.6rem;
  letter-spacing: 0.1em;
  font-size: 1.92rem;
  font-weight: 400;
}

#feature .bg03 .item_detail__btn {
  padding-top: 0;
}

#feature .bg03 .item_detail__btn span {
  font-size: 1.92rem;
  margin: auto;
}

#feature .bg03 .item_detail__btn span:first-child {
  transform: translateX(2.16rem);
}

#feature .bg03 .item_detail__btn a {
  width: 25.2rem;
  height: 4.92rem;
  display: flex;
  margin: 2.1rem auto 0;
  background: #EEB475;
  color: #fff;
  font-size: 1.92rem;
  letter-spacing: 0.075em;
  padding: 0;
  position: relative;
}

#feature .item_detail__btn a:before {
  content: "";
  position: absolute;
  z-index: 0;
  transform: translateY(-50%);
  top: 50%;
  right: 0.66rem;
  width: 0.84rem;
  height: 0.84rem;
  background-image: url(../img/arrow02.svg);
  background-size: contain;
  background-repeat: no-repeat;
  z-index: 10;
}

#feature .item_detail__btn span.border {
  position: relative;
  overflow: clip;
  width: 2.1rem;
  height: 0.1rem;
  margin-right: 1.05rem;
  z-index: 0;
}

#feature .bg03 .item_detail__btn .border:after {
  content: "";
  position: absolute;
  z-index: 0;
  top: 0;
  left: 0;
  width: 0;
  height: 0.15rem;
  background-color: #ffffff;
  background-position: right;
  -webkit-animation: extend 2s ease-in-out infinite;
  animation: extend 2s ease-in-out infinite;
  z-index: 0;
}

@-webkit-keyframes extend {
  0% {
    width: 0;
    transform: translateX(0);
    opacity: 0;
  }

  1% {
    transform: translateX(0);
    opacity: 0;
  }

  2% {
    width: calc(0 * 100vw/468);
    opacity: 1;
  }

  28% {
    transform: translateX(0);
  }

  32% {
    width: 2.1rem;
  }

  90% {
    transform: translateX(2.1rem);
    width: 2.1rem;
    opacity: 1;
  }

  91% {
    opacity: 0;
  }

  100% {
    width: 0;
    transform: translateX(0);
    opacity: 0;
  }
}

@keyframes extend {
  0% {
    width: 0;
    transform: translateX(0);
    opacity: 0;
  }

  1% {
    transform: translateX(0);
    opacity: 0;
  }

  2% {
    width: calc(0 * 100vw/468);
    opacity: 1;
  }

  28% {
    transform: translateX(0);
  }

  32% {
    width: 2.1rem;
  }

  90% {
    transform: translateX(2.1rem);
    width: 2.1rem;
    opacity: 1;
  }

  91% {
    opacity: 0;
  }

  100% {
    width: 0;
    transform: translateX(0);
    opacity: 0;
  }
}

#feature .bg03 .content--2 {
  position: relative;
  height: 37.8rem;
}

#feature .bg03 .content--2 p {
  padding-top: 0;
  line-height: 1.8;
  font-size: 1.68rem;
  letter-spacing: 0.125em;
  display: flex;
  justify-content: center;
  align-items: center;
  vertical-align: middle;
}

#feature .bg03 .content--2 .content__box.--1 {
  background-image: url(../img/circle03-1.png);
  background-repeat: no-repeat;
  background-size: 14.4rem;
  width: 14.4rem;
  height: 14.4rem;
  position: absolute;
  top: 10.8rem;
  left: 2.7rem;
}

#feature .bg03 .content--2 .content__box.--2 {
  background-image: url(../img/circle03-2.png);
  background-repeat: no-repeat;
  background-size: 15.6rem;
  width: 15.6rem;
  height: 15rem;
  position: absolute;
  top: 5.7rem;
  left: 16.2rem;
}

#feature .bg03 .content--2 .content__box.--3 {
  background-image: url(../img/circle03-3.png);
  background-repeat: no-repeat;
  background-size: 13.2rem;
  width: 13.2rem;
  height: 12rem;
  position: absolute;
  top: 8.7rem;
  left: 30.9rem;
}

#feature .bg03 .content--2 .content__box.--4 {
  background-image: url(../img/circle03-4.png);
  background-repeat: no-repeat;
  background-size: 16.2rem;
  width: 16.2rem;
  height: 16.8rem;
  position: absolute;
  top: 22.2rem;
  left: 11.7rem;
}

#feature .bg03 .content--2 .content__box.--5 {
  background-image: url(../img/circle03-5.png);
  background-repeat: no-repeat;
  background-size: 13.8rem;
  width: 13.8rem;
  height: 13.2rem;
  position: absolute;
  top: 20.1rem;
  left: 26.4rem;
}

#feature .bg03 .content--2 .content__box.--1 p {
  margin: -0.6rem 0 0 -0.5rem;
}

#feature .bg03 .content--2 .content__box.--2 p {
  margin: -0.6rem 0 0 -2rem;
}

#feature .bg03 .content--2 .content__box.--3 p {
  margin: 0.48rem 0 0 0;
}

#feature .bg03 .content--2 .content__box.--4 p {
  margin: -1.8rem 0 0 -1.38rem;
}

#feature .bg03 .content--2 .content__box.--5 p {
  margin: -1.2rem 0 0 -1.5rem;
}

#feature .bg03 .content--2 .content__box p span {
  margin-top: -0.72rem;
}

#feature .bg03 .point_area {
  position: relative;
  margin-top: 2.4rem;
}

#feature .bg03 .point_area.--2,
#feature .bg03 .point_area.--3 {
  margin-top: 4.8rem;
}

#feature .bg03 .point_area h2 {
  background-image: url(../img/point01.svg);
  background-repeat: no-repeat;
  background-size: 6.12rem;
  width: 6.3rem;
  height: 6.3rem;
  position: absolute;
  top: -1.8rem;
  left: 1.26rem;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  text-align: center;
  line-height: 1;
  padding: 1.32rem 0;
  margin-left: -0.3rem;
  color: #1F1F1F;
  font-weight: 400;
  z-index: 20;
}

#feature .bg03 .point_area h2 span {
  font-size: 2.7rem;
  letter-spacing: 0.1em;
  text-align: center;
  line-height: 1;
  display: block;
}

#feature .bg03 .point_area__block {
  width: 43.8rem;
  margin: 4.2rem 0 0 auto;
  background: rgba(255, 255, 255, 0.5);
}

#feature .bg03 .point_area__block p {
  margin-left: 5rem;
  padding: 1.8rem 0 0;
  text-align: left;
  color: #EEB475;
  font-size: 2.16rem;
  letter-spacing: 0;
  line-height: 2;
}

#feature .bg03 .point_area__block p span {
  font-size: 1.2rem;
  vertical-align: top;
  display: inline-block;
  margin-top: 0.66rem;
}

#feature .bg03 .point_area__block .readmore {
  font-size: 1.44rem;
  letter-spacing: 0.1em;
  color: #1F1F1F;
  margin: 1.8rem 0 0 5rem;
  padding: 0;
  padding-bottom: 3.5rem;
  text-decoration: underline 1px #666666;
  text-underline-offset: 0.7rem;
  font-weight: 400;
}

#feature .bg03 .note {
  font-size: 1.08rem;
  text-align: right;
  letter-spacing: 0.125em;
  line-height: 1.8;
  color: #828282;
  margin: 3.3rem 1.08rem 0 0;
  padding: 0;
}

#feature .bg03 .accordion_list {
  width: 36rem;
  margin: 5.52rem auto 0;
  padding-bottom: 8.4rem;
}

#feature .bg03 .accordion_list p {
  font-size: 2.04rem;
  letter-spacing: 0.125em;
  text-align: center;
  padding: 0 0 1.02rem 0;
  margin-top: 1.8rem;
  line-height: 1.25;
}

/** sec02 **/
#feature .sec02 .ripples {
  background-image: url(../img/img03.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  height: 61.2rem;
  overflow: hidden;
}

#feature .sec02 .bg03 .list_area {
  background-image: url(../img/frame02.svg);
  height: 40.68rem;
  margin: 3.78rem auto 0;
}

#feature .sec02 .bg03 .list_area li:before {
  background-image: url(../img/icon02.svg);
}

#feature .sec02 .content__box.--1 {
  background-image: url(../img/circle04-1.png);
  background-size: 15.24rem;
  width: 15.84rem;
  height: 15.24rem;
  position: absolute;
  top: 6.12rem;
  left: 21rem;
}

#feature .sec02 .content__box.--2 {
  background-image: url(../img/circle04-2.png);
  background-size: 10.8rem;
  width: 10.8rem;
  height: 10.8rem;
  position: absolute;
  top: 16.8rem;
  left: 34.8rem;
}

#feature .sec02 .bg03 .content__box.--3 {
  background-image: url(../img/circle04-3.png);
  background-size: 10.8rem;
  width: 10.8rem;
  height: 10.8rem;
  position: absolute;
  top: 22.5rem;
  left: 20.4rem;
}

#feature .sec02 .bg03.--2 .content__box.--4 {
  background-image: url(../img/circle04-4.png);
  background-size: 14.4rem;
  width: 14.4rem;
  height: 14.4rem;
  position: absolute;
  top: 28.92rem;
  left: 30.6rem;
}

#feature .sec02 .bg03.--2 .content__box.--5 {
  background-image: url(../img/circle04-5.png);
  background-size: 13.2rem;
  width: 13.2rem;
  height: 13.2rem;
  position: absolute;
  top: 38.1rem;
  left: 18.6rem;
  z-index: 20;
}

#feature .sec02 .bg03 .content__box.--1 h2 {
  line-height: 1.8;
  letter-spacing: 0.125em;
  margin-top: 0.42rem;
  font-weight: 400;
}

#feature .sec02 .bg03 .content__box.--4 h2 {
  line-height: 1.8;
  margin-top: -0.3rem;
}

#feature .sec02 .bg03 .content__box.--5 h2 {
  line-height: 1.8;
  margin-top: 1.2rem;
  font-weight: 400;
}

#feature .sec02 .bg03 .point_area h2 {
  background-image: url(../img/point02.svg);
}

#feature .sec02 .bg03 .content--2 .content__box.--1 {
  background-image: url(../img/circle05-1.png);
  background-repeat: no-repeat;
  background-size: 18rem;
  width: 18rem;
  height: 16.2rem;
  position: absolute;
  top: 10.2rem;
  left: 2.1rem;
}

#feature .sec02 .bg03 .content--2 .content__box.--2 {
  background-image: url(../img/circle05-2.png);
  background-repeat: no-repeat;
  background-size: 12rem;
  width: 12rem;
  height: 11.4rem;
  position: absolute;
  top: 6rem;
  left: 18.3rem;
}

#feature .sec02 .bg03 .content--2 .content__box.--3 {
  background-image: url(../img/circle05-3.png);
  background-repeat: no-repeat;
  background-size: 14.4rem;
  width: 14.4rem;
  height: 13.2rem;
  position: absolute;
  top: 8.4rem;
  left: 30.3rem;
}

#feature .sec02 .bg03 .content--2 .content__box.--4 {
  background-image: url(../img/circle05-4.png);
  background-repeat: no-repeat;
  background-size: 15rem;
  width: 15rem;
  height: 12.6rem;
  position: absolute;
  top: 24rem;
  left: 9.3rem;
}

#feature .sec02 .bg03 .content--2 .content__box.--5 {
  background-image: url(../img/circle05-5.png);
  background-repeat: no-repeat;
  background-size: 15.6rem;
  width: 15.6rem;
  height: 13.8rem;
  position: absolute;
  top: 20.1rem;
  left: 22.8rem;
}

#feature .sec02 .bg03 .accordion_content__block p {
  background-image: url('../img/img07.svg');
}

#feature .sec02 .list_area h2,
#feature .sec02 .bg03 .content__box h2,
#feature .sec02 .bg03 .content__box.--2 h2 span,
#feature .sec02 .bg03 .item_detail__name,
#feature .sec02 .bg03 .point_area__block p,
#feature .sec02 .content__box h2 span {
  color: #78C7B9;
}

#feature .sec02 .bg03 .item_detail__btn a {
  background: #78C7B9;
}

#feature .sec02 .bg03 p.hide-text__text {
  color: #1f1f1f;
}

#feature .sec02 .list_area ul {
  width: 38.52rem;
  margin-top: 3.48rem;
}

#feature .sec02 .list_area ul li {
  text-indent: 0;
  padding-left: 3.6rem;
  line-height: 2.2;
  display: flex;
  margin: 0;
}

#feature .sec02 .bg03 .item01 {
  width: 18rem;
  height: 31.2rem;
  position: absolute;
  top: 15.9rem;
  left: 1.2rem;
}

#feature .sec02 .bg03 .item_detail {
  margin-top: 4.8rem;
}

#feature .sec02 .bg03 .content--2 p {
  padding-top: 3.9rem;
  line-height: 2;
}

#feature .sec02 .bg03 .content--2 .content__box.--1 p {
  margin: -5.4rem 0 0 -1.5rem;
  line-height: 2;
}

#feature .sec02 .bg03 .content--2 .content__box.--2 p {
  line-height: 2;
  margin: -3.6rem 0 0 -0.3rem;
}

#feature .sec02 .bg03 .content--2 .content__box.--3 p {
  margin: -5.4rem 0 0 -1.5rem;
  line-height: 2;
}

#feature .sec02 .bg03 .content--2 .content__box.--4 p {
  margin: -5.4rem 0 0 -2rem;
  line-height: 2;
}

#feature .sec02 .bg03 .content--2 .content__box.--5 p {
  margin: -6.6rem 0 0 -1.5rem;
  line-height: 2;
}

#feature .sec02 .bg03 .content--2 {
  margin-bottom: -2.22rem;
}

#feature .sec02 .content__box h2 span {
  
#feature .content__box.
  --4 h2 span {
    font-size: 0.84rem;
  line-height: 0;
  display: inline-block;
  margin-top: 1.2rem;
  vertical-align: top;
  color: #EAB158;
};
  font-size: 0.84rem;
  line-height: 0;
  display: inline-block;
  margin-top: 1.2rem;
  vertical-align: top;
}

/** nav **/
#feature .fixedMenu {
  align-items: center;
  box-sizing: border-box;
  display: flex;
  height: 6.24rem;
  justify-content: center;
  position: fixed;
  bottom: 0;
  left: 0;
  transition: bottom 0.6s 0.3s;
  transform: translateY(100%);
  visibility: hidden;
  width: 100%;
  z-index: 4;
}

#feature .fixedMenu__inner {
  display: flex;
  width: 46.8rem;
  height: 6.24rem;
  justify-content: center;
}

#feature .fixedMenu a {
  align-items: center;
  display: flex;
  font-size: 1.56rem;
  justify-content: center;
  letter-spacing: 0.075em;
  line-height: 1.5;
  color: #fff;
}

#feature .fixedMenu a:first-child {
  background: #EAB158;
  width: 50%;
  text-align: center;
}

#feature .fixedMenu a:last-child {
  background: #78C7B9;
  width: 50%;
  text-align: center;
}

#feature .fixedMenu a:last-of-type {
  border-right: none;
}

#feature .fixedMenu.is-scrolling-down {
  bottom: -6.24rem;
}

#feature .fixedMenu.visible {
  transition: all 0.6s 0.3s;
  transform: translateY(100%);
}

#feature .fixedMenu.hidden {
  transition: all 0.6s 0.3s;
  visibility: visible;
  transform: translateY(0);
  z-index: 50;
}

#feature .fixedMenu.UpMove {
  animation: UpAnime 0.5s forwards;
}

@keyframes UpAnime {
  from {
    opacity: 0;
    transform: translateY(6.24rem);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#feature .fixedMenu.DownMove {
  animation: DownAnime 0.5s forwards;
}

@keyframes DownAnime {
  from {
    opacity: 1;
    transform: translateY(0);
  }

  to {
    opacity: 1;
    transform: translateY(6.24rem);
  }
}

/** @accordion01 **/
#feature .readmore {
  position: relative;
  margin: 3em auto 0;
  display: block;
  color: #666;
  border: none;
  outline: 0;
  cursor: pointer;
  background: none;
  letter-spacing: 0.1em;
}

#feature .readmore.on-click:before {
  transform: rotate(180deg);
}

#feature .readmore .open {
  display: block;
}

#feature .readmore.on-click .open {
  display: none;
}

#feature .readmore .close {
  display: none;
}

#feature .readmore.on-click .close {
  display: block;
}

/** accordion02 **/
#feature .accordion {
  margin: 3em auto;
  width: 36rem;
  margin: 3.66rem auto 0;
}

#feature .accordion_title {
  cursor: pointer;
  border-bottom: 0.15rem solid #666666;
  margin: 0;
  position: relative;
}

#feature .accordion_title.active {
  border-bottom: unset;
}

#feature .accordion_title .icon {
  position: absolute;
  right: 0.6rem;
  top: 50%;
  transform: translateY(-50%);
}

#feature .accordion_title::before {
  content: "";
  position: absolute;
  right: 2.4rem;
  top: 0.6rem;
  width: 0.15rem;
  height: 0.75em;
  background-color: #666666;
  transition: all 0.3s;
  transform: rotate(-90deg);
  font-size: 1.8rem;
}

#feature .accordion_title::after {
  content: "";
  position: absolute;
  right: 2.4rem;
  top: 0.6rem;
  width: 0.15rem;
  height: 0.75em;
  background-color: #666666;
  transition: all 0.3s;
  font-size: 1.8rem;
}

#feature .accordion_title.active::after {
  transform: rotate(90deg);
}

/** accordion_txt01 **/
#feature .hide-text__block {
  width: 37.8rem;
  margin: 4.2rem auto 0;
}

#feature .hide-text__block:nth-child(2) {
  margin: 0.9rem auto 0;
}

#feature .hide-text__block:nth-child(3) {
  margin: 1.2rem auto 0;
}

#feature .hide-text__block__ttl,
#feature .ttl_set {
  display: flex;
  position: relative;
  align-items: center;
}

#feature .hide-text__block__ttl {
  gap: 1.08rem;
}

#feature .bg02 .circle-text {
  display: inline-block;
  border-radius: 50%;
  text-align: center;
  width: 7.2rem;
  height: 7.2rem;
  line-height: 7.2rem;
}

#feature .bg02 .ttl_set__ttl {
  line-height: 2.2;
  text-align: left;
  white-space: nowrap;
}

#feature .bg02 .ttl_set__ttl span {
  font-size: 0.84rem;
  vertical-align: top;
  display: inline-block;
  margin-top: 0.36rem;
  color: #1f1f1f;
}

#feature .bg02 .ttl_set__text {
  font-size: 1.32rem;
  text-align: left;
  letter-spacing: 0.125em;
  line-height: 2.2;
  margin-top: 1.5rem;
  text-align: justify;
}

#feature .bg02 .ttl_set__text span {
  font-size: 0.84rem;
  vertical-align: top;
  display: inline-block;
  margin-top: 0.36rem;
  color: #1f1f1f;
}

#feature .ttl_set.--1 p:first-child {
  background: #F7E4C3;
  color: #EAB158;
  z-index: 10;
}

#feature .ttl_set.--1 p:last-child {
  border: 0.15rem solid #EB7DA2;
  background: rgba(255,255,255,0.5);
  color: #EB7DA2;
  transform: translateX(-0.66rem);
  letter-spacing: 0.1em;
}

#feature .ttl_set.--2 p:first-child {
  background: #E4F4F1;
  color: #78C7B9;
  z-index: 10;
}

#feature .ttl_set.--2 p:last-child {
  border: 0.15rem solid #78C7B9;
  background: rgba(255,255,255,0.5);
  color: #78C7B9;
  transform: translateX(-0.6rem);
  letter-spacing: 0.1em;
  padding: 0;
  font-size: 1.08rem;
  letter-spacing: 0.08em;
  line-height: 1.8;
  vertical-align: middle;
  display: flex;
  align-items: center;
  justify-content: center;
}

#feature .ttl_set.--3 p:first-child {
  background: #ECEFF6;
  color: #A0A6B3;
  z-index: 10;
}

#feature .ttl_set.--3 p:last-child {
  border: 0.15rem solid #B3B8C2;
  background: rgba(255,255,255,0.5);
  color: #B3B8C2;
  transform: translateX(-0.6rem);
  letter-spacing: 0.1em;
  padding: 0;
  font-size: 1.08rem;
  letter-spacing: 0.08em;
  line-height: 1.8;
  vertical-align: middle;
  display: flex;
  align-items: center;
  justify-content: center;
}

#feature .bg02 .note {
  font-size: 1.08rem;
  text-align: right;
  letter-spacing: 0.125em;
  line-height: 1.8;
  color: #828282;
  margin: 2.7rem 4.38rem -0.9rem 0;
  padding: 0;
}

/** accordion_txt02 **/
#feature .bg03 p.hide-text__text {
  font-size: 1.32rem;
  line-height: 2.2;
  letter-spacing: 0.115em;
  color: #1f1f1f;
  width: 36rem;
  text-align: justify;
}

#feature .bg03 .point_area.--2 p.hide-text__text {
  letter-spacing: 0.12em;
}

#feature .bg03 .point_area.--3 p.hide-text__text {
  letter-spacing: 0.08em;
}

#feature .bg03 p.hide-text__text span {
  font-size: 0.84rem;
  vertical-align: top;
  display: inline-block;
  margin-top: 0.36rem;
  color: #1f1f1f;
}

/** accordion03 **/
#feature .bg03 .accordion_content {
  width: 36rem;
  margin: auto;
}

#feature .bg03 .accordion_content__block {
  display: flex;
  flex-wrap: wrap;
  width: 36rem;
  justify-content: center;
  margin: 0.9rem auto 0;
  gap: 1.5rem;
  padding: 0.96rem 0 2.7rem;
}

#feature .bg03 .accordion_content__block p {
  background-image: url('../img/img04.svg');
  background-position: center;
  background-repeat: no-repeat;
  padding: 0.6rem;
  width: 9rem;
  height: 9rem;
  font-size: 1.26rem;
  line-height: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 0;
}

#feature .bg03 p.accordion_content__text {
  text-align: justify;
  font-size: 1.32rem;
  letter-spacing: 0.11em;
  margin-top: 0.9rem;
  line-height: 2.2;
  padding-bottom: 2.82rem;
  margin: 0.6rem auto;
}

#feature .img05 {
  margin: 1.5rem auto 2.28rem;
}

#feature .bg03 p.accordion_content__text.--2 {
  letter-spacing: 0.125em;
  padding-bottom: 2.1rem;
}

#feature .img06 {
  margin: 2.7rem auto 2.1rem;
  width: 13.2rem;
}

#feature .bg03 p.accordion_content__text.--3 {
  letter-spacing: 0.13em;
  padding-bottom: 1.8rem;
  text-align: justify;
}

#feature .bg03 p.accordion_content__text.--4 {
  letter-spacing: 0.125em;
  margin-top: -0.6rem;
}