/* ---------------------
  common
--------------------- */
.fwsb {
  font-weight: 600;
}

.f30 {
  font-size: 3rem;
}
@media screen and (max-width: 834px) {
  .f30 {
    font-size: 3.5vw;
  }
}
@media screen and (max-width: 600px) {
  .f30 {
    font-size: 2rem;
  }
}

.f34 {
  font-size: 3.4rem;
}
@media screen and (max-width: 834px) {
  .f34 {
    font-size: 3.5vw;
  }
}
@media screen and (max-width: 600px) {
  .f34 {
    font-size: 2rem;
  }
}
@media screen and (max-width: 370px) {
  .f34 {
    font-size: 1.9rem;
  }
}

@media screen and (max-width: 834px) {
  .f42 {
    font-size: 4vw;
  }
}
@media screen and (max-width: 600px) {
  .f42 {
    font-size: 2.8rem;
  }
}
@media screen and (max-width: 390px) {
  .f42 {
    font-size: 2.5rem;
  }
}

.f44 {
  font-size: 4.4rem;
}
@media screen and (max-width: 845px) {
  .f44 {
    font-size: 5vw;
  }
}

@media screen and (max-width: 834px) {
  .c-hg__ja.f24 {
    font-size: 1.8rem;
  }
}

/* ---------------------
  ideal
--------------------- */
.ideal-intro {
  padding: 14rem 0;
  background: url(../img/ideal/intro-bg.webp) no-repeat center center/cover;
}
@media screen and (max-width: 834px) {
  .ideal-intro {
    padding: 5rem 0;
  }
}
.ideal-intro__hg .f44 {
  margin-top: 5rem;
}
@media screen and (max-width: 834px) {
  .ideal-intro__hg .f44 {
    margin-top: 2rem;
  }
}
.ideal-intro .c-txt {
  max-width: 70rem;
  margin: 5rem 0 0 auto;
}
@media screen and (max-width: 834px) {
  .ideal-intro .c-txt {
    margin-top: 3rem;
  }
}
@media screen and (max-width: 450px) {
  .ideal-intro .c-txt {
    margin-top: 2rem;
  }
}

.ideal-main {
  margin-top: 10rem;
}
@media screen and (max-width: 834px) {
  .ideal-main {
    margin-top: 5rem;
  }
}
.ideal-main__item {
  padding: 12rem 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  gap: 22%;
}
@media screen and (max-width: 1100px) {
  .ideal-main__item {
    gap: 3rem;
  }
}
@media screen and (max-width: 834px) {
  .ideal-main__item {
    gap: 2rem;
  }
}
@media screen and (max-width: 970px) {
  .ideal-main__item {
    padding: 3rem 0;
    -webkit-box-direction: normal;
    -webkit-box-orient: horizontal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.ideal-main__item:not(:first-child) {
  border-top: 1px solid #eee;
}
.ideal-main__item:first-child {
  padding-top: 0;
}
@media screen and (max-width: 450px) {
  .ideal-main__item:first-child .f34 {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 450px) {
  .ideal-main__item:nth-child(2) .f30 {
    font-size: 1.8rem;
  }
}
.ideal-main__item:last-child {
  padding-bottom: 0;
}
.ideal-main__item .c-hg__ja {
  min-width: 15rem;
}
.ideal-main__item h3 {
  line-height: 1.5;
}
.ideal-main__item .c-txt {
  margin-top: 4rem;
}
@media screen and (max-width: 970px) {
  .ideal-main__item .c-txt {
    margin-top: 2rem;
  }
}
.ideal-main__cont {
  width: calc(100% - (22% + 15rem));
}
@media screen and (max-width: 1100px) {
  .ideal-main__cont {
    width: calc(100% - 18rem);
  }
}
@media screen and (max-width: 970px) {
  .ideal-main__cont {
    width: 100%;
  }
}
.ideal-main__value {
  margin-top: 8rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (max-width: 970px) {
  .ideal-main__value {
    margin-top: 3rem;
  }
}
@media screen and (max-width: 760px) {
  .ideal-main__value {
    -webkit-box-direction: normal;
    -webkit-box-orient: horizontal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}
.ideal-main__value-item {
  max-width: 31rem;
  width: 100%;
  aspect-ratio: 1/1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-direction: normal;
  -webkit-box-orient: horizontal;
  -ms-flex-direction: column;
  flex-direction: column;
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
}
@media screen and (max-width: 450px) {
  .ideal-main__value-item {
    max-width: 25rem;
  }
}
.ideal-main__value-item:first-child {
  background-image: url(../img/ideal/ideal-circle01.webp);
}
.ideal-main__value-item:nth-child(2) {
  background-image: url(../img/ideal/ideal-circle02.webp);
}
.ideal-main__value-item:last-child {
  background-image: url(../img/ideal/ideal-circle03.webp);
}
.ideal-main__value-item:not(:first-child) {
  margin-left: -3rem;
}
@media screen and (max-width: 760px) {
  .ideal-main__value-item:not(:first-child) {
    margin-left: 0;
    margin-top: -3rem;
  }
}
.ideal-main__value-item .f18 {
  margin-bottom: 1.5rem;
  color: #1ca9d7;
}