@charset "UTF-8";
/* コンテンツ最大幅 */
/* color */
/* ============================================ */
/* font-size */
/* ============================================ */
/* font-family */
/* ============================================ */
/* about */
/* ============================================ */
.about-outer {
  padding-bottom: 150px;
}
@media all and (max-width: 896px) {
  .about-outer {
    padding-bottom: 64px;
  }
}

.about-intro {
  position: relative;
}
.about-intro::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, transparent 0%, #F9F5ED 100%);
  position: absolute;
  top: 0;
  left: 0;
}
.about-intro__wrapper {
  position: relative;
  z-index: 10;
}
@media all and (max-width: 896px) {
  .about-intro__wrapper {
    width: 100%;
  }
}
.about-intro__symbol {
  position: absolute;
}
.about-intro__symbol.--symbol01 {
  width: 2.38cqw;
  top: 23.73cqw;
  left: -10.97cqw;
}
@media all and (max-width: 896px) {
  .about-intro__symbol.--symbol01 {
    width: 3.73vw;
    top: 36.73vw;
    left: 3.73vw;
  }
}
.about-intro__symbol.--symbol02 {
  width: 5.75cqw;
  bottom: 5.9cqw;
  left: 17.76cqw;
}
@media all and (max-width: 896px) {
  .about-intro__symbol.--symbol02 {
    width: 15.2vw;
    bottom: 29.67vw;
    left: 17.76vw;
  }
}
.about-intro__symbol.--symbol03 {
  width: 1.49cqw;
  right: 7.91cqw;
  bottom: 18.28cqw;
}
@media all and (max-width: 896px) {
  .about-intro__symbol.--symbol03 {
    width: 3.73vw;
    right: 7.91vw;
    bottom: auto;
    top: 11.28vw;
  }
}
.about-intro__symbol.--symbol04 {
  width: 5.75cqw;
  right: -14.25cqw;
  bottom: 3.28cqw;
}
@media all and (max-width: 896px) {
  .about-intro__symbol.--symbol04 {
    width: 15.2vw;
    right: 0;
    bottom: 3.28vw;
  }
}
.about-intro__img {
  position: absolute;
  filter: drop-shadow(8px 8px 50px rgba(74, 74, 74, 0.15));
}
@media all and (max-width: 896px) {
  .about-intro__img {
    filter: drop-shadow(6px 6px 40px rgba(74, 74, 74, 0.15));
  }
}
.about-intro__img img {
  width: 100%;
  max-width: none;
  border-radius: 8px;
}
@media all and (max-width: 896px) {
  .about-intro__img img {
    border-radius: 4px;
  }
}
.about-intro__img.--img01 {
  width: 22.24cqw;
  top: 2.54cqw;
  left: -4.78cqw;
}
@media all and (max-width: 896px) {
  .about-intro__img.--img01 {
    width: 30.65vw;
    top: -20px;
    left: -2.54vw;
  }
}
.about-intro__img.--img02 {
  width: 33.51cqw;
  top: 7.16cqw;
  right: -18.13cqw;
}
@media all and (max-width: 896px) {
  .about-intro__img.--img02 {
    width: 46.19vw;
    top: auto;
    right: -2.54vw;
    bottom: 11vw;
  }
}
.about-intro__img.--img03 {
  width: 31.11cqw;
  bottom: -3.2cqw;
  left: -15.9cqw;
}
@media all and (max-width: 896px) {
  .about-intro__img.--img03 {
    width: 42.9vw;
    bottom: -3.2vw;
    left: -3.2vw;
  }
}
.about-intro__img.--img04 {
  width: 24.48cqw;
  right: -1.19cqw;
  bottom: -8.58cqw;
}
@media all and (max-width: 896px) {
  .about-intro__img.--img04 {
    display: none;
  }
}
.about-intro__container {
  text-align: center;
  padding-top: 8.21cqw;
  padding-bottom: 9.03cqw;
  position: relative;
  z-index: 20;
}
@media all and (max-width: 896px) {
  .about-intro__container {
    padding-top: 10.66vw;
    padding-bottom: 42.67vw;
    padding-inline: 15px;
  }
}
.about-intro__ttl {
  font-size: clamp(1.25rem, -0.2635rem + 2.7027vw, 2rem);
  font-weight: 700;
  letter-spacing: 0.15em;
  line-height: 2.2;
}
.about-intro__ttl > span {
  background: #E7E9F5;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  color: #3E41B5;
}
.about-intro__txt {
  word-break: keep-all;
  font-size: clamp(1rem, 0.4955rem + 0.9009vw, 1.25rem);
  font-weight: 500;
  line-height: 3;
  margin-top: 3.58cqw;
}
@media all and (max-width: 896px) {
  .about-intro__txt {
    line-height: 2.5;
    margin-top: 3.2vw;
  }
}

.about-reason {
  position: relative;
}
.about-reason::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, transparent 0%, #F9F5ED 100%);
  position: absolute;
  top: 0;
  left: 0;
}
.about-reason__wrapper {
  position: relative;
  z-index: 10;
}
.about-reason__container {
  padding-top: 13.06cqw;
  padding-bottom: 120px;
}
@media all and (max-width: 896px) {
  .about-reason__container {
    padding-top: 15vw;
    padding-bottom: 64px;
  }
}
.about-reason__item {
  padding: 5.37cqw;
  background: #fff;
  border-radius: 8px;
  box-shadow: 6px 6px 30px 0 rgba(74, 74, 74, 0.05);
  margin-top: 48px;
}
@media all and (max-width: 896px) {
  .about-reason__item {
    padding: 24px;
    margin-top: 24px;
  }
}
.about-reason__item + .about-reason__item {
  margin-top: 40px;
}
@media all and (max-width: 896px) {
  .about-reason__item + .about-reason__item {
    margin-top: 32px;
  }
}
.about-reason__inner {
  display: flex;
  gap: 20px 4.18cqw;
}
@media all and (max-width: 600px) {
  .about-reason__inner {
    flex-direction: column;
  }
}
.about-reason__contents {
  flex-grow: 1;
}
@media all and (max-width: 600px) {
  .about-reason__contents {
    width: 100%;
  }
}
.about-reason__block {
  display: flex;
  align-items: center;
  gap: 24px;
}
@media all and (max-width: 896px) {
  .about-reason__block {
    gap: 16px;
  }
}
.about-reason__number {
  flex-shrink: 0;
  width: 7.76cqw;
}
@media all and (max-width: 600px) {
  .about-reason__number {
    width: 17.07cqw;
  }
}
.about-reason__number img {
  width: 100%;
  max-width: none;
}
.about-reason__ttl {
  font-size: clamp(1.25rem, -0.2635rem + 2.7027vw, 2rem);
  font-weight: 700;
  line-height: 1.5;
}
.about-reason__txt {
  font-size: clamp(0.9375rem, 0.5591rem + 0.6757vw, 1.125rem);
  line-height: 2;
  margin-top: 24px;
}
@media all and (max-width: 896px) {
  .about-reason__txt {
    margin-top: 16px;
  }
}
.about-reason__img {
  flex-shrink: 0;
  width: 29.85cqw;
}
@media all and (max-width: 600px) {
  .about-reason__img {
    width: 100%;
  }
}
.about-reason__img img {
  width: 100%;
  max-width: none;
  border-radius: 8px;
}

.about-teacher {
  padding: 120px 0;
}
@media all and (max-width: 896px) {
  .about-teacher {
    padding: 64px 0;
  }
}
.about-teacher__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  margin-top: 48px;
}
@media all and (max-width: 896px) {
  .about-teacher__list {
    grid-template-columns: repeat(1, 1fr);
    gap: 32px 24px;
    margin-top: 32px;
  }
}
.about-teacher__item {
  box-shadow: 6px 6px 30px 0 rgba(74, 74, 74, 0.05);
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  gap: 0;
}
.about-teacher__ttl {
  text-align: center;
  background: #3E41B5;
  color: #fff;
  padding: 0.6em 0.8em;
  font-size: clamp(1rem, 0.4955rem + 0.9009vw, 1.25rem);
  font-weight: 500;
  border-radius: 8px 8px 0 0;
}
@media all and (max-width: 896px) {
  .about-teacher__img {
    max-width: 400px;
    margin-inline: auto;
  }
}
.about-teacher__img img {
  border-radius: 8px;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 522/353;
}
.about-teacher__contents {
  padding: 44px 4.78cqw 64px;
  background: #fff;
  border-radius: 0 0 8px 8px;
}
@media all and (max-width: 896px) {
  .about-teacher__contents {
    padding: 20px;
  }
}
.about-teacher__detail {
  margin-top: 24px;
}
@media all and (max-width: 896px) {
  .about-teacher__detail {
    margin-top: 16px;
  }
}
.about-teacher__detail__item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-top: 16px;
}
@media all and (max-width: 896px) {
  .about-teacher__detail__item {
    gap: 12px;
    margin-top: 12px;
  }
}
.about-teacher__detail__item:first-of-type {
  margin-top: 0;
}
.about-teacher__detail__item dt {
  flex-shrink: 0;
  text-align: center;
  padding: 0.2em;
  width: 6.5em;
  color: #3E41B5;
  font-weight: 500;
  line-height: 1.4;
  border: 2px solid #3E41B5;
  border-radius: 9999px;
}
.about-teacher__detail__item dd {
  font-size: clamp(0.9375rem, 0.5591rem + 0.6757vw, 1.125rem);
}
.about-teacher__message {
  margin-top: 20px;
  padding: 20px 24px 24px;
  background: #EBEBF1;
  border-radius: 8px;
}
@media all and (max-width: 896px) {
  .about-teacher__message {
    margin-top: 16px;
    padding: 12px 16px 16px;
  }
}
.about-teacher__message__ttl {
  font-size: clamp(1rem, 0.4955rem + 0.9009vw, 1.25rem);
  font-weight: 700;
  color: #3E41B5;
  margin-bottom: 4px;
}
.about-teacher__message__txt {
  font-size: clamp(0.9375rem, 0.5591rem + 0.6757vw, 1.125rem);
  font-weight: 500;
}

.about-message {
  padding: 120px 0;
  background: #F9F5ED;
  position: relative;
}
@media all and (max-width: 896px) {
  .about-message {
    padding: 64px 0;
  }
}
.about-message__symbol {
  position: absolute;
}
.about-message__symbol.--symbol01 {
  width: 11.2vw;
  top: 1.25vw;
  left: 1.25vw;
}
@media all and (max-width: 896px) {
  .about-message__symbol.--symbol01 {
    width: 25.06vw;
  }
}
.about-message__symbol.--symbol02 {
  width: 11.2vw;
  right: 1.25vw;
  bottom: 1.25vw;
}
@media all and (max-width: 896px) {
  .about-message__symbol.--symbol02 {
    width: 25.06vw;
  }
}
.about-message__wrapper {
  position: relative;
  z-index: 20;
}
.about-message__container {
  display: flex;
  gap: 32px 4.78cqw;
  margin-top: 48px;
}
@media all and (max-width: 896px) {
  .about-message__container {
    flex-direction: column;
    margin-top: 32px;
  }
}
.about-message__inner {
  flex-grow: 1;
}
@media all and (max-width: 896px) {
  .about-message__inner {
    width: 100%;
  }
}
.about-message__catch {
  font-size: clamp(1.125rem, 0.3682rem + 1.3514vw, 1.5rem);
  font-weight: 700;
}
.about-message__txt {
  font-size: clamp(0.9375rem, 0.5591rem + 0.6757vw, 1.125rem);
  line-height: 2;
  margin-top: 24px;
}
@media all and (max-width: 896px) {
  .about-message__txt {
    margin-top: 20px;
  }
}
.about-message__txt + .about-message__txt {
  margin-top: 16px;
}
@media all and (max-width: 896px) {
  .about-message__txt + .about-message__txt {
    margin-top: 12px;
  }
}
.about-message__name {
  font-size: clamp(0.9375rem, 0.5591rem + 0.6757vw, 1.125rem);
  inline-size: -webkit-fit-content;
  inline-size: -moz-fit-content;
  inline-size: fit-content;
  margin: 40px 0 0 auto;
}
@media all and (max-width: 896px) {
  .about-message__name {
    margin-top: 20px;
  }
}
.about-message__name .txt_large {
  display: inline-block;
  font-size: 1.33em;
}
.about-message__img {
  flex-shrink: 0;
  width: 47.61cqw;
}
@media all and (max-width: 896px) {
  .about-message__img {
    width: 100%;
    max-width: 400px;
    margin-inline: auto;
  }
}
.about-message__img img {
  width: 100%;
  max-width: none;
  border-radius: 8px;
}

.about-class {
  padding: 120px 0;
}
@media all and (max-width: 896px) {
  .about-class {
    padding: 64px 0;
  }
}
.about-class__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  margin-top: 48px;
}
@media all and (max-width: 896px) {
  .about-class__list {
    gap: 32px 24px;
    margin-top: 40px;
  }
}
@media all and (max-width: 600px) {
  .about-class__list {
    grid-template-columns: repeat(1, 1fr);
  }
}
.about-class__img img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 650/403;
  border-radius: 8px;
}
.about-class__ttl {
  font-size: clamp(1.125rem, 0.3682rem + 1.3514vw, 1.5rem);
  font-weight: 700;
  color: #3E41B5;
  margin-top: 12px;
}
.about-class__txt {
  font-size: clamp(0.9375rem, 0.5591rem + 0.6757vw, 1.125rem);
  line-height: 2;
  margin-top: 4px;
}

.about-access {
  padding: 120px 0;
  position: relative;
}
@media all and (max-width: 896px) {
  .about-access {
    padding: 64px 0;
  }
}
.about-access::before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(180deg, transparent 0%, #F9F5ED 100%);
  position: absolute;
  top: 0;
  left: 0;
}
@media all and (max-width: 896px) {
  .about-access .common-btn {
    margin-inline: auto;
  }
}
.about-access__wrapper {
  position: relative;
  z-index: 20;
}
.about-access__container {
  display: flex;
  gap: 32px 48px;
  margin-top: 48px;
}
@media all and (max-width: 896px) {
  .about-access__container {
    flex-direction: column;
    margin-top: 40px;
  }
}
.about-access__map {
  flex-shrink: 0;
  width: 48.21cqw;
}
@media all and (max-width: 896px) {
  .about-access__map {
    width: 100%;
  }
}
.about-access__map iframe {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 646/473;
}
.about-access__inner {
  flex-grow: 1;
}
.about-access__ttl {
  font-size: clamp(1.125rem, 0.3682rem + 1.3514vw, 1.5rem);
  font-weight: 700;
  color: #3E41B5;
}
.about-access__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 16px;
}
@media all and (max-width: 600px) {
  .about-access__list {
    grid-template-columns: repeat(1, 1fr);
  }
}
.about-access__item {
  padding-block: 16px;
  padding-right: 16px;
  border-bottom: 1px solid #E8E8E8;
}
@media all and (max-width: 896px) {
  .about-access__item {
    padding-right: 0;
  }
}
.about-access__name {
  font-size: clamp(0.9375rem, 0.5591rem + 0.6757vw, 1.125rem);
  color: #3E41B5;
  display: flex;
  gap: 4px;
}
.about-access__name__icon {
  flex-shrink: 0;
  width: 1.11em;
}
.about-access__name__jp {
  font-weight: 700;
  margin-top: 0.1em;
}
.about-access__txt {
  font-size: clamp(0.9375rem, 0.5591rem + 0.6757vw, 1.125rem);
  line-height: 1.8;
  margin-top: 4px;
}
.about-access__txt a {
  color: #3E41B5;
  text-decoration: underline;
  text-underline-offset: 0.2em;
}
.about-access__txt a[target=_blank]::after {
  content: "";
  display: inline-block;
  width: 1.33em;
  height: 1.33em;
  background: url("../images/common/arrow_blank.svg") center center/contain no-repeat;
  vertical-align: -0.3em;
}

.about-flow {
  padding: 120px 0 60px;
}
@media all and (max-width: 896px) {
  .about-flow {
    padding: 64px 0 40px;
  }
}
.about-flow__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3.12cqw 32px;
  margin-top: 40px;
}
@media all and (max-width: 1025px) {
  .about-flow__list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media all and (max-width: 896px) {
  .about-flow__list {
    gap: 20px;
  }
}
@media all and (max-width: 600px) {
  .about-flow__list {
    grid-template-columns: repeat(1, 1fr);
  }
}
.about-flow__item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  gap: 0;
}
.about-flow__number {
  text-align: center;
  margin-bottom: -4.39cqw;
  position: relative;
  z-index: 40;
}
@media all and (max-width: 600px) {
  .about-flow__number {
    margin-bottom: -8cqw;
  }
}
.about-flow__number img {
  width: 7.81cqw;
}
@media all and (max-width: 600px) {
  .about-flow__number img {
    width: 17.07cqw;
  }
}
.about-flow__block {
  padding: 5.46cqw 3.12cqw 32px;
  background: #fff;
  border-radius: 8px;
  box-shadow: 6px 6px 30px 0 rgba(74, 74, 74, 0.05);
}
@media all and (max-width: 896px) {
  .about-flow__block {
    padding: 5.46cqw 20px 20px;
  }
}
@media all and (max-width: 600px) {
  .about-flow__block {
    padding: 10.67cqw 20px 20px;
  }
}
.about-flow__ttl {
  word-break: keep-all;
  text-align: center;
  font-size: clamp(1rem, -0.009rem + 1.8018vw, 1.5rem);
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.5;
}
.about-flow__img {
  margin-top: 16px;
}
.about-flow__box {
  margin-top: 16px;
}
.about-flow__txt {
  font-size: clamp(0.9375rem, 0.5591rem + 0.6757vw, 1.125rem);
  line-height: 2;
}
.about-flow__btn {
  text-align: center;
  max-width: 380px;
  margin-inline: auto;
  margin-top: 48px;
}
@media all and (max-width: 896px) {
  .about-flow__btn {
    margin-top: 40px;
  }
}
.about-flow__btn__link {
  display: block;
  padding: 0.89em 1.33em 0.89em 2.22em;
  border: 2px solid #EF9E4C;
  border-radius: 9999px;
  color: #fff;
  background: #EF9E4C;
  font-size: clamp(0.9375rem, 0.5591rem + 0.6757vw, 1.125rem);
  font-weight: 700;
  letter-spacing: 0.1em;
  position: relative;
}
.about-flow__btn__link::before {
  content: "";
  display: inline-block;
  width: 1.33em;
  height: 1.33em;
  background: url("../images/common/icon_fukidashi_white.svg") center center/contain no-repeat;
  position: absolute;
  top: 50%;
  left: 0.6em;
  translate: 0 -50%;
}