/*!**************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[2].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[2].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[2].use[3]!./scss/top.scss ***!
  \**************************************************************************************************************************************************************************************************************************************/
@import url(https://fonts.googleapis.com/css2?family=Kumbh+Sans:wght@700&family=Noto+Sans+JP:wght@400;500;700&display=swap);
/*!******************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[2].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[2].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[2].use[3]!./scss/top.scss (1) ***!
  \******************************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
/* -------------------------------------------------------------------
  default colors
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  default web-font
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  default spacing
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  hover anitionの適用（～xまで）
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  default font-size
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  background
------------------------------------------------------------------- */
.background.--base {
  background-color: #F7F7F7;
}
.background.--white {
  background-color: white;
}
.background.--main {
  background-color: #FE7CAF;
}

/* -------------------------------------------------------------------
  display
------------------------------------------------------------------- */
.d-inline {
  display: inline;
}
.d-inline-block {
  display: inline-block;
}
.d-block {
  display: block;
}
.d-flex {
  display: flex;
}

/* -------------------------------------------------------------------
  show and hide
------------------------------------------------------------------- */
@media screen and (min-width: 769px) {
  .--sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .--pc {
    display: none !important;
  }
}
/* -------------------------------------------------------------------
  font rem計算
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  各種rem計算（font以外）
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  flex時のgapを差し引いた横幅計算
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  アスペクト比固定
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  vw変換
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  margin / padding
------------------------------------------------------------------- */
.mt-0 {
  margin-top: 0rem !important;
}

.mr-0 {
  margin-right: 0rem !important;
}

.mb-0 {
  margin-bottom: 0rem !important;
}

.ml-0 {
  margin-left: 0rem !important;
}

.mx-0 {
  margin-left: 0rem !important;
  margin-right: 0rem !important;
}

.my-0 {
  margin-top: 0rem !important;
  margin-bottom: 0rem !important;
}

.ma-0 {
  margin: 0rem !important;
}

.pt-0 {
  padding-top: 0rem !important;
}

.pr {
  padding-right: min(1.25rem, 3.2vw);
}
.pr-0 {
  padding-right: 0rem !important;
}

.pb-0 {
  padding-bottom: 0rem !important;
}

.pl {
  padding-left: min(1.25rem, 3.2vw);
}
.pl-0 {
  padding-left: 0rem !important;
}

.px {
  padding-inline: min(1.25rem, 3.2vw);
}
.px-0 {
  padding-left: 0rem !important;
  padding-right: 0rem !important;
}

.py-0 {
  padding-top: 0rem !important;
  padding-bottom: 0rem !important;
}

.pa-0 {
  padding: 0rem !important;
}

/* -------------------------------------------------------------------
  label
------------------------------------------------------------------- */
.label, .content-course__meta-label, .content-news__category, .post-content__meta-label,
.editor-area__meta-label, .header__catch-label__label {
  display: inline-block;
  border-radius: 8px;
  padding: 0.2rem 0.5rem;
  background-color: #E3E1E2;
  font-size: 0.75rem;
  min-width: -webkit-max-content;
  min-width: -moz-max-content;
  min-width: max-content;
  text-align: center;
}
.label-block, .content-voice__label, .content-class__label {
  flex-shrink: 0;
  display: inline-block;
  padding: 0.25rem 0.5rem;
  background-color: #EF4D36;
  color: white;
}
.--osaka .label-block, .--osaka .content-voice__label, .--osaka .content-class__label {
  background-color: #FDC00E;
}
.label-fukidashi, .top-event__label, .footer-banners__title span {
  position: relative;
  display: inline-block;
  padding: 0.25rem 2rem;
  border-radius: 0.5rem;
  color: #7DCEF4;
  font-weight: bold;
  font-size: min(2.25rem, 4.2666666667vw);
  background-color: white;
  border: 2px solid #7DCEF4;
}
.label-fukidashi::after, .top-event__label::after, .footer-banners__title span::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 100%);
  display: block;
  width: 0;
  height: 0;
  border-top: min(1.5rem, 2.1333333333vw) solid white;
  border-right: min(1.5rem, 2.1333333333vw) solid transparent;
  border-bottom: 0 solid transparent;
  border-left: min(1.5rem, 2.1333333333vw) solid transparent;
}
.label-mini {
  display: grid;
  align-self: baseline;
  display: inline-block;
  font-weight: bold;
  font-size: 0.625rem;
  padding: 0.25em 1em;
  background-color: #FF3685;
  color: white;
  border-radius: 0.25rem;
}

/* -------------------------------------------------------------------
  header
------------------------------------------------------------------- */
.header {
  position: relative;
  z-index: 9999;
}
.header__group {
  position: relative;
  z-index: 10;
  display: grid;
  grid-template-areas: "logo nav-btn" "catch-group catch-group";
  padding: 0.5rem 0 0.5rem 0.75rem;
  background-color: white;
}
.header__logo {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: logo;
  align-self: center;
}
.header__catch {
  margin: 0;
  font-size: min(1.25rem, 3.2vw);
  color: #FE7CAF;
  text-align: center;
  font-weight: normal;
}
.header__catch-group {
  -ms-grid-row: 2;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
  grid-area: catch-group;
}
.header__catch-label {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
  font-weight: bold;
}
.header__catch-label__label {
  background-color: rgba(255, 54, 133, 0.08);
  color: #FF3685;
}
.header__catch-label__text {
  font-size: 1.125rem;
  color: #FF3685;
}
.header__nav-btn {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
  grid-area: nav-btn;
  align-self: center;
  justify-self: self-end;
}
.header-btn {
  position: fixed;
  width: 100%;
  bottom: 0;
  left: 0;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 2px;
  padding: 4px 2px 2px;
  background-color: white;
}
.--on .header-btn {
  display: none;
}
.header-btn__item {
  display: grid;
  grid-template-columns: 1fr;
  place-items: center;
  border-radius: 0.5rem;
  border: 2px solid #FE7CAF;
  padding-block: 0.5rem 0.25rem;
  font-size: 14px;
  font-weight: bold;
  text-decoration: none;
}
.header-btn__item.--myclass {
  font-size: 12px;
}
.header-btn__item.--blue, .header-btn__item.--pink {
  color: white;
}
.header-btn__item.--blue {
  border-color: #7DCEF4;
  background-color: #7DCEF4;
}
.header-btn__item.--pink {
  border-color: #FF3685;
  background-color: #FF3685;
}
.header-btn__item i {
  font-size: 1.25rem;
  line-height: 1;
}
.header__group.--clone {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  width: 100%;
  transform: translateY(-120%);
  transition: 0.5s linear transform;
  box-shadow: 0 4px 4px rgba(87, 86, 87, 0.3);
}
.header__group.--clone.scroll-on {
  transform: translateY(0%);
}
.header__group.--clone .header-btn,
.header__group.--clone .header__catch-group {
  display: none;
}

@media screen and (min-width: 600px) {
  .header-btn__item {
    transition: 0.5s linear color, 0.5s linear background-color;
  }
  .header-btn__item i::before {
    transition: 0.5s linear color;
  }
  .header-btn__item:hover {
    color: white;
    background-color: #FE7CAF;
  }
  .header-btn__item:hover i::before {
    color: white;
  }
  .header-btn__item.--blue:hover {
    background-color: white;
    color: #7DCEF4;
  }
  .header-btn__item.--blue:hover i::before {
    color: #7DCEF4;
  }
  .header-btn__item.--pink:hover {
    background-color: white;
    color: #FF3685;
  }
  .header-btn__item.--pink:hover i::before {
    color: #FF3685;
  }
}
@media screen and (min-width: 1024px) {
  .header__group {
    grid-template-areas: "logo catch-group btn nav-btn";
    grid-template-columns: -webkit-max-content 1fr -webkit-max-content;
    grid-template-columns: max-content 1fr max-content;
    padding: 0 0.25rem 0 2rem;
  }
  .header__catch {
    color: #575657;
    font-size: min(1.25rem, 1.5625vw);
  }
  .header__catch-group {
    -ms-grid-row: 2;
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
    grid-area: catch-group;
    display: flex;
    justify-content: center;
    flex-direction: column;
    gap: 0;
  }
  .header__catch-label {
    display: flex;
  }
  .header-btn {
    grid-area: btn;
    position: relative;
    bottom: auto;
    left: auto;
    display: flex;
    justify-content: flex-end;
    width: auto;
    padding-right: 0;
    background-color: transparent;
  }
  .header-btn__item {
    width: 72px;
  }
  .header__group.--clone .header-btn {
    display: flex;
  }
  .header__logo {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .header__catch-group {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
  }
  .header__nav-btn {
    -ms-grid-row: 1;
    -ms-grid-column: 4;
  }
}
@media screen and (max-width: 1023px) {
  .header-btn {
    transform: translateY(100%);
    transition: 0.5s linear transform;
  }
  .header-btn.scroll-on {
    transform: translateY(0%);
  }
  .header__group {
    box-shadow: 0 4px 4px rgba(87, 86, 87, 0.3);
  }
}
/* -------------------------------------------------------------------
  layout
------------------------------------------------------------------- */
.section {
  padding-bottom: min(5rem, 17.0666666667vw);
}

.inner {
  width: 1080px;
  max-width: 100%;
  margin-inline: auto;
  padding-bottom: 2.5rem;
}
.inner__narrow, .content-big-image__inner {
  width: 800px;
  max-width: 100%;
  margin-inline: auto;
  padding-bottom: 2.5rem;
  padding-inline: min(1.25rem, 3.2vw);
}

@media screen and (max-width: 767px) {
  .inner__narrow.--sp-pd-inline-0, .--sp-pd-inline-0.content-big-image__inner {
    padding-inline: 0;
  }
}
/* -------------------------------------------------------------------
  banner
------------------------------------------------------------------- */
.banner, .common-event-banner__item-img, .top-head-banners__img, .sidebar .wp-block-image img, .footer-recommend-banners__img,
.footer-mov-banners__img {
  width: 335px;
  height: auto;
  border-radius: 8px;
  box-shadow: 2px 4px 4px rgba(87, 86, 87, 0.3);
}

/* -------------------------------------------------------------------
  768px以上
------------------------------------------------------------------- */
@media screen and (min-width: 768px) {
  .banner, .common-event-banner__item-img, .top-head-banners__img, .sidebar .wp-block-image img, .footer-recommend-banners__img,
  .footer-mov-banners__img {
    width: 305px;
  }
}
/* -------------------------------------------------------------------
  footer
------------------------------------------------------------------- */
.footer__logo {
  text-align: center;
  padding-block: 0.5rem;
}
.footer__bottom {
  background-color: #E3E1E2;
}
.footer__bottom__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.875rem;
  padding-inline: 0.75rem;
  padding-top: 1.5rem;
}
.footer__bottom__nav {
  list-style-type: none;
  margin: 0;
  padding: 0;
  display: flex;
  gap: 1.25rem;
}
.footer__bottom__nav li:not(:first-child)::before {
  content: "|";
  margin-right: 1.25rem;
}
.footer__bottom__nav a {
  font-size: 0.812rem;
  color: #575657;
  text-decoration: none;
}
.footer__bottom__privacy {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  max-width: 78%;
}
.footer__bottom__privacy-text {
  font-size: min(13px, 2.6666666667vw);
}
.footer__bottom__privacy-link {
  flex-shrink: 0;
}
.footer__bottom__copy {
  padding: 9px;
}
.footer__bottom__copy-text {
  font-size: min(13px, 2.9333333333vw);
}

.footer__nav-sp__ul, .header__nav-sp__ul, .footer__nav-pc__ul {
  margin: 0;
  padding: 0;
  list-style-type: none;
}
.footer__nav-sp__ul a, .header__nav-sp__ul a, .footer__nav-pc__ul a {
  display: block;
  color: #575657;
  text-decoration: none;
}
.footer__nav-sp__ul .sub-menu, .header__nav-sp__ul .sub-menu, .footer__nav-pc__ul .sub-menu {
  margin: 0;
  padding: 0;
  list-style-type: none;
}
.footer__nav-pc {
  display: none;
}
.footer__nav-sp__ul, .header__nav-sp__ul {
  border-top: 1px solid #E3E1E2;
}
.footer__nav-sp__ul a, .header__nav-sp__ul a {
  font-size: 1rem;
  font-weight: 700;
}
.footer__nav-sp__ul a[target=_blank], .header__nav-sp__ul a[target=_blank] {
  display: flex;
  width: 100%;
  gap: 0.75rem;
  justify-content: space-between;
}
.footer__nav-sp__ul a[target=_blank]::after, .header__nav-sp__ul a[target=_blank]::after {
  content: "\e908";
  color: #FE7CAF;
  font-weight: normal;
  font-family: icomoon;
}
.footer__nav-sp__ul > li > a, .header__nav-sp__ul > li > a {
  border-bottom: 1px solid #E3E1E2;
  padding: 1rem 0.75rem;
}
.footer__nav-sp__ul .sub-menu, .header__nav-sp__ul .sub-menu {
  display: none;
  padding: 1rem 1rem 1rem 1.5rem;
  border-bottom: 1px solid #E3E1E2;
}
.footer__nav-sp__ul .sub-menu li, .header__nav-sp__ul .sub-menu li {
  display: flex;
  gap: 0.5rem;
  padding-bottom: 1rem;
}
.footer__nav-sp__ul .sub-menu li:last-child, .header__nav-sp__ul .sub-menu li:last-child {
  padding-bottom: 0;
}
.footer__nav-sp__ul .sub-menu li::before, .header__nav-sp__ul .sub-menu li::before {
  content: "-";
}
.footer__nav-sp__ul .menu-item-has-children > a, .header__nav-sp__ul .menu-item-has-children > a {
  display: flex;
  width: 100%;
  justify-content: space-between;
}
.footer__nav-sp__ul .menu-item-has-children > a::after, .header__nav-sp__ul .menu-item-has-children > a::after {
  content: "＋";
  color: #FE7CAF;
  font-weight: normal;
  font-size: 1rem;
  line-height: 1;
}
.footer__nav-sp__ul .menu-item-has-children > a.--accordion-on::after, .header__nav-sp__ul .menu-item-has-children > a.--accordion-on::after {
  content: "ー";
}
.footer__nav-pc {
  display: none;
}
.footer__nav-pc__ul {
  display: flex;
  flex-wrap: wrap;
  gap: 2.5rem;
}
.footer__nav-pc__ul a {
  font-size: 0.875rem;
  margin-top: 0.4rem;
}
.footer__nav-pc__ul > li > a {
  display: none;
}
.footer__nav-pc__ul > li > .sub-menu > li > a {
  margin-block: 0 0.5rem;
  font-size: 1rem;
  font-weight: bold;
}
.footer__nav-pc__ul > li > .sub-menu > li > a::before {
  content: "\e900";
  font-family: icomoon;
  color: #FE7CAF;
  font-size: 0.8em;
  font-weight: normal;
  margin-right: 0.5rem;
}
.footer__nav-pc__ul > li > .sub-menu > li:not(:first-child) > a {
  margin-top: 1.5rem;
}

.footer-banners {
  margin-top: 1rem;
  background-color: #F7F7F7;
}
.footer-banners__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
  transform: translateY(-1rem);
}
.footer-banners__title {
  margin-block: 0 2rem;
  text-align: center;
}
.footer-banners__title span {
  border: 0;
  background-color: #FE7CAF;
  color: white;
}
.footer-banners__title span::after {
  border-top-color: #FE7CAF;
}

.footer-recommend-banners .splide__slide,
.footer-mov-banners .splide__slide {
  padding-bottom: 5px;
}
.footer-top__btns-title {
  font-weight: bold;
}
.footer-top__btns .inner__narrow {
  padding-top: 2.5rem;
}
.footer-top .menu {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.25rem;
  list-style-type: none;
  margin: 0;
  padding: 0;
}
.footer-top .menu li {
  width: 200px;
  max-width: calc(50% - 0.25rem);
}
.footer-top .menu li a {
  display: grid;
  place-items: center;
  width: 100%;
  padding: 1rem 0.5rem;
  background-color: white;
  border: 1px solid #575657;
  border-radius: 0.5rem;
  font-size: min(0.875rem, 3.2vw);
  font-weight: bold;
  box-shadow: 2px 4px 4px rgba(87, 86, 87, 0.3);
  color: #575657;
  text-decoration: none;
}

.footer-top-sub {
  background-color: #FDF8F2;
}
.footer-top-sub-link {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  padding: 1.25rem;
  gap: 1rem;
}
.footer-top-sub .btn-block {
  margin-top: 0;
}

/* -------------------------------------------------------------------
  768px以上
------------------------------------------------------------------- */
@media screen and (min-width: 768px) {
  .footer-banners {
    background-color: #FDF8F2;
    margin-top: 0;
  }
  .footer-banners__inner {
    transform: translateY(0);
    padding-block: 2.5rem;
    gap: 2.5rem;
  }
  .footer-banners__title span {
    padding: 0;
    background-color: transparent;
    font-size: 2rem;
    color: #575657;
  }
  .footer-banners__title span::after {
    display: none;
  }
  .body .footer-top__cvp {
    background-color: white;
  }
  .body .footer-top__cvp .inner__narrow {
    width: 1080px;
    background-color: white;
  }
  .body .footer-top__cvp .common-cta__btn {
    flex-direction: row;
    justify-content: center;
    padding-block: 1rem;
  }
  .body .footer-top__cvp .common-cta__btn i {
    margin: 0;
  }
  .body .footer-top__btns .inner__narrow {
    width: 1080px;
    padding-inline: 0;
  }
  .body .footer-top__btns.--contents {
    background-color: white;
  }
  .body .footer-top__btns-title {
    text-align: center;
    border-left: 0;
    padding: 0;
    color: #FE7CAF;
    font-size: 1.75rem;
  }
  .body .footer-top__btns-title::before {
    content: "＼";
    position: relative;
    display: inline;
    background-color: transparent;
  }
  .body .footer-top__btns-title::after {
    content: "／";
    margin-left: 0;
  }
  .body .footer-top .menu {
    gap: 0.875rem 1rem;
  }
  .body .footer-top .menu li {
    width: 200px;
  }
  .body .footer-top .menu li a {
    border-width: 2px;
    padding-inline: 0.5rem;
  }
}
/* -------------------------------------------------------------------
  1024px以上
------------------------------------------------------------------- */
@media screen and (min-width: 1024px) {
  .footer {
    background-color: #F7F7F7;
  }
  .footer__top {
    display: grid;
    grid-template-columns: -webkit-max-content 1fr;
    grid-template-columns: max-content 1fr;
    gap: 4.5rem;
    max-width: calc(1080px + 9rem);
    margin-inline: auto;
    padding: 5rem 3rem 3.5rem;
  }
  .footer__nav-wrap {
    order: 1;
    display: grid;
  }
  .footer__nav-sp {
    display: none;
  }
  .footer__nav-pc {
    display: block;
  }
  .footer__logo {
    order: 0;
  }
  .footer__bottom__inner {
    flex-direction: row;
    align-items: center;
    gap: 0.5rem 2.5rem;
    max-width: 1080px;
    margin-inline: auto;
    padding-bottom: 1.5rem;
    padding-left: 1.5rem;
  }
  .footer__bottom__nav {
    flex-shrink: 0;
  }
  .footer__bottom__nav li:not(:first-child)::before {
    display: none;
  }
  .footer__bottom__privacy {
    flex-shrink: 0;
    max-width: 375px;
  }
  .footer__bottom__copy {
    align-self: flex-end;
    padding-block: 0;
  }
}
@media screen and (min-width: 1080px) {
  body {
    overflow-x: hidden;
  }
  .footer-top-sub {
    position: relative;
    right: calc((100vw - 100%) / 2);
    width: calc(100% + 100vw - 100%);
    max-width: 100vw;
  }
}
/* -------------------------------------------------------------------
  header__nav
------------------------------------------------------------------- */
.header__nav-btn {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 64px;
  height: 64px;
  background-color: white;
  border-radius: 50%;
  cursor: pointer;
}
.header__nav-btn__burger {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.header__nav-btn__burger span {
  display: block;
  width: min(32px, 6.4vw);
  height: 2px;
  background-color: #575657;
}
.--on .header__nav-btn__burger span:first-child {
  position: relative;
  top: 6px;
  transform: rotate(45deg);
}
.--on .header__nav-btn__burger span:last-child {
  transform: rotate(-45deg);
}
.--on .header__nav-btn__burger span:nth-child(2) {
  display: none;
}
.header__nav-btn__text {
  display: block;
  line-height: 1;
  margin-top: 12px;
  text-transform: uppercase;
  font-family: "Kumbh Sans", sans-serif;
}
.header__nav-pc {
  display: none;
}

@media screen and (min-width: 1024px) {
  .header__nav-contents {
    height: auto !important;
  }
  .header__nav-info, .header__nav-info__btn, .header__nav-cta, .header__nav-btn, .header__nav-sp {
    display: none;
  }
  .header__nav-pc {
    display: block;
    padding-inline: 12px;
    background-color: #F7F7F7;
  }
  .header__nav-pc__ul {
    display: flex;
    gap: 2rem;
    justify-content: center;
    align-items: baseline;
  }
  .header__nav-pc__ul > li {
    padding: 0.875rem 1.25rem;
  }
  .header__nav-pc__ul > li > a {
    position: relative;
    cursor: pointer;
  }
  .header__nav-pc__ul > li > a::before {
    content: "";
    display: block;
    width: 0%;
    height: 1px;
    background-color: #FE7CAF;
    position: absolute;
    left: 0;
    bottom: -2px;
    transition: 0.5s linear width;
  }
  .header__nav-pc__ul > li > a:hover {
    color: #575657;
  }
  .header__nav-pc__ul > li > a:hover::before {
    width: 100%;
  }
  .header__nav-pc__ul .menu-item-has-children {
    position: relative;
  }
  .header__nav-pc__ul .menu-item-has-children:hover .sub-menu {
    transform: translateY(100%) scaleY(1);
    opacity: 1;
  }
  .header__nav-pc__ul .menu-item-has-children > a {
    display: flex;
    gap: 0.5rem;
  }
  .header__nav-pc__ul .menu-item-has-children > a::after {
    content: "\e900";
    font-family: icomoon;
    transition: 0.5s linear transform;
    transform: scale(1, 1) rotate(90deg);
  }
  .header__nav-pc__ul .menu-item-has-children > a.--accordion-on::after {
    transform: scale(-1, -1) rotate(90deg);
  }
  .header__nav-pc__ul .menu-item-has-children > a.--accordion-on::before {
    width: 100%;
  }
  .header__nav-pc__ul .sub-menu {
    position: absolute;
    bottom: 0;
    left: 0;
    transform: translateY(100%) scaleY(0);
    opacity: 0;
    width: -webkit-max-content;
    width: -moz-max-content;
    width: max-content;
    transition: 0.2s linear transform, 0.3s linear opacity;
    transform-origin: top center;
  }
  .header__nav-pc__ul .sub-menu a {
    display: block;
    padding: 1rem 1.25rem;
    background-color: #F7F7F7;
    transition: 0.5s linear background-color, 0.5s linear color;
  }
  .header__nav-pc__ul .sub-menu a:hover {
    background-color: white;
  }
  .header__nav-pc ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
  }
  .header__nav-pc a {
    text-decoration: none;
    color: #575657;
    font-size: 0.875rem;
  }
}
@media screen and (max-width: 1023px) {
  .header__nav-contents {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    z-index: 1;
    overflow-y: auto;
    padding-bottom: 6.5rem;
    background-color: white;
    transform: translateY(-120%);
    transition: 0.5s linear transform;
  }
  .--on .header__nav-contents {
    transform: translateY(0%);
  }
  .header__nav-contents__inner {
    display: grid;
    grid-template-columns: 1fr;
    justify-content: center;
    width: 100%;
    max-width: 1080px;
    margin-inline: auto;
  }
  .header__nav-cta .inner__narrow {
    width: 100%;
    padding-block: 0;
    background-color: transparent !important;
  }
  .header__nav-info__tel, .header__nav-info__open {
    display: block;
    text-align: center;
  }
  .header__nav-info__tel {
    font-size: 2rem;
    font-weight: bold;
    color: #575657;
    text-decoration: none;
  }
  .header__nav-info__tel::before {
    content: "\e905";
    margin-right: 0.25rem;
    font-size: 0.8em;
    font-family: icomoon;
    font-weight: normal;
  }
  .header__nav-info__open {
    font-size: 0.75rem;
  }
}
/* -------------------------------------------------------------------
  title
------------------------------------------------------------------- */
.title__main {
  display: flex;
  gap: 0.5rem;
  padding-top: 2.5rem;
  margin-bottom: 20px;
  margin-top: 0;
}
.title__main::before {
  flex-shrink: 0;
  content: url(../assets/mark.svg);
  display: block;
  width: 29px;
  height: 32px;
}
.title__mini {
  font-size: 18px;
  font-weight: 700;
  margin-top: 0;
  margin-bottom: min(0.625rem, 5.3333333333vw);
}
.title__h2, .post-content h2,
.editor-area h2 {
  position: relative;
  margin-top: 0;
  margin-bottom: min(2.5rem, 5.3333333333vw);
  padding-top: 1.5rem;
  font-size: 1.5rem;
}
.title__h2::before, .post-content h2::before,
.editor-area h2::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: min(0.5rem, 1.0666666667vw);
  background-image: linear-gradient(to right, #FE7CAF 0%, #FE7CAF 25%, #EEEEEE 25%, #EEEEEE 100%);
}
.title__h3, .post-content h3,
.editor-area h3 {
  position: relative;
  margin-top: 0;
  margin-bottom: min(1.5rem, 5.3333333333vw);
  padding-left: 1rem;
  font-size: 1.125rem;
}
.title__h3::before, .post-content h3::before,
.editor-area h3::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 4px;
  height: 100%;
  border-radius: 0.5rem;
  background-color: #FE7CAF;
}
.title__h3::after, .post-content h3::after,
.editor-area h3::after {
  content: attr(after);
  font-size: 0.875rem;
  margin-left: 1.125rem;
}
.title__text {
  font-size: min(1.625rem, 4.8vw);
  font-weight: bold;
  color: #FE7CAF;
}

@media screen and (min-width: 768px) {
  .title__main {
    padding-top: 1.25rem;
    margin-bottom: 1.875rem;
  }
  .title__h2, .post-content h2,
  .editor-area h2 {
    padding-left: 2rem;
  }
}
/* -------------------------------------------------------------------
  sidebar
------------------------------------------------------------------- */
.sidebar {
  display: flex;
  flex-direction: column;
  align-self: flex-start;
  padding-block: 1.25rem;
  background-color: #F7F7F7;
}
.sidebar-content {
  padding-inline: min(1.25rem, 3.2vw);
}
.sidebar-content:not(:first-child) {
  padding-top: 2.5rem;
}
.sidebar .menu {
  list-style-type: none;
  margin: 0;
  padding: 0;
}
.sidebar .wp-block-gallery {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.75rem;
  text-align: center;
}
.main-contents {
  grid-area: main;
}

.footer-top {
  grid-area: footer-top;
}

.footer-top-sub {
  grid-area: footer-top-sub;
}

.sidebar {
  grid-area: sidebar;
}
.sidebar__title {
  margin-block: 0 1.25rem;
  padding-left: 1.25rem;
  font-size: 1.5rem;
  font-weight: bold;
}
.sidebar-other-link {
  padding-top: 1.5rem;
  padding-inline: 0.625rem;
}
.sidebar-other-link__list {
  margin: 0;
  padding: 0;
  list-style-type: none;
  position: relative;
}
.sidebar-other-link__list::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #575657 2px, transparent 2px);
  background-size: 5px 2px;
}
.sidebar-other-link__list-item {
  position: relative;
  font-size: 1rem;
}
.sidebar-other-link__list-item::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #575657 2px, transparent 2px);
  background-size: 5px 2px;
}
.sidebar-other-link__list-item a {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 0.5rem;
  padding: 0.875rem 0.75rem;
  font-size: 1rem;
  font-weight: bold;
  color: #575657;
  text-decoration: none;
}
.sidebar-other-link__list-item a::after {
  content: "\e900";
  font-family: icomoon;
  color: #FE7CAF;
  font-size: 75%;
}

.sidebar-toc {
  padding-inline: 0.625rem;
}
.sidebar-toc ul {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  list-style-type: none;
  margin: 0;
  padding: 0;
}
.sidebar-toc > ul > li {
  padding-inline: 0.625rem;
  font-size: 1rem;
  font-weight: bold;
}
.sidebar-toc > ul > li ul {
  padding-left: 1rem;
  gap: 0;
}
.sidebar-toc > ul > li ul li {
  font-weight: normal;
  text-decoration: underline;
}
.sidebar-toc > ul > li ul li a {
  font-size: 0.875rem;
}
.sidebar-toc__has-child {
  padding-bottom: 0.625rem;
  background-color: white;
}
.sidebar-toc__has-child > a {
  padding-top: 0.625rem;
}
.sidebar-toc a {
  display: block;
  color: #575657;
  text-decoration: none;
}

@media screen and (min-width: 1024px) {
  .sidebar {
    border-top: 0.5rem solid #FE7CAF;
    margin-bottom: 100px;
  }
  .sidebar-content:has(.--sidebar-sp) {
    display: none;
  }
  .sidebar-content__title {
    position: relative;
    margin-top: 0;
    margin-bottom: 1rem;
    padding-top: 1.5rem;
  }
  .sidebar-content__title::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: min(0.5rem, 1.0666666667vw);
    background-image: linear-gradient(to right, #FE7CAF 0%, #FE7CAF 25%, #EEEEEE 25%, #EEEEEE 100%);
  }
  .has-sidebar {
    display: grid;
    grid-template-columns: 1fr 260px;
    grid-template: "main sidebar" auto "footer-top-sub footer-top-sub" auto "footer-top footer-top" auto/1fr 260px;
    gap: 1.687rem;
    width: 1080px;
    max-width: 100%;
    margin-inline: auto;
  }
  .has-sidebar > .main-contents .inner__narrow,
  .has-sidebar > .main-contents .content-big-image {
    padding-inline: 0;
  }
  .has-sidebar > .sidebar {
    flex-shrink: 0;
    width: 260px;
  }
  .main-contents {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
  }
  .footer-top {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .footer-top-sub {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .sidebar {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
}
@media screen and (max-width: 1023px) {
  .sidebar-content:has(.--sidebar-pc) {
    display: none;
  }
  .sidebar-content__title {
    position: relative;
    margin-top: 0;
    margin-bottom: min(1.5rem, 5.3333333333vw);
    padding-left: 1rem;
    font-size: 1.125rem;
  }
  .sidebar-content__title::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 4px;
    height: 100%;
    border-radius: 0.5rem;
    background-color: #FE7CAF;
  }
  .sidebar-content__title::after {
    content: attr(after);
    font-size: 0.875rem;
    margin-left: 1.125rem;
  }
  .sidebar-toc,
  .sidebar__title,
  .sidebar-other-link {
    display: none;
  }
}
@font-face {
  font-family: "icomoon";
  src: url("../fonts/icomoon.eot?p13rvy");
  src: url("../fonts/icomoon.eot?p13rvy#iefix") format("embedded-opentype"), url("../fonts/icomoon.woff2?p13rvy") format("woff2"), url("../fonts/icomoon.ttf?p13rvy") format("truetype"), url("../fonts/icomoon.woff?p13rvy") format("woff"), url("../fonts/icomoon.svg?p13rvy#icomoon") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
[class^=icon-], [class*=" icon-"] {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: "icomoon" !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.icon-cart:before {
  content: "\e90a";
  color: #575657;
}

.icon-tel:before {
  content: "\e909";
  color: #fe7caf;
}

.icon-blank:before {
  content: "\e908";
  color: #fe7caf;
}

.icon-arrow:before {
  content: "\e900";
  color: #fe7caf;
}

.icon-book:before {
  content: "\e901";
  color: #fff;
}

.icon-class:before {
  content: "\e902";
  color: #fe7caf;
}

.icon-freedial:before {
  content: "\e903";
  color: #fe7caf;
}

.icon-mappin:before {
  content: "\e904";
  color: #575657;
}

.icon-tel1:before {
  content: "\e905";
  color: #575657;
}

.icon-user:before {
  content: "\e906";
  color: #fe7caf;
}

.icon-users:before {
  content: "\e907";
  color: #fff;
}

/* -------------------------------------------------------------------
  table
------------------------------------------------------------------- */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

table,
.table,
.table-scroll {
  width: 100%;
  position: relative;
}
table::before,
.table::before,
.table-scroll::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #575657 2px, transparent 2px);
  background-size: 5px 2px;
}
table tr,
.table tr,
.table-scroll tr {
  position: relative;
}
table tr::after,
.table tr::after,
.table-scroll tr::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #575657 2px, transparent 2px);
  background-size: 5px 2px;
}
table th,
table td,
.table th,
.table td,
.table-scroll th,
.table-scroll td {
  padding-block: min(1.875rem, 4.2666666667vw);
  padding-left: min(2rem, 3.2vw);
}
table th,
.table th,
.table-scroll th {
  text-align: left;
  font-weight: normal;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  vertical-align: baseline;
  min-width: 6em;
}
table__remark,
.table__remark,
.table-scroll__remark {
  padding-top: 0.5rem;
  text-align: right;
  font-size: 0.75rem;
}
table.--price th,
table.--price td,
.table.--price th,
.table.--price td,
.table-scroll.--price th,
.table-scroll.--price td {
  font-weight: bold;
}
table.--price th,
.table.--price th,
.table-scroll.--price th {
  font-size: min(1.25rem, 3.7333333333vw);
}
table.--price td,
.table.--price td,
.table-scroll.--price td {
  text-align: right;
  font-size: min(1.25rem, 4.8vw);
  padding-right: min(2rem, 3.2vw);
}
table.--price td small,
.table.--price td small,
.table-scroll.--price td small {
  font-size: min(1.25rem, 3.2vw);
}

.table-scroll__wrap {
  overflow: auto;
  white-space: nowrap;
  margin: 1em 0;
}
.table-scroll::-webkit-scrollbar {
  height: 5px;
}
.table-scroll::-webkit-scrollbar-track {
  background: #f1f1f1;
}
.table-scroll::-webkit-scrollbar-thumb {
  background: #bcbcbc;
}

/* -------------------------------------------------------------------
  box
------------------------------------------------------------------- */
.box, .content-big-image__contents, .content-course-age, .content-column, .content-faq__title-wrap {
  border-radius: 0.5rem;
  background-color: white;
  box-shadow: 2px 4px 4px rgba(87, 86, 87, 0.3);
  border: 1px solid #EEEEEE;
}
.box-border {
  padding: min(1.25rem, 4.2666666667vw);
  border: 1px solid #FE7CAF;
  border-radius: 0.5rem;
}

/* -------------------------------------------------------------------
  767以下
------------------------------------------------------------------- */
@media screen and (max-width: 767px) {
  .box-gray {
    display: grid;
    gap: 1.25rem;
    padding: 1.25rem;
    background-color: #F7F7F7;
  }
  .box-gray > .btn-block {
    margin-top: 0;
  }
}
/* -------------------------------------------------------------------
  main-sub
------------------------------------------------------------------- */
.main-sub__contents {
  width: 1080px;
  max-width: 100%;
  margin-inline: auto;
}
.main-sub__title {
  margin-block: 0;
  padding: min(2.5rem, 5.3333333333vw) min(2rem, 3.2vw);
  border-top: 0.5rem solid #FE7CAF;
  font-size: min(2.25rem, 6.4vw);
  line-height: 1.3;
}
.main-sub__title::before {
  content: attr(before);
  display: block;
  font-size: min(1.125rem, 3.2vw);
  font-weight: normal;
}

@media screen and (max-width: 767px) {
  .main-sub__title {
    padding-bottom: 2.5rem;
  }
}
.breadcrumbs {
  width: 1800px;
  max-width: 100%;
  padding-inline: min(3.75rem, 2.1333333333vw);
  padding-top: min(1.25rem, 3.2vw);
  padding-bottom: min(1.25rem, 1.0666666667vw);
  margin-inline: auto;
  font-size: min(0.812rem, 2.6666666667vw);
}
.breadcrumbs a {
  text-decoration: none;
  color: #575657;
}
.breadcrumbs span {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

/* -------------------------------------------------------------------
  btn-block
------------------------------------------------------------------- */
.btn-block, .btn-block__mini {
  position: relative;
  display: inline-block;
  min-width: 300px;
  border-radius: 2em;
  padding: 0.75rem 1rem;
  margin-top: min(2.5rem, 5.3333333333vw);
  border: 2px solid #FE7CAF;
  text-decoration: none;
  font-size: 1rem;
  font-weight: 700;
  background-color: white;
  box-shadow: 2px 4px 4px rgba(87, 86, 87, 0.3);
}
.btn-block--fill, .btn-block.--fill, .--fill.btn-block__mini {
  background-color: #FE7CAF;
  color: white;
}
.btn-block::after, .btn-block__mini::after {
  content: "\e900";
  font-family: icomoon;
  position: absolute;
  top: 50%;
  right: 1rem;
  transform: translateY(-50%);
  font-size: 0.8em;
}
.btn-block.--tel::after, .--tel.btn-block__mini::after {
  content: "\e909";
}
.btn-block.--blank::after, .--blank.btn-block__mini::after {
  content: "\e908";
}
.btn-block.--before::after, .--before.btn-block__mini::after {
  position: absolute;
  top: 50%;
  left: 1rem;
  right: auto;
  transform: translateY(-50%) rotate(180deg);
  font-size: 0.8em;
}
.btn-block__mini {
  width: 100%;
  min-width: 0;
  margin-top: 0;
  padding-block: 0.5rem;
  text-align: center;
  font-size: 0.875rem;
}
.btn-block__mini--fill, .btn-block__mini.--fill {
  background-color: #FE7CAF;
  color: white;
}
.btn-block.--solid, .--solid.btn-block__mini {
  border-color: #575657;
  color: #575657;
}

@media screen and (min-width: 600px) {
  .btn-block,
  .btn-block__mini {
    transition: 0.5s linear background-color, 0.5s linear color;
  }
  .btn-block::after,
  .btn-block__mini::after {
    transition: 0.5s linear right, 0.5s linear left;
  }
  .btn-block:hover,
  .btn-block__mini:hover {
    background-color: #FE7CAF;
    color: white;
  }
  .btn-block:hover::after,
  .btn-block__mini:hover::after {
    right: 0.75rem;
  }
  .btn-block--fill, .btn-block.--fill,
  .btn-block__mini--fill,
  .btn-block__mini.--fill {
    transition: 0.5s linear background-color, 0.5s linear color;
  }
  .btn-block--fill:hover, .btn-block.--fill:hover,
  .btn-block__mini--fill:hover,
  .btn-block__mini.--fill:hover {
    background-color: white;
    color: #FE7CAF;
  }
  .btn-block--fill:hover::after, .btn-block.--fill:hover::after,
  .btn-block__mini--fill:hover::after,
  .btn-block__mini.--fill:hover::after {
    right: 0.75rem;
  }
  .btn-block.--before:hover::after,
  .btn-block__mini.--before:hover::after {
    right: auto;
    left: 0.75rem;
  }
  .btn-block.--solid:hover,
  .btn-block__mini.--solid:hover {
    background-color: #575657;
    color: white;
  }
}
@media screen and (min-width: 768px) {
  .btn-block__mini {
    max-width: 154px;
    padding-block: 0.4rem;
  }
}
.post-content__meta,
.editor-area__meta {
  display: flex;
  align-items: baseline;
  gap: 1.125rem;
}
.post-content__meta-label,
.editor-area__meta-label {
  color: white;
}
.post-content__description,
.editor-area__description {
  margin-top: 0.75rem;
  font-size: 0.875rem;
}
.post-content h2,
.editor-area h2 {
  margin-top: 2.5rem;
}
.post-content h3,
.editor-area h3 {
  margin-top: 2.5rem;
}
.post-content b, .post-content strong,
.editor-area b,
.editor-area strong {
  font-weight: bold;
}
.post-content ol, .post-content ul,
.editor-area ol,
.editor-area ul {
  display: flex;
  flex-direction: column;
  gap: min(1.25rem, 2.1333333333vw);
  margin-block: 0;
  padding-left: 0;
  list-style-type: none;
  padding-left: 1.5rem;
}
.post-content ol li, .post-content ul li,
.editor-area ol li,
.editor-area ul li {
  position: relative;
}
.post-content ol li::before, .post-content ul li::before,
.editor-area ol li::before,
.editor-area ul li::before {
  color: #FE7CAF;
  font-weight: bold;
  position: absolute;
  left: -1.5rem;
}
.post-content ol,
.editor-area ol {
  counter-reset: ol-num;
}
.post-content ol li,
.editor-area ol li {
  counter-increment: ol-num 1;
}
.post-content ol li::before,
.editor-area ol li::before {
  content: counter(ol-num) ".";
}
.post-content ul,
.editor-area ul {
  gap: 0.5rem;
}
.post-content ul li::before,
.editor-area ul li::before {
  content: "・";
}
.post-content p,
.editor-area p {
  line-height: 1.7;
}
.post-content p a:not(.btn-block):not(.btn-block__mini):not(.btn-block__mini--fill),
.editor-area p a:not(.btn-block):not(.btn-block__mini):not(.btn-block__mini--fill) {
  font-weight: bold;
  text-decoration: underline;
  color: #0DA9F2;
}

@media screen and (min-width: 768px) {
  h2 {
    margin-top: 2.5rem;
  }
  h3 {
    margin-top: 2rem;
  }
  .post-content__meta {
    padding-left: min(2rem, 3.2vw);
  }
  .post-content__description {
    padding-left: min(2rem, 3.2vw);
  }
}
/*!
 * Luminous v2.3.5
 * Copyright 2015-2021, Zebrafish Labs
 * Licensed under BSD-2 (https://github.com/imgix/luminous/blob/main/LICENSE.md)
 */
@keyframes a {
  0% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes b {
  0% {
    opacity: 0;
    transform: scale(0.5);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes c {
  0% {
    transform: translate(-50%, -50%) rotate(0);
  }
  50% {
    transform: translate(-50%, -50%) rotate(-180deg);
  }
  to {
    transform: translate(-50%, -50%) rotate(-1turn);
  }
}
@keyframes d {
  0% {
    transform: scale(1);
  }
  10% {
    transform: scale(1.2) translateX(6px);
  }
  25% {
    transform: scale(1.3) translateX(8px);
  }
  40% {
    transform: scale(1.2) translateX(6px);
  }
  50% {
    transform: scale(1);
  }
  60% {
    transform: scale(0.8) translateX(6px);
  }
  75% {
    transform: scale(0.7) translateX(8px);
  }
  90% {
    transform: scale(0.8) translateX(6px);
  }
  to {
    transform: scale(1);
  }
}
@keyframes e {
  0% {
    transform: scale(1);
  }
  10% {
    transform: scale(1.2) translateX(-6px);
  }
  25% {
    transform: scale(1.3) translateX(-8px);
  }
  40% {
    transform: scale(1.2) translateX(-6px);
  }
  50% {
    transform: scale(1);
  }
  60% {
    transform: scale(0.8) translateX(-6px);
  }
  75% {
    transform: scale(0.7) translateX(-8px);
  }
  90% {
    transform: scale(0.8) translateX(-6px);
  }
  to {
    transform: scale(1);
  }
}
.lum-lightbox {
  background: rgba(0, 0, 0, 0.6);
}

.lum-lightbox-inner {
  bottom: 2.5%;
  left: 2.5%;
  right: 2.5%;
  top: 2.5%;
}

.lum-lightbox-inner img {
  position: relative;
}

.lum-lightbox-inner .lum-lightbox-caption {
  color: #fff;
  margin: 0 auto;
  max-width: 700px;
  text-align: center;
}

.lum-loading .lum-lightbox-loader {
  animation: c 1.8s linear infinite;
  display: block;
  height: 20px;
  left: 50%;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 66px;
}

.lum-lightbox-loader:after, .lum-lightbox-loader:before {
  background: hsla(0, 0%, 100%, 0.9);
  border-radius: 20px;
  content: "";
  display: block;
  height: 20px;
  margin-top: -10px;
  position: absolute;
  top: 50%;
  width: 20px;
}

.lum-lightbox-loader:before {
  animation: d 1.8s linear infinite;
  left: 0;
}

.lum-lightbox-loader:after {
  animation: e 1.8s linear infinite;
  animation-delay: -0.9s;
  right: 0;
}

.lum-lightbox.lum-opening {
  animation: a 0.18s ease-out;
}

.lum-lightbox.lum-opening .lum-lightbox-inner {
  animation: b 0.18s ease-out;
}

.lum-lightbox.lum-closing {
  animation: a 0.3s ease-in;
  animation-direction: reverse;
}

.lum-lightbox.lum-closing .lum-lightbox-inner {
  animation: b 0.3s ease-in;
  animation-direction: reverse;
}

.lum-img {
  transition: opacity 0.12s ease-out;
}

.lum-loading .lum-img {
  opacity: 0;
}

.lum-gallery-button {
  background: transparent;
  border: 0;
  cursor: pointer;
  height: 100px;
  margin: 0;
  max-height: 100%;
  outline: 0;
  overflow: hidden;
  padding: 0;
  position: absolute;
  text-indent: 150%;
  top: 50%;
  transform: translateY(-50%);
  white-space: nowrap;
  width: 60px;
}

.lum-close-button {
  height: 32px;
  opacity: 0.3;
  position: absolute;
  right: 5px;
  top: 5px;
  width: 32px;
}

.lum-close-button:hover {
  opacity: 1;
}

.lum-close-button:after, .lum-close-button:before {
  background-color: #fff;
  content: " ";
  height: 33px;
  left: 15px;
  position: absolute;
  width: 2px;
}

.lum-close-button:before {
  transform: rotate(45deg);
}

.lum-close-button:after {
  transform: rotate(-45deg);
}

.lum-previous-button {
  left: 12px;
}

.lum-next-button {
  right: 12px;
}

.lum-gallery-button:after {
  border-top: 4px solid hsla(0, 0%, 100%, 0.8);
  content: "";
  display: block;
  height: 36px;
  position: absolute;
  top: 50%;
  width: 36px;
}

.lum-previous-button:after {
  border-left: 4px solid hsla(0, 0%, 100%, 0.8);
  border-radius: 3px 0 0 0;
  box-shadow: -2px 0 rgba(0, 0, 0, 0.2);
  left: 12%;
  transform: translateY(-50%) rotate(-45deg);
}

.lum-next-button:after {
  border-radius: 0 3px 0 0;
  border-right: 4px solid hsla(0, 0%, 100%, 0.8);
  box-shadow: 2px 0 rgba(0, 0, 0, 0.2);
  right: 12%;
  transform: translateY(-50%) rotate(45deg);
}

@media (max-width: 460px) {
  .lum-lightbox-image-wrapper {
    -webkit-overflow-scrolling: touch;
    display: flex;
    overflow: auto;
  }
  .lum-lightbox-caption {
    bottom: 0;
    position: absolute;
    width: 100%;
  }
  .lum-lightbox-position-helper {
    margin: auto;
  }
  .lum-lightbox-inner img {
    max-height: none;
    max-width: none;
  }
}
.lum-lightbox {
  z-index: 9999;
}
.lum-lightbox-inner img {
  max-width: 90vw !important;
  max-height: 85vh !important;
}

/* -------------------------------------------------------------------
  base
------------------------------------------------------------------- */
html,
body {
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
}

body {
  font-size: min(1rem, 3.7333333333vw);
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.5;
  font-weight: 400;
  color: #575657;
  background-color: #ffffff;
}
body.--on {
  overflow: hidden;
}

a {
  color: #FE7CAF;
  text-decoration: underline;
}
@media screen and (min-width: 600px) {
  a {
    transition: 0.5s linear color;
  }
  a:hover {
    color: #FE7CAF;
  }
  a img {
    transition: 0.5s linear opacity;
  }
  a img:hover {
    opacity: 0.5;
  }
}

p {
  margin-top: 0;
}
p:last-child {
  margin-bottom: 0;
}

img,
svg {
  vertical-align: bottom;
  max-width: 100%;
}

img {
  height: auto;
}

figure {
  margin: 0;
}

* {
  box-sizing: border-box;
}

.border-top {
  border-top: 0.5rem solid #FE7CAF;
}

.color-main {
  color: #FE7CAF;
}
.color-link {
  color: #0DA9F2 !important;
  text-decoration: underline !important;
}

.text-left {
  text-align: left;
}
.text-center {
  text-align: center;
}
.text-right {
  text-align: right;
}

.common-eyecatch {
  width: 100%;
}

.common-cta .inner__narrow {
  padding-block: 2.5rem;
}
.common-cta__title {
  margin-bottom: min(3rem, 2.1333333333vw);
  font-size: min(2rem, 4.2666666667vw);
  font-weight: 700;
  text-align: center;
  line-height: 1.3;
}
.common-cta__btns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: min(22px, 2.1333333333vw);
}
.common-cta__btn {
  display: flex;
  gap: 0.5rem;
  justify-content: center;
  padding: 14px;
  border-radius: 0.5rem;
  color: white;
  text-decoration: none;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.7;
  box-shadow: 2px 4px 4px rgba(87, 86, 87, 0.3);
}
.common-cta__btn.--blue {
  background-color: #7DCEF4;
}
.common-cta__btn.--pink {
  background-color: #FF3685;
}
.common-cta__btn i {
  font-size: 1.2em;
  line-height: 1.5;
}
.common-cta__btn.--big {
  flex-direction: column;
  align-items: center;
  gap: 0.3rem;
  margin-inline: auto;
  line-height: 1;
  max-width: 370px;
  margin-bottom: 0.5rem;
}
.common-cta__btn.--big i {
  font-size: 1.5em;
  line-height: 1;
  margin-bottom: 0.4rem;
}

.page-top {
  position: fixed;
  right: 1.5vw;
  bottom: 4.5rem;
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  font-family: "Kumbh Sans", sans-serif;
  font-size: 12px;
  color: #575657;
  text-decoration: none;
  background-color: white;
  border-radius: 50%;
  box-shadow: 2px 4px 4px rgba(87, 86, 87, 0.3);
  transform: translateX(calc(100% + 1.5vw));
  transition: 0.5s linear transform;
}
.page-top::before {
  content: "";
  width: 0;
  height: 0;
  display: block;
  border-top: 0 solid transparent;
  border-right: 0.5rem solid transparent;
  border-bottom: 0.75rem solid #575657;
  border-left: 0.5rem solid transparent;
}
.page-top.scroll-on {
  transform: translateX(0);
}

.common-event-banner {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: min(1.25rem, 3.2vw) min(2.5rem, 2.1333333333vw);
  max-width: 650px;
  margin-inline: auto;
}
.common-event-banner__item {
  color: #575657;
}
.common-event-banner__item:-moz-any-link {
  color: #575657;
}
.common-event-banner__item:any-link {
  color: #575657;
}
.common-event-banner__item-img {
  background-color: #fff;
}
.common-event-banner__item-text {
  display: block;
  font-size: min(0.875rem, 2.6666666667vw);
  line-height: 3;
}

.common-passing__contents {
  padding: 1rem 1rem min(2.5rem, 6.4vw);
}
.common-passing__img {
  position: relative;
  left: -1rem;
  max-width: 653px;
  width: calc(100% + 2rem);
  transform: translateY(max(-132px, -9.6vw));
}
.common-passing__content {
  position: relative;
  margin: 0 auto;
  margin-top: max(-132px, -9.6vw);
  padding-block: min(1rem, 2.6666666667vw) min(1.5rem, 3.2vw);
  background: url(../assets/top-passing-bg.png) center bottom no-repeat;
  background-size: contain;
  font-weight: bold;
  text-align: center;
}
.common-passing__content-label {
  font-size: min(1.25rem, 3.2vw);
  color: #FE7CAF;
}
.common-passing__content-text--low {
  font-size: min(1.5rem, 4.2666666667vw);
}
.common-passing__content-text--large {
  font-size: min(2.5rem, 8.5333333333vw);
  line-height: 1;
}
.common-passing__content-text--medium {
  font-size: min(1.5rem, 4.8vw);
}
.common-passing__btn-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
  max-width: 640px;
  margin-top: 1rem;
}
.common-passing__btn-wrap .btn-block__mini {
  justify-self: center;
}
.--no-record .common-passing__btn-wrap {
  grid-template-columns: 1fr;
}

/* 2024/12/12 追加 */
.content-big-image__contents.top_pass_img {
  padding: 0 !important;
  margin-top: max(-8rem, -16.0666666667vw) !important;
  background-color: unset;
  box-shadow: none;
  border: none;
}
.top_pass_img .new-common-passing__img{
    img {
        filter: drop-shadow(2px 4px 4px rgba(87, 86, 87, 0.3));
    }
}
.top_pass_img .common-passing__btn-wrap{
  max-width: 688px;
  position: absolute;
  padding: min(2.5rem, 5.3333333333vw) min(2.5rem, 4.2666666667vw);
  left: 0;
  right: 0;
  bottom: 0.5dvw;
}
/* ここまで */

.common-instagram__title {
  font-size: min(1.125rem, 3.7333333333vw);
  color: #FE7CAF;
  text-align: center;
}
.common-instagram__title span {
  position: relative;
  display: inline-block;
}
.common-instagram__title span::before, .common-instagram__title span::after {
  content: "";
  position: absolute;
  top: 0;
  display: block;
  width: 2px;
  height: 100%;
  background-color: #FE7CAF;
  transform-origin: bottom;
}
.common-instagram__title span::before {
  left: -0.5rem;
  transform: rotate(-30deg);
}
.common-instagram__title span::after {
  right: -0.5rem;
  transform: rotate(30deg);
}

.common-btn-wrap {
  display: flex;
  justify-content: center;
  gap: 1.875rem;
}

.common-anchor {
  background-color: #F7F7F7;
  margin-bottom: 2.5rem;
}
.common-anchor__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem 0;
  margin: 0;
  padding: 1.25rem 0;
}
.--col-1 .common-anchor__items {
  grid-template-columns: repeat(1, 1fr);
}
.--col-2 .common-anchor__items {
  grid-template-columns: repeat(2, 1fr);
}
.--col-4 .common-anchor__items {
  grid-template-columns: repeat(4, 1fr);
}
.common-anchor__item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding-inline: 0.5rem;
  border-right: 1px solid #575657;
  font-size: 0.875rem;
}
.common-anchor__item::after {
  content: "\e900";
  flex-shrink: 0;
  font-family: icomoon;
  font-size: 0.75rem;
  transform: rotate(90deg);
}
.common-anchor__item:nth-child(3n+1) {
  border-left: 1px solid #575657;
}
.common-anchor__item a {
  display: block;
  width: 100%;
  color: #575657;
  text-decoration: none;
}

@media screen and (min-width: 600px) {
  .common-cta__btn {
    transition: 0.5s linear background-color, 0.5s linear color;
  }
  .common-cta__btn i::before {
    transition: 0.5s linear background-color, 0.5s linear color;
  }
  .common-cta__btn.--blue:hover {
    color: #7DCEF4;
    background-color: #dbf1fc;
  }
  .common-cta__btn.--blue:hover i::before {
    color: #7DCEF4;
  }
  .common-cta__btn.--pink:hover {
    color: #FF3685;
    background-color: #ffd9e8;
  }
  .common-cta__btn.--pink:hover i::before {
    color: #FF3685;
  }
}
/* -------------------------------------------------------------------
  1024px以上
------------------------------------------------------------------- */
@media screen and (min-width: 1024px) {
  .common-anchor {
    display: none;
  }
}
/* -------------------------------------------------------------------
  768px以上
------------------------------------------------------------------- */
@media screen and (min-width: 768px) {
  .common-cta__btn {
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
    line-height: 1;
  }
  .common-cta__btn i {
    font-size: 1.5em;
    line-height: 1;
    margin-bottom: 0.4rem;
  }
  .common-passing {
    padding-top: 2.5rem;
    background-color: transparent;
  }
  .common-passing__img {
    left: auto;
    margin-inline: auto;
    width: 100%;
  }
  .common-passing__btn-wrap {
    margin-inline: auto;
  }
  .common-passing .btn-block__mini {
    font-size: 1rem;
    min-width: 300px;
    border-radius: 2em;
    padding: 0.75rem 1rem;
  }
}
/* -------------------------------------------------------------------
  767以下
------------------------------------------------------------------- */
/* -------------------------------------------------------------------
  faq
------------------------------------------------------------------- */
.content-faq__title {
  display: flex;
  align-items: center;
  gap: min(1rem, 2.1333333333vw);
  margin-bottom: 0;
}
.content-faq__title::before {
  flex-shrink: 0;
  content: "Q";
  font-family: "Kumbh Sans", sans-serif;
  color: #FE7CAF;
  font-size: min(1.5rem, 5.3333333333vw);
}
.content-faq__title-wrap {
  display: flex;
  justify-content: space-between;
  gap: min(1rem, 2.1333333333vw);
  padding: 1rem 10px;
  cursor: pointer;
}
.content-faq__title-wrap::after {
  flex-shrink: 0;
  align-self: center;
  content: "＋";
  font-size: 1rem;
}
.content-faq__title-wrap.--accordion-on::after {
  content: "ー";
}
.content-faq__description {
  padding-block: min(1.5rem, 3.2vw);
  padding-inline: min(2.8rem, 9.6vw);
  display: none;
}
.content-faq-items {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

/* -------------------------------------------------------------------
  news
------------------------------------------------------------------- */
.content-news {
  position: relative;
  display: block;
  color: #575657;
  text-decoration: none;
  padding-block: 1rem;
}
.content-news::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #575657 2px, transparent 2px);
  background-size: 5px 2px;
}
.content-news:last-child::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #575657 2px, transparent 2px);
  background-size: 5px 2px;
}
.content-news__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}
.top-head-news .content-news__meta {
  margin-bottom: 0;
}
.content-news__categories {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}
.content-news__category {
  color: white;
  min-width: 6em;
}
.content-news__date {
  font-size: min(1rem, 3.2vw);
}
.content-news__title {
  font-weight: 500;
}
.content-news__items {
  margin-bottom: 1.5rem;
}

@media screen and (min-width: 768px) {
  .content-news {
    display: flex;
    align-items: center;
    width: 100%;
  }
  .content-news__meta {
    margin-bottom: 0;
    flex-wrap: nowrap;
    flex-shrink: 0;
    gap: 1.125rem;
  }
  .content-news::before, .content-news::after {
    display: none;
  }
  .content-news:last-child::after {
    display: none;
  }
  .content-news__title {
    padding-left: 1rem;
    width: 100%;
  }
  .content-news__date, .content-news__title {
    border-bottom: 1px solid #575657;
  }
  .content-news-wrap .content-news-list {
    padding-inline: 2rem;
  }
}
/* -------------------------------------------------------------------
  content-column
------------------------------------------------------------------- */
.content-column {
  display: block;
  width: 235px;
  margin-bottom: 5px;
  color: #575657;
  text-decoration: none;
  overflow: hidden;
}
.content-column__figure {
  margin: 0;
}
.content-column__title {
  font-size: 14px;
  font-weight: 700;
  text-decoration: underline;
  margin-block: 1rem 0.5rem;
  padding-inline: 1rem;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.content-column__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0 0.5rem;
  padding: 0 1rem 1rem;
}
.content-column__tag {
  color: #FE7CAF;
  font-size: 0.75rem;
}
.content-column__tag::before {
  content: "#";
}

/* -------------------------------------------------------------------
  course
------------------------------------------------------------------- */
.content-course {
  position: relative;
  display: grid;
  width: 100%;
  grid-template-columns: min(130px, 21.8666666667vw) 1fr;
  grid-template-areas: "figure title" "figure meta" "contents contents";
  gap: 0.75rem;
  padding-bottom: 1.5rem;
}
.content-course.--is-btn {
  grid-template-areas: "figure title" "figure meta" "contents contents" "btn btn";
}
.content-course:not(:first-child) {
  padding-top: 1.5rem;
}
.content-course::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #575657 2px, transparent 2px);
  background-size: 5px 2px;
}
.content-course__figure {
  -ms-grid-row: 1;
  -ms-grid-row-span: 3;
  -ms-grid-column: 1;
  grid-area: figure;
  flex-shrink: 0;
  aspect-ratio: 1;
  width: 100%;
  width: min(130px, 21.8666666667vw);
}
.content-course.--is-btn > .content-course__figure {
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  -ms-grid-column: 1;
}
.content-class > .content-course__figure {
  -ms-grid-row: 3;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
}
.content-course__figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.content-course__img {
  border-radius: 0.25rem;
}
.content-course__title {
  font-size: 1.125rem;
  font-weight: 700;
  margin: 0;
}
.content-course__title a {
  color: #575657;
}
.content-course__meta {
  -ms-grid-row: 3;
  -ms-grid-column: 3;
  grid-area: meta;
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem 0.5rem;
  align-self: baseline;
}
.content-course.--is-btn > .content-course__meta {
  -ms-grid-row: 2;
  -ms-grid-column: 2;
}
.content-course-age > .content-course__meta {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
}
.content-class > .content-course__meta {
  -ms-grid-row: 3;
  -ms-grid-column: 3;
  -ms-grid-column-span: 1;
}
.content-course__meta-label {
  flex-shrink: 0;
  align-self: flex-start;
}
.content-course__meta-text {
  font-size: 0.875rem;
}
.--meta-column .content-course__meta-text {
  flex-direction: column;
  font-size: 0.75rem;
}
.content-course__contents {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
  grid-area: contents;
}
.content-course.--is-btn > .content-course__contents {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
}
.content-class > .content-course__contents {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
}
.content-course__contents-title {
  margin-block: 0 0.25rem;
  font-size: 0.875rem;
  color: #FE7CAF;
}
.content-course__contents-content {
  font-size: 0.75rem;
}
.content-course__contents-content a {
  color: #575657;
}
.content-course__contents-description {
  font-size: min(1rem, 3.2vw);
}
.content-course__contents-sub {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: min(1.25rem, 3.2vw);
}
.content-course__btn-wrap {
  grid-area: btn;
  display: grid;
  grid-template-columns: 1fr 1fr;
  direction: rtl;
  gap: 0.75rem;
  width: 100%;
}
.content-course-list .content-course__figure {
  width: min(90px, 21.8666666667vw);
}

@media screen and (min-width: 768px) {
  .content-course {
    grid-template-areas: "figure title" "figure meta" "figure contents";
    padding-block: 1.75rem;
  }
  .content-course.--is-btn {
    grid-template-columns: min(130px, 21.8666666667vw) 1fr 154px;
    grid-template-areas: "figure title btn" "figure meta btn" "figure contents btn";
  }
  .content-course:first-child::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 1px;
    background-image: linear-gradient(to right, #575657 2px, transparent 2px);
    background-size: 5px 2px;
  }
  .content-course__btn:last-child {
    order: 0;
  }
  .content-course__btn:first-child {
    order: 1;
  }
  .content-course__btn-wrap {
    grid-template-columns: 1fr;
    align-self: flex-end;
  }
  .content-course-list {
    display: flex;
    flex-direction: column;
    gap: 1.25rem;
  }
  .content-course-list .content-course {
    grid-template: "figure title" auto "figure meta" 1fr "contents contents" auto "btn btn" auto/min(90px, 21.8666666667vw) 1fr;
    gap: 1.25rem;
    padding: 1.25rem;
    border-radius: 0.5rem;
    background-color: white;
    box-shadow: 2px 4px 4px rgba(87, 86, 87, 0.3);
    border: 1px solid #EEEEEE;
  }
  .content-course-list .content-course::before, .content-course-list .content-course::after {
    display: none;
  }
  .content-course-list .content-course__contents-content {
    font-size: 1rem;
  }
  .content-course__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-course.--is-btn > .content-course__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-course-list .content-course > .content-course__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-course__meta {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .content-course.--is-btn > .content-course__meta {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .content-course-list .content-course > .content-course__meta {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
  }
  .content-course__contents {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
  }
  .content-course.--is-btn > .content-course__contents {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
  }
  .content-course-list .content-course > .content-course__contents {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
}
@media screen and (max-width: 767px) {
  .content-course__btn {
    max-width: 100%;
  }
  .--meta-column .content-course__meta {
    flex-direction: column;
  }
}
/* -------------------------------------------------------------------
  course-age
------------------------------------------------------------------- */
.content-course-age {
  display: grid;
  grid-template-areas: "icon age" "meta meta" "title title";
  align-items: center;
  gap: 0.25rem;
  padding: 1rem 1rem 0.75rem;
  color: #575657;
  text-decoration: none;
}
.content-course-age__title {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  grid-area: title;
  margin-block: 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: min(1.25rem, 4.8vw);
}
.content-course.--is-btn > .content-course-age__title {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
}
.content-course-age > .content-course-age__title {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
}
.content-voice > .content-course-age__title {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
}
.content-voice__header > .content-course-age__title {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
}
.content-course-age__title::after {
  content: "\e900";
  font-family: icomoon;
  font-size: 0.8em;
}
.content-course-age__icon {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: icon;
  max-height: 36px;
}
.content-course-age__age {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  grid-area: age;
  justify-self: flex-end;
  font-size: 1.125rem;
  font-weight: bold;
}
.--risu .content-course-age__age {
  color: #0EBC81;
}
.--rakko .content-course-age__age {
  color: #FDC00E;
}
.--koara .content-course-age__age {
  color: #7DCEF4;
}
.--karugamo .content-course-age__age {
  color: #EF4D36;
}
.content-course-age__meta {
  -ms-grid-row: 3;
  -ms-grid-column: 3;
  grid-area: meta;
  font-size: 0.875rem;
}
.content-course.--is-btn > .content-course-age__meta {
  -ms-grid-row: 2;
  -ms-grid-column: 2;
}
.content-course-age > .content-course-age__meta {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
}
.content-class > .content-course-age__meta {
  -ms-grid-row: 3;
  -ms-grid-column: 3;
  -ms-grid-column-span: 1;
}

/* -------------------------------------------------------------------
  class
------------------------------------------------------------------- */
.content-class {
  position: relative;
  display: grid;
  width: 100%;
  grid-template-columns: min(130px, 26.6666666667vw) 1fr;
  grid-template-areas: "header header" "figure meta" "contents contents" "btn btn";
  gap: 0.75rem;
  padding-bottom: 1.5rem;
}
.content-class__items {
  padding-inline: 1rem;
}
.content-class:not(:first-child) {
  padding-top: 1.5rem;
}
.content-class::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #575657 2px, transparent 2px);
  background-size: 5px 2px;
}
.content-class__header {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
  grid-area: header;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.content-voice > .content-class__header {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
}
.content-class__label {
  font-size: 0.625rem;
}
.content-class__title {
  margin: 0;
  font-size: 1.125rem;
}
.content-class__title a {
  color: #575657;
}
.content-class__figure {
  -ms-grid-row: 1;
  -ms-grid-row-span: 3;
  -ms-grid-column: 1;
  grid-area: figure;
  flex-shrink: 0;
  aspect-ratio: 1;
  width: 100%;
  width: min(130px, 26.6666666667vw);
  margin: 0;
}
.content-course.--is-btn > .content-class__figure {
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  -ms-grid-column: 1;
}
.content-class > .content-class__figure {
  -ms-grid-row: 3;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
}
.content-class__figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.content-class__img {
  border-radius: 0.25rem;
}
.content-class__meta {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  font-size: min(0.875rem, 3.2vw);
}
.content-class__meta-address, .content-class__meta-tel {
  display: flex;
  gap: 0.25rem;
}
.content-class__meta-address::before, .content-class__meta-tel::before {
  flex-shrink: 0;
  font-family: icomoon;
  margin-right: 0.25rem;
}
.content-class__meta-map {
  font-size: 0.625rem;
  color: #575657;
  text-decoration: none;
}
.content-class__meta-address {
  align-items: baseline;
}
.content-class__meta-address::before {
  content: "\e904";
}
.content-class__meta-tel::before {
  content: "\e905";
}
.content-class__contents {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
  grid-area: contents;
}
.content-course.--is-btn > .content-class__contents {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 2;
}
.content-class > .content-class__contents {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
}
.content-class__contents-title {
  position: relative;
  margin: 0;
  font-size: 0.875rem;
  color: #EF4D36;
  background-color: rgba(239, 77, 54, 0.16);
  border-radius: 2px;
  padding: 0.25rem 1rem;
  text-align: center;
  cursor: pointer;
}
.content-class__contents-title::after {
  content: "＋";
  position: absolute;
  right: 1rem;
  top: 50%;
  font-size: 1rem;
  line-height: 1.5;
  transform: translateY(-50%);
}
.content-class__contents-title.--accordion-on::after {
  content: "ー";
}
.content-class__contents-content {
  display: none;
  font-size: 0.875rem;
  margin-top: 0.5rem;
}
.content-class__btn-wrap {
  grid-area: btn;
  display: grid;
  grid-template-columns: 1fr 1fr;
  direction: rtl;
  gap: 0.75rem;
  width: 100%;
}
@media screen and (min-width: 1024px){
  .header__catch-group {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
  }
  .header-btn {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .content-course__btn-wrap {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .content-class__btn-wrap {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
}

@media screen and (min-width: 768px) {
  .content-class {
    grid-template: "figure header btn" auto "figure meta btn" auto "figure contents contents" 1fr/min(130px, 26.6666666667vw) 1fr 154px;
    gap: 0.5rem 0.75rem;
    padding-bottom: 0.625rem;
  }
  .content-class__items {
    padding-inline: 0;
  }
  .content-class:not(:first-child) {
    padding-top: 0.625rem;
  }
  .content-class:last-child:after {
    display: none;
  }
  .content-class__btn {
    align-self: flex-start;
  }
  .content-class__btn-wrap {
    grid-template-columns: 1fr;
    align-self: flex-start;
    gap: 0.625rem;
  }
  .content-class__contents {
    justify-self: flex-end;
  }
  .content-class__contents-title {
    padding: 0;
    background-color: transparent !important;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
  }
  .content-class__contents-title::after {
    position: relative;
    top: 0.15rem;
    right: auto;
    margin-left: 1.25rem;
    transform: translateY(-5%);
  }
  .content-class > .content-course__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 5;
    -ms-grid-column: 1;
  }
  .content-class > .content-course__meta {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
  }
  .content-class > .content-course__contents {
    -ms-grid-row: 5;
    -ms-grid-column: 3;
    -ms-grid-column-span: 3;
  }
  .content-class > .content-course-age__meta {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
  }
  .content-class__header {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
  }
  .content-class > .content-class__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 5;
    -ms-grid-column: 1;
  }
  .content-class > .content-class__contents {
    -ms-grid-row: 5;
    -ms-grid-column: 3;
    -ms-grid-column-span: 3;
  }
}
/* -------------------------------------------------------------------
  feature
------------------------------------------------------------------- */
.content-feature {
  counter-increment: feature-num;
}
.content-feature__items {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem 0.5rem;
}
.content-feature__figure {
  position: relative;
  aspect-ratio: 1.7551020408;
  width: 100%;
}
.content-feature__figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.content-feature__figure::after {
  content: counter(feature-num, decimal-leading-zero);
  position: absolute;
  top: 0;
  left: 0;
  padding-inline: 0.5rem;
  border-radius: 0 0 0.5rem 0;
  background-color: #7DCEF4;
  color: white;
  font-family: "Kumbh Sans", sans-serif;
  font-weight: bold;
  font-size: 1.5rem;
}
.content-feature__contents {
  position: relative;
  z-index: 5;
  display: grid;
  gap: 0.5rem;
  margin: -1rem 0.5rem 0;
  padding: 0.5rem 0.75rem;
  border-radius: 0.5rem;
  box-shadow: 2px 4px 4px rgba(87, 86, 87, 0.3);
  background-color: white;
}
.content-feature__title {
  margin: 0;
  font-size: min(1.5rem, 4.2666666667vw);
  font-weight: bold;
  text-align: right;
  color: #FE7CAF;
}
.content-feature__excerpt {
  font-size: min(1rem, 3.2vw);
  margin-bottom: 0;
}
.content-feature__link {
  display: inline-block;
  margin-left: auto;
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: bold;
  color: #575657;
}
.content-feature__link-text {
  text-decoration: underline;
}
.content-feature__link::after {
  content: "\e900";
  font-size: 0.8em;
  font-family: icomoon;
  margin-left: 0.5rem;
}
.content-feature.--no-pc {
  max-width: 380px;
  display: grid;
  grid-template-rows: auto 1fr;
}
.content-feature.--no-pc .content-feature__title {
  font-size: 1.125rem;
  text-align: left;
}
.content-feature.--no-pc .content-feature__figure {
  align-self: flex-start;
}
.content-feature.--no-pc .content-feature__excerpt {
  font-size: min(1rem, 3.7333333333vw);
}
.content-feature.--no-pc .content-feature__contents {
  padding: min(1.25rem, 4.2666666667vw);
  grid-template-rows: auto 1fr;
}

@media screen and (min-width: 768px) {
  .content-feature.--no-pc .content-feature__contents {
    margin-inline: 1.25rem;
  }
  .content-feature__items {
    grid-template-columns: 1fr;
    gap: 0;
    padding: 0.625rem 0.625rem 0;
    border-radius: 0.5rem;
    border: 1px solid #EEEEEE;
  }
  .content-feature:not(.--no-pc):not(:first-child) {
    padding-top: 0.625rem;
  }
  .content-feature:not(.--no-pc):not(:last-child)::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 1px;
    background-image: linear-gradient(to right, #575657 2px, transparent 2px);
    background-size: 5px 2px;
  }
  .content-feature:not(.--no-pc) {
    position: relative;
    display: grid;
    grid-template-columns: 130px 1fr;
    gap: 3rem;
    align-items: center;
    grid-template-areas: "figure contents";
    padding-bottom: 0.625rem;
    padding-right: 2.5rem;
  }
  .content-feature:not(.--no-pc) .content-feature__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
    grid-area: figure;
    aspect-ratio: 1;
    width: 100%;
    width: 130px;
  }
  .content-feature:not(.--no-pc) .content-feature__figure img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .content-feature:not(.--no-pc) .content-feature__figure::after {
    top: 0.625rem;
    left: -0.625rem;
    border-radius: 0 0.5rem 0.5rem 0;
  }
  .content-feature:not(.--no-pc) .content-feature__img {
    border-radius: 0.25rem;
  }
  .content-feature:not(.--no-pc) .content-feature__contents {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
    grid-area: contents;
    display: flex;
    flex-direction: column;
    padding: 0;
    margin-inline: 0;
    box-shadow: none;
    background-color: transparent;
  }
  .content-feature:not(.--no-pc) .content-feature__title {
    text-align: left;
    margin-top: 0.5em;
  }
  .content-feature:not(.--no-pc) .content-feature__title br {
    display: none;
  }
  .content-feature:not(.--no-pc) > .content-course__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
  }
  .content-feature:not(.--no-pc) > .content-course__contents {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
  }
  .content-feature:not(.--no-pc) > .content-class__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
  }
  .content-feature:not(.--no-pc) > .content-class__contents {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
  }
}
@media screen and (max-width: 767px) {
  .content-feature {
    display: grid;
    grid-template-rows: auto 1fr;
  }
  .content-feature__link {
    align-self: self-end;
  }
}
/* -------------------------------------------------------------------
  voice
------------------------------------------------------------------- */
.content-voice {
  position: relative;
  display: grid;
  width: 100%;
  grid-template-columns: 1fr -webkit-max-content;
  grid-template-columns: 1fr max-content;
  grid-template-areas: "header" "title" "excerpt" "link";
  gap: 1rem 0.5rem;
  border-radius: 0.5rem;
  background-color: white;
  padding: 1rem;
}
.content-voice__header {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
  grid-area: header;
  display: grid;
  grid-auto-columns: -webkit-max-content 1fr;
  grid-auto-columns: max-content 1fr;
  grid-template-areas: "label class" "title title";
  align-items: baseline;
  gap: 0.5rem;
}
.content-voice > .content-voice__header {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
}
.content-voice__label {
  -ms-grid-row: 1;
  -ms-grid-column: 1;
  grid-area: label;
  flex-shrink: 0;
  font-size: 0.625rem;
}
.content-voice__class {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  grid-area: class;
  font-size: min(18px, 3.7333333333vw);
  font-weight: bold;
}
.content-voice__title {
  -ms-grid-row: 1;
  -ms-grid-column: 3;
  grid-area: title;
  margin: 0;
  font-size: 1rem;
}
.content-course.--is-btn > .content-voice__title {
  -ms-grid-row: 1;
  -ms-grid-column: 2;
}
.content-course-age > .content-voice__title {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
}
.content-voice > .content-voice__title {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 1;
}
.content-voice__header > .content-voice__title {
  -ms-grid-row: 3;
  -ms-grid-column: 1;
  -ms-grid-column-span: 3;
}
.content-voice__figure {
  -ms-grid-row: 1;
  -ms-grid-row-span: 3;
  -ms-grid-column: 1;
  grid-area: figure;
  flex-shrink: 0;
  aspect-ratio: 1;
  width: 100%;
  width: 80px;
  margin: 0;
  display: none;
}
.content-course.--is-btn > .content-voice__figure {
  -ms-grid-row: 1;
  -ms-grid-row-span: 2;
  -ms-grid-column: 1;
}
.content-class > .content-voice__figure {
  -ms-grid-row: 3;
  -ms-grid-row-span: 1;
  -ms-grid-column: 1;
}
.content-voice__figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.content-voice__excerpt {
  -ms-grid-row: 5;
  -ms-grid-column: 1;
  grid-area: excerpt;
  position: relative;
  overflow: hidden;
  max-height: 4.5em;
}
.content-voice__excerpt p {
  margin-bottom: 0;
}
.content-voice__excerpt::after {
  content: "...";
  display: inline-block;
  position: absolute;
  right: 0;
  bottom: 0;
  padding-left: 0.5rem;
  background-color: white;
}
.--accordion-on .content-voice__excerpt {
  max-height: 100%;
}
.--accordion-on .content-voice__excerpt::after {
  display: none;
}
.content-voice__link {
  -ms-grid-row: 7;
  -ms-grid-column: 1;
  grid-area: link;
  display: flex;
  gap: 0.5rem;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
  font-weight: bold;
  color: #FE7CAF;
  text-decoration: none;
  cursor: pointer;
}
@media screen and (min-width: 768px){
  .content-course-age__title {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .content-course.--is-btn > .content-course-age__title {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .content-course-list .content-course > .content-course-age__title {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .content-course-age__meta {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .content-course.--is-btn > .content-course-age__meta {
    -ms-grid-row: 2;
    -ms-grid-column: 2;
  }
  .content-course-list .content-course > .content-course-age__meta {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
  }
  .content-class__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-course.--is-btn > .content-class__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-course-list .content-course > .content-class__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-class__contents {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
  }
  .content-course.--is-btn > .content-class__contents {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
  }
  .content-course-list .content-course > .content-class__contents {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .content-feature:not(.--no-pc) .content-feature__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-course.--is-btn > .content-feature__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-course-list .content-course > .content-feature__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-class > .content-feature__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 5;
    -ms-grid-column: 1;
  }
  .content-feature:not(.--no-pc) > .content-feature__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
  }
  .content-feature:not(.--no-pc) .content-feature__contents {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
  }
  .content-course.--is-btn > .content-feature__contents {
    -ms-grid-row: 3;
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
  }
  .content-course-list .content-course > .content-feature__contents {
    -ms-grid-row: 5;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .content-class > .content-feature__contents {
    -ms-grid-row: 5;
    -ms-grid-column: 3;
    -ms-grid-column-span: 3;
  }
  .content-feature:not(.--no-pc) > .content-feature__contents {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
  }
  .content-voice__header {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
    -ms-grid-column-span: 1;
  }
  .content-voice__title {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .content-course.--is-btn > .content-voice__title {
    -ms-grid-row: 1;
    -ms-grid-column: 2;
  }
  .content-course-list .content-course > .content-voice__title {
    -ms-grid-row: 1;
    -ms-grid-column: 3;
  }
  .content-voice__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-course.--is-btn > .content-voice__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-course-list .content-course > .content-voice__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 3;
    -ms-grid-column: 1;
  }
  .content-class > .content-voice__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 5;
    -ms-grid-column: 1;
  }
  .content-feature:not(.--no-pc) > .content-voice__figure {
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
    -ms-grid-column: 1;
  }
}
.content-voice__link::before {
  content: attr(open);
}
.content-voice__link::after {
  content: "＋";
  font-size: 1rem;
}
.--accordion-on .content-voice__link::before {
  content: attr(close);
}
.--accordion-on .content-voice__link::after {
  content: "ー";
}

@media screen and (min-width: 768px) {
  .content-voice {
    position: relative;
    max-width: 100%;
    grid-template-columns: 1fr -webkit-max-content;
    grid-template-columns: 1fr max-content;
    grid-template-areas: "header header" "excerpt link";
    gap: 1rem 2.5rem;
    padding: 1rem 2rem;
    border-radius: 0;
    cursor: pointer;
  }
  .content-voice::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0.625rem;
    display: block;
    width: calc(100% - 1.25rem);
    height: 1px;
    background-image: linear-gradient(to right, #575657 2px, transparent 2px);
    background-size: 5px 2px;
  }
  .content-voice__label {
    align-self: center;
  }
  .content-voice__figure {
    width: 130px;
  }
  .content-voice__excerpt {
    max-height: 3rem;
  }
  .content-voice__link {
    align-self: flex-end;
  }
  .content-voice > .content-class__header {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .content-voice > .content-voice__header {
    -ms-grid-row: 1;
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
  }
  .content-voice__excerpt {
    -ms-grid-row: 3;
    -ms-grid-column: 1;
  }
  .content-voice__link {
    -ms-grid-row: 3;
    -ms-grid-column: 3;
  }
}
/* -------------------------------------------------------------------
  767以下
------------------------------------------------------------------- */
@media screen and (max-width: 767px) {
  .splide .content-voice {
    width: 100%;
    max-width: 310px;
  }
  .content-voice__items {
    display: grid;
    gap: 1.25rem;
    justify-content: center;
    padding: 1.25rem;
    background-color: #F7F7F7;
  }
  .content-voice__items .btn-block {
    margin-top: 0;
  }
}
/* -------------------------------------------------------------------
  content-big-image
------------------------------------------------------------------- */
.content-big-image {
  padding-bottom: min(5rem, 10.6666666667vw);
}
.content-big-image__title {
  position: relative;
  margin: 0 auto;
  max-width: 1080px;
}
.content-big-image__inner {
  padding-bottom: 0;
}
.has-sidebar .content-big-image__inner {
  width: 700px;
}
.content-big-image__contents {
  position: relative;
  margin-top: max(-3rem, -9.0666666667vw);
  padding: min(2.5rem, 5.3333333333vw) min(2.5rem, 4.2666666667vw);
}
.content-big-image__contents-title {
  margin-top: 0;
  color: #FE7CAF;
  font-size: min(1.25rem, 4.2666666667vw);
}
.content-big-image__sub-contents {
  display: flex;
  justify-content: center;
  padding-top: 1.25rem;
}
.content-big-image__sub-contents-img {
  height: auto;
}

@media screen and (min-width: 768px) {
  .content-big-image {
    padding-inline: 0.75rem;
  }
  .content-big-image__sub-contents {
    margin-top: -2.5rem;
    padding: 5rem 2.5rem 2.5rem;
    background-color: #F7F7F7;
  }
}
@media screen and (min-width: 800px) {
  .content-big-image__title img {
    border-radius: 1rem;
  }
  .content-big-image__inner {
    padding-inline: 0;
  }
}
/* -------------------------------------------------------------------
  content-big-slider
------------------------------------------------------------------- */
.content-big-slider .splide__slide {
  width: 100%;
  max-width: 1080px;
}
.content-big-slider .splide__slide picture {
  aspect-ratio: 1.6438356164;
  width: 100%;
}
.content-big-slider .splide__slide picture img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.content-big-slider .splide__pagination {
  position: relative;
  bottom: auto;
  padding-block: 0.5rem 1.25rem;
}
.content-big-slider .splide__pagination__page {
  background-color: #E3E1E2;
}
.content-big-slider .splide__pagination__page.is-active {
  background-color: #575657;
}

@media screen and (min-width: 768px) {
  .content-big-slider .splide__slide {
    padding-inline: 0.75rem;
  }
  .content-big-slider .splide__slide img {
    width: 1080px;
    max-width: 100%;
    border-radius: 1rem;
    box-shadow: 2px 4px 4px rgba(87, 86, 87, 0.3);
    margin-bottom: 0.5rem;
  }
  .content-big-slider .splide__pagination {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
  }
  .content-big-slider .splide__pagination__page {
    background-color: white;
    border: 1px solid #575657;
  }
}
.splide__container {
  box-sizing: border-box;
  position: relative;
}

.splide__list {
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  align-items: center;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide:not(.is-overflow) .splide__pagination {
  display: none;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized, .splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
  box-sizing: border-box;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

.splide__sr {
  clip: rect(0 0 0 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.splide__toggle.is-active .splide__toggle__play, .splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -moz-user-select: none;
       user-select: none;
}

.splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__arrow {
  align-items: center;
  background: #ccc;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  height: 2em;
  justify-content: center;
  opacity: 0.7;
  padding: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2em;
  z-index: 1;
}

.splide__arrow svg {
  fill: #000;
  height: 1.2em;
  width: 1.2em;
}

.splide__arrow:hover:not(:disabled) {
  opacity: 0.9;
}

.splide__arrow:disabled {
  opacity: 0.3;
}

.splide__arrow:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__arrow--prev {
  left: 1em;
}

.splide__arrow--prev svg {
  transform: scaleX(-1);
}

.splide__arrow--next {
  right: 1em;
}

.splide.is-focus-in .splide__arrow:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__pagination {
  bottom: 0.5em;
  left: 0;
  padding: 0 1em;
  position: absolute;
  right: 0;
  z-index: 1;
}

.splide__pagination__page {
  background: #ccc;
  border: 0;
  border-radius: 50%;
  display: inline-block;
  height: 8px;
  margin: 3px;
  opacity: 0.7;
  padding: 0;
  position: relative;
  transition: transform 0.2s linear;
  width: 8px;
}

.splide__pagination__page.is-active {
  background: #fff;
  transform: scale(1.4);
  z-index: 1;
}

.splide__pagination__page:hover {
  cursor: pointer;
  opacity: 0.9;
}

.splide__pagination__page:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__pagination__page:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__progress__bar {
  background: #ccc;
  height: 3px;
}

.splide__slide {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.splide__slide:focus {
  outline: 0;
}

@supports (outline-offset: -3px) {
  .splide__slide:focus-visible {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide__slide:focus-visible {
    border: 3px solid #0bf;
  }
}
@supports (outline-offset: -3px) {
  .splide.is-focus-in .splide__slide:focus {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide.is-focus-in .splide__slide:focus {
    border: 3px solid #0bf;
  }
  .splide.is-focus-in .splide__track > .splide__list > .splide__slide:focus {
    border-color: #0bf;
  }
}
.splide__toggle {
  cursor: pointer;
}

.splide__toggle:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__toggle:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__track--nav > .splide__list > .splide__slide {
  border: 3px solid transparent;
  cursor: pointer;
}

.splide__track--nav > .splide__list > .splide__slide.is-active {
  border: 3px solid #000;
}

.splide__arrows--rtl .splide__arrow--prev {
  left: auto;
  right: 1em;
}

.splide__arrows--rtl .splide__arrow--prev svg {
  transform: scaleX(1);
}

.splide__arrows--rtl .splide__arrow--next {
  left: 1em;
  right: auto;
}

.splide__arrows--rtl .splide__arrow--next svg {
  transform: scaleX(-1);
}

.splide__arrows--ttb .splide__arrow {
  left: 50%;
  transform: translate(-50%);
}

.splide__arrows--ttb .splide__arrow--prev {
  top: 1em;
}

.splide__arrows--ttb .splide__arrow--prev svg {
  transform: rotate(-90deg);
}

.splide__arrows--ttb .splide__arrow--next {
  bottom: 1em;
  top: auto;
}

.splide__arrows--ttb .splide__arrow--next svg {
  transform: rotate(90deg);
}

.splide__pagination--ttb {
  bottom: 0;
  display: flex;
  flex-direction: column;
  left: auto;
  padding: 1em 0;
  right: 0.5em;
  top: 0;
}

.splide__arrow {
  width: 1.5rem;
  height: 1.5rem;
  background: white;
  box-shadow: 2px 4px 4px rgba(87, 86, 87, 0.3);
}
.splide__arrow--prev {
  left: 0.5rem;
}
.splide__arrow--next {
  right: 0.5rem;
}
.splide__arrow svg {
  width: 10px;
}

/* -------------------------------------------------------------------
  768px以上
------------------------------------------------------------------- */
@media screen and (min-width: 768px) {
  .splide__arrow {
    width: 3.5rem;
    height: 3.5rem;
    opacity: 0.9;
  }
  .splide__arrow--prev {
    left: 2rem;
  }
  .splide__arrow--next {
    right: 2rem;
  }
  .splide__arrow svg {
    width: 1.5rem;
    fill: #FE7CAF;
  }
}
/* -------------------------------------------------------------------
  top
------------------------------------------------------------------- */
.top-course-age .inner__narrow,
.top-class .inner__narrow,
.top-scenery .inner__narrow,
.top-feature .inner__narrow,
.top-course .inner__narrow,
.top-event .inner__narrow,
.top-voice .inner__narrow,
.top-column .inner__narrow,
.common-cta .inner__narrow {
  background-color: #F7F7F7;
}

.top-greeting,
.top-passing {
  background-color: #F7F7F7;
}

.main-top {
  background-color: #F7F7F7;
}

.top-head-news__inner {
  padding: 0;
}
.top-head-news__contents {
  display: flex;
  gap: 0.75rem;
}
.top-head-news__title {
  flex-shrink: 0;
  margin: 0;
  padding: 1.25rem 0.75rem;
  border-top: 4px solid #FE7CAF;
  font-size: min(1.25rem, 3.7333333333vw);
}
.top-head-news .content-news {
  padding-block: 0.75rem;
}
.top-head-news .content-news::before, .top-head-news .content-news::after {
  display: none;
}
.top-head-news .content-news__title {
  font-size: min(1rem, 3.2vw);
}
.top-head-news .content-news__category {
  padding-top: 0.2em;
  font-size: min(0.875rem, 2.6666666667vw);
}

.top-head-banners {
  padding-top: 1.25rem;
  background-color: #F7F7F7;
}
.top-head-banners .splide__slide {
  padding-bottom: 5px;
}
.top-greeting__contents {
  padding: min(3.5rem, 4.2666666667vw) 1rem 0.75rem;
}
.top-greeting__description {
  position: relative;
  max-width: min(510px, 85.3333333333vw);
  margin: 0 auto;
  padding: min(2rem, 7.4666666667vw) min(1.23rem, 4.2666666667vw);
  font-size: min(1.25rem, 3.7333333333vw);
  font-weight: bold;
  line-height: 2.2;
  text-align: center;
}
.top-greeting__description::before, .top-greeting__description::after {
  content: "";
  position: absolute;
  display: block;
  width: 1.5rem;
  height: 2.5rem;
}
.top-greeting__description::before {
  top: 0;
  left: 0;
  border-top: 3px solid #FE7CAF;
  border-left: 3px solid #FE7CAF;
}
.top-greeting__description::after {
  right: 0;
  bottom: 0;
  border-bottom: 3px solid #FE7CAF;
  border-right: 3px solid #FE7CAF;
}
.top-greeting__btn-wrap {
  max-width: 610px;
  margin-top: min(1.75rem, 1.0666666667vw);
  margin-inline: auto;
  padding-block: min(57px, 14.9333333333vw) min(36px, 2.6666666667vw);
  background: url(../assets/top-greeting-object.png) right bottom no-repeat;
  background-size: contain;
}

.top-column__title {
  text-align: center;
  margin: 0;
}
.top-column__items {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
  padding-block: 1.5rem 2.5rem;
}
.top-column__slider .splide__track {
  padding-right: 0.75rem !important;
}

.top-course__items,
.top-class__items {
  padding: 1rem;
  border-radius: 0.5rem;
  background-color: white;
}

.top-course-age__items {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: min(1.25rem, 2.1333333333vw);
}
.top-course-age__title {
  margin-block: 0 0.5rem;
}
.top-course-age__contents {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

.top-feature__items {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem 0.5rem;
}

.top-scenery .inner__narrow {
  padding-bottom: 3rem;
}
.top-scenery__content {
  width: 375px;
  margin: 0 auto;
  background-image: url(../assets/top-class-scenery-sp.png);
  background-repeat: no-repeat;
  background-size: contain;
  padding: 203px 34px 70px 33px;
}

.top-voice__banners {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem 2.5rem;
  margin-top: 3rem;
}

.top-event__inner {
  background-color: #7DCEF4;
  background-image: url(../assets/bg-grid.png);
  padding-bottom: 2.5rem;
}
.top-event__label {
  transform: translateY(-50%);
}
.top-event__title {
  font-size: min(1.875rem, 6.4vw);
  color: white;
  text-align: center;
  margin-block: 0 min(2rem, 5.3333333333vw);
}
.top-event__banner {
  color: #575657;
}
.top-event__banner-text {
  display: block;
  font-size: 0.625rem;
  line-height: 3;
}
.top-event__banners {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: min(1.25rem, 3.2vw) min(2.5rem, 2.1333333333vw);
  max-width: 650px;
  margin-inline: auto;
}

/* -------------------------------------------------------------------
  768px以上
------------------------------------------------------------------- */
@media screen and (min-width: 768px) {
  .main-top {
    position: relative;
    padding-block: 2.5rem;
    background-color: transparent;
  }
  .top-head-news__title {
    padding-block: 0.625rem;
  }
  .top-head-news__contents {
    gap: 2.5rem;
  }
  .top-head-banners {
    padding-bottom: 5rem;
    background-color: transparent;
  }
  .top-greeting {
    background-color: transparent;
  }
  .top-greeting__description {
    line-height: 2;
  }
  .top-scenery__content {
    width: 772px;
    max-width: 100%;
    padding: 46px 0px 45px 414px;
    background-image: url(../assets/top-class-scenery-pc.png);
  }
  .top-scenery__content iframe {
    width: 307px;
    height: 171px;
  }
  .top-course-age__contents {
    grid-template-columns: 1fr 1fr;
  }
  .top-voice .content-voice {
    padding: 0.625rem;
  }
  .top-voice__banner {
    max-width: 308px;
  }
  .top-voice__banners {
    flex-direction: row;
    justify-content: center;
  }
  .top-voice .splide__slide:first-child .content-voice {
    border-radius: 0.5rem 0.5rem 0 0;
  }
  .top-voice .splide__slide:last-child .content-voice {
    border-radius: 0 0 0.5rem 0.5rem;
  }
  .top-voice .splide__slide:last-child .content-voice::after {
    display: none;
  }
  .top-class__items,
  .top-course__items,
  .top-feature__items {
    padding: 0.625rem 0.625rem 0;
  }
  .top-course .inner__narrow {
    padding-bottom: 5rem;
  }
  .top-course .content-course {
    padding-block: 0.625rem;
  }
  .top-course .content-course:first-child {
    padding-top: 0;
  }
  .top-course .content-course:first-child::before {
    display: none;
  }
  .top-course .content-course:last-child::after {
    display: none;
  }
  .top-feature__items {
    grid-template-columns: 1fr;
    gap: 0;
    background-color: white;
    border-radius: 0.5rem;
  }
  .top-feature .inner__narrow {
    padding-bottom: 0;
  }
  .top-event__inner {
    position: relative;
    background-image: none;
    border-radius: 0.5rem;
    box-shadow: 2px 4px 4px rgba(87, 86, 87, 0.3);
  }
  .top-event__inner::before {
    content: "";
    position: absolute;
    top: 0.625rem;
    left: 0.625rem;
    display: block;
    width: calc(100% - 1.25rem);
    height: calc(100% - 1.25rem);
    border: 1px solid white;
    border-radius: 0.25rem;
  }
  .top-event__title {
    position: relative;
  }
  .top-column {
    padding-top: 3rem;
    border-top: 0;
  }
  .top-column .border-top {
    border-top: 0;
  }
  .top-column .inner__narrow {
    background-color: transparent;
  }
  .top-column .splide__list {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem !important;
    justify-content: space-between !important;
  }
  .top-column .splide__slide {
    justify-self: center;
  }
  .top-column__items {
    gap: 2.25rem;
    padding-top: 2.5rem;
  }
}

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