.page_campus_index {
  padding: clamp(60px, 8vw, 100px) 20px 100px;
}
.page_campus_index .mainvisual {
  display: flex;
  align-items: center;
  max-width: 1300px;
  margin: 0 auto;
  margin-bottom: 40px;
  gap: clamp(20px, 3vw, 50px);
}
@media (max-width: 1000px) {
  .page_campus_index .mainvisual {
    flex-direction: column-reverse;
  }
}
.page_campus_index .mainvisual .map {
  width: 35%;
}
@media (max-width: 1000px) {
  .page_campus_index .mainvisual .map {
    width: 100%;
    max-width: 600px;
  }
}
.page_campus_index .mainvisual .map img {
  width: 100%;
  border-radius: 10px;
}
.page_campus_index .mainvisual .txt {
  flex: 1;
}
.page_campus_index .mainvisual .txt h1 {
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 600;
  margin-bottom: 0.5em;
}
@media (max-width: 1000px) {
  .page_campus_index .mainvisual .txt h1 {
    text-align: center;
  }
}
.page_campus_index .mainvisual .txt h1 span {
  display: block;
  font-size: clamp(18px, 2vw, 24px);
  color: #249e49;
}
.page_campus_index .mainvisual .txt p {
  font-size: 16px;
  line-height: 1.8;
}
.page_campus_index .campus_list {
  max-width: 1300px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
@media (max-width: 1000px) {
  .page_campus_index .campus_list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 800px) {
  .page_campus_index .campus_list {
    grid-template-columns: repeat(1, 1fr);
  }
}
.page_campus_index .campus_list .item {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 15px;
  background: #fff;
  border: 2px solid;
  border-radius: 10px;
  overflow: hidden;
  gap: 20px;
  transition: 0.3s;
}
.page_campus_index .campus_list .item.red {
  border-color: #f74c01;
}
.page_campus_index .campus_list .item.red .number {
  background: #f74c01;
}
.page_campus_index .campus_list .item.red .txt .name {
  color: #f74c01;
}
.page_campus_index .campus_list .item.yellow {
  border-color: #ecb102;
}
.page_campus_index .campus_list .item.yellow .number {
  background: #ecb102;
}
.page_campus_index .campus_list .item.yellow .txt .name {
  color: #ecb102;
}
.page_campus_index .campus_list .item.green {
  border-color: #7ac303;
}
.page_campus_index .campus_list .item.green .number {
  background: #7ac303;
}
.page_campus_index .campus_list .item.green .txt .name {
  color: #7ac303;
}
.page_campus_index .campus_list .item.blue {
  border-color: #02adea;
}
.page_campus_index .campus_list .item.blue .number {
  background: #02adea;
}
.page_campus_index .campus_list .item.blue .txt .name {
  color: #02adea;
}
.page_campus_index .campus_list .item:hover.red {
  background: rgba(247, 76, 1, 0.1);
}
.page_campus_index .campus_list .item:hover.yellow {
  background: rgba(236, 177, 2, 0.1);
}
.page_campus_index .campus_list .item:hover.green {
  background: rgba(122, 195, 3, 0.1);
}
.page_campus_index .campus_list .item:hover.blue {
  background: rgba(2, 173, 234, 0.1);
}
.page_campus_index .campus_list .item a {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.page_campus_index .campus_list .item .number {
  padding: 0.3em 0.8em 0.5em;
  color: #fff;
  font-size: 18px;
  font-weight: 500;
  border-bottom-right-radius: 10px;
  position: absolute;
  top: 0;
  left: 0;
}
.page_campus_index .campus_list .item .photo {
  width: 100%;
  aspect-ratio: 4/3;
}
.page_campus_index .campus_list .item .photo img {
  width: 100%;
  height: 100%;
  border-radius: 10px;
  -o-object-fit: cover;
     object-fit: cover;
}
.page_campus_index .campus_list .item .txt {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.page_campus_index .campus_list .item .txt .name {
  margin-bottom: 0.8em;
  font-size: 18px;
  font-weight: 700;
  text-align: center;
}
.page_campus_index .campus_list .item .txt .address {
  display: flex;
  align-items: center;
  flex: 1;
  color: #595959;
  font-size: 14px;
}

.page_program_index .page_title {
  text-align: center;
  padding: clamp(60px, 8vw, 100px) 20px 20px;
}
.page_program_index .page_title .en {
  color: #249e49;
  font-size: clamp(14px, 1.6vw, 20px);
  font-weight: 500;
  margin-bottom: 0.5em;
}
.page_program_index .page_title h2 {
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 500;
}
.page_program_index .section_title {
  text-align: center;
  margin-bottom: 40px;
}
.page_program_index .section_title .en {
  color: #249e49;
  font-size: clamp(14px, 1.6vw, 20px);
  font-weight: 500;
  margin-bottom: 0.5em;
}
.page_program_index .program.sort {
  background: #edf8db;
  margin-top: 40px;
}
.page_program_index .program.sort::before {
  background: #fff;
}
.page_program_index .program.sort::after {
  background: #edf8db;
  border-top-right-radius: 100%;
}
.page_program_index .program.sort .inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: clamp(60px, 8vw, 100px) 20px;
}
.page_program_index .program.sort .inner h3 {
  display: inline-block;
  font-size: 16px;
  font-weight: 500;
  padding: 0.8em 1.5em;
  border-radius: 30px;
  border-bottom-left-radius: 0;
  background: #fff;
  margin-bottom: 1em;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .inner h3 {
    font-size: 14px;
  }
}
.page_program_index .program.sort .inner h3 span {
  color: #249e49;
}
.page_program_index .program.sort .inner .select {
  margin-bottom: 60px;
}
.page_program_index .program.sort .inner .select ul.age-group {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  flex-wrap: wrap;
  gap: 10px;
  padding-left: 40px;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .inner .select ul.age-group {
    grid-template-columns: repeat(2, 1fr);
    padding-left: 10px;
  }
}
.page_program_index .program.sort .inner .select ul.age-group li {
  list-style: none;
  text-align: center;
  color: #249e49;
  border: solid 1px #249e49;
  background: #fff;
  padding: 1em;
  font-weight: 500;
  border-radius: 10em;
  cursor: pointer;
  transition: 0.2s;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .inner .select ul.age-group li {
    font-size: 14px;
  }
}
.page_program_index .program.sort .inner .select ul.age-group li:hover {
  background: #249e49;
  color: #fff;
}
.page_program_index .program.sort .inner .select ul.age-group li.selected {
  background: #249e49;
  color: #fff;
}
.page_program_index .program.sort .inner .select.campus-select {
  display: none;
}
.page_program_index .program.sort .inner .select.campus-select.show {
  display: block;
}
.page_program_index .program.sort .inner .select.campus-select ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  flex-wrap: wrap;
  gap: 10px;
  padding-left: 40px;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .inner .select.campus-select ul {
    grid-template-columns: repeat(1, 1fr);
    padding-left: 10px;
  }
}
.page_program_index .program.sort .inner .select.campus-select ul li {
  background: #fff;
  padding: 1em;
  font-weight: 500;
  border-radius: 10em;
  cursor: pointer;
  transition: 0.2s;
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 20px;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .inner .select.campus-select ul li {
    padding: 15px 10px;
    font-size: 14px;
  }
}
.page_program_index .program.sort .inner .select.campus-select ul li.red {
  color: #f74b01;
  border: solid 1px #f74b01;
}
.page_program_index .program.sort .inner .select.campus-select ul li.red .number::before {
  background: #f74b01;
}
.page_program_index .program.sort .inner .select.campus-select ul li.red:hover {
  background: #f74b01;
  color: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.red:hover .number {
  color: #f74b01;
}
.page_program_index .program.sort .inner .select.campus-select ul li.red:hover .number::before {
  background: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.red.selected {
  background: #f74b01;
  color: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.red.selected .number {
  color: #f74b01;
}
.page_program_index .program.sort .inner .select.campus-select ul li.red.selected .number::before {
  background: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.yellow {
  color: #ecb100;
  border: solid 1px #ecb100;
}
.page_program_index .program.sort .inner .select.campus-select ul li.yellow .number::before {
  background: #ecb100;
}
.page_program_index .program.sort .inner .select.campus-select ul li.yellow:hover {
  background: #ecb100;
  color: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.yellow:hover .number {
  color: #ecb100;
}
.page_program_index .program.sort .inner .select.campus-select ul li.yellow:hover .number::before {
  background: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.yellow.selected {
  background: #ecb100;
  color: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.yellow.selected .number {
  color: #ecb100;
}
.page_program_index .program.sort .inner .select.campus-select ul li.yellow.selected .number::before {
  background: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.mint {
  color: #7ac301;
  border: solid 1px #7ac301;
}
.page_program_index .program.sort .inner .select.campus-select ul li.mint .number::before {
  background: #7ac301;
}
.page_program_index .program.sort .inner .select.campus-select ul li.mint:hover {
  background: #7ac301;
  color: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.mint:hover .number {
  color: #7ac301;
}
.page_program_index .program.sort .inner .select.campus-select ul li.mint:hover .number::before {
  background: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.mint.selected {
  background: #7ac301;
  color: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.mint.selected .number {
  color: #7ac301;
}
.page_program_index .program.sort .inner .select.campus-select ul li.mint.selected .number::before {
  background: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.blue {
  color: #01adea;
  border: solid 1px #01adea;
}
.page_program_index .program.sort .inner .select.campus-select ul li.blue .number::before {
  background: #01adea;
}
.page_program_index .program.sort .inner .select.campus-select ul li.blue:hover {
  background: #01adea;
  color: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.blue:hover .number {
  color: #01adea;
}
.page_program_index .program.sort .inner .select.campus-select ul li.blue:hover .number::before {
  background: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.blue.selected {
  background: #01adea;
  color: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li.blue.selected .number {
  color: #01adea;
}
.page_program_index .program.sort .inner .select.campus-select ul li.blue.selected .number::before {
  background: #fff;
}
.page_program_index .program.sort .inner .select.campus-select ul li .number {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  color: #fff;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .inner .select.campus-select ul li .number {
    font-size: 12px;
    width: 25px;
    height: 25px;
  }
}
.page_program_index .program.sort .inner .select.campus-select ul li .number::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  border-radius: 10em;
  border-bottom-right-radius: 0;
  transform: rotate(45deg);
  z-index: -1;
}
.page_program_index .program.sort .inner .select.campus-select ul li .txt {
  font-weight: 500;
  flex: 1;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .inner .select.campus-select ul li .txt {
    font-size: 14px;
  }
}
.page_program_index .program.sort .result.program-result {
  display: none;
}
.page_program_index .program.sort .result.program-result.show {
  display: block;
}
.page_program_index .program.sort .result.program-result .result_inner {
  padding-left: 40px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .result.program-result .result_inner {
    padding-left: 10px;
  }
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus {
  background: #fff;
  border-radius: 30px;
  padding: 30px;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .result.program-result .result_inner .result_campus {
    padding: 20px;
  }
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 20px;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .result.program-result .result_inner .result_campus .title {
    margin-bottom: 10px;
  }
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title .number {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  color: #fff;
  z-index: 1;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .result.program-result .result_inner .result_campus .title .number {
    font-size: 12px;
    width: 25px;
    height: 25px;
  }
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title .number::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  border-radius: 10em;
  border-bottom-right-radius: 0;
  transform: rotate(45deg);
  z-index: -1;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title .txt {
  font-weight: 500;
  flex: 1;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .result.program-result .result_inner .result_campus .title .txt {
    font-size: 14px;
  }
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title.red {
  color: #f74b01;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title.red .number::before {
  background: #f74b01;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title.yellow {
  color: #ecb100;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title.yellow .number::before {
  background: #ecb100;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title.mint {
  color: #7ac301;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title.mint .number::before {
  background: #7ac301;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title.blue {
  color: #01adea;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .title.blue .number::before {
  background: #01adea;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info {
  display: flex;
  gap: 40px;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .result.program-result .result_inner .result_campus .info {
    flex-direction: column;
    padding: 20px 10px;
    gap: 10px;
  }
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .photo {
  flex: 1;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .photo img {
  width: 100%;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt {
  flex: 1;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .result_item {
  display: none;
  background-image: repeating-linear-gradient(90deg, #249e49, #249e49 6px, transparent 6px, transparent 12px);
  background-position: left bottom;
  background-repeat: repeat-x;
  background-size: 100% 1px;
  font-size: 16px;
  padding: 20px 0;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .result_item {
    font-size: 12px;
  }
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .result_item.show {
  display: block;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .result_item.noresult {
  text-align: center;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .result_item a {
  color: #000;
  font-size: 16px;
  text-decoration: none;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .result_item a {
    font-size: 14px;
  }
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .result_item p {
  padding-top: 5px;
  font-size: 13px;
}
@media screen and (max-width: 800px) {
  .page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .result_item p {
    font-size: 12px;
  }
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .btn {
  text-align: right;
  padding-top: 20px;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .btn a {
  position: relative;
  display: inline-block;
  padding: 0.2em 2.5em 0.2em 0;
  font-size: clamp(16px, 1.8vw, 20px);
  color: #249e49;
  font-weight: 500;
  text-decoration: none;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .btn a::before, .page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .btn a::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  transition: 0.2s;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .btn a::before {
  width: 1.6em;
  height: 1.6em;
  background: #249e49;
  right: 0.5em;
  border-radius: 100%;
}
.page_program_index .program.sort .result.program-result .result_inner .result_campus .info .txt .btn a::after {
  width: 0.4em;
  height: 0.4em;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(45deg);
  right: 1.2em;
}
.page_program_index .program_list {
  padding: 100px 20px;
}
.page_program_index .program_list h3 {
  font-size: 20px;
  font-weight: 600;
  text-align: center;
  color: #249e49;
  padding: 2em 0 1em;
}
.page_program_index .program_list .inner {
  max-width: 1300px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 1000px) {
  .page_program_index .program_list .inner {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 800px) {
  .page_program_index .program_list .inner {
    grid-template-columns: repeat(1, 1fr);
  }
}
.page_program_index .program_list .inner .item:hover {
  background: rgba(36, 158, 73, 0.1);
}
.page_program_index .program_list .inner .item a {
  position: relative;
  display: flex;
  align-items: center;
  padding: 10px;
  border: 1px solid #249e49;
  border-radius: 5px;
  gap: 20px;
  text-decoration: none;
}
.page_program_index .program_list .inner .item .photo {
  width: 20%;
  aspect-ratio: 4/3;
  line-height: 0;
}
.page_program_index .program_list .inner .item .photo img {
  width: 100%;
  height: 100%;
  border-radius: 5px;
  -o-object-fit: cover;
     object-fit: cover;
}
.page_program_index .program_list .inner .item .name {
  flex: 1;
  font-size: 15px;
  font-weight: 500;
  color: #000;
}
.page_program_index .program_list .inner .item .arrow {
  width: 32px;
  height: 32px;
  background: #249e49;
  border-radius: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page_program_index .program_list .inner .item .arrow:before {
  content: "";
  display: block;
  width: 25%;
  height: 25%;
  transform: rotate(45deg);
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  position: relative;
  right: 6%;
}

.page_school {
  padding-top: clamp(60px, 8vw, 100px);
}
.page_school .slider_view1,
.page_school .slider_view3,
.page_school .slider_view5,
.page_school .slider_club {
  overflow: hidden;
  width: 100%;
  padding: 20px 0;
  height: -moz-fit-content;
  height: fit-content;
}
.page_school .slider_view1 .swiper-slide,
.page_school .slider_view3 .swiper-slide,
.page_school .slider_view5 .swiper-slide,
.page_school .slider_club .swiper-slide {
  overflow: hidden;
  margin-right: 0;
}
.page_school .slider_view1 .swiper-slide img,
.page_school .slider_view3 .swiper-slide img,
.page_school .slider_view5 .swiper-slide img,
.page_school .slider_club .swiper-slide img {
  display: block;
  width: 100%;
  aspect-ratio: 5/3;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px;
}
.page_school .slider_view1 .swiper-slide span,
.page_school .slider_view3 .swiper-slide span,
.page_school .slider_view5 .swiper-slide span,
.page_school .slider_club .swiper-slide span {
  display: block;
  text-align: center;
  font-size: 14px;
  padding-top: 0.5em;
}
.page_school .slider_view1 .controls,
.page_school .slider_view3 .controls,
.page_school .slider_view5 .controls,
.page_school .slider_club .controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 15px;
  padding: 20px;
  line-height: 0;
  position: relative;
  z-index: 5;
}
.page_school .slider_view1 .controls .prev,
.page_school .slider_view1 .controls .next,
.page_school .slider_view3 .controls .prev,
.page_school .slider_view3 .controls .next,
.page_school .slider_view5 .controls .prev,
.page_school .slider_view5 .controls .next,
.page_school .slider_club .controls .prev,
.page_school .slider_club .controls .next {
  width: 15px;
  height: 15px;
  cursor: pointer;
  transform: rotate(45deg);
  transition: all 0.3s ease;
}
.page_school .slider_view1 .controls .prev,
.page_school .slider_view3 .controls .prev,
.page_school .slider_view5 .controls .prev,
.page_school .slider_club .controls .prev {
  border-bottom: solid 2px #249e49;
  border-left: solid 2px #249e49;
}
.page_school .slider_view1 .controls .next,
.page_school .slider_view3 .controls .next,
.page_school .slider_view5 .controls .next,
.page_school .slider_club .controls .next {
  border-top: solid 2px #249e49;
  border-right: solid 2px #249e49;
}
.page_school .slider_view1 .controls .dot,
.page_school .slider_view3 .controls .dot,
.page_school .slider_view5 .controls .dot,
.page_school .slider_club .controls .dot {
  width: -moz-fit-content;
  width: fit-content;
  position: initial;
}
.page_school .slider_view1 .controls .dot .swiper-pagination-bullet,
.page_school .slider_view3 .controls .dot .swiper-pagination-bullet,
.page_school .slider_view5 .controls .dot .swiper-pagination-bullet,
.page_school .slider_club .controls .dot .swiper-pagination-bullet {
  background: rgba(36, 158, 73, 0.2);
  opacity: 1;
  width: 8px;
  height: 8px;
  margin: 5px;
  transition: all 0.3s ease;
}
.page_school .slider_view1 .controls .dot .swiper-pagination-bullet.swiper-pagination-bullet-active,
.page_school .slider_view3 .controls .dot .swiper-pagination-bullet.swiper-pagination-bullet-active,
.page_school .slider_view5 .controls .dot .swiper-pagination-bullet.swiper-pagination-bullet-active,
.page_school .slider_club .controls .dot .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: #249e49;
}
.page_school .slider_club .swiper-slide .club_inner {
  display: flex;
  align-items: flex-start;
  background: #fff;
  border: 1px solid #249e49;
  padding: 30px;
  border-radius: 10px;
  gap: clamp(20px, 3vw, 40px);
}
@media (max-width: 800px) {
  .page_school .slider_club .swiper-slide .club_inner {
    flex-direction: column;
  }
}
.page_school .slider_club .swiper-slide .club_inner .club_content {
  flex: 1;
}
.page_school .slider_club .swiper-slide .club_inner .club_content h3 {
  font-size: 20px;
  font-weight: 500;
  color: #249e49;
  margin-bottom: 0.4em;
}
.page_school .slider_club .swiper-slide .club_inner .club_content .txt {
  font-size: 15px;
  line-height: 1.8;
}
.page_school .slider_club .swiper-slide .club_inner img {
  width: 30%;
}
@media (max-width: 800px) {
  .page_school .slider_club .swiper-slide .club_inner img {
    width: 100%;
  }
}
.page_school .program_mv {
  max-width: 1300px;
  padding: 0 clamp(20px, 4vw, 60px);
  margin: 0 auto 60px;
  display: flex;
  gap: clamp(20px, 4vw, 80px);
}
@media (max-width: 1000px) {
  .page_school .program_mv {
    flex-direction: column;
  }
}
.page_school .program_mv .program_mv_txt {
  flex: 1;
}
@media (max-width: 1000px) {
  .page_school .program_mv .program_mv_txt {
    max-width: 600px;
    margin: 0 auto;
  }
}
.page_school .program_mv .program_mv_txt .page_title {
  color: #249e49;
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 500;
  margin-bottom: 0.3em;
}
@media (max-width: 1000px) {
  .page_school .program_mv .program_mv_txt .page_title {
    text-align: center;
  }
}
.page_school .program_mv .program_mv_txt h1 {
  font-size: clamp(22px, 2.6vw, 30px);
  font-weight: 700;
  color: #000;
  margin-bottom: 20px;
  line-height: 1.4;
}
@media (max-width: 1000px) {
  .page_school .program_mv .program_mv_txt h1 {
    text-align: center;
  }
}
.page_school .program_mv .program_mv_txt h1 span {
  display: block;
  font-size: 0.7em;
  padding-top: 0.2em;
}
.page_school .program_mv .program_mv_txt .read {
  font-size: clamp(15px, 1.5vw, 16px);
  line-height: 1.8;
}
.page_school .program_mv .program_mv_txt ul {
  display: flex;
  gap: clamp(10px, 1.3vw, 15px);
  flex-wrap: wrap;
  padding-top: 20px;
}
@media (max-width: 1000px) {
  .page_school .program_mv .program_mv_txt ul {
    justify-content: center;
  }
}
.page_school .program_mv .program_mv_txt ul li {
  list-style: none;
}
.page_school .program_mv .program_mv_txt ul li.green a {
  background: #249e49;
  color: #fff;
}
.page_school .program_mv .program_mv_txt ul li.green a::after {
  border-bottom: solid 2px #fff;
  border-right: solid 2px #fff;
}
.page_school .program_mv .program_mv_txt ul li a {
  display: flex;
  align-items: center;
  padding: 0.8em 1em;
  border: 2px solid #249e49;
  color: #000;
  border-radius: 10px 10px 10px 0;
  text-decoration: none;
  font-size: clamp(14px, 1.5vw, 16px);
  font-weight: 500;
  gap: clamp(30px, 6vw, 80px);
}
.page_school .program_mv .program_mv_txt ul li a::after {
  content: "";
  display: block;
  width: 0.4em;
  height: 0.4em;
  border-bottom: solid 2px #000;
  border-right: solid 2px #000;
  transform: rotate(45deg) translateY(-30%);
}
.page_school .program_mv .program_mv_slider {
  flex: 1;
  width: 40%;
}
@media (max-width: 1000px) {
  .page_school .program_mv .program_mv_slider {
    width: 100%;
  }
}
.page_school .campus_mv .campus_title {
  text-align: center;
  margin-bottom: 40px;
}
.page_school .campus_mv .campus_title .en {
  color: #249e49;
  font-size: clamp(18px, 2vw, 22px);
  font-weight: 500;
  margin-bottom: 0.3em;
}
.page_school .campus_mv .campus_title h1 {
  font-size: clamp(22px, 2.6vw, 30px);
  font-weight: 700;
}
.page_school .page_school_inner {
  padding: 80px 0 120px;
  position: relative;
}
.page_school .page_school_inner.yellow {
  background: #fcffe6;
}
.page_school .page_school_inner.green {
  background: #edf8db;
}
.page_school .page_school_inner .section_radius {
  display: block;
  width: clamp(40px, 6vw, 100px);
  aspect-ratio: 1/1;
  position: absolute;
  top: 0;
  right: 0;
}
.page_school .page_school_inner .section_radius::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border-top-right-radius: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.page_school .page_school_inner .section_radius.white_yellow {
  background: #fff;
}
.page_school .page_school_inner .section_radius.white_yellow::before {
  background: #fcffe6;
}
.page_school .page_school_inner .section_radius.yellow_green {
  background: #fcffe6;
}
.page_school .page_school_inner .section_radius.yellow_green::before {
  background: #edf8db;
}
.page_school .page_school_inner .section_radius.white_green {
  background: #fff;
}
.page_school .page_school_inner .section_radius.white_green::before {
  background: #edf8db;
}
.page_school .page_school_inner .section_radius.green_yellow {
  background: #edf8db;
}
.page_school .page_school_inner .section_radius.green_yellow::before {
  background: #fcffe6;
}
.page_school .page_school_inner .section_radius.green_white {
  background: #edf8db;
}
.page_school .page_school_inner .section_radius.green_white::before {
  background: #fff;
}
.page_school .page_school_inner .section_radius.yellow_white {
  background: #fcffe6;
}
.page_school .page_school_inner .section_radius.yellow_white::before {
  background: #fff;
}
.page_school .page_school_inner .banner_link, .page_school .page_school_inner .table_box, .page_school .page_school_inner .program_link, .page_school .page_school_inner .grid_gallery, .page_school .page_school_inner .tab, .page_school .page_school_inner .video_mp4, .page_school .page_school_inner .schedule_img, .page_school .page_school_inner .special_activities, .page_school .page_school_inner .time_schedule, .page_school .page_school_inner .feature_list, .page_school .page_school_inner .list_box, .page_school .page_school_inner .txt_img_clm, .page_school .page_school_inner .img_clm, .page_school .page_school_inner .txt_box, .page_school .page_school_inner .img_box {
  max-width: 900px;
  margin: 0 auto;
  padding: 10px 20px;
}
.page_school .page_school_inner .img_box img {
  width: 100%;
  border-radius: 10px;
}
.page_school .page_school_inner .txt_box h3 {
  font-size: 20px;
  font-weight: 500;
  margin-bottom: 0.5em;
  padding-top: 1.5em;
}
.page_school .page_school_inner .txt_box h4 {
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 0.5em;
  padding-top: 1em;
}
.page_school .page_school_inner .txt_box p {
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 1em;
}
.page_school .page_school_inner .txt_box p a {
  text-decoration: underline;
  color: #249e49;
}
.page_school .page_school_inner .txt_box ul,
.page_school .page_school_inner .txt_box ol {
  padding-left: clamp(20px, 3vw, 40px);
}
.page_school .page_school_inner .txt_box ul li,
.page_school .page_school_inner .txt_box ol li {
  margin-bottom: 0.6em;
  font-size: 15px;
  line-height: 1.8;
}
.page_school .page_school_inner .txt_box ul li a,
.page_school .page_school_inner .txt_box ol li a {
  text-decoration: underline;
  color: #249e49;
}
.page_school .page_school_inner .txt_box ul li {
  list-style: disc;
}
.page_school .page_school_inner .img_clm {
  display: flex;
  gap: 20px;
}
.page_school .page_school_inner .img_clm .thumbnail {
  flex: 1;
}
.page_school .page_school_inner .img_clm .thumbnail img {
  width: 100%;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px;
}
.page_school .page_school_inner .txt_img_clm {
  display: flex;
  align-items: center;
  gap: 40px;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .txt_img_clm {
    flex-direction: column;
  }
}
.page_school .page_school_inner .txt_img_clm .txt {
  flex: 1;
}
.page_school .page_school_inner .txt_img_clm .txt p {
  line-height: 1.8;
  margin-bottom: 1em;
}
.page_school .page_school_inner .txt_img_clm .thumbnail {
  width: 35%;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .txt_img_clm .thumbnail {
    width: 100%;
  }
}
.page_school .page_school_inner .txt_img_clm .thumbnail img {
  width: 100%;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px;
}
.page_school .page_school_inner .list_box .item {
  background: #fff;
  border-radius: 10px;
  margin-bottom: 20px;
  padding-bottom: 20px;
}
.page_school .page_school_inner .list_box .item h3 {
  display: inline-block;
  max-width: 90%;
  font-size: 18px;
  font-weight: 500;
  margin-bottom: 1em;
  background: #249e49;
  color: #fff;
  padding: 0.5em 1em;
  border-radius: 10px 0 10px 0;
}
.page_school .page_school_inner .list_box .item .txt_box {
  padding: 10px clamp(20px, 3vw, 40px);
}
.page_school .page_school_inner .feature_list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: center;
}
.page_school .page_school_inner .feature_list .item {
  width: 27%;
  background: #fff;
  padding: 20px;
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .feature_list .item {
    width: 100%;
  }
}
.page_school .page_school_inner .feature_list .item .thumbnail {
  width: 100%;
  aspect-ratio: 4/3;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .feature_list .item .thumbnail {
    aspect-ratio: 5/3;
    width: 70%;
    margin: 0 auto;
  }
}
.page_school .page_school_inner .feature_list .item .thumbnail img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px;
}
.page_school .page_school_inner .feature_list .item .content h3 {
  font-size: 17px;
  font-weight: 500;
  text-align: center;
  margin-bottom: 0.5em;
  color: #249e49;
}
.page_school .page_school_inner .feature_list .item .content .txt {
  font-size: 15px;
  line-height: 1.8;
}
.page_school .page_school_inner .feature_list .item .content .txt a {
  text-decoration: underline;
  color: #249e49;
}
.page_school .page_school_inner .program_title {
  text-align: center;
  padding: clamp(20px, 3vw, 40px) 20px 20px;
}
.page_school .page_school_inner .program_title h2 {
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 700;
  color: #249e49;
}
.page_school .page_school_inner .time_schedule .time_schedule_inner {
  background: #fff;
  padding: 60px clamp(0px, 2vw, 40px) 60px;
  border-radius: 10px;
}
.page_school .page_school_inner .time_schedule .time_schedule_inner table {
  width: 100%;
  table-layout: fixed;
  border-spacing: 5px;
}
.page_school .page_school_inner .time_schedule .time_schedule_inner table td {
  font-weight: 500;
  text-align: center;
  border-radius: 5px;
  font-size: clamp(12px, 1.3vw, 14px);
  padding: 0.1em 0.5em;
  background: #dbeebb;
}
.page_school .page_school_inner .time_schedule .time_schedule_inner table td.none {
  font-size: 10px;
  opacity: 0;
}
.page_school .page_school_inner .time_schedule .time_schedule_inner table td.green {
  background: #5eb177;
  color: #fff;
}
.page_school .page_school_inner .time_schedule .time_schedule_inner table td.yellow {
  background: #ffffcf;
}
.page_school .page_school_inner .time_schedule .time_schedule_inner table thead td:first-child {
  width: clamp(40px, 5.5vw, 50px);
  background: none;
}
.page_school .page_school_inner .time_schedule .time_schedule_inner table thead td:not(:first-child) {
  background: #f74b01;
  padding: 0.5em;
  color: #fff;
  width: auto;
}
.page_school .page_school_inner .time_schedule .time_schedule_inner table tbody td:first-child {
  width: 50px;
  background: none;
}
.page_school .page_school_inner .time_schedule .time_schedule_inner table tbody td:not(:first-child) {
  width: auto;
}
.page_school .page_school_inner .special_activities .item {
  background: #fff;
  border-radius: 10px;
  margin-bottom: 20px;
  padding: clamp(20px, 3vw, 40px);
  display: flex;
  gap: 40px;
}
.page_school .page_school_inner .special_activities .item:nth-child(odd) {
  flex-direction: row-reverse;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .special_activities .item:nth-child(odd) {
    flex-direction: column;
    gap: 20px;
  }
}
@media (max-width: 800px) {
  .page_school .page_school_inner .special_activities .item {
    gap: 20px;
    flex-direction: column;
  }
}
.page_school .page_school_inner .special_activities .item .thumbnail {
  width: 30%;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .special_activities .item .thumbnail {
    width: 100%;
  }
}
.page_school .page_school_inner .special_activities .item .thumbnail img {
  width: 100%;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px;
}
.page_school .page_school_inner .special_activities .item .txt {
  flex: 1;
}
.page_school .page_school_inner .special_activities .item .txt h3 {
  font-size: 22px;
  font-weight: 500;
  margin-bottom: 0.5em;
  color: #249e49;
}
.page_school .page_school_inner .special_activities .item .txt h4 {
  font-weight: 500;
  color: #249e49;
  padding-top: 1em;
}
.page_school .page_school_inner .special_activities .item .txt p {
  font-size: 15px;
  line-height: 1.8;
}
.page_school .page_school_inner .special_activities .item .txt p a {
  text-decoration: underline;
  color: #249e49;
}
.page_school .page_school_inner .page_link {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 60px;
}
.page_school .page_school_inner .page_link a {
  display: flex;
  align-items: center;
  padding: 0.5em 1em;
  background: #249e49;
  color: #fff;
  border-radius: 5px;
  text-decoration: none;
  font-size: 14px;
  gap: 0.5em;
}
.page_school .page_school_inner .page_link a::after {
  content: "";
  display: block;
  width: 0.4em;
  height: 0.4em;
  border-bottom: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(45deg) translateY(-30%);
}
.page_school .page_school_inner .section_title {
  text-align: center;
  padding: clamp(60px, 8vw, 100px) 20px 20px;
}
.page_school .page_school_inner .section_title .en {
  color: #249e49;
  font-size: clamp(14px, 1.6vw, 20px);
  font-weight: 500;
  margin-bottom: 0.5em;
}
.page_school .page_school_inner .section_title h2 {
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 500;
}
.page_school .page_school_inner .schedule_img {
  border-radius: 10px;
  text-align: center;
}
.page_school .page_school_inner .schedule_img .schedule_img_inner {
  padding: 20px;
  background: #fff;
}
.page_school .page_school_inner .schedule_img .schedule_img_inner img {
  width: 100%;
}
.page_school .page_school_inner .schedule_img .schedule_img_inner img.sp {
  display: none;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .schedule_img .schedule_img_inner img.sp {
    display: block;
  }
}
.page_school .page_school_inner .schedule_img .schedule_img_inner img.pc {
  display: block;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .schedule_img .schedule_img_inner img.pc {
    display: none;
  }
}
.page_school .page_school_inner .link_btn {
  text-align: center;
  padding: 40px 0;
}
.page_school .page_school_inner .link_btn a {
  color: #249e49;
  text-decoration: none;
  font-size: 16px;
  font-weight: 500;
  background: #fff;
  border: 1px solid #249e49;
  margin: 0 0.5em 30px 0.5em;
  padding: 1em 2em;
  display: inline-block;
  border-radius: 10em;
}
.page_school .page_school_inner .video_mp4 {
  max-width: 800px;
  width: 90%;
  margin: 60px auto;
  aspect-ratio: 16/9;
  border-radius: 10px;
  overflow: hidden;
}
.page_school .page_school_inner .video_mp4 video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.page_school .page_school_inner .youtube {
  max-width: 800px;
  width: 90%;
  margin: 60px auto;
  position: relative;
  aspect-ratio: 16/9;
  border-radius: 10px;
  overflow: hidden;
}
.page_school .page_school_inner .youtube iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.page_school .page_school_inner .tab .tab_btn {
  display: flex;
  align-items: flex-end;
  padding: 0 20px;
  gap: 5px;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .tab .tab_btn {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    padding: 0;
    padding-bottom: 5px;
  }
}
.page_school .page_school_inner .tab .tab_btn .btn {
  font-size: 14px;
  padding: 0.5em 1em 0.8em;
  background: #fff;
  transform: translateY(5px);
  border: 1px solid #249e49;
  border-bottom: none;
  border-radius: 10px 10px 0 0;
  cursor: pointer;
  transition: all 0.3s ease;
  color: #249e49;
  font-weight: 500;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .tab .tab_btn .btn {
    transform: translateY(0);
    padding: 0.5em;
    border-radius: 10px;
    text-align: center;
    border-bottom: 1px solid #249e49;
  }
}
.page_school .page_school_inner .tab .tab_btn .btn.open {
  background: #249e49;
  transform: translateY(0);
  color: #fff;
  font-weight: 600;
}
.page_school .page_school_inner .tab .tab_inner {
  position: relative;
}
.page_school .page_school_inner .tab .tab_inner .item {
  display: none;
  padding: clamp(20px, 3vw, 30px);
  background: #fff;
  border: 1px solid #249e49;
  border-radius: 10px;
  align-items: flex-start;
  gap: 30px;
}
.page_school .page_school_inner .tab .tab_inner .item.open {
  display: flex;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .tab .tab_inner .item.open {
    flex-direction: column;
    align-items: center;
  }
}
.page_school .page_school_inner .tab .tab_inner .item .tab_content {
  flex: 1;
}
.page_school .page_school_inner .tab .tab_inner .item .tab_content h3 {
  font-size: 20px;
  font-weight: 500;
  margin-bottom: 0.4em;
  color: #249e49;
}
.page_school .page_school_inner .tab .tab_inner .item .tab_content .txt {
  font-size: 15px;
  line-height: 1.8;
}
.page_school .page_school_inner .tab .tab_inner .item img {
  width: 35%;
  height: auto;
  border-radius: 10px;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .tab .tab_inner .item img {
    width: 100%;
  }
}
.page_school .page_school_inner .grid_gallery {
  max-width: 1300px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(10px, 1.5vw, 20px);
}
@media (max-width: 1000px) {
  .page_school .page_school_inner .grid_gallery {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 800px) {
  .page_school .page_school_inner .grid_gallery {
    grid-template-columns: repeat(2, 1fr);
  }
}
.page_school .page_school_inner .grid_gallery .item {
  position: relative;
  aspect-ratio: 3/2;
}
.page_school .page_school_inner .grid_gallery .item img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: clamp(5px, 0.5vw, 10px);
}
.page_school .page_school_inner .grid_gallery .item span {
  max-width: 75%;
  font-size: clamp(12px, 1.3vw, 14px);
  font-weight: 500;
  padding: 0.4em 0.8em;
  background: #fff;
  border-radius: clamp(5px, 0.5vw, 10px);
  border-bottom-left-radius: 0;
  position: absolute;
  bottom: 0.6em;
  left: 0.6em;
}
.page_school .page_school_inner .program_link {
  max-width: 1300px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(10px, 1.5vw, 20px);
}
@media (max-width: 1000px) {
  .page_school .page_school_inner .program_link {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 800px) {
  .page_school .page_school_inner .program_link {
    grid-template-columns: repeat(1, 1fr);
  }
}
.page_school .page_school_inner .program_link .item {
  display: flex;
  flex-direction: column;
}
.page_school .page_school_inner .program_link .item a {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  background: #fff;
  border-radius: 20px 20px 20px 0;
  padding: 20px;
  flex: 1;
  text-decoration: none;
  color: #000;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .program_link .item a {
    display: flex;
    flex-direction: row;
    padding: 10px;
  }
}
.page_school .page_school_inner .program_link .item a .thumbnail {
  width: 100%;
  aspect-ratio: 3/2;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .program_link .item a .thumbnail {
    width: 30%;
    aspect-ratio: 4/3;
  }
}
.page_school .page_school_inner .program_link .item a .thumbnail img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 10px;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .program_link .item a .thumbnail img {
    border-radius: 10px 10px 10px 0;
  }
}
.page_school .page_school_inner .program_link .item a .txt {
  flex: 1;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1em;
  font-size: clamp(14px, 1.5vw, 15px);
}
@media (max-width: 800px) {
  .page_school .page_school_inner .program_link .item a .txt {
    align-items: center;
  }
}
.page_school .page_school_inner .program_link .item a .txt .name {
  flex: 1;
  font-weight: 500;
}
.page_school .page_school_inner .program_link .item a .txt .arrow {
  display: block;
  width: 2em;
  aspect-ratio: 1/1;
  background: #249e49;
  border-radius: 50%;
  position: relative;
}
.page_school .page_school_inner .program_link .item a .txt .arrow::before {
  content: "";
  width: 20%;
  height: 20%;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 10%;
  margin: auto;
}
.page_school .page_school_inner .table_box .table_inner {
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid #249e49;
}
.page_school .page_school_inner .table_box .table_inner table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
}
.page_school .page_school_inner .table_box .table_inner table thead tr th,
.page_school .page_school_inner .table_box .table_inner table thead tr td {
  background: #f9ffee;
  text-align: center;
  border-bottom: 1px solid #249e49;
  border-left: 1px solid #249e49;
}
.page_school .page_school_inner .table_box .table_inner table thead tr th:first-child,
.page_school .page_school_inner .table_box .table_inner table thead tr td:first-child {
  border-left: none;
}
.page_school .page_school_inner .table_box .table_inner table tr:not(:last-child) th,
.page_school .page_school_inner .table_box .table_inner table tr:not(:last-child) td {
  border-bottom: 1px solid #249e49;
}
.page_school .page_school_inner .table_box .table_inner table tr th,
.page_school .page_school_inner .table_box .table_inner table tr td {
  vertical-align: middle;
  text-align: left;
  padding: 0.8em 1.5em;
  font-size: clamp(13px, 1.4vw, 15px);
  line-height: 1.8;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .table_box .table_inner table tr th,
  .page_school .page_school_inner .table_box .table_inner table tr td {
    padding: 0.6em 0.8em;
  }
}
.page_school .page_school_inner .table_box .table_inner table tr th a,
.page_school .page_school_inner .table_box .table_inner table tr td a {
  text-decoration: underline;
  color: #249e49;
}
.page_school .page_school_inner .table_box .table_inner table tr th {
  background: #f9ffee;
  font-weight: 500;
  width: 1%;
  white-space: nowrap;
}
.page_school .page_school_inner .table_box .table_inner table tr td {
  border-left: 1px solid #249e49;
}
.page_school .page_school_inner .table_box.timetable .table_inner table tr th,
.page_school .page_school_inner .table_box.timetable .table_inner table tr td {
  text-align: center;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .table_box.scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-left: 0;
    padding-right: 0;
  }
  .page_school .page_school_inner .table_box.scroll .table_inner {
    margin: 0 20px;
    min-width: 700px;
  }
}
.page_school .page_school_inner .banner_link {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(10px, 1.5vw, 20px);
  padding-top: 40px;
}
@media (max-width: 800px) {
  .page_school .page_school_inner .banner_link {
    grid-template-columns: repeat(2, 1fr);
  }
}
.page_school .page_school_inner .banner_link a {
  flex: 1;
}
.page_school .page_school_inner .banner_link a img {
  width: 100%;
  height: auto;
}

.page_post_index {
  margin-bottom: 100px;
}
.page_post_index .page_title {
  text-align: center;
  padding: clamp(60px, 8vw, 100px) 20px 20px;
}
.page_post_index .page_title .en {
  color: #249e49;
  font-size: clamp(14px, 1.6vw, 20px);
  font-weight: 500;
  margin-bottom: 0.5em;
}
.page_post_index .page_title h2 {
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 500;
}
.page_post_index .post_category {
  max-width: 800px;
  padding: 20px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 14px;
}
.page_post_index .post_category a {
  text-decoration: none;
  color: #249e49;
  border: solid 1px #249e49;
  padding: 0.5em 1em;
  border-radius: 10em;
  transition: 0.2s;
}
.page_post_index .post_category a.current {
  background: #edf8db;
}
.page_post_index .post_category a:hover {
  background: #edf8db;
}
.page_post_index .post {
  max-width: 900px;
  padding: 20px;
  margin: 0 auto;
}
.page_post_index .post .item {
  background-image: repeating-linear-gradient(90deg, #249e49, #249e49 6px, transparent 6px, transparent 12px);
  background-position: left top;
  background-repeat: repeat-x;
  background-size: 100% 1px;
  position: relative;
  padding: 30px 60px 30px 0;
}
.page_post_index .post .item:last-child {
  background-image: repeating-linear-gradient(90deg, #249e49, #249e49 6px, transparent 6px, transparent 12px), repeating-linear-gradient(90deg, #249e49, #249e49 6px, transparent 6px, transparent 12px);
  background-position: left top, left bottom;
  background-repeat: repeat-x, repeat-x;
  background-size: 100% 1px, 100% 1px;
}
.page_post_index .post .item::before, .page_post_index .post .item::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  transition: 0.2s;
}
.page_post_index .post .item::before {
  width: 1.6em;
  height: 1.6em;
  background: #249e49;
  right: 1em;
  border-radius: 100%;
  border: solid 1px #249e49;
}
.page_post_index .post .item::after {
  width: 0.4em;
  height: 0.4em;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(45deg);
  right: 1.7em;
}
.page_post_index .post .item .data {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 0.5em 0.6em;
  margin-bottom: 10px;
  font-size: clamp(10px, 1.2vw, 14px);
}
.page_post_index .post .item .data .day {
  padding-top: 0.2em;
}
.page_post_index .post .item .data .category {
  padding: 0.2em 0.8em 0.3em;
  border-radius: 10em;
}
.page_post_index .post .item .data .category.green {
  color: #249e49;
  border: solid 1px #249e49;
}
.page_post_index .post .item .data .category.red {
  color: #f74b01;
  border: solid 1px #f74b01;
}
.page_post_index .post .item .data .category.yellow {
  color: #ecb100;
  border: solid 1px #ecb100;
}
.page_post_index .post .item .data .category.mint {
  color: #7ac301;
  border: solid 1px #7ac301;
}
.page_post_index .post .item .data .category.blue {
  color: #01adea;
  border: solid 1px #01adea;
}
.page_post_index .post .item .title a {
  font-size: clamp(14px, 1.5vw, 16px);
  font-weight: 500;
  color: #000;
  text-decoration: none;
}

.page_document {
  margin-bottom: 100px;
}
.page_document .page_title {
  text-align: center;
  padding: clamp(60px, 8vw, 100px) 20px 20px;
}
.page_document .page_title .en {
  color: #249e49;
  font-size: clamp(14px, 1.6vw, 20px);
  font-weight: 500;
  margin-bottom: 0.5em;
}
.page_document .document_inner {
  max-width: 900px;
  padding: 20px;
  margin: 0 auto;
}
.page_document .document_inner h1 {
  font-size: 28px;
  font-weight: 500;
  color: #249e49;
  padding: 2em 0 1em;
}
.page_document .document_inner h2 {
  font-size: 24px;
  font-weight: 500;
  color: #249e49;
  padding: 2em 0 1em;
}
.page_document .document_inner h3 {
  font-size: 22px;
  font-weight: 500;
  padding: 1.5em 0 1em;
}
.page_document .document_inner ul,
.page_document .document_inner ol {
  margin-bottom: 2em;
  padding-left: 2em;
}
.page_document .document_inner ul li,
.page_document .document_inner ol li {
  line-height: 1.8;
  margin-bottom: 0.5em;
}
.page_document .document_inner ul {
  list-style: disc;
  font-size: 16px;
}
.page_document .document_inner ol {
  list-style: decimal;
  font-size: 16px;
}
.page_document .document_inner p {
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 1em;
}
.page_document .document_inner a {
  text-decoration: underline;
  color: #249e49;
}

.footer_sns {
  background: #daecb9;
  padding: 40px 20px 60px;
  text-align: center;
  border-top: solid 2px #249e49;
}
.footer_sns .title {
  color: #249e49;
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 30px;
}
.footer_sns .sns_buttons {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: clamp(10px, 1.5vw, 20px);
  flex-wrap: wrap;
  max-width: 1000px;
  margin: 0 auto;
}
.footer_sns .sns_buttons a {
  font-size: 16px;
  flex: 1;
  display: flex;
  align-items: center;
  background: #fff;
  padding: 0.5em;
  border-radius: 10em;
  text-decoration: none;
  color: #000;
  font-weight: 500;
  transition: 0.3s;
}
.footer_sns .sns_buttons a img {
  width: 2.5em;
  display: block;
}
.footer_sns .sns_buttons a span {
  flex: 1;
  text-align: center;
  padding: 0 0.5em;
}

footer .inner {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.wp-pagenavi {
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  margin: 20px 0 50px;
}
.wp-pagenavi .pages {
  display: none;
}
.wp-pagenavi .extend,
.wp-pagenavi .first,
.wp-pagenavi .last {
  padding: 3px 5px;
}
.wp-pagenavi a {
  color: #249e49;
  margin: 0 10px;
  padding: 3px;
  text-decoration: none;
}
.wp-pagenavi a:hover {
  border-bottom: solid 2px #249e49;
}
.wp-pagenavi .current {
  border-bottom: solid 2px #249e49;
  color: #249e49;
  margin: 0 10px;
  padding: 3px;
}
.wp-pagenavi .extend {
  color: #999 !important;
  margin: 0 5px 0 0;
  padding: 3px 5px;
}

.page_interview_index .page_title {
  text-align: center;
  padding: clamp(60px, 8vw, 100px) 20px 20px;
}
.page_interview_index .page_title .en {
  color: #249e49;
  font-size: clamp(14px, 1.6vw, 20px);
  font-weight: 500;
  margin-bottom: 0.5em;
}
.page_interview_index .page_title h2 {
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 500;
}
.page_interview_index .post_category {
  max-width: 800px;
  padding: 20px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 14px;
}
.page_interview_index .post_category a {
  text-decoration: none;
  color: #249e49;
  border: solid 1px #249e49;
  padding: 0.5em 1em;
  border-radius: 10em;
  transition: 0.2s;
}
.page_interview_index .post_category a.current {
  background: #edf8db;
}
.page_interview_index .post_category a:hover {
  background: #edf8db;
}
.page_interview_index .interview_list {
  max-width: 900px;
  padding: 20px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
@media (max-width: 800px) {
  .page_interview_index .interview_list {
    grid-template-columns: repeat(2, 1fr);
  }
}
.page_interview_index .interview_list .item .photo {
  margin-bottom: 15px;
}
.page_interview_index .interview_list .item .photo img {
  aspect-ratio: 37/42;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  border-top-right-radius: 40px;
}
.page_interview_index .interview_list .item .genre {
  font-size: 14px;
}
.page_interview_index .interview_list .item .btn a {
  display: block;
  position: relative;
  padding: 0.2em 2.5em 0.2em 0;
  font-size: clamp(16px, 1.8vw, 20px);
  color: #249e49;
  font-weight: 500;
  text-decoration: none;
}
.page_interview_index .interview_list .item .btn a::before, .page_interview_index .interview_list .item .btn a::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  transition: 0.2s;
}
.page_interview_index .interview_list .item .btn a::before {
  width: 1.6em;
  height: 1.6em;
  background: #249e49;
  right: 0.3em;
  border-radius: 100%;
  border: solid 1px #249e49;
}
.page_interview_index .interview_list .item .btn a::after {
  width: 0.4em;
  height: 0.4em;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(45deg);
  right: 1em;
}

.page_single {
  max-width: 900px;
  padding: 80px 20px 160px;
  margin: 0 auto;
}
.page_single .category {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 14px;
  margin-bottom: 40px;
}
.page_single .category span {
  color: #249e49;
  border: solid 1px #249e49;
  padding: 0.3em 0.8em;
  border-radius: 10em;
}
.page_single .category span:hover {
  background: #edf8db;
}
.page_single .single_article .wp-block-columns {
  gap: 40px;
}
.page_single .single_article h1,
.page_single .single_article h2,
.page_single .single_article h3,
.page_single .single_article h4,
.page_single .single_article h5,
.page_single .single_article h6 {
  padding: 1em 0 0.5em;
}
.page_single .single_article h1 {
  font-size: clamp(26px, 2.8vw, 30px);
  color: #249e49;
  line-height: 1.5;
  text-align: center;
}
.page_single .single_article h2 {
  font-size: 24px;
  color: #249e49;
  margin: 0.9em 0;
  line-height: 1.5;
}
.page_single .single_article h3 {
  font-size: 22px;
  color: #249e49;
  margin: 0.8em 0;
  line-height: 1.5;
}
.page_single .single_article h4 {
  font-size: 20px;
  margin: 0.7em 0;
  line-height: 1.5;
}
.page_single .single_article h5 {
  font-size: 18px;
  margin: 0.6em 0;
  line-height: 1.5;
}
.page_single .single_article h6 {
  font-size: 16px;
  margin: 0.5em 0;
  line-height: 1.5;
}
.page_single .single_article p {
  margin: 1em 0;
  line-height: 1.8;
}
.page_single .single_article a {
  color: #249e49;
}
.page_single .single_article ul {
  margin: 1em 0;
  padding-left: 2em;
  list-style-type: disc;
}
.page_single .single_article ol {
  margin: 1em 0;
  padding-left: 2em;
  list-style-type: decimal;
}
.page_single .single_article li {
  margin: 0.5em 0;
  line-height: 1.8;
}
.page_single .single_article img {
  max-width: 100%;
  height: auto;
  display: block;
  border-radius: 10px;
}
.page_single .single_article hr {
  border: none;
  border-top: 2px dashed #249e49;
  margin: 2em 0;
}
.page_single .single_article table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 20px;
}
.page_single .single_article table th,
.page_single .single_article table td {
  padding: 0.8em;
  border: 1px solid #249e49;
}
.page_single .single_article table th:first-child,
.page_single .single_article table td:first-child {
  background-color: #f9ffee;
}

.page_about .page_title {
  text-align: center;
  padding: clamp(60px, 8vw, 100px) 20px 20px;
}
.page_about .page_title .en {
  color: #249e49;
  font-size: clamp(14px, 1.6vw, 20px);
  font-weight: 500;
  margin-bottom: 0.5em;
}
.page_about .page_title h2 {
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 500;
}
.page_about .page_nav {
  display: flex;
  justify-content: center;
  gap: clamp(10px, 1.3vw, 15px);
  flex-wrap: wrap;
  padding-top: 20px;
}
.page_about .page_nav a {
  display: flex;
  align-items: center;
  padding: 0.8em 1em;
  border: 2px solid #249e49;
  color: #000;
  border-radius: 10px 10px 10px 0;
  text-decoration: none;
  font-size: clamp(14px, 1.5vw, 16px);
  font-weight: 500;
  gap: 20px;
}
.page_about .page_nav a::after {
  content: "";
  display: block;
  width: 0.4em;
  height: 0.4em;
  border-bottom: solid 2px #000;
  border-right: solid 2px #000;
  transform: rotate(45deg) translateY(-30%);
}
.page_about .page_about_title {
  text-align: center;
  padding: clamp(60px, 8vw, 100px) 20px 20px;
}
.page_about .page_about_title h2 {
  font-size: clamp(26px, 2.8vw, 40px);
  font-weight: 700;
  color: #249e49;
}
.page_about .section_title {
  text-align: center;
  padding: clamp(60px, 8vw, 100px) 20px 20px;
}
.page_about .section_title .en {
  color: #249e49;
  font-size: clamp(14px, 1.6vw, 20px);
  font-weight: 500;
  margin-bottom: 0.5em;
}
.page_about .section_title h2 {
  font-size: clamp(22px, 2.4vw, 28px);
  font-weight: 500;
}
.page_about .yellow {
  background: #fcffe6;
}
.page_about .green {
  background: #edf8db;
}
.page_about .section_radius {
  display: block;
  width: clamp(40px, 6vw, 100px);
  aspect-ratio: 1/1;
  position: absolute;
  top: 0;
  right: 0;
}
.page_about .section_radius::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border-top-right-radius: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.page_about .section_radius.white_yellow {
  background: #fff;
}
.page_about .section_radius.white_yellow::before {
  background: #fcffe6;
}
.page_about .section_radius.yellow_green {
  background: #fcffe6;
}
.page_about .section_radius.yellow_green::before {
  background: #edf8db;
}
.page_about .section_radius.white_green {
  background: #fff;
}
.page_about .section_radius.white_green::before {
  background: #edf8db;
}
.page_about .section_radius.green_yellow {
  background: #edf8db;
}
.page_about .section_radius.green_yellow::before {
  background: #fcffe6;
}
.page_about .section_radius.green_white {
  background: #edf8db;
}
.page_about .section_radius.green_white::before {
  background: #fff;
}
.page_about .section_radius.yellow_white {
  background: #fcffe6;
}
.page_about .section_radius.yellow_white::before {
  background: #fff;
}
.page_about .table_box .table_inner {
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid #249e49;
}
.page_about .table_box .table_inner table {
  width: 100%;
  border-collapse: collapse;
  background: #fff;
}
.page_about .table_box .table_inner table thead tr th,
.page_about .table_box .table_inner table thead tr td {
  background: #f9ffee;
  text-align: center;
  border-bottom: 1px solid #249e49;
  border-left: 1px solid #249e49;
}
.page_about .table_box .table_inner table thead tr th:first-child,
.page_about .table_box .table_inner table thead tr td:first-child {
  border-left: none;
}
.page_about .table_box .table_inner table tr:not(:last-child) th,
.page_about .table_box .table_inner table tr:not(:last-child) td {
  border-bottom: 1px solid #249e49;
}
.page_about .table_box .table_inner table tr th,
.page_about .table_box .table_inner table tr td {
  vertical-align: middle;
  text-align: left;
  padding: 0.8em 1.5em;
  font-size: clamp(13px, 1.4vw, 15px);
  line-height: 1.8;
}
@media (max-width: 800px) {
  .page_about .table_box .table_inner table tr th,
  .page_about .table_box .table_inner table tr td {
    padding: 0.6em 0.8em;
  }
}
.page_about .table_box .table_inner table tr th a,
.page_about .table_box .table_inner table tr td a {
  text-decoration: underline;
  color: #249e49;
}
.page_about .table_box .table_inner table tr th {
  background: #f9ffee;
  font-weight: 500;
  width: 1%;
  white-space: nowrap;
}
.page_about .table_box .table_inner table tr td {
  border-left: 1px solid #249e49;
}
.page_about .table_box.timetable .table_inner table tr th,
.page_about .table_box.timetable .table_inner table tr td {
  text-align: center;
}
@media (max-width: 800px) {
  .page_about .table_box.scroll {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-left: 0;
    padding-right: 0;
  }
  .page_about .table_box.scroll .table_inner {
    margin: 0 20px;
    min-width: 700px;
  }
}
.page_about #section_about {
  padding-bottom: 100px;
}
.page_about #section_about .inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 20px;
}
.page_about #section_about .inner h3 {
  font-size: clamp(20px, 2.2vw, 22px);
  font-weight: 700;
  color: #249e49;
  padding: 1.5em 0 1em;
}
.page_about #section_about .inner p {
  line-height: 1.8;
  font-size: 16px;
}
.page_about #section_message {
  padding-bottom: 100px;
  position: relative;
}
.page_about #section_message .inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 20px;
  display: flex;
  gap: 40px;
}
@media (max-width: 800px) {
  .page_about #section_message .inner {
    flex-direction: column;
    align-items: center;
  }
}
.page_about #section_message .inner .photo {
  width: 35%;
}
@media (max-width: 800px) {
  .page_about #section_message .inner .photo {
    width: 80%;
  }
}
.page_about #section_message .inner .photo img {
  width: 100%;
  border-radius: 10px;
}
.page_about #section_message .inner .txt {
  flex: 1;
}
.page_about #section_message .inner .txt p {
  line-height: 1.8;
  font-size: 16px;
  margin-bottom: 1em;
}
.page_about #section_message .inner .txt .name {
  font-size: 16px;
  text-align: right;
}
.page_about #section_overview {
  padding-bottom: 100px;
  position: relative;
}
.page_about #section_overview .page_link {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: center;
}
.page_about #section_overview .page_link a {
  display: flex;
  align-items: center;
  padding: 0.5em 1em;
  background: #249e49;
  color: #fff;
  border-radius: 5px;
  text-decoration: none;
  font-size: 14px;
  gap: 0.5em;
}
.page_about #section_overview .page_link a::after {
  content: "";
  display: block;
  width: 0.4em;
  height: 0.4em;
  border-bottom: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(45deg) translateY(-30%);
}
.page_about #section_overview .inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 20px;
}
.page_about #section_history {
  padding-bottom: 100px;
  position: relative;
}
.page_about #section_history .inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 20px;
}
.page_about #section_history .inner .history_contents {
  position: relative;
  max-height: 750px;
  overflow: hidden;
  transition: max-height 0.5s ease;
}
.page_about #section_history .inner .history_contents.show_all {
  max-height: none;
}
.page_about #section_history .inner .history_contents.show_all .more {
  display: none;
}
.page_about #section_history .inner .history_contents .more {
  text-align: center;
  padding: 20px;
  cursor: pointer;
  color: #249e49;
  font-weight: 500;
  font-size: 16px;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.95) 30%, #fff);
  padding-top: 100px;
  transition: opacity 0.3s ease;
}
.page_about #section_history .inner .history_contents .more span {
  border: solid 1px #249e49;
  border-radius: 10em;
  padding: 1em 2em;
  display: inline-block;
  transition: all 0.3s ease;
}/*# sourceMappingURL=style.css.map */

/* added */
.page_interview_index .interview_list .item .photo img{
    height: auto;	
}