@charset "utf-8";
/* ===================================================================
CSS information

  file name  :page.css
  style info :各ページ
=================================================================== */

/* -----------------------------------------------------------
  TOP
----------------------------------------------------------- */

.halfway-wrap {
  max-width: 1592px;
  width: 95%;
  padding: 37px 0 108px;
}

/*
// MV スライダー
*/
.mv-wrap {
  position: relative;
}

.mv-wrap::before {
  content: '';
  width: 83px;
  height: 83px;
  background: url(../img/top/corner.svg) no-repeat;
  background-size: contain;
  display: block;
  position: absolute;
  top: -1px;
  left: -1px;
  z-index: 1;
}

.mv-slider {
  /*height: 53vw;*/
  margin-inline: auto;
  overflow: hidden;
  /* 画像がはみ出ないようにする */
  width: 100%;
}

.mv-slider .slick-img img {
  width: 100%;
}

@keyframes zoomUp {
  0% {
    transform: scale(1);
  }

  100% {
    transform: scale(1.15);
    /* 拡大率 */
  }
}

.add-animation {
  animation: zoomUp 10s linear 0s normal both;
}

.right_banner {
  width: 75px;
  right: 0;
  position: absolute;
  top: 160px;
}
.mv-slider .slick-img img.spNone {
    display: none;
}
.right_banner a:nth-child(1) {
  background: #FC7D74;
}

.right_banner a:nth-child(2) {
  background: #39B9AD;
}

.right_banner a {
  display: block;
  border-top-left-radius: 15px;
  border-bottom-left-radius: 15px;
  padding-top: 20px;
  padding-bottom: 20px;
}

.right_banner a img {
  margin: auto;
}

.right_banner a:hover {
  background: #b5d753;
}

section.top__introduction-wrap {
  background: #f1f2cd;
  padding-bottom: 100px;
  position: relative;
}

section.top__introduction-wrap img.balloon {
  position: absolute;
  top: -100px;
  left: 100px;
  z-index: 1;
}

section.top__introduction-wrap img.tree01 {
  position: absolute;
  right: 230px;
  top: -50px;
  z-index: 1;
}

section.top__introduction-wrap img.tree03 {
  position: absolute;
  top: -150px;
  right: 50px;
  z-index: 1;
}

section.top__introduction-wrap ul.flex {
  flex-wrap: wrap;
  margin-top: 35px;
}

section.top__aboutContents-wrap .inner div a {
  display: flex;
  border: 1px solid #F08A00;
  width: 230px;
  border-radius: 30px;
  justify-content: center;
  height: 52px;
  line-height: 52px;
  align-items: center;
  margin-left: 30px;
  letter-spacing: 0.2rem;
}

section.top__aboutContents-wrap .inner div a:hover {
  background: #F08A00;
  color: #fff;
}

section.top__aboutContents-wrap .inner div a img {
  width: 25px;
  margin-right: 10px;
  margin-left: 0;
}

section.top__aboutContents-wrap {
  margin-top: 150px;
  margin-bottom: 100px;
}

section.top__about-wrap img.animal:before {
  position: absolute;
  content: "";
  background: url(../img/top/panda.png) no-repeat;
  top: 0;
  right: 0;
  z-index: 9;
  width: 200px;
  height: 100px;
}

.mv-wrap .news {
  width: max-content;
  position: absolute;
  z-index: 9;
  background: #fff;
  bottom: 25%;
  border-radius: 25px;
  max-width: 530px;
  right: 10%;
  display: flex;
  padding: 20px 25px;
}

.mv-wrap .news div {
  width: 110px;
  margin-right: 20px;
}

.mv-wrap .news div span {
  border: 1px solid #F08A00;
  width: 100%;
  display: block;
  text-align: center;
  border-radius: 20px;
  color: #F08A00;
  font-size: 12px;
}

.mv-wrap .news a {
  font-size: 16px;
}

.mv-wrap .news div p {
  font-size: 12px;
}

.mv-wrap .news div span {
  border: 1px solid #F08A00;
  width: 100%;
  display: block;
  text-align: center;
  border-radius: 20px;
  color: #F08A00;
  font-size: 12px;
  margin-top: 5px;
}

section.top__aboutContents-wrap a:hover img.a_title {
  transform-origin: center bottom;
  animation: yurayura 2.5s linear infinite;
}

/*
//　園のご紹介　top
*/
section.top__acquisition-wrap .top__acquisition-plan__ttl {
  margin-right: 13px;
}

section.top__introduction-wrap .inner img.hay {
  position: absolute;
  right: 80px;
  bottom: 80px;
}

section.top__introduction-wrap .inner {
  background: #fff;
  border-radius: 50px;
  padding: 40px;
  position: relative;
}

p.line {
  border-bottom: 1px solid #F08A00;
  width: max-content;
  margin: auto;
  position: relative;
  padding-bottom: 5px;
  padding-left: 10px;
  padding-right: 10px;
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 10px;
}

p.line:before {
  content: "●";
  color: #F08A00;
  position: absolute;
  top: 26px;
  left: -8px;
  font-size: 10px;
}

p.line:after {
  content: "●";
  color: #F08A00;
  position: absolute;
  top: 26px;
  right: -8px;
  font-size: 10px;
}

section.top__introduction-wrap ul li {
  text-align: center;
  width: 31%;
  margin-bottom: 35px;
}

section.top__introduction-wrap ul li img {
  margin-bottom: 10px;
}

section.top__introduction-wrap ul li a img.obtn {
  position: absolute;
  right: 0;
  bottom: 10px;
}

section.top__introduction-wrap ul li a {
  position: relative;
  cursor: pointer;
}

section.top__introduction-wrap h2.flex {
  display: flex;
  justify-content: center;
  font-size: 40px;
  align-items: center;
}

section.top__introduction-wrap h2.flex img {
  margin-left: 15px;
  margin-right: 15px;
}



/*
//　保育理念　top
*/
section.top__about-wrap {
  background: #ffe7df;
  position: relative;
}

section.top__about-wrap ul {
  flex-wrap: wrap;
  margin-top: 100px;
  margin-bottom: 50px;
}

section.top__about-wrap ul li {
  max-width: 700px;
  position: relative;
  margin-bottom: 100px;
  width: 48%;
}

section.top__about-wrap ul li p.title {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-lr;
  padding: 26px 15px;
  color: #151515;
  font-size: 30px;
  font-weight: bold;
  background: #ffffff;
  border-radius: 38px;
  letter-spacing: 0.2em;
  padding-bottom: 0;
  max-height: 500px;
  position: absolute;
  top: -70px;
  left: 50px;
  border: 1px solid #EE7F5B;
  height: 200px;
}

section.top__about-wrap ul li img {
  margin-bottom: 15px;
}

section.top__about-wrap img.panda {
  margin: auto;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -30px;
  z-index: 1;
}

section.top__about-wrap img.animal_img {
  position: absolute;
  right: 100px;
  top: -20px;
}

/*
//　コドモン　top
*/
.top__acquisition-plan-wrap img.baby {
  position: absolute;
  right: -176px;
  top: -100px;
}

.top__acquisition-wrap {
  padding-top: 100px;
  background: #fff;
}

.top__acquisition-wrap .halfway-wrap {
  margin-right: auto;
  background: #F5F5F5;
  border-radius: 0 30px 30px 0;
  position: relative;
}

.top__acquisition-wrap .halfway-wrap img.triple_baby {
  position: absolute;
  right: 5%;
}

.top__acquisition-wrap .halfway__inner-wrap {
  max-width: 1420px;
  width: 90%;
  margin: 0 auto;
}

.top__acquisition-wrap .protrude__ttl {
  color: #0E4FAF;
  text-align: left;
}

.top__acquisition-wrap .protrude__ttl span {
  color: #9FB9DF;
  left: 0;
}

.top__acquisition-plan-wrap {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
}

.top__acquisition-plan__ttl {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-lr;
  padding: 50px 15px;
  color: #151515;
  font-size: 40px;
  font-weight: bold;
  background: #ffffff;
  border-radius: 38px;
  letter-spacing: 0.4em;
  padding-bottom: 0;
  max-height: 500px;
  align-self: flex-start;
  height: 48%;
  margin-left: 4.5%;
}

p.top__acquisition-plan__ttl.second {
  margin-top: 98px;
  margin-right: 10px;
  padding-bottom: 80px;
}

section.top__acquisition-wrap .top__acquisition-plan__ttl {
  height: auto;
  margin-left: auto;
}

.top__acquisition-plan-list-wrap {
  -ms-flex-pack: distribute;
  justify-content: space-around;
  max-width: 1209px;
  width: calc(100% - 74.8px - 57.5px);
  /*gap: 0 1.7370%;*/
}

.top__acquisition-plan-list-wrap li:last-child {
  max-width: 370px;
  width: 100%;
  margin-left: 0;
}

.top__acquisition-plan-list-wrap li a {
  color: #000;
}

.top__acquisition-plan-list-wrap .imgWrap {
  max-width: max-content;
  margin-bottom: 27px;
  overflow: hidden;
}

.top__acquisition-plan-list-wrap .imgWrap img {
  width: 100%;
  object-fit: cover;
  transition: 1s all;
}

.top__acquisition-plan-list-wrap li:hover .imgWrap img {
  transform: scale(1.2, 1.2);
  transition: 1s all;
}

.top__acquisition-plan-list_co {
  height: calc(100% - 283px - 27px);
}

.top__acquisition-plan-list_co .top__acquisition-plan__num {
  padding-right: 15.5px;
  margin-right: 27.5px;
  color: #0E4FAF;
  font-size: 45px;
  font-weight: bold;
  font-family: "Arial", "メイリオ";
  border-right: 1px solid #0E4FAF;
  line-height: 1.2;
}

.top__acquisition-plan-list_co .top__acquisition-plan__num span {
  display: block;
  font-size: 18px;
  font-weight: normal;
  letter-spacing: 0.01em;
}

.top__acquisition-plan-list_co dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  max-width: 100%;
}

.top__acquisition-plan-list_co dl dt {
  margin-bottom: 50px;
}

.top__acquisition-plan-list_co dl dt span {
  display: block;
  margin-bottom: 8px;
  font-size: 30px;
}

.top__acquisition-plan-list_co dl dt span::after {
  padding-left: 10px;
  font-size: 14px;
  display: inline-block;
  vertical-align: middle;
}

.top__acquisition-plan-list_co dl dt small {
  display: block;
  font-size: 16px;
}

.top__acquisition-plan-list_co dd {
  margin-top: auto;
}

.top__acquisition-plan-list_co dd .moreLink {
  border: 1px solid #F9A084;
  background: #ffffff;
  border-radius: 40px;
  display: flex;
  justify-content: center;
  width: 230px;
  height: 52px;
  line-height: 52px;
  align-items: center;
  letter-spacing: 0.3rem;
}

.top__acquisition-plan-list_co dd .moreLink img {
  margin-right: 10px;
}

.top__acquisition-plan-list_co dd .moreLink:hover {
  background: #ffcebd;
}

.top__staff-co-wrap .moreLink:hover {
  background: #ffa72d;
}

.top__acquisition-item-wrap {
  padding: 47px 37px;
  background: rgba(112, 112, 112, 0.1);
  border-radius: 8px 30px 0 0;
}

.top__acquisition-item__ttl {
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  margin-right: 38.5px;
  font-size: 28px;
  font-weight: bold;
  letter-spacing: 0.4em;
}

.top__acquisition-item-list-wrap {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: calc(100% - 44.8px - 38.5px);
}

.top__acquisition-item-list-wrap li {
  max-width: 284px;
  width: 23.4711%;
  position: relative;
  overflow: hidden;
  border-radius: 10px 30px 10px 10px;
}

.top__acquisition-item-list-wrap li:after {
  position: absolute;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  top: 0;
  background: url(../img/top/acquisition-item01.jpg) no-repeat center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  background-size: cover;
  -webkit-transition: all .3s ease-out;
  -moz-transition: all .3s ease-out;
  -ms-transition: all .3s ease-out;
  transition: all .3s ease-out;
}

.top__acquisition-item-list-wrap li:nth-child(2):after {
  background: url(../img/top/acquisition-item02.jpg) no-repeat center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  background-size: cover;
}

.top__acquisition-item-list-wrap li:nth-child(3):after {
  background: url(../img/top/acquisition-item03.jpg) no-repeat center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  background-size: cover;
}

.top__acquisition-item-list-wrap li:nth-child(4):after {
  background: url(../img/top/acquisition-item04.jpg) no-repeat center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -ms-background-size: cover;
  background-size: cover;
}

.top__acquisition-item-list-wrap li:hover:after {
  opacity: .8;
  -moz-transform: scale(1.1);
  -webkit-transform: scale(1.1);
  -ms-transform: scale(1.1);
  transform: scale(1.1);
}

.top__acquisition-item-list-wrap li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 40px 0;
  position: relative;
  z-index: 1;
  color: #fff;
}

.top__acquisition-item-list-wrap li .blueBg {
  max-width: 249px;
  width: 95%;
  padding: 19px 28px;
  background: rgba(14, 79, 175, 0.8);
  border-radius: 0px 8px 8px 0px;
}

.top__acquisition-item-list-wrap li:last-child .blueBg {
  background: rgba(220, 0, 12, 0.8);
}

.top__acquisition-item-list-wrap li dt {
  margin-bottom: 16px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 0.05em;
}

.top__acquisition-item-list-wrap li dt::after {
  content: ' >';
  padding-left: 14px;
  font-size: 16px;
  display: inline-block;
  vertical-align: middle;
}

.top__acquisition-item-list-wrap li dd {
  font-size: 14px;
}

section.top__aboutContents-wrap .inner {
  position: relative;
}

section.top__aboutContents-wrap a .a_title {
  position: absolute;
  z-index: 1;
  left: 0;
  right: 0;
  margin: auto;
  bottom: 0;
  top: 0;
}

section.top__aboutContents-wrap a img {
  margin-left: auto;
  margin-right: auto;
}

section.top__aboutContents-wrap .inner div {
  display: flex;
}

section.top__aboutContents-wrap a {
  text-align: center;
}

section.top__aboutContents-wrap .inner div {
  display: flex;
  margin-top: 30px;
  justify-content: center;
}

section.top__aboutContents-wrap .inner div p {
  max-width: 965px;
  width: calc(90% - 230px);
}

section.top__introduction-wrap h2.flex:before {
  content: url(../img/top/hata1.png);
  vertical-align: middle;
  padding-right: 5px;
}

section.top__introduction-wrap h2.flex:after {
  content: url(../img/top/hata2.png);
  vertical-align: middle;
  padding-left: 5px;
}

@media screen and (max-width: 1550px) {
  .top__acquisition-plan-list-wrap li {
    width: 50%;
  }

  .top__acquisition-plan-list-wrap li:last-child img {
    width: max-content;
  }

}

@media screen and (max-width: 1360px) {
  .top__acquisition-plan-list-wrap li:last-child {
    width: 50%;
    margin-left: 5%;
  }

  ul.top__acquisition-plan-list-wrap.flex {
    justify-content: flex-start;
  }

  .top__acquisition-plan-list-wrap li {
    width: 40%;
  }

  section.top__acquisition-wrap .top__acquisition-plan__ttl.second {
    padding-bottom: 61px;
    right: 0;
  }

  section.top__acquisition-wrap .top__acquisition-plan__ttl {
    right: -94px;
  }

  .top__acquisition-plan-list-wrap li:last-child img {
    margin: auto;
  }

  .top__acquisition-plan-list-wrap li img {
    margin-left: auto;
    margin-right: auto;
  }

  section.top__about-wrap ul li p.title {
    left: 20px;
    font-size: 23px;
    height: 200px;
  }

  .top__acquisition-plan__ttl {
    font-size: 30px;
    height: 275px;
    margin-left: 2%;
    padding: 38px 10px;
  }

  .top__acquisition-plan-wrap {
    display: block;
  }

  section.top__acquisition-wrap .top__acquisition-plan__ttl {
    position: absolute;
    top: 0;
    right: 0;
  }

  .top__acquisition-plan-list-wrap {
    width: 100%;
  }

  section.top__acquisition-wrap .top__acquisition-plan__ttl.second {
    right: 90px;
  }

  .top__acquisition-plan-list-wrap .imgWrap {
    max-width: 300px;
    margin-left: auto;
    margin-right: auto;
  }

  .top__acquisition-plan-list_co dd .moreLink img {
    margin: 0;
    margin-right: 10px;
  }
}

@media screen and (max-width: 1280px) {
  .top__acquisition-plan-list-wrap li:last-child {
    max-width: 100%;
    width: 100%;
    margin-left: 0%
  }

  .top__acquisition-plan-list-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 35px 0;
  }

  .top__acquisition-plan-list-wrap li {
    max-width: none;
    width: 100%;
  }

  .top__acquisition-plan-list-wrap .imgWrap {
    max-width: none;
    width: 100%;
  }

  .top__acquisition-plan-list_co {
    height: auto;
  }

  .top__acquisition-item-list-wrap {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 25px 0;
  }

  .top__acquisition-item-list-wrap li {
    width: 49%;
  }

  section.top__aboutContents-wrap .inner div a {
    margin-left: auto;
    margin-top: 15px;
  }

}


/*
// 採用情報 top
*/

.top__staff-co-wrap .moreLink img {
  margin-right: 10px;
}

.top__staff-co-wrap .moreLink {
  border: none;
  background: #F08A00;
  border-radius: 40px;
  display: flex;
  justify-content: center;
  width: max-content;
  height: 70px;
  line-height: 70px;
  align-items: center;
  color: #fff;
  margin: auto;
  font-size: 20px;
  padding-left: 4%;
  padding-right: 4%;
  letter-spacing: 0.3rem;
  margin-top: 40px;
}

.top__staff-wrap {
  padding-top: 100px;
  background: #fff;
}

.top__staff-wrap .halfway-wrap {
  margin-left: auto;
  background: #FFF0BE;
  border-radius: 30px 0px 0px 30px;
  border: 2px dashed #EE7F5B;
  outline: solid 13px #fff0be;
  /* 外側の線になる一本線の枠線をひく*/
  outline-offset: 0px;
  /* 外側の線と内側の線の空き具合を調整*/
  border-right: 0;
  max-width: 1580px;
  position: relative;
}

.top__staff-wrap img.ehon {
  position: absolute;
  bottom: -50px;
  left: -8%;
}

.top__staff-wrap .halfway__inner-wrap .protrude__ttl {
  max-width: 1342px;
  width: 90%;
  margin: 0 auto 36px;
  text-align: left;
}

.top__staff-wrap .protrude__ttl span {
  color: #DC000C;
  left: 0;
}

.top__staff-slider-wrap {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  margin-bottom: 18px;
  gap: 0 19px;
}

.top__staff-slider-wrap .slider.-staff {
  /*max-width: 1127px;*/
  width: 84.8645%;
  border-radius: 0 30px 10px 0;
  overflow: hidden;
}

.top__staff-slider-wrap .staff_slide-wrap {
  width: 550px;
  margin-left: 30px;
}

.top__staff-slider-wrap .staff_slide-wrap img {
  width: 100%;
  height: auto;
}

.top__staff-slider-wrap .imgWrap {
  max-width: 149px;
  width: 11.2199%;
}

.top__staff-co-wrap {
  max-width: 950px;
  width: 90%;
  margin: 0 auto;
}

.top__staff-co-wrap p {
  margin-bottom: 23px;
  color: #fff;
  font-size: 15px;
  line-height: 1.86;
  letter-spacing: 0.05em;
}

.top__staff-co-wrap a {
  display: block;
}

.frog {
  transform-origin: center bottom;
  animation: yurayura 2.5s linear infinite;
}

@keyframes yurayura {

  0%,
  100% {
    transform: rotate(7deg);
  }

  50% {
    transform: rotate(-7deg);
  }
}


/* -----------------------------------------------------------
  志陽会について
----------------------------------------------------------- */
#about .philosophy_sec {
  .thumb {
    aspect-ratio: 1316 / 415;
    border-radius: 50px;
    overflow: hidden;
    margin: 0 0 90px;

    .img {
      object-fit: cover;
      width: 100%;
      height: 100%;
    }
  }

  .subttl {
    font-size: 3rem;
    line-height: calc(45 / 30);
    letter-spacing: .1em;
    font-weight: bold;
    text-align: center;
    color: #240A00;
    margin: 0 0 50px;
  }

  .philosophy_items {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 50px 45px;

    .item {
      padding: 65px 55px 55px;
      display: grid;
      grid-template-rows: subgrid;
      grid-row: span 3;
      gap: 0px 0px;
      background: #FFFFEF;
      border-radius: 28px;
    }

    .item .ttl {
      font-size: 2.6rem;
      line-height: calc(38 / 26);
      letter-spacing: .1em;
      text-align: center;
      font-weight: bold;
      color: #F08A00;
      margin: 0 0 15px;
    }

    .item .icon {
      aspect-ratio: 154 / 108;
      width: 154px;
      margin: 0 auto 20px;
    }

    .item .txtbox {
      font-size: 1.6rem;
      line-height: calc(26 / 16);
      letter-spacing: .05em;
      color: #240A00;
    }

    .item .txtbox p+p {
      margin-top: 1.5em;
    }

  }

}

#about .overview_sec {
  padding: 100px 10% 135px;
  border: 2px dotted #F08A00;
  border-radius: 9.895vw;
  position: relative;
  z-index: 0;

  .icon {
    position: absolute;
    top: -60px;
    left: 50%;
    transform: translateX(-50%);
    width: 130px;
  }

  .overview_tbl {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(4, 1fr);
    gap: 0 38px;
    max-width: 1056px;
    width: 100%;
    margin: 0 auto;
  }

  .overview_tbl .item {
    padding: 30px 0 25px;
    border-top: 1px solid #D2D2D2;
    display: grid;
    align-items: center;
    grid-template-columns: 115px 1fr;
    gap: 0px 0px;
    letter-spacing: .15em;
  }

  .overview_tbl .item:first-child {
    grid-column: 1 / 3;
    grid-row: 1 / 2;
  }

  .overview_tbl .item:nth-child(2) {
    grid-column: 1 / 3;
    grid-row: 2 / 3;
  }

  .overview_tbl .item:nth-child(3) {
    grid-column: 1 / 3;
    grid-row: 3 / 4;
  }

  .overview_tbl .item:nth-child(4) {
    grid-column: 1 / 3;
    grid-row: 4 / 5;
    border-bottom: 1px solid #D2D2D2;
  }

  .overview_tbl .item:nth-child(5) {
    grid-column: 3 / 5;
    grid-row: 1 / 2;
  }

  .overview_tbl .item:nth-child(6) {
    grid-column: 3 / 5;
    grid-row: 2 / 5;
    border-bottom: 1px solid #D2D2D2;
  }

  .overview_tbl .item .ttl {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .overview_tbl .item .ttl:before {
    content: "";
    aspect-ratio: 1 / 1;
    width: 8px;
    border-radius: 50%;
    background: #F08A00;
  }

}

#about .information_sec {
  .information_items {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 27px;
    max-width: 1100px;
    width: 100%;
    margin: 0 auto;
  }

  .item {
    padding: 30px 35px 30px 50px;
    border: 1px solid #F08A00;
    border-radius: 22px;
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 3;
    gap: 0px 0px;
  }

  .item .ttl {
    font-size: 2rem;
    line-height: calc(29 / 20);
    letter-spacing: .1em;
    color: #240A00;
    margin: 0 0 10px;
  }

  .item .txt {
    font-size: 1.4rem;
    letter-spacing: .1em;
    line-height: calc(20 / 14);
    margin: 0 0 20px;
  }
}


#about .history_sec {
  margin: 0 -70px;
  background: #FAFFE2;
  padding: 120px 70px;

  .contents {
    max-width: 1100px;
    margin: 0 auto;
    padding: 100px 20px 125px;
    background: #fff;
    border-radius: 70px;
  }

  .history_items {
    max-width: 740px;
    width: 100%;
    margin: 0 auto;
  }

  .history_items .item {
    display: grid;
    grid-template-columns: 150px 1fr;
    letter-spacing: .15em;
    position: relative;
    z-index: 0;
    padding: 0 0 20px;
  }

  .history_items .item:not(:last-of-type):before,
  .history_items .item:after {
    content: "";
    position: absolute;
  }

  .history_items .item:not(:last-of-type):before {
    width: 2px;
    height: 100%;
    background: #F08A00;
    top: 10px;
    left: 100px;
  }

  .history_items .item:after {
    position: absolute;
    aspect-ratio: 1 / 1;
    width: 11px;
    background: #F08A00;
    top: 10px;
    left: 95px;
    border-radius: 50%;
  }

  .history_items .item .num {
    font-size: 2rem;
    font-weight: bold;
    color: #F08A00;
  }

  .history_items .item .txt {
    font-size: 1.6rem;
    line-height: calc(23 / 16);
    color: #240A00;
  }

  .history_items .item .txt p+p {
    margin-top: 20px;
  }

}

#about .facilities_sec {
  margin-inline: -70px;
  padding: 150px 70px;
  background: #FFFFEF;
  border-radius: 36px 0 0 36px;

  .facilities_items {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px 20px;
  }

  .facilities_items .item {
    display: grid;
    grid-template-columns: 1fr;
  }

  .facilities_items .item .thumb {
    order: -1;
    aspect-ratio: 424 / 300;
    border-radius: 28px;
    overflow: hidden;
  }

  .facilities_items .item .thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }

  .facilities_items .item .ttl {
    min-width: 210px;
    width: fit-content;
    height: 39px;
    border-radius: 39px;
    margin: 18px auto 0;
    background: #fff;
    border: 1px dashed #F08A00;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    letter-spacing: .1em;
    color: #240A00;
    font-weight: 500;
    padding: 0 25px;
  }

  .details_box {
    margin: 70px 0 0;
  }

  .details_box .ttl {
    max-width: 464px;
    width: 100%;
    margin: 0 auto 45px;
  }

  .details_box .btnbox {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
  }

}


#about .rightColumn {
  padding-bottom: 0;
}

#about .rightColumn>section+section {
  margin-top: 165px;
}

/* -----------------------------------------------------------
  園のご紹介
----------------------------------------------------------- */
#hoikuen-list .rightColumn {
  padding: 56px 70px 150px 70px;
  container-name: hoikuen-item;
  container-type: inline-size;
}

#hoikuen-list .map_box {
  max-width: 1136px;
  margin: 0 auto 20px;
  display: flex;
  align-items: center;
  gap: 75px;
}

#hoikuen-list .map_box .ttl {
  flex-basis: 50%;
}

#hoikuen-list .map_box .map {
  flex-basis: 40%;
}

#hoikuen-list .hoikuen-item {
  margin-right: -70px;
  display: flex;
  align-items: flex-end;
  gap: 40px;
  padding: 5.14% 0 6.61% 7.13%;
  background: #F9F9F9;
  border-radius: 15px;
}

#hoikuen-list .hoikuen-item+.hoikuen-item {
  margin-top: 75px;
}

#hoikuen-list .hoikuen-item .txtbox {
  flex: 1 1;
  display: flex;
  flex-direction: column;
}

#hoikuen-list .hoikuen-item .txtbox .ttlbox {
  display: grid;
  align-items: center;
  grid-template-columns: 90px 1fr;
  gap: 35px;
  margin: 0 0 40px;
}

#hoikuen-list .hoikuen-item .txtbox .ttlbox .ttl {
  font-size: 3.5rem;
  line-height: calc(52 / 35);
  letter-spacing: .1em;
  font-weight: bold;
  color: #240A00;
}

#hoikuen-list .hoikuen-item .txtbox .ttlbox .num {
  font-family: "Inter", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  color: #fff;
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: .1em;
}

#hoikuen-list .hoikuen-item .txtbox .ttlbox .num._ver1 {
  background: #F08A00;
}

#hoikuen-list .hoikuen-item .txtbox .ttlbox .num._ver2 {
  background: #73CFDD;
}

#hoikuen-list .hoikuen-item .txtbox .ttlbox .num._ver3 {
  background: #EF7171;
}

#hoikuen-list .hoikuen-item .txtbox .ttlbox .num._ver4 {
  background: #B86ACB;
}

#hoikuen-list .hoikuen-item .txtbox .subttl {
  font-size: 3rem;
  line-height: calc(45 / 30);
  letter-spacing: .1em;
  font-weight: bold;
  margin: 0 0 25px;
}

#hoikuen-list .hoikuen-item .txtbox .txt {
  font-size: 1.6rem;
  line-height: calc(26 / 16);
  font-weight: 500;
  letter-spacing: .1em;
  color: #240A00;
  margin: 0 0 60px;
}

#hoikuen-list .hoikuen-item .txtbox .txt p+p {
  margin-top: 1.5em;
}

#hoikuen-list .hoikuen-item .txtbox .c_btn_3 {
  margin-top: auto;
}

#hoikuen-list .hoikuen-item .txtbox {
  flex: 1 1;
}

#hoikuen-list .hoikuen-item .imgbox {
  aspect-ratio: 670 / 500;
  border-radius: 28px 0 0 28px;
  overflow: hidden;
  flex-basis: 49.26%;
}

#hoikuen-list .hoikuen-item .imgbox .img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

@container hoikuen-item (max-width: 1000px) {
  #hoikuen-list .hoikuen-item {
    align-items: center;
  }

  #hoikuen-list .hoikuen-item .txtbox .ttlbox {
    grid-template-columns: 60px 1fr;
    gap: 20px;
    margin: 0 0 20px;
  }

  #hoikuen-list .hoikuen-item .txtbox .ttlbox .ttl {
    font-size: 2.5rem;
  }

  #hoikuen-list .hoikuen-item .txtbox .ttlbox .num {
    font-size: 3rem;
  }

  #hoikuen-list .hoikuen-item .txtbox .subttl {
    font-size: 1.8rem;
    margin: 0 0 20px;
  }

  #hoikuen-list .hoikuen-item .txtbox .txt {
    margin: 0 0 20px;
  }
}

@container hoikuen-item (max-width: 768px) {
  #hoikuen-list .hoikuen-item {
    padding: 20px 20px 40px;
    margin-right: 0;
    flex-direction: column;
    gap: 20px;
  }

  #hoikuen-list .hoikuen-item+.hoikuen-item {
    margin-top: 20px;
  }

  #hoikuen-list .hoikuen-item .imgbox {
    order: -1;
    border-radius: 15px;
  }
}

@container hoikuen-item (max-width: 520px) {
  #hoikuen-list .map_box {
    display: block;
  }

  #hoikuen-list .map_box .ttl {
    width: 70%;
    margin: 0 auto 10px;
  }

  #hoikuen-list .map_box .map {
    width: 100%;
  }

  #hoikuen-list .hoikuen-item .txtbox .ttlbox {
    grid-template-columns: 40px 1fr;
    gap: 10px;
  }

  #hoikuen-list .hoikuen-item .txtbox .ttlbox .ttl {
    font-size: 1.8rem;
  }

  #hoikuen-list .hoikuen-item .txtbox .ttlbox .num {
    font-size: 2rem;
  }

  #hoikuen-list .hoikuen-item .txtbox .subttl {
    font-size: 1.6rem;
  }

  #hoikuen-list .hoikuen-item .txtbox .txt {
    font-size: 1.4rem;
  }
}


/* -----------------------------------------------------------
  各保育園配下ページ
----------------------------------------------------------- */
#hoikuen.lower .bg-title {
  color: rgba(255, 255, 255, 1);
}

#hoikuen .rightColumn {
  padding: 0;
  background: 0;
  container-name: hoikuen-single;
  container-type: inline-size;
}

#hoikuen .rightColumn:before {
  content: "";
  display: none;
}

#hoikuen .guide_btn_box {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 5px;
  padding: 0 0 0 0;
  margin: 0 0 20px;
}

@media only screen and (min-width: 769px) {

#hoikuen .guide_btn_box {
    width: 95%;
}

}

#hoikuen .guide_btn_box .btn {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  font-size: 2rem;
  font-weight: bold;
  color: #240A00;
  border-radius: 13px;
  height: 60px;
}

@container hoikuen-single (max-width: 768px) {
  #hoikuen .guide_btn_box {
    padding: 0;
  }

  #hoikuen .guide_btn_box .btn {
    font-size: 1.6rem;
    border-radius: 10px;
    height: 50px;
  }
}

@container hoikuen-single (max-width: 520px) {
  #hoikuen .guide_btn_box {
    padding: 0;
  }

  #hoikuen .guide_btn_box .btn {
    font-size: 1.4rem;
    border-radius: 10px;
    height: 50px;
  }
}

#hoikuen .guide_btn_box._ver1 .btn:hover,
#hoikuen .guide_btn_box._ver1 .btn.is-active {
  background: #F08A00;
  color: #fff;
}

#hoikuen .guide_btn_box._ver2 .btn:hover,
#hoikuen .guide_btn_box._ver2 .btn.is-active {
  background: #73CFDD;
  color: #fff;
}

#hoikuen .guide_btn_box._ver3 .btn:hover,
#hoikuen .guide_btn_box._ver3 .btn.is-active {
  background: #EF7171;
  color: #fff;
}

#hoikuen .guide_btn_box._ver4 .btn:hover,
#hoikuen .guide_btn_box._ver4 .btn.is-active {
  background: #B86ACB;
  color: #fff;
}

#hoikuen .contents-wrap {
  background: #fff;
  border-radius: 36px 0 0 36px;
  padding: 80px 70px;
  position: relative;
  z-index: 0;
}

#hoikuen .contents-wrap:before {
  content: "";
  width: 100%;
  height: 100%;
  background: #fff;
  position: absolute;
  right: -100%;
  top: 0;
  z-index: -1;
}

#hoikuen .sec_page_num_box {
  margin: -80px auto 20px;
}

#hoikuen .sec_page_num_box .num {
  aspect-ratio: 1 / 1;
  width: 120px;
  font-family: "Inter", sans-serif;
  font-size: 6rem;
  font-weight: bold;
  color: #fff;
  letter-spacing: .1em;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
}

#hoikuen .sec_page_num_box._ver1 .num {
  background: #F08A00;
}

#hoikuen .sec_page_num_box._ver2 .num {
  background: #73CFDD;
}

#hoikuen .sec_page_num_box._ver3 .num {
  background: #EF7171;
}

#hoikuen .sec_page_num_box._ver4 .num {
  background: #B86ACB;
}

@container hoikuen-single (max-width: 768px) {
  #hoikuen .sec_page_num_box {
    margin: -40px auto 20px;
  }

  #hoikuen .sec_page_num_box .num {
    width: 60px;
    font-size: 3rem;
  }
}

@container hoikuen-single (max-width: 520px) {
  #hoikuen .sec_page_num_box {
    margin: -40px auto 20px;
  }

  #hoikuen .sec_page_num_box .num {
    width: 50px;
    font-size: 2rem;
  }
}

#hoikuen .about_sec {
  &>.thumb {
    aspect-ratio: 1316 / 415;
    border-radius: 50px;
    overflow: hidden;
    margin: 0 0 90px;

    .img {
      object-fit: cover;
      width: 100%;
      height: 100%;
    }
  }
}

#hoikuen .about_sec .headbox {
  display: grid;
  align-items: center;
  grid-template-columns: 38% 1fr;
  gap: 60px;

  & .thumb {
    aspect-ratio: 50 / 61;
    border-radius: 1.458vw;
    overflow: hidden;
  }

  & .thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }
}

#hoikuen .about_sec .subttl {
  font-size: 3rem;
  font-weight: bold;
  line-height: calc(45 / 30);
  margin: 0 auto 45px;
}

#hoikuen .about_sec .txtbox .txt {
  font-weight: 500;
  letter-spacing: .1em;
  color: #240A00;
}

#hoikuen .about_sec .txtbox p+p {
  margin-top: 1.5em;
}

#hoikuen .about_sec .gallery_box {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px 25px;
  margin: 80px 0 0;

  & .item {
    aspect-ratio: 106 / 75;
    border-radius: 1.458vw;
    overflow: hidden;
  }

  & .item .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }
}

@container hoikuen-single (max-width: 768px) {
  #hoikuen .about_sec {
    &>.thumb {
      aspect-ratio: 6 / 3;
      border-radius: 20px;
      margin: 0 0 25px;
    }
  }

  #hoikuen .about_sec .subttl {
    font-size: 1.8rem;
    margin: 0 0 20px;
  }

  #hoikuen .about_sec .headbox {
    grid-template-columns: 1fr;
    gap: 20px;

    & .thumb {
      aspect-ratio: 3 / 2;
    }
  }
}

@container hoikuen-single (max-width: 520px) {
  #hoikuen .about_sec .gallery_box {
    margin: 50px 0 0;
  }
}

/* ひだまり保育園用 */
#hoikuen.hidamarihoikuen .about_sec .subttl,
#hoikuen.hidamarihoikuen .about_sec .txtbox {
  max-width: 960px;
  width: 100%;
  margin-inline: auto;
}

#hoikuen .overview_sec {
  margin: 230px 0 0;
  padding: 100px 10% 135px;
  border: 2px dotted #F08A00;
  border-radius: 9.895vw;
  position: relative;
  z-index: 0;

  .icon {
    position: absolute;
    top: -60px;
    left: 50%;
    transform: translateX(-50%);
    width: 130px;
  }

  .overview_tbl {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(6, 1fr);
    gap: 0 38px;
    max-width: 1056px;
    width: 100%;
    margin: 0 auto;
    color: #240A00;
  }

  .overview_tbl .item {
    padding: 30px 0 25px;
    border-top: 1px solid #D2D2D2;
    display: grid;
    align-items: center;
    grid-template-columns: 115px 1fr;
    gap: 0px 0px;
    letter-spacing: .15em;
  }

  .overview_tbl .item:first-child {
    grid-column: 1 / 3;
    grid-row: 1 / 2;
  }

  .overview_tbl .item:nth-child(2) {
    grid-column: 1 / 3;
    grid-row: 2 / 3;
  }

  .overview_tbl .item:nth-child(3) {
    grid-column: 1 / 3;
    grid-row: 3 / 4;
  }

  .overview_tbl .item:nth-child(4) {
    grid-column: 1 / 3;
    grid-row: 4 / 5;
  }

  .overview_tbl .item:nth-child(5) {
    grid-column: 1 / 3;
    grid-row: 5 / 6;
  }

  .overview_tbl .item:nth-child(6) {
    grid-column: 1 / 3;
    grid-row: 6 / 7;
    border-bottom: 1px solid #D2D2D2;
  }

  .overview_tbl .item:nth-child(7) {
    grid-column: 3 / 5;
    grid-row: 1 / 3;
  }

  .overview_tbl .item:nth-child(8) {
    grid-column: 3 / 5;
    grid-row: 3 / 4;
  }

  .overview_tbl .item:nth-child(9) {
    grid-column: 3 / 5;
    grid-row: 4 / 5;
  }

  .overview_tbl .item:nth-child(10) {
    grid-column: 3 / 5;
    grid-row: 5 / 7;
    border-bottom: 1px solid #D2D2D2;
  }

  .overview_tbl .item .ttl {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .overview_tbl .item .ttl:before {
    content: "";
    aspect-ratio: 1 / 1;
    width: 8px;
    border-radius: 50%;
    background: #F08A00;
  }

  .overview_thumb {
    aspect-ratio: 962 / 304;
    max-width: 962px;
    width: 100%;
    overflow: hidden;
    border-radius: 50px;
    margin: 100px auto 0;
  }

  .overview_thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }
}

@container hoikuen-single (width < 768px) {
  #hoikuen .overview_sec {
    padding: 50px 10% 40px;
    border: 2px dotted #F08A00;
    border-radius: 9.895vw;
    margin-top: 80px;
  }

  #hoikuen .overview_sec {
    .icon {
      top: -40px;
      width: 80px;
    }

    .overview_tbl .item {
      padding: 20px 0 15px;
      grid-template-columns: 1fr;
      grid-template-rows: auto;
    }

    .overview_thumb {
      aspect-ratio: 3 / 1;
      border-radius: 20px;
      margin: 40px auto 0;
    }
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen .overview_sec {
    padding: 50px 10% 30px;

    .overview_tbl {
      grid-template-columns: 1fr;
      grid-template-rows: auto;
    }

    .overview_tbl .item {
      padding: 20px 0;
      grid-template-columns: 1fr;
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:first-child {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(2) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(3) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(4) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(5) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(6) {
      grid-column: auto;
      grid-row: auto;
      border-bottom: none;
    }

    .overview_tbl .item:nth-child(7) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(8) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(9) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(10) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_thumb {
      aspect-ratio: 2 / 1;
      border-radius: 10px;
      margin: 20px auto 0;
    }
  }
}

/* すまいるひだまり保育園用 */
#hoikuen.smile-hidamarihoikuen .overview_sec {
  .overview_tbl {
    grid-auto-rows: auto;
  }

  .overview_tbl .item {
    align-items: start;
  }

  .overview_tbl .item:first-child {
    grid-column: 1 / 3;
    grid-row: 1 / 2;
  }

  .overview_tbl .item:nth-child(2) {
    grid-column: 1 / 3;
    grid-row: 2 / 3;
  }

  .overview_tbl .item:nth-child(3) {
    grid-column: 1 / 3;
    grid-row: 3 / 4;
  }

  .overview_tbl .item:nth-child(4) {
    grid-column: 1 / 3;
    grid-row: 4 / 5;
  }

  .overview_tbl .item:nth-child(5) {
    grid-column: 1 / 3;
    grid-row: 5 / 6;
  }

  .overview_tbl .item:nth-child(6) {
    grid-column: 1 / 3;
    grid-row: 6 / 7;
    border-bottom: 1px solid #D2D2D2;
  }

  .overview_tbl .item:nth-child(7) {
    grid-column: 3 / 5;
    grid-row: 1 / 2;
  }

  .overview_tbl .item:nth-child(8) {
    grid-column: 3 / 5;
    grid-row: 2 / 4;
  }

  .overview_tbl .item:nth-child(9) {
    grid-column: 3 / 5;
    grid-row: 4 / 5;
  }

  .overview_tbl .item:nth-child(10) {
    grid-column: 3 / 5;
    grid-row: 5 / 6;
    border-bottom: 0;
  }

  .overview_tbl .item:nth-child(11) {
    grid-column: 3 / 5;
    grid-row: 6 / 7;
    border-bottom: 1px solid #D2D2D2;
  }

  .overview_tbl .item:nth-child(12) {
    grid-column: 1 / 5;
    grid-row: 7 / 8;
    border-top: 0;
    border-bottom: 1px solid #D2D2D2;
  }

  .overview_tbl .item .dtl>*:not(:first-child) {
    margin: 20px 0 0;
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen.smile-hidamarihoikuen .overview_sec {
    .overview_tbl {
      grid-auto-rows: auto;
    }

    .overview_tbl .item {
      align-items: start;
    }

    .overview_tbl .item:first-child {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(2) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(3) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(4) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(5) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(6) {
      grid-column: auto;
      grid-row: auto;
      border-bottom: none;
    }

    .overview_tbl .item:nth-child(7) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(8) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(9) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(10) {
      grid-column: auto;
      grid-row: auto;
      border-bottom: 0;
    }

    .overview_tbl .item:nth-child(11) {
      grid-column: auto;
      grid-row: auto;
      border-bottom: 0;
    }

    .overview_tbl .item:nth-child(12) {
      grid-column: auto;
      grid-row: auto;
      border-top: 1px solid #D2D2D2;
      border-bottom: 1px solid #D2D2D2;
    }

    .overview_tbl .item .dtl>*:not(:first-child) {
      margin: 20px 0 0;
    }
  }
}

/* きらりひだまり保育園用 */
#hoikuen.kirari-hidamarihoikuen .overview_sec {
  .overview_tbl {
    grid-auto-rows: auto;
  }

  .overview_tbl .item:nth-child(7) {
    grid-column: 3 / 5;
    grid-row: 1 / 2;
  }

  .overview_tbl .item:nth-child(8) {
    grid-column: 3 / 5;
    grid-row: 2 / 3;
  }

  .overview_tbl .item:nth-child(9) {
    grid-column: 3 / 5;
    grid-row: 3 / 4;
  }

  .overview_tbl .item:nth-child(10) {
    grid-column: 3 / 5;
    grid-row: 4 / 6;
    border-bottom: 0;
  }

  .overview_tbl .item:nth-child(11) {
    grid-column: 3 / 5;
    grid-row: 6 / 7;
    border-bottom: 1px solid #D2D2D2;
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen.kirari-hidamarihoikuen .overview_sec {
    .overview_tbl .item:nth-child(7) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(8) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(9) {
      grid-column: auto;
      grid-row: auto;
    }

    .overview_tbl .item:nth-child(10) {
      grid-column: auto;
      grid-row: auto;
      border-bottom: 0;
    }

    .overview_tbl .item:nth-child(11) {
      grid-column: auto;
      grid-row: auto;
      border-bottom: 1px solid #D2D2D2;
    }
  }
}

#hoikuen .facilities_sec {
  padding: 160px 0 0;

  .headbox {
    display: grid;
    grid-template-columns: 34% 1fr;
    align-items: center;
    gap: 0 3.877%;
  }

  .headbox .thumb {
    aspect-ratio: 500 / 615;
    border-radius: 3.4%;
    overflow: hidden;
  }

  .headbox .thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }

  .headbox .txtbox .subttl {
    font-size: 3rem;
    line-height: calc(45 / 30);
    font-weight: bold;
    letter-spacing: .1em;
    margin-bottom: 50px;
  }

  .headbox .txtbox .txt p {
    color: #240A00;
    letter-spacing: .1em;
  }

  .headbox .txtbox .txt p+p {
    margin-top: 1.5em;
  }

  .facilities_items {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px 20px;
    margin: 80px 0 0;
  }

  .facilities_items .item {
    display: grid;
    grid-template-columns: 1fr;
  }

  .facilities_items .item .thumb {
    order: -1;
    aspect-ratio: 424 / 300;
    border-radius: 28px;
    overflow: hidden;
  }

  .facilities_items .item .thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }

  .facilities_items .item .ttl {
    min-width: 210px;
    width: fit-content;
    height: 39px;
    border-radius: 39px;
    margin: 18px auto 0;
    background: #fff;
    border: 1px dashed #F08A00;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    letter-spacing: .1em;
    color: #240A00;
    font-weight: 500;
    padding: 0 25px;
  }

}

@container hoikuen-single (width < 768px) {
  #hoikuen .facilities_sec {
    padding: 80px 0 0;

    .headbox {
      display: grid;
      grid-template-columns: 1fr;
      align-items: center;
      gap: 30px;
    }

    .headbox .txtbox .subttl {
      font-size: 1.8rem;
      margin-bottom: 20px;
    }

    .headbox .txtbox .txt p {
      color: #240A00;
      letter-spacing: .1em;
    }

    .headbox .txtbox .txt p+p {
      margin-top: 1.5em;
    }

    .facilities_items {
      margin: 40px 0 0;
    }
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen .facilities_sec {
    padding: 60px 0 0;
  }
}

#hoikuen .teacher_sec {
  padding: 160px 0 0;

  .headbox {
    display: grid;
    grid-template-columns: 34% 1fr;
    align-items: center;
    gap: 0 3.877%;
  }

  .headbox .thumb {
    aspect-ratio: 500 / 615;
    border-radius: 3.4%;
    overflow: hidden;
  }

  .headbox .thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }

  .headbox .txtbox .subttl {
    font-size: 3rem;
    line-height: calc(45 / 30);
    font-weight: bold;
    letter-spacing: .1em;
    margin-bottom: 50px;
  }

  .headbox .txtbox .txt p {
    color: #240A00;
    letter-spacing: .1em;
  }

  .headbox .txtbox .txt p+p {
    margin-top: 1.5em;
  }
}

@container hoikuen-single (width < 768px) {
  #hoikuen .teacher_sec {
    padding: 80px 0 0;

    .headbox {
      display: grid;
      grid-template-columns: 1fr;
      align-items: center;
      gap: 30px;
    }

    .headbox .txtbox .subttl {
      font-size: 1.8rem;
      margin-bottom: 20px;
    }

    .headbox .txtbox .txt p {
      color: #240A00;
      letter-spacing: .1em;
    }

    .headbox .txtbox .txt p+p {
      margin-top: 1.5em;
    }

    .facilities_items {
      margin: 40px 0 0;
    }
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen .teacher_sec {
    padding: 60px 0 0;
  }
}

@media only screen and (max-width: 768px) {
  #hoikuen .contents-wrap {
    border-radius: 26px;
    padding: 40px 5%;
  }

  #hoikuen .contents-wrap:before {
    display: none;
  }
}

#hoikuen .short_term_sec {
  margin: 80px 0 0;
  padding: 80px 7%;
  background: #FFF3F3;
  border-radius: 9.895vw;
  position: relative;
  z-index: 0;

  & .headbox {
    padding: 80px 50px;
    border-radius: 3.125vw;
    background: #fff;
    display: grid;
    grid-template-columns: repeat(15, 1fr);
  }

  & .headbox .item {
    grid-column: 1 / 8;
    grid-row: auto;
    padding: 30px 0 25px;
    border-top: 1px solid #D2D2D2;
    display: grid;
    align-items: center;
    grid-template-columns: 120px 1fr;
    gap: 0px 0px;
    letter-spacing: .15em;
  }

  & .headbox .item:nth-of-type(4) {
    border-bottom: 1px solid #D2D2D2;
  }

  & .headbox .item:nth-of-type(5) {
    grid-column: 1 / 16;
    grid-row: 5 / 6;
    border-top: 0;
    border-bottom: 1px solid #D2D2D2;
  }

  & .headbox .item .ttl {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  & .headbox .item .ttl:before {
    content: "";
    aspect-ratio: 1 / 1;
    width: 8px;
    border-radius: 50%;
    background: #F08A00;
  }

  & .headbox .item .dtl ul li {
    text-indent: -1em;
    padding-left: 1em;
  }

  & .headbox .item .dtl ul li+li {
    margin: 10px 0 0;
  }

  & .headbox .thumb {
    grid-column: 11 / 16;
    grid-row: 1 / 5;
    aspect-ratio: 185 / 229;
    border-radius: 1.458vw;
    overflow: hidden;
  }

  & .headbox .thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }

  & .btmbox {
    margin: 70px 0 0;
  }

  & .btmbox .ttl {
    font-size: 3rem;
    font-weight: bold;
    letter-spacing: .1em;
    color: #240A00;
    width: fit-content;
    margin: 0 auto 50px;
    padding: 0 30px;
    position: relative;
    z-index: 0;
  }

  & .btmbox .ttl:before,
  & .btmbox .ttl:after {
    content: "";
    position: absolute;
    bottom: 0;
    width: 2px;
    height: 40px;
    background: #240A00;
    border-radius: 1px;
  }

  & .btmbox .ttl:before {
    left: 0;
    transform: rotate(-25deg);
  }

  & .btmbox .ttl:after {
    right: 0;
    transform: rotate(25deg);
  }

  & .btmbox .short_term_items {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 30px;
  }

  & .btmbox .short_term_items .item {
    padding: 45px 25px;
    border-radius: 34px;
    border: 1px solid #EF7171;
    background: #fff;
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 3;
    gap: 0px;
  }

  & .btmbox .short_term_items .item .item_ttl {
    font-size: 2.2rem;
    text-align: center;
    color: #240A00;
    margin: 0 0 5px;
  }

  & .btmbox .short_term_items .item .ico {
    text-align: center;
    margin: 0 auto;
  }

  & .btmbox .short_term_items .item .txt {
    padding: 0 10px;
  }

}

@container hoikuen-single (width < 768px) {
  #hoikuen .short_term_sec {
    margin: 40px 0 0;
    padding: 50px 5% 30px;
    border-radius: 3.125vw;

    & .headbox {
      padding: 50px 5% 30px;
    }

    & .headbox .item {
      grid-column: 1 / 16;
      grid-row: auto;
      padding: 30px 0 25px;
      border-top: 1px solid #D2D2D2;
      display: grid;
      align-items: center;
      grid-template-columns: 120px 1fr;
      gap: 0px 0px;
      letter-spacing: .15em;
    }

    & .headbox .item:nth-of-type(4) {
      border-bottom: 1px solid #D2D2D2;
    }

    & .headbox .item:nth-of-type(5) {
      grid-column: 1 / 16;
      grid-row: auto;
      border-top: 0;
      border-bottom: 1px solid #D2D2D2;
    }

    & .headbox .thumb {
      grid-column: 1 / 16;
      grid-row: auto;
      aspect-ratio: 3 / 2;
      order: -1;
    }

    & .headbox .thumb .img {
      object-position: top;
    }

  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen .short_term_sec {
    padding: 40px 5% 30px;

    & .headbox {
      padding: 30px 5%;
    }

    & .headbox .item {
      grid-column: 1 / 16;
      grid-row: auto;
      padding: 30px 0 25px;
      border-top: 1px solid #D2D2D2;
      display: grid;
      align-items: center;
      grid-template-columns: 1fr;
      gap: 0px 0px;
      letter-spacing: .15em;
    }

    & .btmbox .ttl {
      font-size: 1.8rem;
      margin: 0 auto 20px;
      padding: 0 20px;
    }

    & .btmbox .ttl:before,
    & .btmbox .ttl:after {
      height: 30px;
    }

    & .btmbox .short_term_items {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
      gap: 30px;
    }

    & .btmbox .short_term_items .item {
      padding: 35px 25px;
    }

    & .btmbox .short_term_items .item .item_ttl {
      font-size: 1.8rem;
    }

    & .btmbox .short_term_items .item .txt {
      padding: 0;
    }
  }
}


/* 園長のご挨拶 */
#hoikuen.greeting .greeting_sec {
  max-width: 960px;
  width: 100%;
  margin: 0 auto;

  .thumb {
    aspect-ratio: 960 / 300;
    width: 100%;
    overflow: hidden;
    border-radius: 2.604vw;
  }

  .thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }

  .ttl {
    font-size: 30px;
    line-height: calc(45 / 30);
    letter-spacing: .1em;
    font-weight: 500;
    margin: 55px 0 30px;
  }

  .txtbox {
    line-height: calc(30 / 16);
    letter-spacing: .1em;
    font-weight: 500;
  }

  .txtbox p+p {
    margin-top: 1.5em;
  }

  .profilebox {
    width: fit-content;
    margin: 85px 0 0 auto;
  }

  .profilebox .affili {
    font-size: 1.8rem;
    letter-spacing: .1em;
  }

  .profilebox .name {
    font-size: 30px;
    line-height: calc(45 / 30);
    letter-spacing: .1em;
    font-weight: 500;
    display: flex;
    align-items: center;
    gap: 15px;
  }

  .profilebox .name .min {
    font-size: 22px;
    line-height: calc(45 / 22);
  }
}

@container hoikuen-single (width < 768px) {
  #hoikuen.greeting .greeting_sec {
    .ttl {
      font-size: 1.8rem;
      margin: 30px 0 20px 0;
    }

    .txtbox {
      font-size: 1.4rem;
    }

    .profilebox {
      margin: 40px 0 0 auto;
    }

    .profilebox .affili {
      font-size: 14px;
    }

    .profilebox .name {
      font-size: 18px;
    }

    .profilebox .name .min {
      font-size: 14px;
    }
  }
}

/* 年間行事 */
#hoikuen.schedule .schedule_sec {
  &>.ttl {
    font-size: 3rem;
    line-height: calc(45 / 30);
    font-weight: 500;
    text-align: center;
    margin: 0 0 30px;
  }

  &>.txtbox {
    font-weight: 500;
    letter-spacing: .1em;
    line-height: calc(26 / 16);
    width: fit-content;
    margin: 0 auto;
  }

  .schedule_items {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 40px;
    margin: 45px 0 0;
  }

  .schedule_items .item {
    display: flex;
    flex-direction: column;
  }

  .schedule_items .item .ttlbox {
    flex: 0 1 auto;
    border-radius: 1.45vw 1.45vw 0 0;
    color: #fff;
    padding: 30px 30px 0;
  }

  .schedule_items .item .ttlbox .en {
    font-size: 1.3rem;
    letter-spacing: .2em;
    font-weight: 600;
    font-style: italic;
    line-height: calc(18 / 13);
  }

  .schedule_items .item .ttlbox .month {
    font-size: 2rem;
    letter-spacing: .1em;
    font-weight: 600;
    line-height: calc(60 / 20);
  }

  .schedule_items .item .ttlbox .month span {
    font-size: 5.1rem;
    font-style: italic;
    line-height: calc(60 / 51);
  }

  .schedule_items .item .cont {
    flex: 1 1;
    font-size: 2rem;
    line-height: calc(30 / 20);
    letter-spacing: .01em;
    font-weight: bold;
    position: relative;
    z-index: 0;
    border-radius: 0 0 1.45vw 1.45vw;
    padding: 25px 30px 70px;
  }

  .schedule_items .item .cont .icon {
    position: absolute;
    right: 10px;
    bottom: 10px;
    z-index: -1;
  }

  .schedule_items .item._ver1 .ttlbox {
    background: #A3C418;
  }

  .schedule_items .item._ver1 .cont {
    border: 1px solid #A3C418;
  }

  .schedule_items .item._ver2 .ttlbox {
    background: #F08A00;
  }

  .schedule_items .item._ver2 .cont {
    border: 1px solid #F08A00;
  }

  .schedule_items .item._ver3 .ttlbox {
    background: #815315;
  }

  .schedule_items .item._ver3 .cont {
    border: 1px solid #815315;
  }

  .schedule_items .item._ver4 .ttlbox {
    background: #B88ECC;
  }

  .schedule_items .item._ver4 .cont {
    border: 1px solid #B88ECC;
  }

  .schedule_note {
    letter-spacing: .1em;
    font-weight: 500;
    line-height: calc(23 / 16);
    margin: 25px 0 0;
  }

  .schedule_topics {
    margin-top: 50px;
  }

  .schedule_topics .ttlbox {
    max-width: 935px;
    width: 100%;
    margin: 0 auto;
    height: 170px;
    position: relative;
    z-index: 0;
    padding: 30px 70px 0;
  }

  .schedule_topics .ttlbox:before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    z-index: -1;
    top: 0;
    left: 0;
    border-radius: 20px;
    background: url(../img/hidamarihoikuen/schedule_topics_ttlbg.png) no-repeat top / cover;
  }

  .schedule_topics .ttlbox .inr {
    display: flex;
    align-items: center;
    gap: 25px;
  }

  .schedule_topics .ttlbox .cat {
    flex-basis: 145px;
    font-size: 2rem;
    line-height: calc(26 / 20);
    letter-spacing: .15em;
    font-weight: 500;
    color: #fff;
    border-radius: 11px;
    background: #C2975A;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
  }

  .schedule_topics .ttlbox .txt {
    flex: 1 1;
    font-size: 2.5rem;
    line-height: calc(37 / 25);
    letter-spacing: .15em;
    font-weight: bold;
  }

  .schedule_topics .ttlbox .txt span {
    font-size: 2.2rem;
    line-height: calc(33 / 22);
  }

  .schedule_topics .ttlbox .img {
    aspect-ratio: 1 / 1;
    width: 158px;
    position: absolute;
    bottom: -10px;
  }

  .schedule_topics .ttlbox .img._01 {
    left: -95px;
  }

  .schedule_topics .ttlbox .img._02 {
    right: -95px;
  }

  .schedule_topics .txtbox {
    padding: 47px 190px 47px 125px;
    border-radius: 100px;
    border: 2px dashed #F08A00;
    max-width: 1060px;
    margin: 50px auto 0;
    font-size: 1.8rem;
    line-height: calc(27 / 18);
    letter-spacing: .1em;
    font-weight: 500;
    position: relative;
    z-index: 0;
  }

  .schedule_topics .txtbox .icon {
    position: absolute;
    top: 50%;
    right: 77px;
    transform: translateY(-50%);
    width: 82px;
  }
}

@container hoikuen-single (width < 980px) {
  #hoikuen.schedule .schedule_sec {
    .schedule_topics .ttlbox {
      width: 100%;
      margin: 0 auto;
      height: auto;
      position: relative;
      z-index: 0;
      padding: 30px 50px 50px;
    }

    .schedule_topics .ttlbox .img {
      width: 100px;
    }

    .schedule_topics .ttlbox .img._01 {
      left: -20px;
    }

    .schedule_topics .ttlbox .img._02 {
      right: -20px;
    }

    .schedule_topics .ttlbox .cat {
      font-size: 1.8rem;
    }

    .schedule_topics .ttlbox .txt {
      font-size: 1.8rem;
    }

    .schedule_topics .ttlbox .txt span {
      font-size: 1.6rem;
    }

    .schedule_topics .txtbox {
      padding: 30px 100px 30px 50px;
      font-size: 1.6rem;
    }

    .schedule_topics .txtbox .icon {
      right: 30px;
      width: 60px;
    }
  }
}

@container hoikuen-single (width < 768px) {
  #hoikuen.schedule .schedule_sec {
    &>.ttl {
      font-size: 1.8rem;
      margin: 0 0 20px;
    }

    .schedule_items {
      gap: 20px;
      margin: 25px 0 0;
    }

    .schedule_items .item .cont {
      font-size: 1.6rem;
      padding: 25px 20px 70px;
    }

    .schedule_note {
      margin: 15px 0 0;
    }

    .schedule_topics .ttlbox {
      padding: 20px 30px 50px;
    }

    .schedule_topics .ttlbox .inr {
      display: block;
    }

    .schedule_topics .ttlbox .img {
      width: 60px;
    }

    .schedule_topics .ttlbox .img._01 {
      left: -20px;
    }

    .schedule_topics .ttlbox .img._02 {
      right: -20px;
    }

    .schedule_topics .ttlbox .cat {
      font-size: 1.6rem;
      height: auto;
      padding: 10px;
      margin: 0 auto 10px;
    }

    .schedule_topics .ttlbox .txt {
      font-size: 1.4rem;
    }

    .schedule_topics .ttlbox .txt span {
      font-size: 1.3rem;
    }

    .schedule_topics .txtbox {
      padding: 20px;
      font-size: 1.4rem;
      margin: 20px auto 0;
      border-radius: 20px;
    }

    .schedule_topics .txtbox .icon {
      right: -10px;
      bottom: -20px;
      top: auto;
      transform: translateY(0);
      width: 60px;
    }
  }
}

#hoikuen.topics-single .topics_single {
  max-width: 1020px;
  width: 100%;
  margin: 0 auto;

  .date {
    display: block;
    font-size: 1.4rem;
    line-height: calc(20 / 14);
    letter-spacing: .05em;
    color: #240A00;
    margin: 0 0 20px 0;
  }

  .cat {
    width: 162px;
    height: 42px;
    border-radius: 21px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    letter-spacing: .15em;
    color: #FFFFFF;
    background: #240A00;
    margin: 0 0 25px 0;
  }

  .cat:hover {
    background: #F08A00;
  }

  .post-title {
    font-size: 2.2rem;
    line-height: calc(33 / 22);
    font-weight: 400;
    margin: 0 0 50px;
  }

  .post-content {
    margin: 75px 0 0;
  }

  .post-content p {
    margin: 1.5em 0 0;
  }

  .post-content:first-child {
    margin: 0;
  }

  .post-content .c_btn_3 {
    margin: 80px auto 0;
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen.topics-single .topics_single {
    .date {
      margin: 0 0 10px 0;
    }

    .cat {
      width: 140px;
      height: 30px;
      font-size: 1.4rem;
      margin: 0 0 15px 0;
    }

    .cat:hover {
      background: #F08A00;
    }

    .post-title {
      font-size: 1.8rem;
      margin: 0 0 20px;
    }

    .post-content {
      margin: 20px 0 0;
    }

    .post-content .c_btn_3 {
      margin: 40px auto 0;
    }
  }
}

#hoikuen.access .access_wrap {
  display: grid;
  align-items: center;
  grid-template-columns: 28.571% 70.23%;
  gap: 12px;
}

#hoikuen.access .access_wrap .ttlbox {
  display: flex;
  align-items: center;
  gap: 13px;
  margin: 0 0 30px;

  & .num {
    font-size: 3.5rem;
    font-weight: bold;
    line-height: calc(42 / 35);
    letter-spacing: .1em;
  }

  & .ttl {
    font-size: 2rem;
    font-weight: bold;
    line-height: calc(29 / 20);
    letter-spacing: .1em;
    color: #240A00;
  }
}

#hoikuen.access .access_wrap .headtxt {
  font-size: 1.4rem;
  line-height: calc(24 / 14);
  color: #240A00;
  margin: 0 0 10px;
}

#hoikuen.access .access_wrap .map_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 160px;
  height: 27px;
  border-radius: 14px;
  background: #F08A00;
  font-size: 1.4rem;
  letter-spacing: .05em;
  line-height: calc(20 / 14);
  color: #fff;
}

#hoikuen.access .access_wrap .map_btn._ver2 {
  background: #73CFDD;
}

#hoikuen.access .access_wrap .map_btn._ver3 {
  background: #EF7171;
}

#hoikuen.access .access_wrap .map_btn._ver4 {
  background: #B86ACB;
}

#hoikuen.access .access_wrap .map_btn:hover {
  background: #240A00;
}

#hoikuen.access .access_wrap .cont {
  margin: 35px 0 0;
  padding: 20px 0;
  border-top: 1px solid #D2D2D2;
  border-bottom: 1px solid #D2D2D2;
  font-size: 1.6rem;
  line-height: calc(23 / 16);
  letter-spacing: .1em;

  & .item+.item {
    margin-top: 20px;
  }

  & .ttl {
    font-weight: 500;
    padding-left: 1em;
    text-indent: -1em;
    margin: 0 0 5px;
  }

  & .dtl {
    padding-left: 1em;
  }

  & .access_note {
    display: block;
    font-size: 1.4rem;
    padding-left: 1em;
    text-indent: -1em;
  }
}

@container hoikuen-single (width < 1000px) {
  #hoikuen.access .access_wrap {
    display: grid;
    align-items: center;
    grid-template-columns: 1fr;
    gap: 20px;

    & .map {
      order: -1;
    }
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen.access .access_wrap .ttlbox {
    gap: 10px;
    margin: 0 0 20px;

    & .num {
      font-size: 2rem;
    }

    & .ttl {
      font-size: 1.6rem;
    }
  }

  #hoikuen.access .access_wrap .cont {
    margin: 20px 0 0;
    padding: 20px 0;
    font-size: 1.4rem;
  }
}

#hoikuen.event .category_btns {
  display: flex;
  justify-content: center;
}

#hoikuen.event .category_btns .category_btn {
  padding: 30px;
  border-radius: 28px 28px 0 0;
}

#hoikuen.event .category_btns .category_btn:hover,
#hoikuen.event .category_btns .category_btn.is-active {
  background: #FFF6E9;
}

#hoikuen.event .category_btns._ver2 .category_btn:hover,
#hoikuen.event .category_btns._ver2 .category_btn.is-active {
  background: #F3FCFE;
}

#hoikuen.event .category_btns._ver3 .category_btn:hover,
#hoikuen.event .category_btns._ver3 .category_btn.is-active {
  background: #FFF3F3;
}

#hoikuen.event .category_btns._ver4 .category_btn:hover,
#hoikuen.event .category_btns._ver4 .category_btn.is-active {
  background: #F8F1F9;
}

#hoikuen.event .category_btns .category_btn .c_sec_title_1 {
  font-size: 2.1rem;
  font-weight: bold;
  margin: 0;
}

#hoikuen.event .c_topics_cards {
  padding: 40px 90px 45px;
  background: #FFF6E9;
  border-radius: 28px;
}

#hoikuen.event .c_topics_cards._ver2 {
  background: #F3FCFE;
}

#hoikuen.event .c_topics_cards._ver3 {
  background: #FFF3F3;
}

#hoikuen.event .c_topics_cards._ver4 {
  background: #F8F1F9;
}

@container hoikuen-single (width < 768px) {
  #hoikuen.event .category_btns {
    flex-wrap: wrap;
  }

  #hoikuen.event .category_btns .category_btn {
    padding: 20px;
    border-radius: 10px;
  }

  #hoikuen.event .category_btns .category_btn .c_sec_title_1 {
    font-size: 1.6rem;
  }

  #hoikuen.event .c_topics_cards {
    padding: 20px 20px 30px;
    border-radius: 10px;
  }
}

#hoikuen.class .class_cat_btns {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 18px;
  padding: 0 1% 70px;
  padding: 0 0 70px;
  margin: 0 0 70px;
  position: relative;
  z-index: 0;

  & .btn {
    flex: 0 1 180px;
    display: flex;
    align-items: center;
    text-align: center;
    padding: 10px 0 15px;
    border-radius: 16px;
    background: #fff;
    position: relative;
    z-index: 0;
  }

  & .btn .inr {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: stretch;
    width: fit-content;
    transition: none;
  }

  & .btn .txt {
    font-size: 1.3rem;
    line-height: calc(19 / 13);
    letter-spacing: .05em;
    padding: 0 0 2px;
    margin: 0 0 2px;
    transition: all 0s;
  }

  & .btn .ttl {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: calc(27 / 18);
    letter-spacing: .1em;
    transition: all 0s;
  }

}

#hoikuen.class .class_cat_btns:after {
  content: "";
  width: 100%;
  height: 17px;
  mask: url(../img/hidamarihoikuen/ico-wave.svg) repeat-x;
  position: absolute;
  left: 0;
  bottom: 0;
}

@container hoikuen-single (width < 520px) {
  #hoikuen.class .class_cat_btns {
    gap: 18px;
    padding: 0 5% 40px;
    margin: 0 0 40px;
    position: relative;
    z-index: 0;

    & .btn {
      flex: 0 1 100%;
    }
  }
}

#hoikuen.class .class_cat_btns._ver1 {
  & .btn {
    border: 1px solid #F08A00;
    color: #240A00;
  }

  & .btn:hover {
    background: #F08A00;
    color: #fff;
  }

  & .btn .txt {
    border-bottom: 1px solid #F08A00;
  }

  & .btn:hover .txt {
    border-bottom: 1px solid #fff;
  }
}

#hoikuen.class .class_cat_btns._ver1:after {
  background: #F08A00;
}

#hoikuen.class .class_cat_btns._ver2 {
  & .btn {
    border: 1px solid #73CFDD;
    color: #240A00;
  }

  & .btn:hover {
    background: #73CFDD;
    color: #fff;
  }

  & .btn .txt {
    border-bottom: 1px solid #73CFDD;
  }

  & .btn:hover .txt {
    border-bottom: 1px solid #fff;
  }
}

#hoikuen.class .class_cat_btns._ver2:after {
  background: #73CFDD;
}

#hoikuen.class .class_cat_btns._ver4 {
  & .btn {
    border: 1px solid #B86ACB;
    color: #240A00;
  }

  & .btn:hover {
    background: #B86ACB;
    color: #fff;
  }

  & .btn .txt {
    border-bottom: 1px solid #B86ACB;
  }

  & .btn:hover .txt {
    border-bottom: 1px solid #fff;
  }
}

#hoikuen.class .class_cat_btns._ver4:after {
  background: #B86ACB;
}



@media only screen and (max-width: 1500px) {
.c_topics_cards .card {
    width: 47%;
}
#hoikuen.event .c_topics_cards {
    padding: 40px 10px 45px;
}
}
@media only screen and (max-width: 1000px) {
    #hoikuen.event .c_topics_cards {
        padding: 20px 20px 30px;
    }
.c_topics_cards .card {
    width: 100%;
}
}


/* ひだまり保育園用 */
#hoikuen.hidamarihoikuen.class .class_cat_btns {
  & .btn._0 {
    padding-left: 40px;
  }

  & .btn._1 {
    padding-left: 50px;
  }

  & .btn._2 {
    padding-left: 60px;
  }

  & .btn._3 {
    padding-left: 60px;
  }

  & .btn._4 {
    padding-left: 60px;
  }

  & .btn._5 {
    padding-left: 50px;
  }

  & .btn:before {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }

  & .btn._0:before {
    aspect-ratio: 25 / 28;
    width: 25px;
    background: url(../img/hidamarihoikuen/ico_class_cherry.png) no-repeat center / contain;
    left: 5px;
  }

  & .btn._1:before {
    aspect-ratio: 24 / 27;
    width: 24px;
    background: url(../img/hidamarihoikuen/ico_class_strawberry.png) no-repeat center / contain;
    left: 20px;
  }

  & .btn._2:before {
    aspect-ratio: 26 / 29;
    width: 26px;
    background: url(../img/hidamarihoikuen/ico_class_apple.png) no-repeat center / contain;
    left: 20px;
  }

  & .btn._3:before {
    aspect-ratio: 44 / 30;
    width: 44px;
    background: url(../img/hidamarihoikuen/ico_class_rainbow.png) no-repeat center / contain;
    left: 10px;
  }

  & .btn._4:before {
    aspect-ratio: 37 / 26;
    width: 37px;
    background: url(../img/hidamarihoikuen/ico_class_sky.png) no-repeat center / contain;
    left: 10px;
  }

  & .btn._5:before {
    aspect-ratio: 40 / 37;
    width: 40px;
    background: url(../img/hidamarihoikuen/ico_class_sun.png) no-repeat center / contain;
    left: 10px;
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen.hidamarihoikuen.class .class_cat_btns {
    & .btn {
      justify-content: center;
    }

    & .btn._0 {
      padding-left: 0;
    }

    & .btn._1 {
      padding-left: 0;
    }

    & .btn._2 {
      padding-left: 0;
    }

    & .btn._3 {
      padding-left: 0;
    }

    & .btn._4 {
      padding-left: 0;
    }

    & .btn._5 {
      padding-left: 0;
    }

    & .btn._0:before {
      left: 20px;
    }

    & .btn._1:before {
      left: 20px;
    }

    & .btn._2:before {
      left: 20px;
    }

    & .btn._3:before {
      left: 20px;
    }

    & .btn._4:before {
      left: 20px;
    }

    & .btn._5:before {
      left: 20px;
    }
  }
}

/* 夢ひだまり保育園 */
#hoikuen.yumehidamarihoikuen.class .class_cat_btns {
  & .btn._0 {
    padding-left: 55px;
  }

  & .btn._1 {
    padding-left: 65px;
  }

  & .btn._2 {
    padding-left: 65px;
  }

  & .btn:before {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }

  & .btn._0:before {
    aspect-ratio: 39 / 42;
    width: 39px;
    background: url(../img/yumehidamarihoikuen/ico_class_peach.png) no-repeat center / contain;
    left: 10px;
  }

  & .btn._1:before {
    aspect-ratio: 50 / 49;
    width: 50px;
    background: url(../img/yumehidamarihoikuen/ico_class_yuri.png) no-repeat center / contain;
    left: 10px;
  }

  & .btn._2:before {
    aspect-ratio: 48 / 51;
    width: 48px;
    background: url(../img/yumehidamarihoikuen/ico_class_sakura.png) no-repeat center / contain;
    left: 10px;
  }
}

/* きらりひだまり保育園 */
#hoikuen.kirari-hidamarihoikuen.class .class_cat_btns {
  & .btn._0 {
    padding-left: 55px;
  }

  & .btn._1 {
    padding-left: 55px;
  }

  & .btn._2 {
    padding-left: 55px;
  }

  & .btn:before {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }

  & .btn._0:before {
    aspect-ratio: 52 / 58;
    width: 35px;
    background: url(../img/kirari-hidamari/ico_class_lemon.png) no-repeat center / contain;
    left: 10px;
  }

  & .btn._1:before {
    aspect-ratio: 52 / 58;
    width: 34px;
    background: url(../img/kirari-hidamari/ico_class_orange.png) no-repeat center / contain;
    left: 10px;
  }

  & .btn._2:before {
    aspect-ratio: 52 / 58;
    width: 28px;
    background: url(../img/kirari-hidamari/ico_class_melon.png) no-repeat center / contain;
    left: 10px;
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen.kirari-hidamarihoikuen.class .class_cat_btns {
    & .btn {
      justify-content: center;
    }

    & .btn._0 {
      padding-left: 0;
    }

    & .btn._1 {
      padding-left: 0;
    }

    & .btn._2 {
      padding-left: 0;
    }

    & .btn._0:before {
      left: 40px;
    }

    & .btn._1:before {
      left: 40px;
    }

    & .btn._2:before {
      left: 40px;
    }
  }
}

#hoikuen.class .contents-wrap {
  border-radius: 36px 0 36px 36px;
  padding: 80px 0 0;
}

#hoikuen.class .sec {
  padding-bottom: 16.666vw;
  background: #fff;
  padding-inline: 70px;
  position: relative;
  z-index: 0;
}

#hoikuen.class .sec:last-of-type {
  border-radius: 0 0 36px 36px;
  padding-bottom: 80px;
}

#hoikuen.class .sec._bg_ver1 {
  background: #FFFAD8;
}

#hoikuen.class .sec._bg_ver2 {
  background: #F3FCFE;
}

#hoikuen.class .sec._bg_ver4 {
  background: #FAEEFC;
}

#hoikuen.class .sec._obj:before {
  content: "";
  width: 100%;
  height: 11.25vw;
  position: absolute;
  top: -10vw;
  left: 0;
  mask: url(../img/hidamarihoikuen/sec_obj_mask.svg) no-repeat top / cover;
}

#hoikuen.class .sec._obj._obj_col1:before {
  background: #FFFAD8;
}

#hoikuen.class .sec._obj._obj_col2:before {
  background: #F3FCFE;
}

#hoikuen.class .sec._obj._obj_col4:before {
  background: #FAEEFC;
}

#hoikuen.class .sec._obj._obj_col_wh:before {
  background: #fff;
}

@container hoikuen-single (width < 768px) {
  #hoikuen.class .contents-wrap {
    border-radius: 26px;
    padding: 40px 0 0;
  }

  #hoikuen.class .sec {
    padding-inline: 5%;
  }

  #hoikuen.class .sec:last-of-type {
    border-radius: 0 0 26px 26px;
    padding-bottom: 40px;
  }

  #hoikuen.class .sec._obj:before {
    height: 13vw;
    top: -12vw;
  }
}

#hoikuen.class .sec_ttlbox {
  width: 415px;
  height: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  background: #fff;
  border-radius: 16px;
  border-width: 1px;
  border-style: solid;
  position: relative;
  z-index: 0;
  color: #240A00;
  margin: 0 auto 50px;

  & .cat {
    font-size: 1.6rem;
    font-weight: 500;
    letter-spacing: .05em;
  }

  & .name {
    font-size: 3rem;
    line-height: calc(45 / 30);
    font-weight: 700;
    letter-spacing: .05em;
  }
}

#hoikuen.class .sec_ttlbox:before {
  content: "";
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
}

#hoikuen.class .sec_ttlbox._ver1 {
  border-color: #F08A00;
}

#hoikuen.class .sec_ttlbox._ver2 {
  border-color: #73CFDD;
}

#hoikuen.class .sec_ttlbox._ver4 {
  border-color: #B86ACB;
}

#hoikuen.class .sec>.ttlbox {
  width: 415px;
  height: 100px;
  border-radius: 50px;
  border: 3px dashed #F08A00;
  margin: 0 auto 75px;
  padding: 7px;

  & .txt {
    width: 100%;
    height: 100%;
    background: #F08A00;
    font-size: 3.5rem;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 40px;
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen.class .sec_ttlbox {
    width: 100%;
    height: 75px;
    margin: 0 auto 30px;

    & .cat {
      font-size: 1.2rem;
    }

    & .name {
      font-size: 2rem;
    }
  }

  #hoikuen.class .sec>.ttlbox {
    width: 100%;
    height: 80px;
    border: 2px dashed #F08A00;
    margin: 0 auto 20px;
    padding: 5px;

    & .txt {
      font-size: 2rem;
    }
  }
}

/* きらりひだまり保育園用 */
#hoikuen.class.kirari-hidamarihoikuen .sec._class00 .sec_ttlbox:before {
  aspect-ratio: 52 / 58;
  width: 52px;
  background: url(../img/kirari-hidamari/ico_class_lemon.png) no-repeat center / contain;
  left: 70px;
}

#hoikuen.class.kirari-hidamarihoikuen .sec._class01 .sec_ttlbox:before {
  aspect-ratio: 52 / 58;
  width: 52px;
  background: url(../img/kirari-hidamari/ico_class_orange.png) no-repeat center / contain;
  left: 70px;
}

#hoikuen.class.kirari-hidamarihoikuen .sec._class02 .sec_ttlbox:before {
  aspect-ratio: 52 / 58;
  width: 52px;
  background: url(../img/kirari-hidamari/ico_class_melon.png) no-repeat center / contain;
  left: 70px;
}

@container hoikuen-single (width < 520px) {
  #hoikuen.class.kirari-hidamarihoikuen .sec._class00 .sec_ttlbox:before {
    left: 50px;
  }

  #hoikuen.class.kirari-hidamarihoikuen .sec._class01 .sec_ttlbox:before {
    left: 50px;
  }

  #hoikuen.class.kirari-hidamarihoikuen .sec._class02 .sec_ttlbox:before {
    width: 40px;
    left: 50px;
  }
}

/* ゆめひだまり保育園用 */
#hoikuen.class.yumehidamarihoikuen .sec._class00 .sec_ttlbox:before {
  aspect-ratio: 39 / 42;
  width: 59px;
  background: url(../img/yumehidamarihoikuen/ico_class_peach.png) no-repeat center / contain;
  left: 70px;
}

#hoikuen.class.yumehidamarihoikuen .sec._class01 .sec_ttlbox:before {
  aspect-ratio: 50 / 49;
  width: 69px;
  background: url(../img/yumehidamarihoikuen/ico_class_yuri.png) no-repeat center / contain;
  left: 70px;
}

#hoikuen.class.yumehidamarihoikuen .sec._class02 .sec_ttlbox:before {
  aspect-ratio: 48 / 51;
  width: 63px;
  background: url(../img/yumehidamarihoikuen/ico_class_sakura.png) no-repeat center / contain;
  left: 70px;
}

/* ひだまり保育園用 */
#hoikuen.class.hidamarihoikuen .sec._class00 .sec_ttlbox:before {
  aspect-ratio: 25 / 28;
  width: 52px;
  background: url(../img/hidamarihoikuen/ico_class_cherry.png) no-repeat center / contain;
}

#hoikuen.class.hidamarihoikuen .sec._class01 .sec_ttlbox:before {
  aspect-ratio: 24 / 27;
  width: 52px;
  background: url(../img/hidamarihoikuen/ico_class_strawberry.png) no-repeat center / contain;
}

#hoikuen.class.hidamarihoikuen .sec._class02 .sec_ttlbox:before {
  aspect-ratio: 26 / 29;
  width: 52px;
  background: url(../img/hidamarihoikuen/ico_class_apple.png) no-repeat center / contain;
}

#hoikuen.class.hidamarihoikuen .sec._class03 .sec_ttlbox:before {
  aspect-ratio: 44 / 30;
  width: 87px;
  background: url(../img/hidamarihoikuen/ico_class_rainbow.png) no-repeat center / contain;
}

#hoikuen.class.hidamarihoikuen .sec._class04 .sec_ttlbox:before {
  aspect-ratio: 37 / 26;
  width: 85px;
  background: url(../img/hidamarihoikuen/ico_class_sky.png) no-repeat center / contain;
}

#hoikuen.class.hidamarihoikuen .sec._class05 .sec_ttlbox:before {
  aspect-ratio: 40 / 37;
  width: 69px;
  background: url(../img/hidamarihoikuen/ico_class_sun.png) no-repeat center / contain;
}


#hoikuen.class .sec .headbox {
  display: grid;
  align-items: center;
  grid-template-columns: 38% 1fr;
  gap: 60px;

  & .thumb {
    aspect-ratio: 50 / 61;
    border-radius: 1.458vw;
    overflow: hidden;
  }

  & .thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }

  & .txtbox .head_ttl {
    font-size: 3rem;
    line-height: calc(45 / 30);
    letter-spacing: .1em;
    font-weight: 700;
    margin: 0 0 28px;
  }

  & .txtbox .txt {
    line-height: calc(26 / 16);
    letter-spacing: .1em;
  }

  & .txtbox .detailbox {
    max-width: 650px;
    width: 100%;
    padding: 45px 55px;
    border-radius: 1.458vw;
    border-width: 1px;
    border-style: solid;
    margin: 35px 0 0;
    font-weight: 500;
  }

  & .txtbox .detailbox .ttl {
    text-indent: -1em;
    padding-left: 1em;
  }

  & .txtbox .detailbox .txt {
    padding-left: 1em;
  }

  & .txtbox .detailbox .txt+.txt {
    margin-top: 1.5em;
  }

  & .txtbox .detailbox._ver1 {
    border-color: #F08A00;
  }

  & .txtbox .detailbox._ver2 {
    border-color: #73CFDD;
  }

  & .txtbox .detailbox._ver3 {
    border-color: #EF7171;
  }

  & .txtbox .detailbox._ver4 {
    border-color: #B86ACB;
  }
}

@container hoikuen-single (width < 768px) {
  #hoikuen.class .sec .headbox {
    grid-template-columns: 1fr;
    gap: 20px;

    & .thumb {
      aspect-ratio: 3 / 2;
    }

    & .txtbox .head_ttl {
      font-size: 1.8rem;
      margin: 0 0 28px;
    }

    & .txtbox .detailbox {
      padding: 25px 20px;
      margin: 35px 0 0;
    }
  }
}

#hoikuen.class .sec .schedule_box {
  display: grid;
  align-items: start;
  grid-template-columns: 1fr 38%;
  gap: 67px;
  margin: 90px 0 0;

  & .thumb {
    aspect-ratio: 50 / 61;
    border-radius: 1.458vw;
    overflow: hidden;
  }

  & .thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }

  & .txtbox>.ttl {
    font-size: 3rem;
    line-height: calc(45 / 30);
    letter-spacing: .1em;
    margin: 0 0 22px;
  }

  & .schedule_tbl .item {
    display: grid;
    grid-template-columns: 300px 1fr;
    position: relative;
    z-index: 0;
  }

  & .schedule_tbl .item>.ttl {
    display: grid;
    grid-template-columns: 120px 1fr;
    font-size: 1.6rem;
    font-weight: bold;
    letter-spacing: .1em;
  }

  & .schedule_tbl .item:not(:last-of-type) {
    padding-bottom: 10px;
  }

  & .schedule_tbl .item:not(:last-of-type):before {
    content: "";
    width: 1px;
    height: calc(100% + 20px);
    position: absolute;
    left: 90px;
    top: 0;
  }

  & .schedule_tbl._ver1 .item:not(:last-of-type):before {
    background: #F08A00;
  }

  & .schedule_tbl._ver2 .item:not(:last-of-type):before {
    background: #73CFDD;
  }

  & .schedule_tbl._ver3 .item:not(:last-of-type):before {
    background: #EF7171;
  }

  & .schedule_tbl._ver4 .item:not(:last-of-type):before {
    background: #B86ACB;
  }

  & .schedule_tbl .item>.dtl {
    font-size: 1.4rem;
    line-height: calc(20 / 14);
    letter-spacing: .05em;
    font-weight: 500;
  }

  & .schedule_tbl .item>.dtl .inr {
    display: flex;
  }

  & .schedule_tbl .item>.dtl>*:not(:first-child) {
    margin: 5px 0 0;
  }

  & .schedule_tbl .item>.dtl .original_program {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 95px;
    height: 40px;
    border-radius: 5px;
    font-size: 1.2rem;
    line-height: calc(16 / 12);
    font-weight: 500;
    letter-spacing: .05em;
    color: #fff;
    background: #3586D0;
    flex: 0 0 auto;
    margin: 0 10px 0 0;
  }

  & .schedule_tbl .item:after {
    content: "";
  }

  & .schedule_tbl._ver1 .item:after {
    background: #F08A00;
  }

  & .schedule_tbl._ver2 .item:after {
    background: #73CFDD;
  }

  & .schedule_tbl._ver3 .item:after {
    background: #EF7171;
  }

  & .schedule_tbl._ver4 .item:after {
    background: #B86ACB;
  }
}

@container hoikuen-single (width < 980px) {
  #hoikuen.class .sec .schedule_box {
    & .schedule_tbl .item {
      align-items: start;
      grid-template-columns: 200px 1fr;
    }

    & .schedule_tbl .item>.ttl {
      grid-template-columns: 1fr;
    }

    & .schedule_tbl .item>.ttl .time {
      font-size: 1.2rem;
    }

    & .schedule_tbl .item:not(:last-of-type):before {
      left: 175px;
    }
  }
}

@container hoikuen-single (width < 768px) {
  #hoikuen.class .sec .schedule_box {
    grid-template-columns: 1fr;
    gap: 20px;

    & .thumb {
      order: -1;
      aspect-ratio: 3 / 2;
    }

    & .txtbox>.ttl {
      font-size: 1.8rem;
      margin: 0 0 20px;
    }

    & .txtbox .head_ttl {
      font-size: 1.8rem;
      margin: 0 0 28px;
    }
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen.class .sec .schedule_box {
    margin: 40px 0 0;

    & .schedule_tbl .item {
      display: grid;
      grid-template-columns: 1fr;
    }

    & .schedule_tbl .item {
      padding-left: 20px;
    }

    & .schedule_tbl .item:not(:last-of-type) {
      padding-bottom: 20px;
    }

    & .schedule_tbl .item>.ttl {
      margin: 0 0 10px;
    }

    & .schedule_tbl .item:not(:last-of-type):before {
      height: 100%;
      left: 4px;
      top: 5px;
    }

    & .schedule_tbl .item:after {
      aspect-ratio: 1 / 1;
      width: 10px;
      position: absolute;
      left: 0;
      top: 0;
      border-radius: 50%;
    }

    & .schedule_tbl .item>.dtl .inr {
      display: block;
    }

    & .schedule_tbl .item>.dtl .inr>*:not(:first-child) {
      margin: 5px 0 0;
    }
  }
}

#hoikuen.class .sec .gallery_box {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px 25px;
  margin: 80px 0 0;

  & .item {
    aspect-ratio: 106 / 75;
    border-radius: 1.458vw;
    overflow: hidden;
  }

  & .item .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }
}

@container hoikuen-single (width < 520px) {
  #hoikuen.class .sec .gallery_box {
    margin: 50px 0 0;
  }
}


/* -----------------------------------------------------------
  個人情報保護方針
----------------------------------------------------------- */

/* 下層ページは body#privacy.lower のときに適用 */
#privacy {

  /* 個人情報保護方針ページのデザイン */
  .privacy-policy {
    max-width: 1200px;
    /* 中央寄せのための最大幅 */
    margin: 0 auto;
    color: #240A00;
  }

  /* 説明テキスト */
  .privacy-policy__description {
    font-size: 1.6rem;
    line-height: 1.8;
    margin-bottom: 30px;
  }

  /* 区切り線 */
  .privacy-policy__separator {
    border-top: 1px dashed #f39800;
    margin: 30px 0;
  }

  /* 見出し */
  .privacy-policy__heading {
    font-size: 1.8rem;
    font-weight: bold;
    margin-top: 35px;
    margin-bottom: 15px;
    text-indent: -1em;
    padding-left: 1em;
  }

  .privacy-policy__content {
    padding-left: 1.5em;
  }

  /* リスト（箇条書き） */
  .privacy-policy__list {
    list-style: none;
    padding: 0;
    margin: 15px 0 0;
  }

  .privacy-policy__list li {
    position: relative;
    padding-left: 20px;
    line-height: 1.8;
  }

  /* リストの先頭にオレンジ色の丸アイコンを付与 */
  .privacy-policy__list li::before {
    content: "●";
    color: #f39800;
    font-size: 0.8rem;
    position: absolute;
    left: 0;
    top: 5px;
  }
}

/* -----------------------------------------------------------
  よくあるご質問
----------------------------------------------------------- */
#faq {
  & .faq_wrap {
    max-width: 1195px;
    width: 100%;
    margin: 0 auto;
  }

  & .faq_wrap .faq_item {
    letter-spacing: .1em;
  }

  & .faq_wrap .faq_item>* {
    transition: none;
  }

  & .faq_wrap .faq_item+.faq_item {
    margin-top: 55px;
  }

  & .faq_wrap .faq_item__ttl {
    color: #F08A00;
    font-weight: bold;
    padding: 0 85px 30px 65px;
    border-bottom: 2px dashed #F08A00;
    position: relative;
    z-index: 0;
  }

  & .faq_wrap .faq_item__ttl .icon {
    aspect-ratio: 1 / 1;
    position: absolute;
    width: 30px;
    border-radius: 50%;
    background: #F08A00;
    border: 1px solid #F08A00;
    bottom: 20px;
    right: 0;
  }

  & .faq_wrap .faq_item__ttl .icon:before,
  & .faq_wrap .faq_item__ttl .icon:after {
    content: "";
    width: 15px;
    height: 2px;
    background: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border-radius: 1px;
    transition: .4s all ease;
  }

  & .faq_wrap .faq_item__ttl .icon:after {
    transform: translate(-50%, -50%) rotate(-90deg);
  }

  & .faq_wrap .faq_item__ttl .icon.is-active {
    background: #fff;
  }

  & .faq_wrap .faq_item__ttl .icon.is-active:before,
  & .faq_wrap .faq_item__ttl .icon.is-active:after {
    background: #F08A00;
  }

  & .faq_wrap .faq_item__ttl .icon.is-active:after {
    transform: translate(-50%, -50%) rotate(0deg);
  }

  & .faq_wrap .faq_item__content {
    color: #240A00;
    padding: 30px 85px 0 65px;
    position: relative;
    z-index: 0;
  }

  & .faq_wrap .faq_item__ttl:before,
  & .faq_wrap .faq_item__content:before {
    font-family: "Inter", sans-serif;
    font-size: 3.5rem;
    font-weight: bold;
    position: absolute;
    left: 12px;
  }

  & .faq_wrap .faq_item__ttl:before {
    content: "Q";
    color: #F08A00;
    bottom: 20px;
  }

  & .faq_wrap .faq_item__content:before {
    content: "A";
    color: #240A00;
    top: 20px;
  }
}

/* -----------------------------------------------------------
  保育内容
----------------------------------------------------------- */
#program .rightColumn {
  container-name: program-wrap;
  container-type: inline-size;
}

#program .goals_sec {
  & .thumb {
    aspect-ratio: 1316 / 415;
    border-radius: 50px;
    overflow: hidden;
    margin: 0 0 60px;

    .img {
      object-fit: cover;
      width: 100%;
      height: 100%;
    }
  }

  & .subttl {
    font-size: 3rem;
    line-height: calc(45 / 30);
    letter-spacing: .1em;
    font-weight: bold;
    text-align: center;
    color: #240A00;
    margin: 0 0 30px;
  }

  & .contents {
    padding: 80px 60px;
    border-radius: 3.645vw;
    background: #FFFFEF;
  }

  & .contents .ttl {
    font-size: 4rem;
    line-height: calc(60 / 40);
    text-align: center;
    letter-spacing: .1em;
    font-weight: bold;
    color: #240A00;
    width: fit-content;
    margin: 0 auto 60px;
    padding: 0 55px;
    position: relative;
    z-index: 0;
  }

  & .contents .ttl:before,
  & .contents .ttl:after {
    content: "";
    width: 2px;
    height: 50px;
    border-radius: 2px;
    background: #240A00;
    position: absolute;
    bottom: 0;
  }

  & .contents .ttl:before {
    left: 0;
    transform: rotate(-15deg);
  }

  & .contents .ttl:after {
    right: 0;
    transform: rotate(15deg);
  }

  & .contents .inr {
    display: grid;
    align-items: center;
    grid-template-columns: 600px 1fr;
    gap: 45px;
  }

  & .contents .inr .txtbox {
    padding: 60px 40px;
    background: #fff;
    border-radius: 3.02vw;
    letter-spacing: .1em;
    font-weight: 500;
  }

  & .contents .inr .txtbox .txt+.txt {
    margin-top: 60px;
  }

  & .contents .inr .txtbox .txt span {
    font-size: 2.2rem;
    line-height: calc(30 / 20);
    font-weight: bold;
  }
}

#program .original_program_sec {
  padding: 50px 0 0;

  &>.subttl {
    max-width: 800px;
    width: 100%;
    margin: 0 auto 20px;
  }

  &>.sec_copy {
    font-weight: 500;
    letter-spacing: .1em;
    line-height: calc(26 / 16);
    text-align: center;
    margin: 0 0 50px;
  }

  & .program_btnbox {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 15px;
  }

  & .program_btnbox .program_btn {
    padding: 0 50px 0 20px;
    letter-spacing: .04em;
  }

  & .program_btnbox .program_btn * {
    transition: 0s;
  }

  & .program_btnbox .program_btn .num {
    font-size: 2.5rem;
    font-weight: bold;
    margin: 0 15px 0 0;
    letter-spacing: .1em;
  }

  & .program_btnbox .program_btn .min {
    font-size: 1.4rem;
  }
}

#program .program_container {
  padding: 70px 60px;
  border: 1px solid #F08A00;
  border-radius: 22px;
  margin: 70px 0 0;

  & .headbox {
    display: grid;
    grid-template-columns: 390px 1fr;
    gap: 60px;
    margin: 0 0 50px;
    color: #240A00;
  }

  & .headbox .head_ttl {
    display: flex;
    align-items: center;
    gap: 20px;
    letter-spacing: .1em;
  }

  & .headbox .head_ttl .num {
    font-size: 5.2rem;
    line-height: calc(62 / 52);
  }

  & .headbox .head_ttl .txt {
    font-size: 3.8rem;
    line-height: calc(56 / 38);
  }

  & .headbox .head_ttl .txt .min {
    font-size: 2.8rem;
    display: block;
  }

  & .contents {
    display: grid;
    grid-template-columns: 390px 1fr;
    gap: 60px;
    color: #240A00;
  }

  & .contents .thumb {
    aspect-ratio: 50 / 61;
    border-radius: 1.458vw;
    overflow: hidden;
  }

  & .contents .thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }

  & .contents .program_item+.program_item {
    margin: 25px 0 0;
  }

  & .contents .program_item>.ttl {
    font-size: 2rem;
    line-height: calc(29 / 20);
    font-weight: bold;
    letter-spacing: .1em;
    text-indent: -1.5em;
    padding-left: 1.5em;
  }

  & .contents .dtl_box {
    padding-left: 1.75em;
    margin: 10px 0 0;
  }

  & .contents .dtl_box .dtl_item+.dtl_item {
    margin: 1em 0 0;
  }

  & .contents .dtl_box .dtl_item .dtl_ttl {
    font-weight: bold;
  }

  & .gallery_box {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 20px 10px;
    margin: 40px 0 0;

    & .item {
      aspect-ratio: 106 / 75;
      border-radius: 1.458vw;
      overflow: hidden;
    }

    & .item .img {
      object-fit: cover;
      width: 100%;
      height: 100%;
    }
  }
}

#program .fee_sec {
  padding: 80px 0 0;

  & .sec_copy {
    line-height: calc(26 / 16);
    letter-spacing: .1em;
  }

  & .sec_copy+.sec_copy {
    margin-top: 1.5em;
  }

  & .program_com_box {
    margin-top: 50px;
  }
}

#program .support_sec {
  padding: 80px 0 0;

  & .support_contents+.support_contents {
    margin-top: 60px;
  }

  & .support_cont {
    display: grid;
    grid-template-columns: 390px 1fr;
    gap: 60px;
  }

  & .support_cont .thumb {
    aspect-ratio: 50 / 61;
    border-radius: 1.458vw;
    overflow: hidden;
  }

  & .support_cont .thumb .img {
    object-fit: cover;
    width: 100%;
    height: 100%;
  }

  & .support_cont .txtbox p {
    font-size: 1.6rem;
    line-height: calc(26 / 16);
    letter-spacing: .1em;
    color: #240A00;
  }

  & .support_cont .btnbox {
    margin: 40px 0 0;
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
  }

  & .support_cont .btnbox .btn {
    max-width: 365px;
    width: 100%;
    padding: 15px 35px;
    color: #fff;
    font-size: 1.5rem;
    letter-spacing: .1em;
    border-radius: 50px;
    background: #F08A00;
    border: 1px solid #F08A00;
    position: relative;
    z-index: 0;
  }

  & .support_cont .btnbox .btn:after {
    content: "";
    width: 14px;
    height: 8px;
    background: #fff;
    mask: url(../img/common/ico_chevron_down.svg) no-repeat center / contain;
    position: absolute;
    top: 50%;
    right: 25px;
    transform: translateY(-50%) rotate(-90deg);
  }

  & .support_cont .btnbox .btn:hover {
    background: #240A00;
  }

  & .support_cont .btnbox .btn .min {
    font-size: 1.4rem;
  }
}

#program .program_com_box {
  padding: 40px 60px;
  border: 1px solid #F08A00;
  border-radius: 1.458vw;

  & .program_com_item+.program_com_item {
    margin-top: 35px;
  }

  & .program_com_ttl {
    font-size: 2rem;
    line-height: calc(29 / 20);
    font-weight: bold;
    letter-spacing: .1em;
    text-indent: -1.5em;
    padding-left: 1.5em;
  }

  & .program_com_cont {
    padding-left: 1.75em;
    margin: 10px 0 0;
  }

  & .program_com_tbl {
    display: grid;
    grid-template-columns: 1fr;
    gap: 25px;
  }

  & .program_com_tbl .program_com_tbl_item {
    padding-bottom: 25px;
    border-bottom: 1px solid #D2D2D2;
    display: grid;
    grid-template-columns: 190px 1fr;
    align-items: start;
    gap: 40px;
  }

  & .program_com_tbl .program_com_tbl_item:first-of-type {
    padding-top: 25px;
    border-top: 1px solid #D2D2D2;
  }

  & .program_com_tbl .program_com_tbl_ttl {
    display: grid;
    grid-template-columns: 8px 1fr;
    gap: 11px;
    align-items: center;
    font-weight: 500;
  }

  & .program_com_tbl .program_com_tbl_ttl:before {
    content: "";
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    background: #F08A00;
  }
}

#program .program_com_notes {
  margin: 30px 0 0;
  line-height: calc(24 / 16);

  &>.item {
    position: relative;
    z-index: 0;
    padding-left: 14px;
  }

  &>.item:before {
    content: "";
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: #F08A00;
    position: absolute;
    left: 0;
    top: .5em;
  }

  & .sub_items>.item {
    text-indent: -1em;
    padding-left: 2em;
  }
}

@container program-wrap (max-width: 768px) {
  #program .goals_sec {
    & .thumb {
      aspect-ratio: 6 / 3;
      border-radius: 20px;
      margin: 0 0 25px;
    }

    & .subttl {
      font-size: 1.8rem;
      margin: 0 0 20px;
    }

    & .contents {
      padding: 30px 15px;
    }

    & .contents .ttl {
      font-size: 2rem;
      margin: 0 auto 20px;
      padding: 0 30px;
    }

    & .contents .ttl:before,
    & .contents .ttl:after {
      width: 2px;
      height: 30px;
      border-radius: 2px;
    }

    & .contents .inr {
      grid-template-columns: 1fr;
      gap: 20px;
    }

    & .contents .inr .txtbox {
      padding: 30px 15px;
    }

    & .contents .inr .imgbox {
      order: -1;
    }

    & .contents .inr .imgbox .img {
      display: block;
      max-width: 400px;
      width: 100%;
      margin: 0 auto;
    }

    & .contents .inr .txtbox .txt+.txt {
      margin-top: 20px;
    }

    & .contents .inr .txtbox .txt span {
      font-size: 1.8rem;
    }
  }

  #program .program_container {
    padding: 30px 20px;
    margin: 40px 0 0;

    & .headbox {
      grid-template-columns: 1fr;
      gap: 20px;
      margin: 0 0 40px;
    }

    & .headbox .head_ttl {
      gap: 10px;
    }

    & .headbox .head_ttl .num {
      font-size: 3rem;
    }

    & .headbox .head_ttl .txt {
      font-size: 2rem;
    }

    & .headbox .head_ttl .txt .min {
      font-size: 1.6rem;
    }

    & .contents {
      grid-template-columns: 1fr;
      gap: 20px;
    }

    & .contents .thumb {
      aspect-ratio: 3 / 2;
    }

    & .contents .program_item+.program_item {
      margin: 20px 0 0;
    }

    & .contents .program_item>.ttl {
      font-size: 1.8rem;
    }

    & .contents .dtl_box .dtl_item+.dtl_item {
      margin: 1em 0 0;
    }

    & .contents .dtl_box .dtl_item .dtl_ttl {
      font-weight: bold;
    }

    & .gallery_box {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
      gap: 20px 25px;
      margin: 40px 0 0;

      & .item {
        aspect-ratio: 106 / 75;
        border-radius: 1.458vw;
        overflow: hidden;
      }

      & .item .img {
        object-fit: cover;
        width: 100%;
        height: 100%;
      }
    }
  }

  #program .fee_sec {
    padding: 40px 0 0;

    & .program_com_box {
      margin-top: 20px;
    }
  }

  #program .program_com_box {
    padding: 20px 15px;
    border: 1px solid #F08A00;
    border-radius: 1.458vw;

    & .program_com_item+.program_com_item {
      margin-top: 20px;
    }

    & .program_com_ttl {
      font-size: 1.8rem;
    }

    & .program_com_tbl {
      display: grid;
      grid-template-columns: 1fr;
      gap: 25px;
    }

    & .program_com_tbl .program_com_tbl_item {
      padding-bottom: 25px;
      grid-template-columns: 1fr;
      gap: 10px;
    }
  }

  #program .support_sec {
    padding: 40px 0 0;

    & .support_contents+.support_contents {
      margin-top: 40px;
    }

    & .support_cont {
      grid-template-columns: 1fr;
      gap: 20px;
    }

    & .support_cont .thumb {
      aspect-ratio: 3 / 2;
    }

    & .support_cont .txtbox p {
      font-size: 1.4rem;
    }

    & .support_cont .btnbox {
      margin: 20px 0 0;
    }

    & .support_cont .btnbox .btn {
      max-width: 365px;
      width: 100%;
      padding: 15px 35px;
      color: #fff;
      font-size: 1.5rem;
      letter-spacing: .1em;
      border-radius: 50px;
      background: #F08A00;
      border: 1px solid #F08A00;
      position: relative;
      z-index: 0;
    }

    & .support_cont .btnbox .btn:after {
      content: "";
      width: 14px;
      height: 8px;
      background: #fff;
      mask: url(../img/common/ico_chevron_down.svg) no-repeat center / contain;
      position: absolute;
      top: 50%;
      right: 25px;
      transform: translateY(-50%) rotate(-90deg);
    }

    & .support_cont .btnbox .btn:hover {
      background: #240A00;
    }

    & .support_cont .btnbox .btn .min {
      font-size: 1.4rem;
    }
  }

}

@container program-wrap (max-width: 520px) {
  #program .goals_sec {
    & .contents .ttl {
      font-size: 1.8rem;
      padding: 0 20px;
    }
  }

  #program .original_program_sec {
    padding: 30px 0;

    & .gallery_box {
      grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    }
  }
}

/* -----------------------------------------------------------
  採用情報
----------------------------------------------------------- */
#recruit .singleColumn {
  container-name: recruit-wrap;
  container-type: inline-size;
}

#recruit .recruit_sec {
  & .recruit_container {
    padding: 70px;
    border-radius: 28px;
    border-width: 1px;
    border-style: solid;
  }

  & .recruit_container._ver1 {
    border-color: #F08A00;
  }

  & .recruit_container._ver2 {
    border-color: #67B70B;
  }

  & .recruit_container+.recruit_container {
    margin-top: 80px;
  }

  & .recruit_contents+.recruit_contents {
    margin-top: 40px;
  }

  & .recruit_contents .btn {
    margin-top: 60px;
  }

  & .recruit_contents_ttl {
    font-size: 2rem;
    margin: 0 0 25px;
    padding-bottom: 15px;
    border-bottom: 1px solid #D2D2D2;
  }

  & .recruit_tbl {
    display: grid;
    grid-template-columns: 1fr;
    gap: 25px;
  }

  & .recruit_tbl .item {
    padding-bottom: 25px;
    border-bottom: 1px solid #D2D2D2;
    display: grid;
    grid-template-columns: 185px 1fr;
    align-items: start;
    gap: 30px;
  }

  & .recruit_tbl .item._first {
    border-bottom: 2px dashed;
  }

  & .recruit_tbl .item._first._ver1 {
    border-color: #F08A00;
  }

  & .recruit_tbl .item._first._ver2 {
    border-color: #67B70B;
  }

  & .recruit_tbl .ttl {
    display: grid;
    grid-template-columns: 8px 1fr;
    gap: 11px;
    align-items: center;
    font-weight: 500;
  }

  & .recruit_tbl .ttl:before {
    content: "";
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    background: #F08A00;
  }

  & .recruit_tbl .dtl .type {
    display: flex;
    align-items: center;
    gap: 20px;
  }

  & .recruit_tbl .dtl .type .occ {
    padding: 0 20px;
    border-radius: 18px;
    height: 29px;
    display: flex;
    align-items: center;
    letter-spacing: .1em;
    color: #fff;
  }

  & .recruit_tbl .dtl .type .occ._ver1 {
    background: #F08A00;
  }

  & .recruit_tbl .dtl .type .occ._ver2 {
    background: #67B70B;
  }

  & .recruit_tbl .dtl .type .employment {
    font-size: 2.6rem;
    letter-spacing: .1em;
  }
}

@container recruit-wrap (max-width: 768px) {
  #recruit .recruit_sec {
    & .recruit_container {
      padding: 30px 20px;
      border-radius: 15px;
      border-width: 1px;
      border-style: solid;
    }

    & .recruit_container+.recruit_container {
      margin-top: 40px;
    }

    & .recruit_contents .btn {
      margin-top: 30px;
    }

    & .recruit_contents_ttl {
      font-size: 1.8rem;
    }

    & .recruit_tbl {
      display: grid;
      grid-template-columns: 1fr;
      gap: 25px;
    }

    & .recruit_tbl .item {
      padding-bottom: 25px;
      grid-template-columns: 1fr;
      gap: 10px;
    }

    & .recruit_tbl .dtl .type {
      gap: 10px;
    }

    & .recruit_tbl .dtl .type .employment {
      font-size: 1.8rem;
      letter-spacing: .1em;
    }
  }
}

/* -----------------------------------------------------------
  エントリーフォーム
----------------------------------------------------------- */
#entry .singleColumn {
  container-name: entry-wrap;
  container-type: inline-size;
}

#entry .entry_sec {
  max-width: 1092px;
  width: 100%;
  margin: 0 auto;
}

#entry .entry_form {
  margin: 45px 0 0;

  & .input {
    background: #F6F6F6;
    height: 60px;
    padding: 10px 15px;
  }

  & .input.min_input {
    width: 240px;
  }

  & .input.default_input {
    width: 350px;
  }

  & .input.full_input {
    width: 100%;
  }

  & .input::placeholder {
    color: #202020;
    opacity: .3;
  }

  & textarea {
    width: 100%;
    background: #F6F6F6;
    padding: 10px 15px;
    height: 315px;
  }

  & #apply-select {
    display: none;
  }

  & .custom-select {
    position: relative;
    z-index: 0;
    width: 460px;
  }

  & .custom-select #select-list {
    display: none;
    transition: 0s;
  }

  & .custom-select #select-list li {
    width: 100%;
    height: 60px;
    background: #E9E9E9;
    padding: 10px 15px;
    text-align: left;
    display: flex;
    align-items: center;
  }

  & .custom-select #select-list li:nth-of-type(odd) {
    background: rgba(243, 243, 242, .45);
  }

  & .custom-select #select-list li.selected {
    background: #F08A00;
    color: #fff;
  }

  & .custom-select button {
    width: 100%;
    height: 60px;
    background: #E9E9E9;
    padding: 10px 15px;
    text-align: left;
    position: relative;
    z-index: 0;
  }

  & .custom-select button:before {
    content: "";
    aspect-ratio: 18 / 12;
    width: 18px;
    background: #F08A00;
    mask: url(../img/entry/ico_chevron.svg) no-repeat center / contain;
    top: 50%;
    right: 18px;
    transform: translateY(-50%);
    position: absolute;
  }

  & .custom-file {
    display: flex;
    align-items: center;
    gap: 45px;
  }

  & .custom-file button {
    width: 250px;
    height: 60px;
    background: #E9E9E9;
    padding: 10px 15px;
    text-align: left;
    position: relative;
    z-index: 0;
  }

  & .custom-file button:before {
    content: "";
    aspect-ratio: 18 / 12;
    width: 18px;
    background: #F08A00;
    mask: url(../img/entry/ico_chevron.svg) no-repeat center / contain;
    top: 50%;
    right: 18px;
    transform: translateY(-50%);
    position: absolute;
  }

  & .form_row {
    display: grid;
    align-items: start;
    grid-template-columns: 190px 1fr;
    gap: 20px;
    padding: 20px 0;
    border-top: 1px solid #BBBBBB;
  }

  & .form_row:last-of-type {
    border-bottom: 1px solid #BBBBBB;
  }

  & .form_row .form_ttl {
    color: #240A00;
    margin-top: 19px;
  }

  & .form_row .form_ttl.require {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }

  & .form_row .form_ttl.require:after {
    content: "必須";
    font-size: 1.2rem;
    color: #fff;
    width: 46px;
    height: 22px;
    border-radius: 4px;
    background: #F08A00;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  & .form_row .form_ttl.optional:after {
    content: "任意";
    font-size: 1.2rem;
    color: #fff;
    width: 46px;
    height: 22px;
    border-radius: 4px;
    background: #3498db;
    display: flex;
    align-items: center;
    justify-content: center;
  }

  & .form_row .form_ttl.optional {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

  & .form_row .form_dtl._flex {
    display: flex;
    align-items: center;
    gap: 32px;
  }

  & .form_row .form_dtl>div+div {
    margin-top: 30px;
  }

  & .form_row .nest_box {
    display: grid;
    align-items: start;
    grid-template-columns: 132px 1fr;
    gap: 20px;
  }

  & .privacy_box {
    margin: 80px 0 0;
  }

  & .privacy_box .copy {
    text-align: center;
  }

  & .privacy_box .copy a {
    color: #0243C5;
    text-decoration: underline;
  }

  & .privacy_box .copy a:hover {
    text-decoration: none;
  }

  & .privacy_box .privacy_input {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 35px 0 0;
    color: #240A00;
  }

  & .privacy_box .privacy_input input {
    display: none;
  }

  & .privacy_box .privacy_input .privacy_input_txt {
    position: relative;
    z-index: 0;
    padding: 0 0 0 36px;
  }

  & .privacy_box .privacy_input .privacy_input_txt:before,
  & .privacy_box .privacy_input .privacy_input_txt:after {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }

  & .privacy_box .privacy_input .privacy_input_txt:before {
    aspect-ratio: 1 / 1;
    width: 18px;
    background: #fff;
    border: 1px solid #240A00;
    left: 0;
  }

  & .privacy_box .privacy_input .privacy_input_txt:after {
    border-right: 2px solid #ed7a9c;
    border-bottom: 2px solid #ed7a9c;
    display: block;
    height: 9px;
    left: 7px;
    margin-top: -6px;
    opacity: 0;
    position: absolute;
    top: 50%;
    transform: rotate(45deg);
    width: 5px;
  }

  & .privacy_box .privacy_input input[type=checkbox]:checked+.privacy_input_txt:after {
    opacity: 1;
  }

  & .entry_btnbox {
    margin: 60px 0 0;
    display: flex;
    flex-wrap: wrap;
    gap: 20px 40px;
    justify-content: center;
  }

  & .entry_btnbox .c_btn_4 {
    margin: 0;
  }

  ._sp {
    display: none;
  }
}

#entry.entry_confirm .entry_form {
  & .form_row .form_ttl {
    margin-top: 0;
  }

  & .message {
    border: 1px solid #BBBBBB;
    padding: 40px;
  }

  & .file-input-confirm {
    min-width: 250px;
    width: fit-content;
    height: 60px;
    padding: 0 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #F1F2CD;
  }
}

@container entry-wrap (max-width: 1280px) {
  #entry .entry_form {
    ._pc {
      display: none !important;
    }

    ._sp {
      display: grid;
    }
  }
}

@container entry-wrap (max-width: 768px) {
  #entry .entry_form {
    & .form_row {
      grid-template-columns: 1fr;
      gap: 10px;
    }

    & .input {
      height: 50px;
      padding: 10px 15px;
    }

    & .input.min_input {
      width: 200px;
    }

    & .input.default_input {
      width: 100%;
    }

    & .form_row .form_ttl {
      margin-top: 0;
    }

    & .custom-select {
      position: relative;
      z-index: 0;
      width: 100%;
    }

    & .custom-select button {
      height: 50px;
    }

    & .custom-file {
      display: flex;
      align-items: flex-start;
      flex-direction: column;
      gap: 10px;
    }

    & .custom-file button {
      height: 50px;
      width: 100%;
    }

    & textarea {
      height: 250px;
    }

    & .privacy_box {
      margin: 30px 0 0;
    }

    & .entry_btnbox {
      margin: 20px 0 0;
    }
  }

  #entry.entry_confirm .entry_form {
    & .form_row .form_ttl {
      margin-top: 0;
    }

    & .message {
      border: 1px solid #BBBBBB;
      padding: 20px;
    }
  }
}

#entry_complete .singleColumn {
  container-name: entry-complete-wrap;
  container-type: inline-size;
  background: #C9DD73;
}

#entry_complete .complete_sec {
  & .ttlbox {
    position: relative;
    z-index: 0;
    padding-top: 110px;
    text-align: center;
  }

  & .ttlbox:before {
    content: "";
    aspect-ratio: 1 / 1;
    width: 65px;
    background: url(../img/entry/complete_check.svg) no-repeat center / contain;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
  }

  & .ttlbox .en {
    font-size: 1.6rem;
    line-height: calc(23 / 16);
    letter-spacing: .1em;
  }

  & .ttlbox .ttl {
    font-size: 3rem;
    line-height: calc(45 / 30);
    letter-spacing: .1em;
    color: #240A00;
  }

  & .contents {
    max-width: 1160px;
    width: 100%;
    margin: 25px auto 0;
    border-radius: 3.645vw;
    background: #fff;
    position: relative;
    z-index: 0;
    padding: 65px 5%;
  }

  & .contents .inr {
    max-width: 915px;
    width: 100%;
    margin: 0 auto;
    color: #240A00;
  }

  & .contents .contents_ttl {
    font-size: 2rem;
    line-height: calc(29 / 20);
    font-weight: 400;
    letter-spacing: .02em;
    margin: 0 0 20px;
  }

  & .contents .copy {
    letter-spacing: .02em;
  }

  & .contents .img {
    position: absolute;
    bottom: -70px;
    left: 50%;
    transform: translateX(-50%);
  }

  & .c_btn_3 {
    margin: 120px auto 0;
  }
}

@container entry-complete-wrap (max-width: 768px) {
  #entry_complete .complete_sec {
    & .ttlbox {
      padding-top: 40px;
    }

    & .ttlbox:before {
      width: 30px;
    }

    & .ttlbox .en {
      font-size: 1.2rem;
    }

    & .ttlbox .ttl {
      font-size: 1.8rem;
    }

    & .contents {
      padding: 30px 5% 50px;
    }

    & .contents .contents_ttl {
      font-size: 1.6rem;
      margin: 0 0 10px;
    }

    & .contents .img {
      position: absolute;
      bottom: -70px;
      left: 50%;
      transform: translateX(-50%);
    }

    & .c_btn_3 {
      margin: 100px auto 0;
    }
  }
}


#staff-voices .singleColumn {
  container-name: staff-voices-wrap;
  container-type: inline-size;
}

#staff-voices {
  & .gallery_box {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 30px 20px;
    margin: 0 0 150px;
  }

  & .gallery_box .item {
    border-radius: 28px;
    overflow: hidden;
  }

  & .voice_box+.voice_box {
    margin-top: 60px;
  }

  & .voice_box {
    position: relative;
    z-index: 0;
  }

  & .voice_box .txtbox {
    border-radius: 4.42vw;
    border: 3px dashed #F08A00;
    padding: 4vw 3vw;
    width: calc(100% - 250px);
  }

  & .voice_box .txtbox .ttl {
    font-size: 3rem;
    font-weight: 500;
    margin: 0 0 20px;
  }

  & .voice_box .txtbox .txt {
    font-weight: 500;
    line-height: calc(23 / 16);
  }

  & .voice_box .txtbox .txt+.txt {
    margin: 1em 0 0;
  }

  & .voice_box .icon {
    position: absolute;
    bottom: 0;
    width: 250px;
  }

  & .voice_box:nth-child(odd) .icon {
    right: 0;
  }

  & .voice_box:nth-child(even) .txtbox {
    margin-left: auto;
  }

  & .entry_btn {
    max-width: 1015px;
    width: 100%;
    margin: 100px auto 0;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 205px;
    border-radius: 40px;
    background: #F08A00;
    position: relative;
    z-index: 0;
    font-size: 3rem;
    font-weight: 500;
    color: #fff;
    border: 2px solid #F08A00;
  }

  & .entry_btn .bg-txt {
    opacity: .1;
    font-size: 15rem;
    color: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-weight: bold;
  }

  & .entry_btn:before,
  & .entry_btn:after {
    content: "";
    position: absolute;
    transition: all .5s ease;
  }

  & .entry_btn:before {
    aspect-ratio: 1 / 1;
    width: 28px;
    top: 50%;
    right: 34.4%;
    transform: translateY(-50%);
    border-radius: 50%;
    background: #fff;
  }

  & .entry_btn:after {
    aspect-ratio: 12 / 8;
    width: 12px;
    background: #F08A00;
    mask: url(../img/common/ico_chevron_down.svg) no-repeat center / contain;
    right: 34.9%;
    top: 50%;
    transform: translateY(-50%) rotate(-90deg);
    z-index: 1;
  }

  & .entry_btn:hover {
    color: #F08A00;
    background: #fff;
  }

  & .entry_btn:hover .bg-txt {
    color: #F08A00;
  }

  & .entry_btn:hover:before {
    background: #F08A00;
  }

  & .entry_btn:hover:after {
    background: #fff;
  }
}

@container staff-voices-wrap (max-width: 768px) {
  #staff-voices {
    & .gallery_box {
      margin: 0 0 40px;
    }

    & .voice_box+.voice_box {
      margin-top: 30px;
    }

    & .voice_box .txtbox {
      width: 100%;
    }

    & .voice_box .txtbox .ttl {
      font-size: 2rem;
    }

    & .voice_box .icon {
      display: none;
    }

    & .entry_btn {
      margin: 60px auto 0;
      height: 150px;
      border-radius: 30px;
      font-size: 2rem;
    }

    & .entry_btn .bg-txt {
      font-size: 10rem;
    }

    & .entry_btn:before,
    & .entry_btn:after {
      content: "";
      position: absolute;
      transition: all .5s ease;
    }

    & .entry_btn:before {
      aspect-ratio: 1 / 1;
      width: 28px;
      top: 50%;
      right: 34.4%;
      transform: translateY(-50%);
      border-radius: 50%;
      background: #fff;
    }

    & .entry_btn:after {
      aspect-ratio: 12 / 8;
      width: 12px;
      background: #F08A00;
      mask: url(../img/common/ico_chevron_down.svg) no-repeat center / contain;
      right: 35.5%;
      top: 50%;
      transform: translateY(-50%) rotate(-90deg);
      z-index: 1;
    }
  }
}

@container staff-voices-wrap (max-width: 480px) {
  #staff-voices {
    & .entry_btn {
      margin: 40px auto 0;
      height: 100px;
      border-radius: 20px;
      font-size: 2rem;
    }

    & .entry_btn .bg-txt {
      font-size: 7rem;
    }

    & .entry_btn:before {
      right: 20px;
    }

    & .entry_btn:after {
      right: 25px;
    }
  }
}


section.top__about-wrap ul li {
  max-width: 470px;
  width: 30.9211%;
}

section.top__about-wrap .top__about-ttl {
  display: inline;
  margin-bottom: 2.6rem;
  font-size: 2.5rem;
  color: #FC7D74;
  background: linear-gradient(transparent 60%, #FFF5D4 0%);
  line-height: 1.6;
  letter-spacing: 0.1em;
}

section.top__about-wrap .top__about-txt {
  margin-top: 2.6rem;
  line-height: 1.625;
  letter-spacing: 0.1em;
}

section.top__introduction-wrap ul.flex {
	justify-content: center;
    gap: 20px;
}

.top__acquisition-plan__ttl {
  background: #FC7D74;
  color: #fff;
  max-height: 610px;
  border-radius: 38px;
}

.top__acquisition-wrap .halfway-wrap .moreLink {
  border: 1px solid #F9A084;
  background: #ffffff;
  border-radius: 40px;
  display: flex;
  justify-content: center;
  width: 230px;
  height: 52px;
  line-height: 52px;
  align-items: center;
  letter-spacing: 0.3rem;
  margin-top: 30px;
}

.top__acquisition-wrap .container {
  display: flex;
  justify-content: space-between;
  gap: 40px;
}

.top__acquisition-wrap .left,
.top__acquisition-wrap .right {
  flex: 1;
  max-width: 600px;
  width: 50%;
}

.top__acquisition-wrap .section {
  padding: 20px;
  margin-bottom: 40px;
}

.top__acquisition-wrap .section h2 {
  font-size: 20px;
  margin: 0 0 10px;
}

.top__acquisition-wrap .section .number {
  font-size: 30px;
  font-weight: bold;
  background-color: #f08080;
  color: #fff;
  border-radius: 50%;
  padding: 18px 15px;
  display: inline-block;
  margin-right: 10px;
  position: absolute;
  z-index: 1;
}

.top__acquisition-wrap .section img {
  width: 100%;
  max-width: 100%;
  height: auto;
  margin: 15px 0;
  border-radius: 8px;
}

.top__acquisition-wrap .highlight {
  color: #FC7D74;
  font-weight: bold;
  margin-top: 10px;
  font-size: 30px;
  line-height: 1.5;
  margin-bottom: 15px;
}

.top__acquisition-wrap .small-note {
  background-color: #FC7D74;
  color: white;
  font-size: 12px;
  display: inline-block;
  padding: 7px 13px;
  border-radius: 15px;
  margin-top: 10px;
  position: absolute;
  right: 200px;
  top: 5px;
}

.top__acquisition-wrap .halfway-wrap img.triple_baby {
  z-index: 1;
}

.top__acquisition-plan-wrap.flex img {
  width: auto;
}

.top__acquisition-wrap .container h3 p {
  background: #fff;
}

.top__acquisition-wrap .section h3 {
  position: relative;
  margin-left: -50px;
}

.top__acquisition-wrap .section h3 span {
  position: absolute;
  z-index: 1;
}

.top__acquisition-wrap .section h3 p {
  position: absolute;
  width: max-content;
  border-radius: 5em;
  font-size: 35px;
  padding-left: 50px;
  padding-right: 50px;
  padding-top: 15px;
  padding-bottom: 15px;
  top: 30px;
  left: 50px;
}

.top__acquisition-wrap .right img {
  float: right;
}

.top__acquisition-plan-wrap.flex img.codmon {
  margin-left: auto;
  margin-top: 50px;
}

.top__acquisition-wrap .right .highlight {
  margin-top: 105px;
}

.top__acquisition-wrap .halfway-wrap {
  max-width: 1700px;
}

.top__acquisition-wrap .right .textBox {
  max-width: 360px;
  width: 100%;
}

header ul.menu_buttan>li:nth-child(4)::before {
  content: url(../img/common/icon04.png);
}


header ul.menu_buttan>li:nth-child(5)::before {
  content: none;
}


.headerMenu .nav>li:nth-child(4):hover::after {
  content: '▲';
  display: block;
  font-size: 20px;
  color: #fe9166;
  position: absolute;
  top: 32px;
  left: 45%;
}

.headerMenu .nav>li:nth-child(5):hover::after {
  content: '';
}


section.top__introduction-wrap ul li {
  width: 30%;
}

section.top__introduction-wrap ul li img {
  margin-left: auto;
  margin-right: auto;
}

section.top__introduction-wrap ul li a img.obtn {
  right: -95px;
  top: 10px;
}

section.top__introduction-wrap .inner img.hay {
  bottom: -110px;
}

.mean-container .mean-nav ul li.h_comm {
  display: none ! IMPORTANT;
}

.mean-container .mean-nav ul li:nth-child(1) ul.sub-menu li:nth-child(3) {
  display: none;
}

@container staff-voices-wrap (max-width: 1300px) {

  .top__acquisition-wrap .section h3 p {
    font-size: 27px;
  }

  .top__acquisition-wrap .highlight {
    font-size: 20px;
  }
}


@media (max-width: 1500px) and (min-width: 1301px) {
  .top__acquisition-wrap .highlight {
    font-size: 25px;
  }

  .top__acquisition-wrap .section h3 p {
    font-size: 27px;
  }

  section.top__acquisition-wrap .top__acquisition-plan__ttl {
    right: -65px;
  }
}

@media (max-width: 1300px) and (min-width: 1201px) {
  .top__acquisition-wrap .highlight {
    font-size: 23px;
  }

  .top__acquisition-wrap .section h3 p {
    font-size: 25px;
  }

  section.top__acquisition-wrap .top__acquisition-plan__ttl {
    right: -85px;
  }
}

select#apply-select {
  display: block !important;
  border: 1px solid #ccc;
  padding: 10px;
  margin-top: 5px;
}

input#file-input {
  margin-top: 10px;
}


@media (max-width: 1300px) {

  .form_row.renewal .form_dtl._flex {
    display: block !IMPORTANT;
  }

  .form_row.renewal .nest_box {
    display: block !IMPORTANT;
    margin-top: 15px;
  }
}

  /* ページネーションのスタイル */
  .pagination-list {
    display: flex;
    list-style: none;
    padding: 0;
    margin: 0;
    justify-content: center;
    margin-top: 40px;
  }
.pagination-link {
    margin-left: auto;
}
  .pagination-link {
    display: inline-block;
    padding: 0.5em 1em;
    margin: 0 0.25em;
    text-decoration: none;
    color: #4a4a4a;
    border-radius: 4px;
    transition: background-color 0.2s ease, color 0.2s ease;
  }

  .pagination-link:hover {
    background-color:#7f6d66;
    color: white;
  }

.pagination-link.is-current {
    background-color: #240a00;
    color: white;
    pointer-events: none;
    border-radius: 50%;
    height: 40px;
    font-size: 15px;
    width: 40px;
    font-weight: 500;
}

  .pagination-link.is-disabled {
    color: #ccc;
    pointer-events: none;
    cursor: not-allowed;
  }

  /* ページネーションの矢印のデザイン */
  .pagination-link:last-child {

  }

a.pagination-link {
    color: #240a00;
    font-size: 15px;
}



.custom-select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background: white url('data:image/svg+xml;utf8,<svg fill="black" height="24" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/2000/svg"><path d="M7 10l5 5 5-5z"/></svg>') no-repeat right 10px center;
    background-size: 16px;
    padding: 5px 30px 5px 10px; /* 矢印の分の余白を右側に確保 */
    border: 1px solid #ccc;
    border-radius: 4px;
    font-size: 14px;
}

.select-wrapper {
    position: relative;
    display: inline-block;
}

.select-wrapper::after {
    content: "▼";
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: #f08a00;
    font-size: 12px;
}

.select-wrapper select {
    width: 100%;
    padding: 8px 30px 8px 10px;
    font-size: 14px;
    border: 1px solid #ccc;
    border-radius: 4px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: #fff;
}
#category-select {
    font-size: 14px;
    padding: 10px 16px;
    border: 1px solid #f08a00;
    border-radius: 6px;
    margin-left: 10px;
    background-color: #fff;
    min-width: 180px;
    color: #240a00;
}
.form_row._sp {
    display: grid !important;
}

select#source {
width: 250px !important;
    text-align: left;
    position: relative;
    }
select#source:before {
    content: "";
    aspect-ratio: 18 / 12;
    width: 18px;
    background: #F08A00;
    -webkit-mask: url(../img/entry/ico_chevron.svg) no-repeat center / contain; /* Webkit対応 */
    mask: url(../img/entry/ico_chevron.svg) no-repeat center / contain;
    top: 50%;
    right: 18px;
    transform: translateY(-50%);
    position: absolute;
}

.select-container {
  display: flex;
  align-items: center;
}

.select-container select {
  width: 250px; /* 任意の幅 */
  padding-right: 30px; /* 画像が重ならないように右側に余白を追加 */
  font-size: 16px;
}

.select-container .select-icon {
  width: 20px; /* アイコンのサイズ */
  height: auto;
  margin-left: 10px; /* select とアイコンの間にスペースを追加 */
}
.select-container img {
    margin-left: -35px;
    z-index: 1;
}

section#active .voice_box {
    max-width: 500px;
    margin: auto;
    width: 49%;
}
section#active .voice_box img {
    margin: auto;
    margin-bottom: 20px;
border-radius: 50px;
}
section#active .details_box {
    display: flex;
    justify-content: space-between;
}

section#active .u_color_1 {
    text-align: center;
}
section#active {
    padding-bottom: 165px;
}
@media (max-width: 1200px) {
section#active .details_box {
    display: block;
}
section#active .voice_box {
    width: 90%;
        margin-bottom: 50px;
}
section#active {
    padding-bottom: 80px;
}
}

.banner_footer ul {
    display: flex;
    justify-content: right;
}

.banner_footer {
    max-width: 865px;
}

/* event */

.event_information .flex {
    display: flex;
    justify-content: center;
    width: max-content;
    margin-left: auto;
    margin-right: auto;
    align-items: center;
}
.event_information .flex p {
}
.event_information img {
    display: block;
    margin: auto;
}
.event_information {
    border-radius: 50px;
    padding: 40px;
    background: #F9A084;
    text-align: center;
    color: #fff;
    max-width: 100%;
    margin: auto;
    position: relative;
    width: 100%;
    margin-top: 85px;
}
.event_information ul li {list-style: none;width: 180px;}
section.top__about-wrap .event_information ul {
	display: flex;
	justify-content: space-between;
	max-width: 900px;
	padding: 0;
	margin-left: auto;
	margin-right: auto;
	list-style: none;
	flex-wrap: nowrap;
	margin-top: 10px;
	margin-bottom: 20px;
}
.event_information p {
    text-align: left;
}
.event_information ul li a {
    color: #000000;
    text-decoration: auto;
    display: flex;
    justify-content: center;
    background: #fff;
    border-radius: 20px;
    padding: 10px 15px;
    width: max-content;
    height: 40px;
    line-height: normal;
    font-weight: 600;
}
.event_information ul li a img {
    margin-left: 10px;
    margin-right: 0;
}
.event_information ul li a:hover {
    background: #ffdcd0;
}
section.top__about-wrap .event_information ul li {
    position: relative;
    margin-bottom: 0;
    width: auto;
    padding: 0;
    margin: 0;
    max-width: none;
}
.event_information .flex img {
    width: 140px;
}
.event_information p.title {
-ms-writing-mode: tb-rl;
    writing-mode: vertical-lr;
    padding: 26px 15px;
    color: #151515;
    font-size: 30px;
    font-weight: bold;
    background: #ffffff;
    border-radius: 38px;
    letter-spacing: 0.2em;
    padding-bottom: 0;
    max-height: 500px;
    position: absolute;
    top: -70px;
    left: 25px;
    border: 1px solid #EE7F5B;
    height: 280px;
}
section.top__about-wrap .event_information ul li img {
    margin-bottom: 0;
}

@media screen and (max-width: 1360px) {
.event_information p.title {
        left: 20px;
        font-size: 23px;
        height: 230px;
    }
}


@media (max-width: 1200px) {
.event_information .flex {
    display: block;
        width: auto;
}
.event_information .flex img {
    margin-top: 15px;
}
section.top__about-wrap .event_information ul li img {
    width: auto;
}
}


@media (max-width: 900px) {
section.top__about-wrap .event_information ul li {
width: 48%;
        margin-bottom: 5px;
        overflow: hidden;
}
.event_information ul li a {
        width: 100%;
        height: auto;
}
    section.top__about-wrap .event_information ul {
        display: flex;
        flex-wrap: wrap;
        max-width: max-content;
        width: auto;
        margin-left: auto;
        margin-right: auto;
    }

    section.top__about-wrap .event_information ul li img {
        width: auto;
        margin-left: 3px;
        margin-right: 0;
    }

.event_information img {
    width: 80%;
}

}

@media (max-width: 500px) {
section.top__about-wrap .event_information ul {
        width: 98%;
        margin-top: 35px;
        margin-bottom: 20px;
}
    section.top__about-wrap .event_information ul li {
        width: 90%;
        margin-left: auto;
        margin-right: auto;
    }
.event_information {
    padding: 40px 10px;
}
section.top__about-wrap .event_information p.title {
        margin-left: 5%;
        padding: 19px 0px;
        padding-left: 0;
        padding-right: 0;
        width: 40px;
        writing-mode: rl;
        text-align: center;
        letter-spacing: 0rem;
        left: 0;
        height: 250px;
        z-index: 9;
        top: -100px;
}
.event_information img {
    margin-right: 5%;
}
.event_information .flex img {margin-left: auto;margin-right: auto;}
}