@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");
@font-face {
  font-family: 'Poppins';
  font-weight: 400;
  font-display: swap;
  src: url("/css/fonts/Poppins-Regular_subset.woff2") format("woff2");
}
@font-face {
  font-family: 'Poppins';
  font-weight: 500;
  font-display: swap;
  src: url("/css/fonts/Poppins-Medium_subset.woff2") format("woff2");
}
@font-face {
  font-family: 'Poppins';
  font-weight: 700;
  font-display: swap;
  src: url("/css/fonts/Poppins-Bold_subset.woff2") format("woff2");
}
.hero-area {
  position: relative;
  background-color: #FFFDF7;
  padding-bottom: 80rem;
}
@media only screen and (max-width: 767px) {
  .hero-area {
    padding-bottom: 10rem;
  }
}
.hero-area .animation-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@keyframes heroImg1 {
  0% {
    top: 240rem;
    left: 840rem;
    opacity: 0;
  }
  100% {
    top: 0;
    left: 0;
    opacity: 1;
  }
}
@keyframes heroImg1Sp {
  0% {
    top: 340rem;
    left: 50%;
    opacity: 0;
  }
  100% {
    top: -20rem;
    left: -15rem;
    opacity: 1;
  }
}
@keyframes heroImg2 {
  0% {
    bottom: 310rem;
    right: 340rem;
    opacity: 0;
  }
  100% {
    bottom: 0;
    right: 0;
    opacity: 1;
  }
}
@keyframes heroImg2Sp {
  0% {
    bottom: 290rem;
    right: 50%;
    opacity: 0;
  }
  100% {
    bottom: -90rem;
    right: -20%;
    opacity: 1;
  }
}
.hero-area .animation-wrap .img-1 {
  position: absolute;
  transform: translate(-50%, -50%);
  width: 238rem;
  top: 0;
  left: 0;
  opacity: 1;
  animation: heroImg1 0.8s cubic-bezier(0.19, 1, 0.22, 1) 0s both;
}
@media only screen and (max-width: 767px) {
  .hero-area .animation-wrap .img-1 {
    width: 192rem;
    top: -20rem;
    left: -15rem;
    animation-name: heroImg1Sp;
  }
}
.hero-area .animation-wrap .img-2 {
  position: absolute;
  transform: translate(50%, 50%);
  width: 145rem;
  bottom: 0;
  right: 0;
  opacity: 1;
  animation: heroImg2 0.8s cubic-bezier(0.19, 1, 0.22, 1) 0s both;
}
@media only screen and (max-width: 767px) {
  .hero-area .animation-wrap .img-2 {
    bottom: 290rem;
    right: -20rem;
    animation-name: heroImg2Sp;
  }
}
.hero-area .catch-wrap {
  position: relative;
  display: inline-block;
  margin-top: 86rem;
}
@media only screen and (max-width: 767px) {
  .hero-area .catch-wrap {
    margin-top: 30rem;
    width: 100%;
  }
}
@media print, screen and (min-width: 768px) {
  .hero-area .catch-wrap .hero-title,
  .hero-area .catch-wrap .text-1 {
    padding-left: 24rem;
    margin-left: 60rem;
    margin-bottom: 50rem;
  }
}
@media only screen and (max-width: 767px) {
  .hero-area .catch-wrap .hero-title,
  .hero-area .catch-wrap .text-1 {
    padding-left: 18rem;
  }
}
.hero-area .catch-wrap .hero-title {
  font-size: 54rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  margin-bottom: 40rem;
}
@media only screen and (max-width: 767px) {
  .hero-area .catch-wrap .hero-title {
    font-size: 36rem;
    margin-bottom: 10rem;
  }
}
.hero-area .catch-wrap .text-1 {
  font-size: 20rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 767px) {
  .hero-area .catch-wrap .text-1 {
    font-size: 16rem;
  }
}
@media only screen and (max-width: 767px) {
  .hero-area .catch-wrap .text-1:last-of-type {
    margin-bottom: 0;
  }
}
@media print, screen and (min-width: 768px) {
  .hero-area .lottie-wrap {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 0;
    width: 820rem;
  }
}
@media only screen and (max-width: 767px) {
  .hero-area .lottie-wrap {
    aspect-ratio: 82 / 52;
    margin-left: -10%;
    margin-bottom: 10rem;
    width: 110%;
  }
}
.hero-area .news-wrap {
  padding-left: 60rem;
  background-color: #F8E9A1;
  border-radius: 0 100rem 100rem 0;
  position: relative;
  width: 584rem;
}
@media only screen and (max-width: 767px) {
  .hero-area .news-wrap {
    padding-left: 0;
    width: calc(100% - 15rem);
    margin-bottom: 20rem;
  }
}
.hero-area .news-wrap::after {
  content: "";
  position: absolute;
  top: -30rem;
  left: 60rem;
  width: 37rem;
  height: 36rem;
  background: url("../img/icon-1.svg") no-repeat center center;
  background-size: contain;
  display: block;
}
@media only screen and (max-width: 767px) {
  .hero-area .news-wrap::after {
    left: 5rem;
  }
}
.hero-area .news-wrap .news-link {
  padding: 10rem 24rem;
  display: block;
  text-decoration: underline;
}
@media only screen and (max-width: 767px) {
  .hero-area .news-wrap .news-link {
    padding-left: 18rem;
  }
}

.nav-area {
  background-color: #FFFDF7;
  padding-bottom: 80rem;
}
@media only screen and (max-width: 767px) {
  .nav-area {
    padding-bottom: 40rem;
  }
}
@media print, screen and (min-width: 768px) {
  .nav-area .wrapper {
    padding: 0 24rem;
    width: 100%;
  }
}
.nav-area .nav-wrap {
  position: relative;
  display: flex;
  gap: 12rem;
  flex-wrap: wrap;
}
.nav-area .nav-wrap .nav-btn {
  border: 2rem solid #EAC200;
  border-radius: 23rem;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 30%;
  flex-grow: 1;
  align-items: center;
  padding: 40rem 20rem;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  .nav-area .nav-wrap .nav-btn {
    width: 48%;
    padding: 30rem 10rem 13rem;
    justify-content: flex-start;
  }
}
@media only screen and (max-width: 767px) {
  .nav-area .nav-wrap .nav-btn .icon-wrap {
    height: 48rem;
    margin-bottom: 10rem;
  }
}
.nav-area .nav-wrap .nav-btn .text-1 {
  font-size: 24rem;
  font-weight: bold;
  letter-spacing: 0.05em;
  margin-bottom: 0;
}
@media only screen and (max-width: 767px) {
  .nav-area .nav-wrap .nav-btn .text-1 {
    font-size: 18rem;
    text-align: center;
  }
}
@media only screen and (max-width: 767px) {
  .nav-area .nav-wrap .nav-btn-1 img {
    width: 33rem;
  }
}
@media only screen and (max-width: 767px) {
  .nav-area .nav-wrap .nav-btn-2 img {
    width: 43rem;
  }
}
@media only screen and (max-width: 767px) {
  .nav-area .nav-wrap .nav-btn-3 img {
    width: 69rem;
  }
}
@media only screen and (max-width: 767px) {
  .nav-area .nav-wrap .nav-btn-4 img {
    width: 51rem;
  }
}
@media only screen and (max-width: 767px) {
  .nav-area .nav-wrap .nav-btn-5 img {
    width: 36rem;
  }
}
@media only screen and (max-width: 767px) {
  .nav-area .nav-wrap .nav-btn-6 img {
    width: 43rem;
  }
}

.news-area {
  background-color: #FFFDF7;
  padding-bottom: 80rem;
}
@media only screen and (max-width: 767px) {
  .news-area {
    padding-bottom: 40rem;
  }
}
.news-area .heading-wrap {
  margin-bottom: 20rem;
}
@media print, screen and (min-width: 768px) {
  .news-area .heading-wrap {
    margin-left: 20rem;
  }
}
.news-area .heading-wrap img {
  width: 48rem;
}
@media only screen and (max-width: 767px) {
  .news-area .heading-wrap img {
    width: 38rem;
  }
}
.news-area .heading-wrap .title-main {
  font-size: 28rem;
  font-weight: bold;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 767px) {
  .news-area .heading-wrap .title-main {
    font-size: 24rem;
  }
}
.news-area .news-list .news-item {
  display: flex;
  gap: 20rem;
  border-bottom: 1px solid #B2B0AA;
  padding: 20rem;
  box-sizing: border-box;
}
@media only screen and (max-width: 767px) {
  .news-area .news-list .news-item {
    padding: 10rem;
    flex-direction: column;
    gap: 3rem;
  }
}
.news-area .news-list .news-item:first-child {
  border-top: 1px solid #B2B0AA;
}

/*# sourceMappingURL=page_top.css.map */
