@charset "UTF-8";
/* _media.scss
-------------------------------------------------------*/
/* /_media.scss
-------------------------------------------------------*/
/* _inner.scss
-------------------------------------------------------*/
/* /_inner.scss
-------------------------------------------------------*/
/* _font.scss
-------------------------------------------------------*/
/* /_font.scss
-------------------------------------------------------*/
/* _over.scss
-------------------------------------------------------*/
/* /_over.scss
-------------------------------------------------------*/
/* _other.scss
-------------------------------------------------------*/
/* /_other.scss
  -------------------------------------------------------*/
/* _top.scss
-------------------------------------------------------*/
/* 個別対応 */
.mv {
  border-radius: 0 0 0 104px;
  z-index: 3;
  background-color: #FFF;
}
.mv_inner {
  padding: 80px 0;
}
@media screen and (max-width: 768px) {
  .mv {
    border-radius: 0 0 0 48px;
  }
  .mv_inner {
    padding: 56px 0;
  }
}

.news {
  padding: 80px 0;
  position: relative;
  position: relative;
}
.news::before {
  content: "";
  aspect-ratio: 1;
  width: 104px;
  -webkit-mask: url("/assets/images/common/bg_parts.svg") center/contain no-repeat;
          mask: url("/assets/images/common/bg_parts.svg") center/contain no-repeat;
  position: absolute;
  right: 0;
  top: 0;
  background-color: #FFF;
}
@media screen and (max-width: 768px) {
  .news::before {
    width: 48px;
  }
}
.news::after {
  content: "";
  aspect-ratio: 1;
  width: 104px;
  -webkit-mask: url("/assets/images/common/bg_parts.svg") center/contain no-repeat;
          mask: url("/assets/images/common/bg_parts.svg") center/contain no-repeat;
  position: absolute;
  right: 0;
  bottom: 0;
  background-color: #FFF;
  rotate: 90deg;
}
@media screen and (max-width: 768px) {
  .news::after {
    width: 48px;
  }
}
.news_bg {
  width: 100%;
  height: calc(100% + 208px);
  position: absolute;
  top: -104px;
  left: 0;
  z-index: -1;
}
.news_bg img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
}
.news_inner {
  padding: 64px 54px;
  background-color: #FFF;
  border-radius: 32px;
}
.news_btn {
  max-width: 300px;
  margin: 48px auto 0;
}
@media screen and (max-width: 768px) {
  .news {
    padding: 56px 0;
  }
  .news_bg {
    height: calc(100% + 104px);
    top: -52px;
  }
  .news_inner {
    padding: 48px 20px;
    border-radius: 16px;
  }
  .news_btn {
    margin-top: 32px;
  }
}

.about {
  position: relative;
  z-index: 2;
  background-color: #FFF;
  border-radius: 104px 0 0 0;
  position: relative;
}
.about::after {
  content: "";
  aspect-ratio: 1;
  width: 104px;
  -webkit-mask: url("/assets/images/common/bg_parts.svg") center/contain no-repeat;
          mask: url("/assets/images/common/bg_parts.svg") center/contain no-repeat;
  position: absolute;
  left: 0;
  bottom: 0;
  background-color: #FFF;
  rotate: 180deg;
}
@media screen and (max-width: 768px) {
  .about::after {
    width: 48px;
  }
}
.about::after {
  background-color: #FFF9EC;
}
.about_inner {
  padding: 80px 0;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 36px;
}
.about_item {
  border: var(--color-border) solid 1px;
  border-radius: 32px;
  padding: 24px 40px 40px;
  width: calc((100% - 72px) / 3);
}
.about_icon {
  background-color: #FFF4F1;
  text-align: center;
  padding: 8px 16px;
  border-radius: 24px;
  margin-inline: -16px;
}
.about_title {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-main);
  margin: 24px 0 32px;
}
.about_link {
  font-size: 1rem;
  border-bottom: var(--color-border) solid 1px;
  -webkit-transition: var(--trans-min02);
  transition: var(--trans-min02);
}
.about_link:hover, a:hover .about_link {
  color: var(--color-main);
}
.about_link + .about_link {
  margin-top: 24px;
}
.about_link-inner {
  display: block;
  position: relative;
  padding-right: 32px;
  padding-bottom: 8px;
  font-weight: 500;
  line-height: var(--lineHeight-m);
}
.about_link-icon {
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
@media screen and (max-width: 768px) {
  .about {
    border-radius: 48px 0 0 0;
  }
  .about_inner {
    padding: 56px 0;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 24px;
  }
  .about_item {
    border-radius: 10px;
    padding: 24px 24px 32px;
    width: 100%;
  }
  .about_icon {
    border-radius: 16px;
    margin-inline: -10px;
  }
  .about_title {
    font-size: 1.25rem;
    margin: 16px 0 24px;
  }
  .about_link {
    font-size: 0.9375rem;
  }
  .about_link + .about_link {
    margin-top: 16px;
  }
  .about_link-inner {
    padding-right: 24px;
  }
}

.calendar {
  padding: 80px 0;
  background-color: #FFF9EC;
  border-radius: 0 104px 104px 0;
}
.calendar_btn {
  max-width: 300px;
  margin: 56px auto 0;
}
@media screen and (max-width: 768px) {
  .calendar {
    padding: 56px 0;
    border-radius: 0 48px 48px 0;
  }
  .calendar_btn {
    margin-top: 40px;
  }
}

.contact {
  padding: 80px 0;
  position: relative;
}
.contact::before {
  content: "";
  aspect-ratio: 1;
  width: 104px;
  -webkit-mask: url("/assets/images/common/bg_parts.svg") center/contain no-repeat;
          mask: url("/assets/images/common/bg_parts.svg") center/contain no-repeat;
  position: absolute;
  left: 0;
  top: 0;
  background-color: #FFF;
  rotate: -90deg;
}
@media screen and (max-width: 768px) {
  .contact::before {
    width: 48px;
  }
}
.contact::before {
  background-color: #FFF9EC;
}
@media screen and (max-width: 768px) {
  .contact {
    padding: 56px 20px;
  }
}/*# sourceMappingURL=ir.css.map */