@charset "utf-8";
/* CSS Document */

   /* # =================================================================
   # Project
   # ================================================================= */
/* お問い合わせ等ヘッダー・フッター */
.p-header.--headergreen {
   background-color: var(--color-green);
}
   .p-form {
   padding-top: 60px;
}
@media (max-width: 767.98px) {
   .p-form {
      padding-top: 30px;
   }
}   
.p-footer-form{
   background-color: var(--color-dark-green);
}
.p-footer-form__txt {
   display: block;
   color: #FFF;
   font-size: 1.3rem;
   text-align: center;
}
.p-footer-form.--bottom-sticky{
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
}

/* ダウンロードページ */
.p-form-download {
  padding: 10px 0;
}


.p-form-download__inner {
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
}


@media (min-width: 768px) {
  .p-form-download__inner {
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
  }

  .p-form-download__txt {
    flex: 1;
  }

  .p-form-download__img {
    flex: 0 0 45%;
  }
}

.p-form-download__img img {
  width: 100%;
  height: auto;
  display: block;
}

.p-form__img {
   width: 100%;
   margin-top: 1.6rem;
}

/* 各校舎お問い合わせページ */
.p-gpt {
   margin-top: 5em;
}

.p-gpt__btns {
   display: flex;
   flex-wrap: wrap;
   justify-content: center;
   align-items: center;
   gap: 20px;
   margin-top: 2em;
}


@media (max-width: 767.98px) {
   .p-gpt {
      margin-top: 5em;
   }
   .p-gpt__btns {
      gap: 10px;
   }
}

.p-gpt__label {
   display: flex;
   justify-content: center;
   align-items: center;
   min-height: 1.6em;
   border-radius: 9999px;
   line-height: 1;
   text-align: center;
   position: absolute;
   width: 17em;
   background-color: var(--color-yellow);
   font-weight: var(--fontweight-bold);
   color: var(--color-green);
   font-size: 1.2rem;
   font-family: var(--font-en);
   padding: 0.3em 0; 
   line-height: 1.2;    
   text-align: center;
   bottom: 100%;
   left: 50%;
   transform: translate(-50%, 35%); 
}
.p-gpt__btns .--btn_center {
   margin-right: 0;
   margin-left: 0;
}
.p-gpt__action {
   position: relative;
   width: 12.5em;
   min-height: 4.8rem;
   margin-top: 20px;
   font-weight: var(--fontweight-bold);
   font-size: 1.4rem;
   letter-spacing: .09em;
}
.p-gpt__action .c-btn__icon {
   flex: 0 0 1.28em;
   height: 1.42em;
}

.p-gpt__action.--narrow {
   margin-right: 0;
   margin-left: 0;
}

.p-gpt__action .c-btn__icon {
    flex: 0 0 1.28em;
    height: 1.42em;
}

/* 電話ページ */
.p-tel {
   padding-top: 26px;
   padding-right: 50px;
   padding-left: 50px;
   border-radius: 20px;
   background-color: #FFF;
}
.p-tel__head {
   margin-bottom: 1.36em;
   border-bottom: 1px solid #E1E1E1;
   font-weight: var(--fontweight-bold);
   font-size: 2.2rem;
}
.p-tel__body+.p-tel__head {
   margin-top: 26px;
}
.p-tel__list {
   display: flex;
   flex-wrap: wrap;
   gap: 20px 10%;
}
.p-tel__item {
   flex: 0 0 165px;
}
.p-tel__item.--s .c-btn {
   font-size: 1.2rem;
}
.p-tel__labels {
   display: flex;
   align-items: center;
   gap: 0 3px;
   position: absolute;
   top: 0;
   left: 0;
   translate: 0 -50%;
}
.p-tel__label {
   display: flex;
   justify-content: center;
   align-items: center;
   min-height: 20px;
   border-radius: 9999px;
   line-height: 1;
   text-align: center;
}
.p-tel__label.--new {
   width: 3.833em;
   background-color: var(--color-yellow);
   font-weight: var(--fontweight-bold);
   color: var(--color-green);
   font-size: 1.2rem;
   font-family: var(--font-en);
}
.p-tel__label.--b {
   width: 5.45em;
   background-color: var(--color-light-green);
   font-weight: var(--fontweight-bold);
   color: #FFF;
   font-size: 1.1rem;
}
.p-tel__desc {
   display: flex;
   flex-wrap: wrap;
   align-items: center;
   margin-top: 1.125em;
}
.p-tel__btns {
   display: flex;
   flex-wrap: wrap;
   justify-content: center;
   align-items: center;
   gap: 20px;
   margin-top: 2em;
}
.p-tel__btns .c-btn {
   margin-right: 0;
   margin-left: 0;
}
.p-tel__body {
   padding-right: 22px;
   padding-left: 22px;
}

@media (max-width: 767.98px) {
   .p-tel {
      padding-right: 0px;
      padding-left: 0px;
   }
   .p-tel__body,
   .p-tel__btns {
      padding-right: 0;
      padding-left: 0;
   }
   .p-tel__desc {
      font-size: 1.2rem;
   }
   .p-tel__btns {
      gap: 10px;
   }
   .p-tel__list {
   display: flex;
   flex-wrap: wrap;
   gap: 20px 2%;
}
}
.p-tel__name{
   display: flex;
   justify-content: center;
   margin-bottom: 6px; 
   letter-spacing: 0.05em;
   font-size: 18px;
}


/* # =================================================================
   # Component
   # ================================================================= */

/* お問い合わせありがとうページ */
.c-title-thanks {
   display: flex;
   align-items: center;
   gap: 10px;
   margin-top: 7rem;
   margin-bottom: 2rem;
   padding-bottom: 3rem;
   border-bottom: 1px solid #E1E1E1; 
   font-weight: var(--fontweight-bold);
   font-size: 2.2rem;
   line-height: 1.5;
   justify-content: center;
}

.c-title-thanks.--green {
   border-bottom-color: inherit;
   color: var(--color-green);
}

/* 電話ページ */
.c-btn.p-tel__link {
    padding-right: 13px;
    padding-left: 13px;
}

.c-btn__icon.--tel.--size {
    width: 2.14em;
    height: 1.42em;
    mask-size: contain;
}

.c-btn__icon.--face {
    mask-image: url(../images/common/icon-face.svg);
}
.c-btn__icon.--mobile {
    mask-image: url(../images/common/icon-mobile.svg);
}

   /* # =================================================================
   # Utility
   # ================================================================= */

.u-bgc-green {
   background-color: var(--color-green) !important;
}