@keyframes blur-circle-bounce {
  0% {
    margin-top: 0;
  }
  50% {
    margin-top: -30px;
  }
  100% {
    margin-top: 0;
  }
}
/* .c-about-news-wave */
.c-about-news-wave {
  background: url(../img/about-news-wave-sp.svg) no-repeat 70% 0/680px;
}

/* .c-about */
.c-about {
  padding: 0;
}
.c-about__inner {
  padding: 60px 20px;
  position: relative;
  overflow: hidden;
}
.c-about__inner::after {
  content: "";
  display: inline-block;
  z-index: -1;
  opacity: 0.7;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: #FFFF9B;
  background: linear-gradient(0deg, #FFEEBE 0%, #FFFF9B 100%);
  transform: translate(-50%, -50%);
  filter: blur(30px);
  animation: blur-circle-bounce 5s ease-in-out infinite;
  position: absolute;
  top: 50%;
  left: 100%;
}
.c-about__headerLabel {
  font-family: "Outfit", "Noto Sans JP", YuGothic, sans-serif;
  font-optical-sizing: auto;
  font-weight: var(--font-weight-bold);
  margin-bottom: 15px;
}
.c-about__headerLabel::before {
  content: "";
  display: inline-block;
  border-radius: 100%;
  background: var(--color-brand);
  width: 5px;
  height: 5px;
  margin-right: 4px;
  vertical-align: middle;
  translate: 0 -2px;
}
.c-about__headerTitle {
  font-size: 25px;
  line-height: 35px;
  font-weight: var(--font-weight-bold);
}
.c-about__image {
  border-radius: 40px;
  width: 100%;
  height: auto;
  margin: 40px 0;
}
/* =============================================
for PC
============================================= */
@media screen and (min-width: 1025px) {
  /* .c-about-news-wave */
  .c-about-news-wave {
    background: url(../img/about-news-wave-pc.svg) no-repeat top/6240px;
  }
  /* .c-about */
  .c-about {
    overflow: hidden;
  }
  .c-about__inner {
    position: relative;
    overflow: visible;
    padding: 0 520px 0 0;
  }
  .c-about__inner::after {
    top: 70%;
    width: 360px;
    height: 360px;
  }
  .c-about__headerLabel {
    font-size: 20px;
  }
  .c-about__headerLabel::before {
    width: 8px;
    height: 8px;
    margin-right: 10px;
  }
  .c-about__headerTitle {
    margin-bottom: 70px;
    font-size: 45px;
    line-height: 64px;
  }
  .c-about__image {
    position: absolute;
    top: 0;
    right: 0;
    width: 430px;
    height: auto;
    margin: 0;
  }
  .c-about__text {
    margin-top: 2.5em;
  }
  .c-about__link {
    position: absolute;
    bottom: 0;
    right: 30px;
    width: 370px;
    font-size: 18px;
  }
}
/* .c-tags */
.c-tags {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-bottom: 20px;
}
.c-tagsItem {
  display: inline-block;
  border-radius: 30px;
  background: #eee;
  padding: 5px 10px 7px;
  font-size: 16px;
  line-height: 16px;
  font-weight: var(--font-weight-bold);
}

/* .c-portfolio */
.c-portfolio {
  background: url(../img/portfolio-bg-sp.svg) no-repeat top/682px #F1F5F0;
  padding: 0;
}
.c-portfolio__inner {
  padding: 60px 20px 40px;
  position: relative;
  overflow: hidden;
}
.c-portfolio__inner::after {
  content: "";
  display: inline-block;
  z-index: -1;
  opacity: 0.7;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: #FFFF9B;
  background: linear-gradient(0deg, #FFEEBE 0%, #FFFF9B 100%);
  transform: translate(-50%, -50%);
  filter: blur(30px);
  animation: blur-circle-bounce 5s ease-in-out infinite;
  position: absolute;
  top: 15%;
  right: -50%;
  z-index: 1;
}
.c-portfolio__intro, .c-portfolio__list {
  position: relative;
  z-index: 2;
}
.c-portfolio__intro {
  margin-bottom: 40px;
}
.c-portfolio__more {
  margin-top: 20px;
}

/* =============================================
for PC
============================================= */
@media screen and (min-width: 1025px) {
  /* .c-portfolio */
  .c-portfolio {
    background: url(../img/portfolio-bg-pc.svg) no-repeat top/4622px #F1F5F0;
    overflow: hidden;
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .c-portfolio__inner {
    display: grid;
    grid-template-columns: auto 430px;
    padding: 0;
    overflow: visible;
  }
  .c-portfolio__inner::after {
    top: 50%;
    right: -40%;
    width: 490px;
    height: 490px;
  }
  .c-portfolio__more {
    grid-column: 1/3;
    margin-top: 60px;
  }
}
/* .c-faq */
.c-faq {
  position: relative;
  background: url(../img/faq-bg-sp.svg) no-repeat top/794px;
  padding: 40px 20px;
}
.c-faq::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  background: rgba(255, 221, 188, 0.5);
  width: 100%;
  height: 676px;
}
.c-faq__list {
  position: relative;
  z-index: 2;
  border-radius: 30px;
  background: #fff;
  padding: 25px 20px 20px;
}
.c-faq__question {
  position: relative;
  margin-bottom: 10px;
  padding-left: 37px;
  color: var(--color-brand);
  font-size: 20px;
  line-height: 28px;
  font-weight: var(--font-weight-bold);
}
.c-faq__question::before {
  content: url(../img/icon-faq.svg);
  position: absolute;
  top: 2px;
  left: 0;
  display: inline-block;
  width: 27px;
  height: 27px;
}
.c-faq__answer {
  border-bottom: 1px solid #ddd;
  margin-bottom: 20px;
  padding-bottom: 20px;
  padding-left: 38px;
}
.c-faq__answer:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}
.c-faq__more {
  margin-top: 20px;
}

/* =============================================
for PC
============================================= */
@media screen and (min-width: 1025px) {
  /* .c-faq */
  .c-faq {
    background: url(../img/faq-bg-pc.svg) no-repeat top/1952px;
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .c-faq::before {
    height: 670px;
  }
  .c-faq__inner {
    display: flex;
    flex-direction: column;
  }
  .c-faq__list {
    padding: 70px;
  }
  .c-faq__question {
    margin-bottom: 20px;
    padding-left: 35px;
    font-size: 23px;
  }
  .c-faq__answer {
    margin-bottom: 30px;
    padding-bottom: 30px;
    padding-left: 0;
  }
  .c-faq__more {
    margin-top: 60px;
  }
}
@keyframes heroBackgroundScroll {
  0% {
    background-position: 0 100%;
  }
  100% {
    background-position: -1556px 100%;
  }
}
#page-home .hero {
  background: url(../img/hero-bg.svg) repeat-x 0 100%/1556px;
  height: 310px;
  padding: 40px 10px;
  animation: heroBackgroundScroll 50s linear infinite;
}
#page-home .hero__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--color-background);
  padding: 20px 10px;
}
#page-home .hero__catchcopy {
  font-size: 24px;
  line-height: 1;
  font-weight: var(--font-weight-bold);
}
#page-home .hero__subcopy {
  font-family: "Outfit", "Noto Sans JP", YuGothic, sans-serif;
  font-optical-sizing: auto;
  font-weight: var(--font-weight-regular);
  padding: 15px 0 25px;
  font-size: 14px;
  line-height: 1;
  color: #CEA31D;
}
#page-home .hero__cta {
  height: 40px;
  margin: 0;
  padding: 10px 15px;
}
#page-home .news {
  background: rgba(255, 239, 213, 0.5);
}
#page-home .news__list {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
#page-home .news__item {
  border-radius: 30px;
  background: #fff;
}
#page-home .news__link {
  display: grid;
  grid-template-columns: 20px auto 20px;
  grid-template-rows: 20px auto auto 20px;
}
#page-home .news__link::after {
  grid-column: 3/4;
  grid-row: 2/4;
  display: inline-block;
  justify-self: start;
  align-self: center;
  content: url(../img/arrow-right-black.svg);
  font-size: 1px;
  line-height: 1px;
  width: 7px;
  height: 12px;
}
#page-home .news__date {
  grid-column: 2/3;
  grid-row: 2/3;
  font-family: "Outfit", "Noto Sans JP", YuGothic, sans-serif;
  font-optical-sizing: auto;
  font-weight: var(--font-weight-regular);
  padding-bottom: 10px;
  font-size: 16px;
  line-height: 1;
}
#page-home .news__text {
  grid-column: 2/3;
  grid-row: 3/4;
  padding-right: 20px;
  font-size: 16px;
  line-height: 26px;
  font-weight: var(--font-weight-bold);
}
#page-home .value-services-wave {
  background: url(../img/value-services-wave-sp.svg) no-repeat 30% 0/680px;
}
#page-home .value {
  padding: 0;
}
#page-home .value__inner {
  padding: 60px 20px;
  position: relative;
  overflow: hidden;
}
#page-home .value__inner::after {
  content: "";
  display: inline-block;
  z-index: -1;
  opacity: 0.7;
  width: 200px;
  height: 200px;
  border-radius: 50%;
  background: #FFFF9B;
  background: linear-gradient(0deg, #FFEEBE 0%, #FFFF9B 100%);
  transform: translate(-50%, -50%);
  filter: blur(30px);
  animation: blur-circle-bounce 5s ease-in-out infinite;
  position: absolute;
  top: 45%;
  left: 0;
}
#page-home .value__image {
  border-radius: 40px;
  border: 1px solid #eee;
  width: 100%;
  height: auto;
  margin: 0 0 40px;
}
#page-home .services {
  background: rgba(222, 237, 219, 0.5);
}
#page-home .services__intro {
  margin-bottom: 40px;
}

/* =============================================
for Tablet and larger
============================================= */
/* =============================================
for PC
============================================= */
@media screen and (min-width: 1025px) {
  @keyframes heroBackgroundScroll {
    0% {
      background-position: 0 100%;
    }
    100% {
      background-position: -2600px 100%;
    }
  }
  #page-home .section {
    padding: 100px 0;
  }
  #page-home .hero {
    background-size: 2600px;
    height: 520px;
  }
  #page-home .hero__inner {
    padding: 30px;
    width: 820px;
    margin: 0 auto;
    padding: 60px 0 40px;
  }
  #page-home .hero__catchcopy {
    font-size: 59px;
  }
  #page-home .hero__subcopy {
    margin: 10px 0 30px;
    font-size: 30px;
  }
  #page-home .hero__cta {
    width: 500px;
    height: 60px;
    font-size: 20px;
  }
  #page-home .hero__cta::after {
    width: 11px;
    height: 17px;
  }
  #page-home .news__link {
    grid-template-columns: 40px auto 40px;
    grid-template-rows: 30px auto auto 30px;
  }
  #page-home .news__link::after {
    width: 9px;
    height: 15px;
  }
  #page-home .news__text {
    padding-right: 30px;
    font-size: 18px;
    line-height: 32px;
  }
  #page-home .value-services-wave {
    background: url(../img/value-services-wave-pc.svg) no-repeat 50% -1px/5590px;
  }
  #page-home .value {
    overflow: hidden;
  }
  #page-home .value__inner {
    overflow: visible;
    display: grid;
    grid-template-columns: 500px auto 520px;
    grid-template-rows: auto auto auto auto;
    padding: 0;
  }
  #page-home .value__inner::after {
    top: 70%;
    width: 360px;
    height: 360px;
  }
  #page-home .value__header {
    grid-column: 1/4;
  }
  #page-home .value__image {
    background: pink;
    grid-column: 1/2;
    grid-row: 2/5;
    width: 500px;
    height: auto;
    margin: 0;
  }
  #page-home .value__text {
    grid-column: 3/4;
  }
  #page-home .value__more {
    grid-column: 3/4;
  }
  #page-home .services__inner {
    display: grid;
    grid-template-columns: auto 430px;
  }
}/*# sourceMappingURL=page-home.css.map */