@charset "UTF-8";
/*--------------------------------------------------------------
    トップページ
---------------------------------------------------------------*/
.top-contents {
  overflow: hidden;
  background: #FBF9EE;
  padding-bottom: 5rem;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .top-contents {
    padding-bottom: 0;
  }
}
/*--------------------------------------------------------------
    キービジュアル
---------------------------------------------------------------*/
.kv-slider {
  aspect-ratio: 1440/795;
  position: relative;
  z-index: 1;
  background: #FBF9EE;
}
.kv-slider .catch {
  position: absolute;
  left: 0;
  bottom: 6rem;
  z-index: 2;
}
.kv-slider .catch .txt {
  background: #fff;
  border-radius: 0 4.95rem 4.95rem 0;
  color: #484848;
  font-size: clamp(16px, 5.5rem, 5.5rem);
  font-family: "Zen Kaku Gothic New", sans-serif;
  letter-spacing: 0.24em;
  line-height: 9.9rem;
  font-weight: 700;
  width: fit-content;
  padding: 0 3.4rem 0 7.3rem;
  margin-bottom: 2.7rem;
}
.kv-slider .catch .txt:last-of-type {
  margin-bottom: 0;
}
.kv-slider .catch2 {
  position: absolute;
  left: 5.21rem;
  bottom: 10.7rem;
  z-index: 2;
  transform: rotateZ(-5.56deg);
}
.kv-slider .catch2 .txt {
  color: #fff;
  font-size: clamp(16px, 6.5rem, 6.5rem);
  font-family: "Zen Kaku Gothic New", sans-serif;
  letter-spacing: 0.22em;
  line-height: 1.46;
  font-weight: 700;
  -webkit-text-stroke: 0.01rem #000;
}
.kv-slider .kv-wrap .kv-item {
  aspect-ratio: 1440/795;
  background-size: cover;
}
.kv-slider .kv-wrap .src {
  aspect-ratio: 1440/795;
}
.kv-slider .kv-wrap .src video {
  width: 100%;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .kv-slider {
    margin-top: 5.5rem;
  }
  .kv-slider .catch2 {
    left: 1.7rem;
    bottom: 1rem;
  }
  .kv-slider .catch2 .txt {
    font-size: 2.2rem;
  }
}
/*--------------------------------------------------------------
    キービジュアル下のリンク
---------------------------------------------------------------*/
.mov-link {
  padding: 1.9rem 3.3rem 3.6rem;
  background: #FBF9EE;
}
.mov-link .link {
  color: #484848;
  font-size: clamp(16px, 2.4rem, 2.4rem);
  letter-spacing: 0.14em;
  line-height: 1;
  display: flex;
  align-items: center;
  width: fit-content;
  margin-left: auto;
}
.mov-link .link::before {
  content: "";
  width: 3.4rem;
  height: 3.4rem;
  display: block;
  margin: 0 1.3rem 0 0;
  background: url(../images/top/arrow.png) no-repeat center/contain;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .mov-link {
    padding: 0.8rem 1.3rem 2.2rem;
    background: #FBF9EE;
  }
  .mov-link .link {
    font-size: 1.2rem;
  }
  .mov-link .link::before {
    width: 1.8rem;
    height: 1.8rem;
    margin: 0 0.7rem 0 0;
  }
}
/*--------------------------------------------------------------
    catchセクション
---------------------------------------------------------------*/
.top-catch {
  background: #FBF9EE;
  padding: 0 0 18.1rem 0;
  position: relative;
  z-index: 1;
}
.top-catch .txt {
  width: 113rem;
  max-width: 100%;
  margin: 0 auto;
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #484848;
  line-height: 3.33;
  font-size: clamp(16px, 2.4rem, 2.4rem);
  letter-spacing: 0.24em;
  font-weight: 700;
}
.top-catch .txt .cl {
  color: #ED7A7A;
}
.top-catch .c01 {
  position: absolute;
  z-index: 2;
  width: 22.8rem;
  top: 17.3rem;
  right: 38.2rem;
}
.top-catch .c02 {
  position: absolute;
  z-index: 3;
  width: 28.9rem;
  top: 1rem;
  right: 17.4rem;
}
.top-catch .l01 {
  position: absolute;
  z-index: 4;
  width: 11.9rem;
  top: 14.2rem;
  right: 9.6rem;
}
.top-catch .l02 {
  position: absolute;
  z-index: 5;
  width: 10.5rem;
  top: 24.6rem;
  right: 16.1rem;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .top-catch {
    padding: 0 7.6rem 35.4rem 7rem;
  }
  .top-catch .txt {
    width: 100%;
    line-height: 2.1;
    font-size: 1.4rem;
  }
  .top-catch .txt .mb {
    margin-bottom: 1.2rem;
  }
  .top-catch .c01 {
    width: 15.1rem;
    top: auto;
    right: auto;
    left: 5.3rem;
    bottom: 10.4rem;
  }
  .top-catch .c02 {
    width: 18.9rem;
    top: auto;
    right: auto;
    left: 15rem;
    bottom: 19rem;
  }
  .top-catch .l01 {
    width: 5.5rem;
    top: auto;
    right: auto;
    left: 29.1rem;
    bottom: 15.2rem;
  }
  .top-catch .l02 {
    width: 4.9rem;
    top: auto;
    right: auto;
    left: 27.1rem;
    bottom: 11.9rem;
  }
}
/*--------------------------------------------------------------
    Instagramセクション
---------------------------------------------------------------*/
.top-ig {
  background: #fff;
  position: relative;
  z-index: 1;
  padding: 5rem 0 12.6rem 0;
}
.top-ig::before {
  content: "";
  width: 100%;
  height: 10rem;
  display: block;
  position: absolute;
  top: -10rem;
  z-index: 1;
  background: url(../images/top/ig_wave.png) no-repeat center/100%;
}
.top-ig .iglogo {
  width: 8.1rem;
  height: 8.1rem;
  display: block;
  margin: 0 auto 3rem;
}
.top-ig .tit {
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
  color: #484848;
  font-size: clamp(16px, 2.4rem, 2.4rem);
  text-align: center;
  line-height: 1.58;
  letter-spacing: 0.24em;
  margin: 0 auto 4.2rem;
  width: fit-content;
  max-width: 100%;
  position: relative;
  z-index: 1;
}
.top-ig .tit .t01 {
  width: 7.2rem;
  z-index: 1;
  position: absolute;
  top: -6.5rem;
  left: -20.7rem;
}
.top-ig .tit .t02 {
  width: 8.3rem;
  z-index: 1;
  position: absolute;
  top: -2.7rem;
  left: -13.1rem;
}
.top-ig .tit .t03 {
  width: 8.3rem;
  transform: scale(-1, 1);
  z-index: 1;
  position: absolute;
  top: -2.7rem;
  right: -13.1rem;
}
.top-ig .tit .t04 {
  width: 7.2rem;
  transform: scale(-1, 1);
  z-index: 1;
  position: absolute;
  top: -6.5rem;
  right: -20.7rem;
}
.top-ig .ig-box {
  width: 113rem;
  max-width: 100%;
  margin: 0 auto 5.8rem;
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 4.6rem;
}
.top-ig .ig-box .ig-item {
  background: #fff;
  border-radius: 1rem;
  border: 0.15rem solid #ABABAB;
  width: calc(25% - 3.45rem);
}
.top-ig .ig-box .ig-item .date {
  padding: 1.6rem 1.5rem;
  color: #ABABAB;
  font-size: clamp(14px, 1.5rem, 1.5rem);
  letter-spacing: 0.14em;
  line-height: 1;
  font-weight: 500;
}
.top-ig .ig-box .ig-item .imgwrap {
  aspect-ratio: 1/1;
}
.top-ig .ig-box .ig-item .imgwrap .pic {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.top-ig .ig-box .ig-item .title {
  padding: 2.2rem 1.9rem 0;
  margin-bottom: 4.3rem;
  line-height: 1.3;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  font-weight: 500;
  letter-spacing: 0.14em;
  color: #484848;
  word-break: break-all;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.top-ig .link-btn {
  background: #ED7A7A;
  color: #fff;
  border-radius: 29.5rem;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1.3;
  padding: 1.4rem 3.8rem 1.6rem 5.3rem;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: auto;
}
.top-ig .link-btn .txt {
  display: flex;
  align-items: center;
  justify-content: center;
}
.top-ig .link-btn .txt::after {
  content: "";
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  background: #fff;
  margin-left: 1.4rem;
  width: 1.2rem;
  height: 1.6rem;
  display: block;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .top-ig {
    padding: 2.5rem 0 12.6rem 0;
  }
  .top-ig::before {
    height: 3.5rem;
    top: -3.5rem;
  }
  .top-ig .iglogo {
    width: 3.6rem;
    height: 3.6rem;
    margin: 0 auto 1.5rem;
  }
  .top-ig .tit {
    font-size: clamp(14px, 1.4rem, 1.4rem);
    margin: 0 auto 2.6rem;
  }
  .top-ig .tit .t01 {
    display: none;
  }
  .top-ig .tit .t02 {
    display: none;
  }
  .top-ig .tit .t03 {
    display: none;
  }
  .top-ig .tit .t04 {
    display: none;
  }
  .top-ig .ig-box {
    width: 100%;
    margin: 0 auto 3.1rem;
    padding: 0 5rem;
    flex-wrap: wrap;
    gap: 2.4rem 2.1rem;
  }
  .top-ig .ig-box .ig-item {
    border-radius: 2rem;
    width: calc(50% - 1.05rem);
  }
  .top-ig .ig-box .ig-item .date {
    padding: 0.8rem 1.3rem 0.7rem;
    font-size: 1rem;
    line-height: 2;
  }
  .top-ig .ig-box .ig-item .title {
    padding: 1.1rem 1rem 0;
    margin-bottom: 2rem;
    font-size: 1rem;
  }
  .top-ig .link-btn {
    border-radius: 2rem;
    font-size: 1.4rem;
    padding: 0.7rem 2.5rem 1rem 3.2rem;
    line-height: 1.71;
  }
  .top-ig .link-btn .txt::after {
    margin-left: 0.5rem;
    width: 1rem;
    height: 1.2rem;
  }
}
/*--------------------------------------------------------------
    教育目標セクション
---------------------------------------------------------------*/
.top-goal {
  position: relative;
  background: #FBECA0;
  padding: 3.2rem 0 4.5rem;
  z-index: 1;
}
.top-goal .sun {
  position: absolute;
  left: 4.8rem;
  top: -10rem;
  width: 21.9rem;
  height: 21.9rem;
  z-index: 2;
}
.top-goal .bird01 {
  position: absolute;
  left: 7.5rem;
  top: -9.1rem;
  width: 13.9rem;
  height: 13.9rem;
  z-index: 2;
}
.top-goal .bird02 {
  position: absolute;
  top: -0.5rem;
  left: 20.7rem;
  width: 8.9rem;
  height: 8.9rem;
  z-index: 2;
}
.top-goal .inner-box {
  position: relative;
  overflow: hidden;
  z-index: 1;
}
.top-goal .inner-box .tit {
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #484848;
  font-size: clamp(16px, 3.8rem, 3.8rem);
  font-weight: 700;
  letter-spacing: 0.24em;
  line-height: 1.44;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto 8.1rem;
  text-align: center;
}
.top-goal .inner-box .tit::before {
  content: "Goal";
  font-weight: 700;
  line-height: 1.11;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  letter-spacing: 0.3em;
  display: block;
  margin: auto;
  color: #ED7A7A;
}
.top-goal .inner-box .tit::after {
  content: "";
  display: block;
  height: 0.9rem;
  width: 100%;
  margin-top: 0.2rem;
  background: url(../images/common/txt-dot.png) repeat-x left top/1.9rem 0.9rem;
}
.top-goal .inner-box .goal-wrap {
  width: 48.5rem;
  max-width: 100%;
  margin: 0 auto 7.2rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
.top-goal .inner-box .goal-wrap .goal-item {
  margin: 0 0 4.3rem 0;
  position: relative;
  z-index: 3;
}
.top-goal .inner-box .goal-wrap .goal-item .od {
  position: absolute;
  top: -5.6rem;
  left: -3.4rem;
  font-weight: 700;
  line-height: 1.11;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  letter-spacing: 0.3em;
  display: block;
  margin: auto;
  color: #ED7A7A;
}
.top-goal .inner-box .goal-wrap .goal-item .od .num {
  display: block;
  font-size: clamp(16px, 4.8rem, 4.8rem);
  line-height: 1;
  letter-spacing: 0.3em;
  color: #484848;
  transform: translateX(-0.2rem);
}
.top-goal .inner-box .goal-wrap .goal-item .txt {
  background: #fff;
  color: #484848;
  letter-spacing: 0.24em;
  font-size: clamp(16px, 3rem, 3rem);
  font-weight: 700;
  line-height: 5.5rem;
  margin: 0 0 1.8rem 0;
  padding: 0 0 0 2.3rem;
  width: fit-content;
  max-width: 100%;
}
.top-goal .inner-box .goal-wrap .goal-item .txt:last-of-type {
  margin-bottom: 0;
}
.top-goal .inner-box .pp1, .top-goal .inner-box .pp2, .top-goal .inner-box .pp3, .top-goal .inner-box .pp4, .top-goal .inner-box .pp5 {
  position: absolute;
  z-index: 1;
}
.top-goal .inner-box .pp1 {
  top: 31rem;
  left: 1.8rem;
  width: 12.6rem;
  height: 12.5rem;
}
.top-goal .inner-box .pp2 {
  top: 11.6rem;
  left: 13rem;
  width: 26rem;
  height: 26.1rem;
}
.top-goal .inner-box .pp3 {
  top: 14.6rem;
  right: 24.4rem;
  width: 26rem;
  height: 26.1rem;
}
.top-goal .inner-box .pp4 {
  top: 12.5rem;
  right: 7.9rem;
  width: 15.5rem;
  height: 15.5rem;
}
.top-goal .inner-box .pp5 {
  top: 26.7rem;
  right: 0;
  width: 11.7rem;
  height: 12.5rem;
}
.top-goal .inner-box .c1 {
  z-index: 2;
  top: -4.5rem;
  right: -4.1rem;
  width: 19.7rem;
  height: 19.7rem;
}
.top-goal .inner-box .link-btn {
  background: #ED7A7A;
  color: #fff;
  border-radius: 29.5rem;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1.3;
  padding: 1.4rem 3.8rem 1.6rem 5.3rem;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: auto;
}
.top-goal .inner-box .link-btn .txt {
  display: flex;
  align-items: center;
  justify-content: center;
}
.top-goal .inner-box .link-btn .txt::after {
  content: "";
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  background: #fff;
  margin-left: 1.4rem;
  width: 1.2rem;
  height: 1.6rem;
  display: block;
}
.top-goal .dot {
  position: absolute;
  z-index: 2;
  top: -4rem;
  right: 4.2rem;
  width: 13.7rem;
  height: 13.7rem;
}
.top-goal .mount {
  position: absolute;
  z-index: 2;
  bottom: -10.9rem;
  right: 13.6rem;
  width: 30.5rem;
  height: 30.5rem;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .top-goal {
    padding: 3.6rem 0 4.5rem;
  }
  .top-goal .bird01 {
    left: 2.7rem;
    top: -3.6rem;
    width: 5.8rem;
    height: 5.8rem;
  }
  .top-goal .bird02 {
    top: 0.7rem;
    left: 7.8rem;
    width: 4.2rem;
    height: 4.2rem;
  }
  .top-goal .inner-box .tit {
    font-size: 2.2rem;
    margin: 0 auto 8.6rem;
  }
  .top-goal .inner-box .tit::before {
    font-size: 1.2rem;
  }
  .top-goal .inner-box .tit::after {
    height: 0.5rem;
    width: 100%;
    margin-top: 0.3rem;
    background: url(../images/common/txt-dot.png) repeat-x left top/1.1rem 0.5rem;
  }
  .top-goal .inner-box .goal-wrap {
    width: 25.8rem;
    margin: 0 auto 34.6rem;
  }
  .top-goal .inner-box .goal-wrap .goal-item {
    margin: 0 0 3rem 0;
  }
  .top-goal .inner-box .goal-wrap .goal-item .od {
    top: -3.6rem;
    left: -2.6rem;
    font-size: 1.2rem;
  }
  .top-goal .inner-box .goal-wrap .goal-item .od .num {
    font-size: 3.2rem;
  }
  .top-goal .inner-box .goal-wrap .goal-item .txt {
    font-size: 1.8rem;
    line-height: 3.6rem;
    margin: 0 0 0.9rem 0;
    padding: 0 2rem 0 1.6rem;
    white-space: nowrap;
  }
  .top-goal .inner-box .goal-wrap .goal-item .txt:last-of-type {
    margin-bottom: 0;
  }
  .top-goal .inner-box .pp1, .top-goal .inner-box .pp2, .top-goal .inner-box .pp3, .top-goal .inner-box .pp4, .top-goal .inner-box .pp5, .top-goal .inner-box .c1, .top-goal .inner-box .c2 {
    position: absolute;
    z-index: 1;
  }
  .top-goal .inner-box .pp3 {
    top: 41.1rem;
    right: auto;
    left: -3.9rem;
    width: 23.5rem;
    height: 23.5rem;
  }
  .top-goal .inner-box .pp4 {
    top: 38.5rem;
    right: 4.2rem;
    width: 14rem;
    height: 14rem;
  }
  .top-goal .inner-box .pp5 {
    top: 53.9rem;
    right: 0;
    width: 11.3rem;
    height: 12.1rem;
  }
  .top-goal .inner-box .link-btn {
    border-radius: 2rem;
    font-size: 1.4rem;
    padding: 0.7rem 2.5rem 1rem 3.2rem;
    line-height: 1.71;
  }
  .top-goal .inner-box .link-btn .txt::after {
    margin-left: 0.5rem;
    width: 1rem;
    height: 1.2rem;
  }
  .top-goal .dot {
    top: 7.8rem;
    right: 3.4rem;
    width: 6.6rem;
    height: 6.6rem;
  }
  .top-goal .mount {
    bottom: -5rem;
    right: 1.9rem;
    width: 13.8rem;
    height: 13.8rem;
  }
}
/*--------------------------------------------------------------
    お知らせセクション
---------------------------------------------------------------*/
.top-news {
  background: #FBF9EE;
  padding: 13.6rem 0 13.3rem;
  position: relative;
}
.top-news .tit {
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #484848;
  font-size: clamp(16px, 3.8rem, 3.8rem);
  font-weight: 700;
  letter-spacing: 0.24em;
  line-height: 1.44;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto 6.8rem;
  text-align: center;
}
.top-news .tit::before {
  content: "News";
  font-weight: 700;
  line-height: 1.11;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  letter-spacing: 0.3em;
  display: block;
  margin: auto;
  color: #ED7A7A;
}
.top-news .tit::after {
  content: "";
  display: block;
  height: 0.9rem;
  width: 100%;
  margin-top: 0.2rem;
  background: url(../images/common/txt-dot.png) repeat-x left top/1.9rem 0.9rem;
}
.top-news .light {
  position: absolute;
  z-index: 1;
  width: 20.7rem;
  height: 20.7rem;
  top: 8.4rem;
  left: 9.5rem;
}
.top-news .news-wrap {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  width: 113.4rem;
  max-width: 100%;
  margin: auto;
  gap: 5.4rem 8.8rem;
}
.top-news .news-wrap .summary {
  width: calc(50% - 4.4rem);
  position: relative;
  z-index: 1;
}
.top-news .news-wrap .summary .bug {
  position: absolute;
  z-index: 2;
  width: 11.9rem;
  left: -10rem;
  top: -1rem;
}
.top-news .news-wrap .summary .mountain {
  position: absolute;
  z-index: 2;
  width: 26.5rem;
  right: -11.7rem;
  bottom: -5.3rem;
}
.top-news .news-wrap .summary .news-title {
  color: #484848;
  font-weight: 500;
  font-size: clamp(16px, 2.4rem, 2.4rem);
  letter-spacing: 0.24em;
  text-align: center;
  line-height: 1.58;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto 2.8rem;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.top-news .news-wrap .summary .news-title::before, .top-news .news-wrap .summary .news-title::after {
  content: "";
  height: 6.1rem;
  width: 0.2rem;
  background: #484848;
  display: block;
  flex-shrink: 0;
}
.top-news .news-wrap .summary .news-title::before {
  transform: rotate(-39deg);
  margin-right: 4.4rem;
}
.top-news .news-wrap .summary .news-title::after {
  transform: rotate(39deg);
  margin-left: 4.4rem;
}
.top-news .news-wrap .summary .box {
  background: #fff;
  border: 0.1rem solid #808080;
  border-radius: 2rem;
  padding: 3.9rem 2.5rem;
  position: relative;
  z-index: 1;
}
.top-news .news-wrap .summary .box .item {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 3.1rem 0 3.2rem 0;
  border-bottom: 0.1rem solid #ED7A7A;
}
.top-news .news-wrap .summary .box .item .item-pic {
  flex-shrink: 0;
  aspect-ratio: 51/41;
  width: 15.3rem;
  overflow: hidden;
  margin-right: 2.7rem;
}
.top-news .news-wrap .summary .box .item .item-pic img {
  width: 100%;
  height: 100%;
  max-height: 100%;
  object-fit: cover;
}
.top-news .news-wrap .summary .box .item .item-txt .date {
  color: #484848;
  letter-spacing: 0.14em;
  font-size: clamp(14px, 1.5rem, 1.5rem);
  font-weight: 700;
  line-height: 1.3;
  margin-bottom: 1.9rem;
}
.top-news .news-wrap .summary .box .item .item-txt .title {
  font-weight: 500;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  letter-spacing: 0.14em;
  line-height: 1.6;
  -webkit-line-clamp: 3;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
}
.top-news .news-wrap .summary .box .item:nth-of-type(1) {
  padding: 0 0 3.2rem 0;
}
.top-news .news-wrap .summary .box .item:nth-of-type(3) {
  padding: 3.1rem 0 0 0;
  border-bottom: none;
}
.top-news .news-wrap .summary .box .link-btn {
  background: #ED7A7A;
  color: #fff;
  border-radius: 29.5rem;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1.3;
  padding: 1.4rem 4.7rem 1.6rem 4.5rem;
  width: fit-content;
  max-width: 100%;
  margin: 3.1rem auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.top-news .news-wrap .summary .box .link-btn .txt {
  display: flex;
  align-items: center;
  justify-content: center;
}
.top-news .news-wrap .summary .box .link-btn .txt::after {
  content: "";
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  background: #fff;
  margin-left: 1.8rem;
  width: 1.2rem;
  height: 1.6rem;
  display: block;
}
@media screen and (max-width: 1268px) {
  .top-news .news-wrap .summary .box .item .item-txt .title {
    -webkit-line-clamp: 2;
  }
}
@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .top-news {
    padding: 8.7rem 0 0;
  }
  .top-news .tit {
    font-size: 2.2rem;
    margin: 0 auto 4.9rem;
  }
  .top-news .tit::before {
    font-size: 1.2rem;
  }
  .top-news .tit::after {
    height: 0.5rem;
    width: 100%;
    margin-top: 0.3rem;
    background: url(../images/common/txt-dot.png) repeat-x left top/1.1rem 0.5rem;
  }
  .top-news .light {
    width: 9.4rem;
    height: 9.4rem;
    top: 0;
    left: 3.3rem;
  }
  .top-news .news-wrap {
    display: block;
    width: 100%;
    max-width: 100%;
    margin: auto;
    padding: 0 1.5rem;
  }
  .top-news .news-wrap .summary {
    width: 100%;
  }
  .top-news .news-wrap .summary:last-of-type .box {
    margin-bottom: 0;
  }
  .top-news .news-wrap .summary .news-title {
    font-size: 1.8rem;
    margin: 0 auto 2.1rem;
  }
  .top-news .news-wrap .summary .news-title::before, .top-news .news-wrap .summary .news-title::after {
    content: "";
    height: 4.3rem;
  }
  .top-news .news-wrap .summary .news-title::before {
    margin-right: 3.4rem;
  }
  .top-news .news-wrap .summary .news-title::after {
    margin-left: 3.4rem;
  }
  .top-news .news-wrap .summary .box {
    padding: 3.4 1.9rem 2.8rem;
    margin-bottom: 4.7rem;
  }
  .top-news .news-wrap .summary .box .item {
    padding: 2.5rem 0;
  }
  .top-news .news-wrap .summary .box .item .item-pic {
    aspect-ratio: 106/85;
    width: 10.6rem;
    margin-right: 1.8rem;
  }
  .top-news .news-wrap .summary .box .item .item-txt .date {
    font-size: 1rem;
    margin-bottom: 0.8rem;
  }
  .top-news .news-wrap .summary .box .item .item-txt .title {
    font-size: 1.4rem;
  }
  .top-news .news-wrap .summary .box .item:nth-of-type(1) {
    padding: 0 0 2.5rem 0;
  }
  .top-news .news-wrap .summary .box .item:nth-of-type(3) {
    padding: 2.5rem 0 0 0;
  }
  .top-news .news-wrap .summary .box .link-btn {
    border-radius: 2rem;
    font-size: 1.4rem;
    padding: 0.7rem 2.5rem 1rem 3.2rem;
    line-height: 1.71;
  }
  .top-news .news-wrap .summary .box .link-btn .txt::after {
    margin-left: 0.5rem;
    width: 1rem;
    height: 1.2rem;
  }
}
/*--------------------------------------------------------------
    園についてセクション
---------------------------------------------------------------*/
.top-about {
  background: #FBF9EE;
  padding: 0 0 12.5rem 0;
  position: relative;
}
.top-about .tit {
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #484848;
  font-size: clamp(16px, 3.8rem, 3.8rem);
  font-weight: 700;
  letter-spacing: 0.24em;
  line-height: 1.44;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto 11.2rem;
  text-align: center;
}
.top-about .tit::before {
  content: "About";
  font-weight: 700;
  line-height: 1.11;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  letter-spacing: 0.3em;
  display: block;
  margin: auto;
  color: #ED7A7A;
}
.top-about .tit::after {
  content: "";
  display: block;
  height: 0.9rem;
  width: 100%;
  margin-top: 0.2rem;
  background: url(../images/common/txt-dot.png) repeat-x left top/1.9rem 0.9rem;
}
.top-about .bird01 {
  position: absolute;
  width: 9.7rem;
  height: 9.7rem;
  top: -7.4rem;
  right: 29.4rem;
  transform: rotateZ(14deg);
}
.top-about .bird02 {
  position: absolute;
  width: 9.7rem;
  height: 9.7rem;
  top: 0.6rem;
  right: 21.4rem;
  transform: rotateZ(14deg);
}
.top-about .bird03 {
  position: absolute;
  width: 9.7rem;
  height: 9.7rem;
  top: -0.1rem;
  right: 10.1rem;
  transform: rotateZ(14deg);
}
.top-about .link-box {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 4.5rem;
  width: 122.4rem;
  max-width: 100%;
  margin: 0 auto 8.4rem;
}
.top-about .link-box .items {
  width: calc(33.3333333333% - 3rem);
  border-radius: 1.3rem;
  aspect-ratio: 378/227;
  background: url(../images/noImage.png) no-repeat center/cover;
}
.top-about .link-box .items.feature {
  background: url(../images/top/about_02.jpg) no-repeat center/cover;
}
.top-about .link-box .items.life {
  background: url(../images/top/about_01.jpg) no-repeat center/cover;
}
.top-about .link-box .items.history {
  background: url(../images/top/about_03.jpg) no-repeat center/cover;
}
.top-about .link-box .items .txt {
  transform: translateY(-3.2rem);
  display: block;
  writing-mode: vertical-lr;
  margin-left: 2.4rem;
  background: #FBECA0;
  border-radius: 0.5rem;
  padding: 1.8rem 1.2rem 1.5rem 1.2rem;
  color: #484848;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-size: clamp(16px, 2.4rem, 2.4rem);
  line-height: 1;
  letter-spacing: 0.3em;
  font-weight: 700;
}
.top-about .blossom-btn .txt {
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  color: #484848;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto 1.8rem;
}
.top-about .blossom-btn .link {
  color: #fff;
  background: #ED7A7A;
  display: block;
  border-radius: 6.35rem;
  font-size: clamp(16px, 3rem, 3rem);
  letter-spacing: 0.14em;
  font-weight: 700;
  line-height: 1;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto 9.9rem;
  padding: 5.2rem 10rem 5.1rem;
  position: relative;
}
.top-about .piyo2center {
  background: #FBECA0;
  border-radius: 4.9rem;
  padding: 6.5rem 5.5rem 6rem;
  width: 122.4rem;
  max-width: 100%;
  margin: auto;
  position: relative;
  z-index: 1;
}
.top-about .piyo2center .tit {
  margin-bottom: 5.4rem;
}
.top-about .piyo2center .tit::before {
  content: "子育て支援センター";
  color: #484848;
}
.top-about .piyo2center .tit::after {
  filter: brightness(0) invert(1);
}
.top-about .piyo2center .p1 {
  position: absolute;
  width: 12.7rem;
  height: 12.7rem;
  top: -6.4rem;
  left: 5.8rem;
}
.top-about .piyo2center .p2 {
  position: absolute;
  width: 9.3rem;
  height: 9.3rem;
  top: -2.3rem;
  left: 20.5rem;
}
.top-about .piyo2center .l1 {
  position: absolute;
  width: 9.2rem;
  height: 9.2rem;
  top: 10.2rem;
  right: 4rem;
}
.top-about .piyo2center .inner {
  display: flex;
}
.top-about .piyo2center .inner .image-box {
  width: 49.5rem;
  max-width: 100%;
  flex-shrink: 0;
  border-radius: 1.3rem;
  overflow: hidden;
  margin-right: 7.5rem;
}
.top-about .piyo2center .inner .txt-box .desc {
  margin-top: 3.3rem;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  font-weight: 500;
  letter-spacing: 0.14em;
  line-height: 2;
  color: #484848;
  margin-bottom: 5.4rem;
}
.top-about .piyo2center .inner .txt-box .link-btn {
  background: #ED7A7A;
  color: #fff;
  border-radius: 29.5rem;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1.3;
  padding: 1.4rem 4.1rem 1.6rem 5.4rem;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto 0;
  position: relative;
}
.top-about .piyo2center .inner .txt-box .link-btn::before {
  content: "";
  display: block;
  position: absolute;
  background: url(../images/top/piyo_l2.png) no-repeat center/contain;
  width: 8.2rem;
  height: 8.2rem;
  left: -14rem;
  top: -1.5rem;
}
.top-about .piyo2center .inner .txt-box .link-btn .txt {
  display: flex;
  align-items: center;
  justify-content: center;
}
.top-about .piyo2center .inner .txt-box .link-btn .txt::after {
  content: "";
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  background: #fff;
  margin-left: 1.4rem;
  width: 1.2rem;
  height: 1.6rem;
  display: block;
}
.top-about .piyo2center .inner .txt-box .link-btn2 {
  color: #484848;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1.3;
  padding: 0.7rem 0;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 5.5rem auto 0;
  border-bottom: 0.1rem solid #484848;
}
.top-about .piyo2center .inner .txt-box .link-btn2 .txt {
  display: flex;
  align-items: center;
  justify-content: center;
}
.top-about .piyo2center .inner .txt-box .link-btn2 .txt::after {
  content: "";
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  background: #484848;
  margin-left: 1.4rem;
  width: 1.2rem;
  height: 1.6rem;
  display: block;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .top-about {
    padding: 9.8rem 0 5.6rem 0;
  }
  .top-about .tit {
    font-size: 2.2rem;
    margin: 0 auto 6.8rem;
  }
  .top-about .tit::before {
    font-size: 1.2rem;
  }
  .top-about .tit::after {
    height: 0.5rem;
    width: 100%;
    margin-top: 0.3rem;
    background: url(../images/common/txt-dot.png) repeat-x left top/1.1rem 0.5rem;
  }
  .top-about .bird01 {
    width: 3.6rem;
    height: 3.6rem;
    top: 3.1rem;
    right: 9.7rem;
  }
  .top-about .bird02 {
    width: 3.6rem;
    height: 3.6rem;
    top: 6.1rem;
    right: 6.7rem;
  }
  .top-about .bird03 {
    width: 3.6rem;
    height: 3.6rem;
    top: 5.4rem;
    right: 1.7rem;
  }
  .top-about .link-box {
    display: block;
    width: 100%;
    margin: 0 auto 4.6rem;
    padding: 0 3.6rem;
  }
  .top-about .link-box .items {
    width: 100%;
    display: block;
    border-radius: 0.5rem;
    margin-bottom: 6.5rem;
    aspect-ratio: 325/195;
    background: url(../images/noImage.png) no-repeat center/cover;
  }
  .top-about .link-box .items:last-of-type {
    margin-bottom: 0;
  }
  .top-about .link-box .items.feature {
    background: url(../images/top/about_01.jpg) no-repeat center/cover;
  }
  .top-about .link-box .items.life {
    background: url(../images/top/about_02.jpg) no-repeat center/cover;
  }
  .top-about .link-box .items.history {
    background: url(../images/top/about_03.jpg) no-repeat center/cover;
  }
  .top-about .link-box .items .txt {
    transform: translateY(-3.2rem);
    margin-left: 2.4rem;
    border-radius: 0.5rem;
    padding: 0.7rem 0.8rem 1.2rem;
    font-size: 1.8rem;
  }
  .top-about .blossom-btn .txt {
    font-size: 1.4rem;
    margin: 0 auto 0.7rem;
  }
  .top-about .blossom-btn .link {
    border-radius: 4rem;
    font-size: 2.2rem;
    margin: 0 auto 10.2rem;
    padding: 2.8rem 4.7rem;
  }
  .top-about .piyo2center {
    border-radius: 4.9rem;
    padding: 4.6rem 2.5rem 5.4rem;
    width: calc(100% - 3rem);
    max-width: 100%;
    margin: auto;
  }
  .top-about .piyo2center .tit {
    font-size: 2.2rem;
    margin: 0 auto 3rem;
  }
  .top-about .piyo2center .tit::before {
    font-size: 1.2rem;
  }
  .top-about .piyo2center .tit::after {
    height: 0.5rem;
    width: 100%;
    margin-top: 0.3rem;
    background: url(../images/common/txt-dot.png) repeat-x left top/1.1rem 0.5rem;
    filter: brightness(0) invert(1);
  }
  .top-about .piyo2center .p1 {
    width: 5.7rem;
    height: 5.7rem;
    top: -3.7rem;
    left: 13.7rem;
  }
  .top-about .piyo2center .p2 {
    display: none;
  }
  .top-about .piyo2center .l1 {
    width: 4rem;
    height: 4rem;
    top: -1.6rem;
    right: 12.9rem;
  }
  .top-about .piyo2center .inner {
    display: block;
  }
  .top-about .piyo2center .inner .image-box {
    width: 100%;
    border-radius: 0.5rem;
    margin-right: 0;
  }
  .top-about .piyo2center .inner .txt-box .desc {
    margin-top: 2.7rem;
    font-size: 1.4rem;
    margin-bottom: 2.7rem;
  }
  .top-about .piyo2center .inner .txt-box .link-btn {
    border-radius: 2rem;
    font-size: 1.4rem;
    padding: 0.7rem 2.5rem 1rem 3.2rem;
    line-height: 1.71;
  }
  .top-about .piyo2center .inner .txt-box .link-btn::before {
    display: none;
  }
  .top-about .piyo2center .inner .txt-box .link-btn .txt::after {
    margin-left: 0.5rem;
    width: 1rem;
    height: 1.2rem;
  }
}
/*--------------------------------------------------------------
   採用情報セクション
---------------------------------------------------------------*/
.top-recruit {
  padding: 5.2rem 0 14.7rem 0;
  position: relative;
  background: #fff;
}
.top-recruit .tit {
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #484848;
  font-size: clamp(16px, 3.8rem, 3.8rem);
  font-weight: 700;
  letter-spacing: 0.24em;
  line-height: 1.44;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto 15.9rem;
  text-align: center;
}
.top-recruit .tit::before {
  content: "Recruit";
  font-weight: 700;
  line-height: 1.11;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  letter-spacing: 0.3em;
  display: block;
  margin: auto;
  color: #ED7A7A;
}
.top-recruit .tit::after {
  content: "";
  display: block;
  height: 0.9rem;
  width: 100%;
  margin-top: 0.2rem;
  background: url(../images/common/txt-dot.png) repeat-x left top/1.9rem 0.9rem;
}
.top-recruit .txt-box {
  margin-left: 86.6rem;
  margin-right: 8.1rem;
}
.top-recruit .txt-box .catch {
  color: #484848;
  font-size: clamp(16px, 2.4rem, 2.4rem);
  letter-spacing: 0.24em;
  line-height: 2;
  margin-bottom: 2.8rem;
  font-family: "Zen Kaku Gothic New", sans-serif;
}
.top-recruit .txt-box .desc {
  color: #484848;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  line-height: 2;
  letter-spacing: 0.14em;
}
.top-recruit .txt-box .link-btn {
  background: #FBECA0;
  color: #484848;
  border-radius: 29.5rem;
  font-size: clamp(16px, 1.8rem, 1.8rem);
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1.3;
  padding: 1.4rem 4.1rem 1.6rem 5.4rem;
  display: block;
  width: fit-content;
  max-width: 100%;
  margin: 6.8rem 0 0 0;
}
.top-recruit .txt-box .link-btn .txt {
  display: flex;
  align-items: center;
  justify-content: center;
}
.top-recruit .txt-box .link-btn .txt::after {
  content: "";
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  background: #484848;
  margin-left: 1.4rem;
  width: 1.2rem;
  height: 1.6rem;
  display: block;
}
.top-recruit .pp1, .top-recruit .pp2, .top-recruit .pp3, .top-recruit .note, .top-recruit .teacher {
  position: absolute;
}
.top-recruit .pp1 {
  width: 35.1rem;
  top: 15.8rem;
  left: 8.1rem;
}
.top-recruit .pp2 {
  width: 24rem;
  top: 43.6rem;
  left: 31.3rem;
}
.top-recruit .pp3 {
  width: 19.5rem;
  top: 25.3rem;
  left: 59.4rem;
}
.top-recruit .note {
  width: 19.6rem;
  left: 4.5rem;
  top: 48rem;
}
.top-recruit .teacher {
  width: 25rem;
  top: 5.1rem;
  right: 4.7rem;
}
.top-recruit .ribbon {
  width: 10.5rem;
  position: absolute;
  top: 9.57rem;
  right: 19.2rem;
}
.top-recruit .dot {
  width: 11.7rem;
  position: absolute;
  top: 16.9rem;
  right: 10.7rem;
}
.top-recruit .tree01 {
  width: 12.2rem;
  position: absolute;
  left: 7.6rem;
  bottom: -3.9rem;
}
.top-recruit .tree02 {
  width: 12.2rem;
  position: absolute;
  left: 18.7rem;
  bottom: -3.9rem;
}

@media screen and (max-width: 767px), (max-width: 896px) and (orientation: landscape) {
  .top-recruit {
    padding: 3rem 0 3.5rem 0;
  }
  .top-recruit .tit {
    font-size: 2.2rem;
    margin: 0 auto 41rem;
  }
  .top-recruit .tit::before {
    font-size: 1.2rem;
  }
  .top-recruit .tit::after {
    height: 0.5rem;
    width: 100%;
    margin-top: 0.3rem;
    background: url(../images/common/txt-dot.png) repeat-x left top/1.1rem 0.5rem;
  }
  .top-recruit .txt-box {
    margin-left: 0;
    margin-right: 0;
    padding: 0 2.4rem 0 3rem;
  }
  .top-recruit .txt-box .catch {
    font-size: 1.8rem;
    margin-bottom: 1.7rem;
    line-height: 1.33;
  }
  .top-recruit .txt-box .desc {
    font-size: 1.4rem;
    line-height: 1.71;
  }
  .top-recruit .txt-box .link-btn {
    border-radius: 2rem;
    font-size: 1.4rem;
    padding: 0.7rem 2.5rem 1rem 3.2rem;
    line-height: 1.71;
    margin-left: auto;
    margin-right: auto;
    margin-top: 3.1rem;
  }
  .top-recruit .txt-box .link-btn .txt::after {
    margin-left: 0.5rem;
    width: 1rem;
    height: 1.2rem;
  }
  .top-recruit .pp1, .top-recruit .pp2, .top-recruit .pp3, .top-recruit .note, .top-recruit .teacher {
    position: absolute;
  }
  .top-recruit .pp1 {
    width: 28.8rem;
    top: 12.2rem;
    left: -2.1rem;
    max-height: 17.3rem;
    object-fit: cover;
    object-position: center;
    overflow: hidden;
    border-radius: 0 0.5rem 0.5rem 0;
  }
  .top-recruit .pp2 {
    width: 19.6rem;
    top: 31.6rem;
    left: auto;
    right: 2.4rem;
  }
  .top-recruit .ribbon {
    width: 5.7rem;
    top: 8.4rem;
    right: 5.48rem;
  }
  .top-recruit .dot {
    width: 5.1rem;
    top: 13.6rem;
    right: 2.4rem;
  }
  .top-recruit .tree01 {
    width: 4.8rem;
    left: 1.7rem;
    bottom: auto;
    top: 42.1rem;
  }
  .top-recruit .tree02 {
    width: 4.8rem;
    left: 6.1rem;
    bottom: auto;
    top: 42.1rem;
  }
}