@charset "UTF-8";
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
small,
button,
time,
figure {
  border: 0;
  font: inherit;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

html {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

li,
dd {
  list-style-type: none;
}

header,
footer,
nav,
section,
article,
main,
aside,
figure,
figcaption {
  display: block;
}

img {
  border: none;
  vertical-align: bottom;
}

body {
  font-family: "Noto Sans JP", "Montserrat", sans-serif;
  font-style: normal;
  font-size: 16px;
  overflow-x: hidden;
}

html,
body {
  max-width: 100%;
}

img {
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  text-decoration: none;
}

@media screen and (max-width: 1439px) and (min-width: 768px) {
  html {
    font-size: calc(16 / 1440 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  html {
    font-size: calc(16 / 375 * 100vw);
  }
}

a[href^="tel:"] {
  pointer-events: none;
}

.l-drawer__icon {
  display: none;
}
@media (max-width: 1280px) {
  .l-drawer__icon {
    position: fixed;
    z-index: 102;
    top: 16px;
    right: 22px;
    width: 28px;
    height: 30px;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
}
@media (max-width: 1280px) and (any-hover: hover) {
  .l-drawer__icon:hover {
    cursor: pointer;
  }
}
@media (max-width: 1280px) {
  .l-drawer__icon.js-show {
    opacity: 1;
    visibility: visible;
  }
}

.l-drawer {
  position: fixed;
  z-index: 20;
  top: 60px;
  right: 0;
  width: 100%;
  height: 100vh;
  height: 100svh;
  background: #ecf6f9;
  overflow-y: auto;
  opacity: 0;
  -webkit-transition: all 0.6s ease;
  transition: all 0.6s ease;
  visibility: hidden;
}
.l-drawer.js-show {
  opacity: 1;
  visibility: visible;
}
@media (min-width: 1281px) {
  .l-drawer {
    display: none;
  }
}

.l-drawer__body {
  padding-block: 60px;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
}

.l-drawer__btn {
  -webkit-margin-before: 8px;
          margin-block-start: 8px;
}

.l-footer {
  background: #ecf6f9;
  padding-block: 60px;
}
@media screen and (max-width: 767px) {
  .l-footer {
    padding-block: 3.75rem;
  }
}

.l-footer__inner {
  width: min(1120px, 100%);
  padding-inline: 40px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .l-footer__inner {
    padding-inline: 20px;
  }
}

.l-header {
  position: fixed;
  z-index: 100;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  background: #ffffff;
  padding-block: 10px;
}
@media (max-width: 1280px) {
  .l-header {
    padding-block: 16px;
  }
}

.l-header__inner {
  width: 100%;
  padding-inline: 40px;
  margin-inline: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media (min-width: 2000px) {
  .l-header__inner {
    width: 2000px;
  }
}
@media (max-width: 1280px) {
  .l-header__inner {
    padding-inline: 20px;
  }
}

.l-inner {
  width: 100%;
  padding-inline: 100px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .l-inner {
    padding-inline: 20px;
    width: 100%;
  }
}

.l-small__inner {
  width: min(960px, 100%);
  padding-inline: 40px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .l-small__inner {
    padding-inline: 20px;
  }
}

.l-fv {
  -webkit-margin-before: 81px;
          margin-block-start: 81px;
  -webkit-padding-after: 72px;
          padding-block-end: 72px;
  position: relative;
  background: url(../img/fv-bg.webp) no-repeat center center/cover;
  overflow: hidden;
}
@media (max-width: 1280px) {
  .l-fv {
    -webkit-margin-before: 62px;
            margin-block-start: 62px;
  }
}
@media screen and (max-width: 767px) {
  .l-fv {
    padding-block: 15.1875rem 12.5rem;
  }
}

@media (min-width: 2000px) {
  .l-fv__inner {
    width: 2000px;
    margin-inline: auto;
  }
}

.l-fv__img {
  text-align: right;
  overflow: hidden;
}

.l-fv-img__inner {
  overflow: hidden;
}

.l-mission {
  background-color: #f7f7f7;
  padding-block: 120px 89px;
}
@media screen and (max-width: 767px) {
  .l-mission {
    padding-block: 80px;
  }
}

.l-cta1 {
  position: relative;
  overflow: hidden;
}
.l-cta1__inner {
  margin-inline: auto;
  width: 820px;
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (max-width: 767px) {
  .l-cta1__inner {
    max-width: 100%;
  }
}

.l-reason {
  padding-block: 120px;
  background: url(../img/fv-bg.webp) no-repeat center center/cover;
}
@media screen and (max-width: 767px) {
  .l-reason {
    padding-block: 1.9375rem 5rem;
  }
}

.l-reason__inner {
  max-width: 1440px;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 9.5rem;
     -moz-column-gap: 9.5rem;
          column-gap: 9.5rem;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}
@media (max-width: 1100px) {
  .l-reason__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (max-width: 767px) {
  .l-reason__inner {
    width: 100%;
  }
}

.l-teacher {
  overflow: hidden;
  padding-block: 120px 222px;
  background: #f7f7f7;
}
@media screen and (max-width: 767px) {
  .l-teacher {
    padding-block: 81px 143px;
  }
}

.l-cta2 {
  position: relative;
  overflow: hidden;
}

.l-cta2__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}

.l-course {
  padding-block: 120px;
  background: #ecf6f9;
}
@media screen and (max-width: 767px) {
  .l-course {
    padding-block: 80px;
  }
}

.l-course__inner {
  position: relative;
}

.l-faq {
  background: #f7f7f7;
  padding-block: 124px 120px;
}
@media screen and (max-width: 767px) {
  .l-faq {
    padding-block: 80px;
  }
}

.l-faq__inner {
  position: relative;
}

.l-contact {
  padding-block: 120px;
}
@media screen and (max-width: 767px) {
  .l-contact {
    padding-block: 80px;
  }
}

.l-contact__inner {
  width: min(680px, 100%);
  padding-inline: 20px;
  margin-inline: auto;
}

.c-btn {
  display: inline-block;
  position: relative;
  border-radius: 10px;
  background: #66b1c5;
  max-width: 100%;
  color: #ffffff;
  font-weight: 700;
  overflow: hidden;
  text-align: center;
  line-height: 1.6;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (any-hover: hover) {
  .c-btn:hover {
    background: #ffffff;
    color: #66b1c5;
    border: 2px solid currentColor;
  }
  .c-btn:hover .c-btn-small__letter-icon path,
  .c-btn:hover .c-btn-large__letter-icon path {
    fill: #66b1c5;
  }
  .c-btn:hover .c-btn-small__arrow-icon circle,
  .c-btn:hover .c-btn-large__arrow-icon circle,
  .c-btn:hover .p-btn-large__arrow-icon circle {
    fill: #66b1c5;
  }
  .c-btn:hover .c-btn-small__arrow-icon path,
  .c-btn:hover .c-btn-large__arrow-icon path,
  .c-btn:hover .p-btn-large__arrow-icon path {
    fill: #ffffff;
  }
}

.c-btn__small {
  width: 220px;
  letter-spacing: 0.48px;
  border-radius: 10px;
  background: #66b1c5;
  padding: 8px 26px;
  border: 2px solid #66b1c5;
}

.c-btn-small__letter-icon path {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.c-btn-small__text {
  margin-inline: 6px;
}

.c-btn-small__arrow-icon {
  width: 18px;
  height: 18px;
}
.c-btn-small__arrow-icon path {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.c-btn__large {
  width: 352px;
  padding: 18px 32px;
  letter-spacing: 1px;
  border: 2px solid #66b1c5;
}
@media screen and (max-width: 767px) {
  .c-btn__large {
    padding: 18px;
    width: 319px;
  }
}
@media (max-width: 365px) {
  .c-btn__large {
    padding: 14px;
    width: 280px;
  }
}

.c-btn-large__letter-icon path {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.c-btn-large__text {
  font-size: 20px;
  margin-inline: 9px;
}
@media screen and (max-width: 767px) {
  .c-btn-large__text {
    font-size: 18px;
  }
}
@media (max-width: 365px) {
  .c-btn-large__text {
    font-size: 16px;
  }
}

.c-btn-large__arrow-icon path {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

#btn_animation.c-btn::before {
  position: absolute;
  content: "";
  display: inline-block;
  top: -180px;
  left: 0;
  width: 30px;
  height: 100%;
  background-color: #fbfbfb;
  -webkit-animation: 4s 1s ease forwards 2 btn_animation;
          animation: 4s 1s ease forwards 2 btn_animation;
}

@-webkit-keyframes btn_animation {
  0% {
    -webkit-transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  80% {
    -webkit-transform: scale(0) rotate(45deg);
    opacity: 0.5;
  }
  81% {
    -webkit-transform: scale(4) rotate(45deg);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}
.c-section__title {
  line-height: 1.5;
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.c-section__title--en {
  color: #66b1c5;
  font-family: Montserrat;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  font-size: 1rem;
}
@media screen and (min-width: 768px) and (max-width: 1440px) {
  .c-section__title--en {
    font-size: 16px;
  }
}

.c-section__title--ja {
  color: #274b66;
  font-size: 2.1875rem;
  letter-spacing: 1.75px;
}
@media screen and (min-width: 768px) and (max-width: 1440px) {
  .c-section__title--ja {
    font-size: 35px;
  }
}
@media screen and (max-width: 767px) {
  .c-section__title--ja {
    font-size: 1.625rem;
    font-style: normal;
    letter-spacing: 1.3px;
  }
}

.c-section-title__center {
  text-align: center;
}

.c-mission__item {
  text-align: center;
  padding-inline: 24px;
  width: 288px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 16px;
}
.c-mission__item:not(:last-of-type) {
  -webkit-border-end: 1px dashed #b4adad;
          border-inline-end: 1px dashed #b4adad;
}
@media (max-width: 1240px) {
  .c-mission__item {
    margin-inline: auto;
  }
  .c-mission__item:not(:last-of-type) {
    -webkit-border-end: unset;
            border-inline-end: unset;
  }
  .c-mission__item:nth-of-type(1) {
    -webkit-border-after: 1px dashed #b4adad;
            border-block-end: 1px dashed #b4adad;
  }
  .c-mission__item:nth-of-type(2) {
    -webkit-border-end: unset;
            border-inline-end: unset;
    -webkit-border-after: 1px dashed #b4adad;
            border-block-end: 1px dashed #b4adad;
  }
}
@media (max-width: 900px) {
  .c-mission__item {
    row-gap: 8px;
    padding-inline: unset;
    min-height: 306px;
  }
  .c-mission__item:nth-of-type(1) {
    -webkit-border-end: unset;
            border-inline-end: unset;
  }
  .c-mission__item:nth-of-type(3) {
    -webkit-border-end: unset;
            border-inline-end: unset;
    -webkit-border-after: 1px dashed #b4adad;
            border-block-end: 1px dashed #b4adad;
  }
}

.c-mission-item__icon-wrap {
  height: 148px;
  display: grid;
  place-items: center;
}
@media screen and (max-width: 767px) {
  .c-mission-item__icon-wrap {
    height: 137px;
  }
}

.c-mission-item__icon1 {
  width: 151px;
  -webkit-margin-before: 35px;
          margin-block-start: 35px;
  -webkit-margin-start: 10px;
          margin-inline-start: 10px;
}
@media screen and (max-width: 767px) {
  .c-mission-item__icon1 {
    width: 140.45px;
    height: 76.107px;
    -webkit-margin-start: unset;
            margin-inline-start: unset;
  }
}

.c-mission-item__icon2 {
  width: 107.332px;
  height: 91px;
  -webkit-margin-before: 17px;
          margin-block-start: 17px;
}

.c-mission-item__icon3 {
  width: 75.228px;
  height: 118px;
}
@media screen and (max-width: 767px) {
  .c-mission-item__icon3 {
    width: 69.441px;
    height: 109.229px;
  }
}

.c-mission-item__icon4 {
  width: 150.664px;
  height: 58px;
  -webkit-margin-before: 43px;
          margin-block-start: 43px;
}

.c-mission-item__text-wrap {
  color: #274b66;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  -webkit-padding-after: 27px;
          padding-block-end: 27px;
}

.c-mission-item__title {
  text-align: center;
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 1.1px;
}
@media screen and (max-width: 767px) {
  .c-mission-item__title {
    font-size: 18px;
    letter-spacing: 0.9px;
  }
}

.c-mission-item__text {
  -webkit-margin-before: 11px;
          margin-block-start: 11px;
  letter-spacing: 0.8px;
  font-weight: 400;
  line-height: 1.6;
  -moz-text-align-last: left;
       text-align-last: left;
}
@media screen and (max-width: 767px) {
  .c-mission-item__text {
    font-size: 15px;
    letter-spacing: 0.75px;
    -webkit-margin-before: 8px;
            margin-block-start: 8px;
  }
}

.c-reason__item {
  border-radius: 20px;
  background: #f7f7f7;
  padding: 1.625rem 2rem 1.625rem 1.4375rem;
  position: relative;
  min-height: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 767px) {
  .c-reason__item {
    padding: 1.125rem 1rem;
  }
}

.c-reason-item__step {
  position: absolute;
  top: -11px;
  left: -30px;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: #66b1c5;
  color: #ffffff;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (max-width: 1300px) {
  .c-reason-item__step {
    top: -30px;
  }
}
@media (max-width: 1100px) {
  .c-reason-item__step {
    top: -11px;
  }
}
@media screen and (max-width: 767px) {
  .c-reason-item__step {
    top: -20px;
    left: calc(100% - 4.625rem);
    width: 3.75rem;
    height: 3.75rem;
  }
}

.c-reason-item-step__text {
  font-size: 6px;
  line-height: 1.5;
  letter-spacing: 0.3px;
}
@media screen and (max-width: 767px) {
  .c-reason-item-step__text {
    font-size: 0.375rem;
  }
}

.c-reason-item-step__num {
  font-size: 30px;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .c-reason-item-step__num {
    font-size: 1.875rem;
  }
}

.c-reason-item__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 2.5rem;
     -moz-column-gap: 2.5rem;
          column-gap: 2.5rem;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-flex: 1;
      -ms-flex: 1 1 auto;
          flex: 1 1 auto;
  min-height: 0;
}
@media screen and (max-width: 767px) {
  .c-reason-item__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    row-gap: 1rem;
  }
}
@media (max-width: 1100px) {
  .c-reason-item__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    row-gap: 16px;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

@media (max-width: 1100px) {
  .c-reason-item__text-wrap {
    -webkit-margin-before: 35px;
            margin-block-start: 35px;
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
@media screen and (max-width: 767px) {
  .c-reason-item__text-wrap {
    -webkit-margin-before: unset;
            margin-block-start: unset;
  }
}

.c-reason-item__title {
  color: #274b66;
  font-size: 1.375rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 1.1px;
}
@media (max-width: 1100px) {
  .c-reason-item__title {
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  .c-reason-item__title {
    font-size: 1.125rem;
    letter-spacing: 0.9px;
  }
}

.c-reason-item__text {
  -webkit-margin-before: 0.75rem;
          margin-block-start: 0.75rem;
  font-size: 1rem;
  color: #000;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.8px;
}
@media (max-width: 1100px) {
  .c-reason-item__text {
    -webkit-margin-before: 12px;
            margin-block-start: 12px;
    font-size: 15px;
  }
}
@media screen and (max-width: 767px) {
  .c-reason-item__text {
    -webkit-margin-before: 0.75rem;
            margin-block-start: 0.75rem;
    font-size: 0.9375rem;
  }
}

.c-reason-item__img {
  margin-inline: auto;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  border-radius: 10px;
  aspect-ratio: 306/228;
  width: 19.125rem;
  overflow: hidden;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 767px) {
  .c-reason-item__img {
    aspect-ratio: 303/200;
    border-radius: 5.038px;
  }
}
.c-reason-item__img img {
  width: 19.125rem;
}
@media (max-width: 1100px) {
  .c-reason-item__img img {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .c-reason-item__img img {
    aspect-ratio: 303/200;
  }
}

.c-teacher__item {
  width: 352px;
  height: 466px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 17px;
}
@media screen and (max-width: 767px) {
  .c-teacher__item {
    width: 320px;
  }
}
@media (max-width: 360px) {
  .c-teacher__item {
    width: 300px;
  }
}

.c-teacher-item__img {
  border-radius: 20px;
  aspect-ratio: 352/260;
}
@media screen and (max-width: 767px) {
  .c-teacher-item__img {
    border-radius: 18.692px;
  }
}
.c-teacher-item__img img {
  aspect-ratio: 352/260;
  width: 352px;
}
@media screen and (max-width: 767px) {
  .c-teacher-item__img img {
    aspect-ratio: 320/240;
    width: 320px;
  }
}

.c-teacher-item__content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

.c-teacher-item__subject-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 8px;
     -moz-column-gap: 8px;
          column-gap: 8px;
}

.c-teacher-item__subject {
  padding: 3px 9px;
  color: #ffffff;
  font-size: 14px;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.56px;
  border-radius: 3px;
  background: #66b1c5;
}
@media screen and (max-width: 767px) {
  .c-teacher-item__subject {
    padding-block: 2px;
  }
}

.c-teacher-item__name {
  font-size: 22px;
  letter-spacing: 1.1px;
  -webkit-margin-before: 4px;
          margin-block-start: 4px;
  color: #274b66;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .c-teacher-item__name {
    font-size: 18px;
    letter-spacing: 0.9px;
  }
}

.c-teacher-item__text {
  -webkit-margin-before: 12px;
          margin-block-start: 12px;
  color: #274b66;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.8px;
}
@media screen and (max-width: 767px) {
  .c-teacher-item__text {
    letter-spacing: 0.75px;
  }
}

.c-course-detail__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 22px;
}
@media screen and (max-width: 767px) {
  .c-course-detail__wrap {
    row-gap: 16px;
  }
}

.c-course-detail-title__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 20px;
     -moz-column-gap: 20px;
          column-gap: 20px;
  color: #274b66;
  max-width: 665px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .c-course-detail-title__wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    row-gap: 4px;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.c-course-detail__title {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 1.1px;
}
@media screen and (max-width: 767px) {
  .c-course-detail__title {
    text-align: center;
    font-size: 18px;
    letter-spacing: 0.9px;
  }
}

.c-course-detail__descliption {
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.8px;
}
@media screen and (max-width: 767px) {
  .c-course-detail__descliption {
    font-size: 15px;
    letter-spacing: 0.75px;
  }
}

.c-course-detail-content__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 24px;
     -moz-column-gap: 24px;
          column-gap: 24px;
  -webkit-margin-before: 20px;
          margin-block-start: 20px;
}
@media screen and (max-width: 767px) {
  .c-course-detail-content__wrap {
    -webkit-column-gap: 8px;
       -moz-column-gap: 8px;
            column-gap: 8px;
  }
}

.c-course-detail__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 12px;
  letter-spacing: 0.8px;
}
@media screen and (max-width: 767px) {
  .c-course-detail__content {
    row-gap: 8px;
    letter-spacing: 0.75px;
  }
}

.c-course-detail__tag {
  padding-block: 4px;
  width: 320.5px;
  max-width: 100%;
  color: #ffffff;
  text-align: center;
  font-weight: 500;
  line-height: 1.8;
  border-radius: 4px;
  background: #66b1c5;
}
@media screen and (max-width: 767px) {
  .c-course-detail__tag {
    width: 147px;
    font-size: 15px;
  }
}
@media (max-width: 365px) {
  .c-course-detail__tag {
    width: 135px;
  }
}

.c-course-detail-text__wrap {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}

.c-course-detail__text {
  color: #274b66;
  font-weight: 400;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .c-course-detail__text {
    font-size: 15px;
  }
}
@media (max-width: 350px) {
  .c-course-detail__text {
    font-size: 13px;
  }
}

.c-faq-item__question {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 16px 24px;
  border-radius: 10px;
  background: #ffffff;
  list-style: none;
}
@media screen and (max-width: 767px) {
  .c-faq-item__question {
    padding: 16px;
  }
}
.c-faq-item__question::-webkit-details-marker {
  display: none;
}

.c-faq-item-question__tag,
.c-faq-item-answer__tag {
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  color: #ffffff;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.8px;
  -webkit-margin-end: 24px;
          margin-inline-end: 24px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .c-faq-item-question__tag,
  .c-faq-item-answer__tag {
    -webkit-margin-end: 12px;
            margin-inline-end: 12px;
  }
}

.c-faq-item-question__tag {
  background: #66b1c5;
}

.c-faq-item-question__text {
  color: #274b66;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.8px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}

.c-faq-item-question__icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.c-faq-item-question__icon line {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  -webkit-transform-origin: center;
          transform-origin: center;
}

.c-faq__item.is-opened .c-faq-item-question__icon line:nth-of-type(1) {
  rotate: 90deg;
}

.c-faq-item__answer {
  height: 0;
  opacity: 0;
  overflow: hidden;
  -webkit-transition: height 0.3s ease, opacity 0.3s ease;
  transition: height 0.3s ease, opacity 0.3s ease;
}

.c-faq-item-answer__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 24px 26px 0 26px;
}
@media screen and (max-width: 767px) {
  .c-faq-item-answer__inner {
    padding-inline: 12px;
  }
}

.c-faq-item-answer__tag {
  background: #e9c243;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.c-faq-item-answer__text {
  color: #274b66;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.8px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
@media screen and (max-width: 767px) {
  .c-faq-item-answer__text {
    font-size: 15px;
    letter-spacing: 0.75px;
  }
}

.is-opened .c-faq-item__answer {
  opacity: 1;
}

.c-course__item {
  color: #274b66;
}

.c-course-item__title {
  font-size: 22px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 1.1px;
}
@media screen and (max-width: 767px) {
  .c-course-item__title {
    font-size: 1.125rem;
    letter-spacing: 0.05625rem;
    text-align: center;
  }
}

.c-course-item__text {
  -webkit-margin-before: 12px;
          margin-block-start: 12px;
  font-weight: 400;
  line-height: 1.6;
  letter-spacing: 0.8px;
}
@media screen and (max-width: 767px) {
  .c-course-item__text {
    font-size: 0.9375rem;
    letter-spacing: 0.046875rem;
  }
}

.c-tel__info {
  color: #274b66;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 9px;
     -moz-column-gap: 9px;
          column-gap: 9px;
}

.c-tel-info__icon {
  width: 31px;
  height: 41px;
}

.c-tel-info__num {
  font-family: "Montserrat", sans-serif;
  font-size: 24px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 1.2px;
}

.c-tel-info__text {
  text-align: center;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.6px;
  -webkit-margin-before: 1px;
          margin-block-start: 1px;
  text-align: left;
}

.p-header__logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (any-hover: hover) {
  .p-header__logo:hover {
    opacity: 0.7;
    cursor: pointer;
  }
}
.p-header__logo img {
  width: 225px;
}
@media (max-width: 1280px) {
  .p-header__logo img {
    width: 187.5px;
  }
}

.p-header__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 26px;
     -moz-column-gap: 26px;
          column-gap: 26px;
}
@media (max-width: 1280px) {
  .p-header__nav {
    display: none;
  }
}

.p-header__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 30px;
     -moz-column-gap: 30px;
          column-gap: 30px;
}

.p-header__link {
  color: #274b66;
  font-size: 14px;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.56px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (any-hover: hover) {
  .p-header__link:hover {
    opacity: 0.7;
  }
}

.p-header-tel__info {
  color: #274b66;
}

.p-header-tel__top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 2px;
     -moz-column-gap: 2px;
          column-gap: 2px;
}

.p-tel-info__num {
  font-family: "Montserrat", sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 1.2px;
}

.p-tel-info__text {
  text-align: center;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.6px;
}

.p-header__btn {
  -webkit-margin-before: 5px;
          margin-block-start: 5px;
}

.p-drawer__icon {
  display: none;
}
@media (max-width: 1280px) {
  .p-drawer__icon {
    width: 30px;
    height: 30px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    background: #ffffff;
    padding-block: 6px;
  }
}

.p-drawer__icon--bar {
  background: #274b66;
  width: 28px;
  height: 3px;
}

.p-drawer__icon--bar {
  width: 100%;
  height: 3px;
  background: #274b66;
  border-radius: 3px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.p-drawer__icon.js-show {
  width: 24px;
  top: 17px;
  right: 24px;
}
.p-drawer__icon.js-show .p-drawer__icon--bar:nth-of-type(1) {
  rotate: 45deg;
  translate: 0 8px;
}
.p-drawer__icon.js-show .p-drawer__icon--bar:nth-of-type(2) {
  display: none;
}
.p-drawer__icon.js-show .p-drawer__icon--bar:nth-of-type(3) {
  rotate: -45deg;
  translate: 0 -8px;
}

.p-drawer__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 36px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-padding-after: 60px;
          padding-block-end: 60px;
}

.p-drawer__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 39px;
}

.p-drawer__item {
  text-align: center;
}
@media (any-hover: hover) {
  .p-drawer__item {
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
  .p-drawer__item:hover {
    opacity: 0.7;
  }
}

.p-drawer__link {
  color: #274b66;
  font-size: 14px;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.56px;
}

.p-fv-title__wrap {
  color: #274b66;
  line-height: 1.5;
  font-weight: 700;
  position: absolute;
  top: 10.7638888889vw;
  left: 3.6111111111vw;
  z-index: 2;
}
@media (min-width: 2000px) {
  .p-fv-title__wrap {
    top: 215px;
    left: 50%;
    translate: -927px;
  }
}
@media screen and (max-width: 767px) {
  .p-fv-title__wrap {
    top: 2.5rem;
    left: 50%;
    translate: -50%;
  }
}

.p-fv-title__main {
  font-size: 3.4722222222vw;
  letter-spacing: 1.5px;
  overflow: hidden;
}
@media (min-width: 2000px) {
  .p-fv-title__main {
    font-size: 69px;
  }
}
@media screen and (max-width: 767px) {
  .p-fv-title__main {
    font-size: 2.5rem;
    letter-spacing: 1.2px;
    white-space: nowrap;
  }
}

.p-fv-title__animation {
  display: inline-block;
  -webkit-animation: 0.5s 1.5s ease forwards slideUp;
          animation: 0.5s 1.5s ease forwards slideUp;
  translate: 0 100%;
}

@-webkit-keyframes slideUp {
  0% {
    translate: 0 100%;
  }
  100% {
    translate: 0 0;
  }
}

@keyframes slideUp {
  0% {
    translate: 0 100%;
  }
  100% {
    translate: 0 0;
  }
}
.p-fv-title__main--accent {
  color: #e9c243;
}

.p-fv-title__sub {
  font-size: 1.6666666667vw;
  letter-spacing: 1.2px;
  -webkit-margin-before: 1.6666666667vw;
          margin-block-start: 1.6666666667vw;
  -webkit-animation: 0.5s 2s ease forwards slideDown;
          animation: 0.5s 2s ease forwards slideDown;
  clip-path: inset(0 0 100% 0);
}
@-webkit-keyframes slideDown {
  0% {
    clip-path: inset(0 0 100% 0);
  }
  100% {
    clip-path: inset(0 0 0 0);
  }
}
@keyframes slideDown {
  0% {
    clip-path: inset(0 0 100% 0);
  }
  100% {
    clip-path: inset(0 0 0 0);
  }
}
@media (min-width: 2000px) {
  .p-fv-title__sub {
    font-size: 33px;
    -webkit-margin-before: 33px;
            margin-block-start: 33px;
  }
}
@media screen and (max-width: 767px) {
  .p-fv-title__sub {
    font-size: 1.125rem;
    letter-spacing: 0.9px;
    -webkit-margin-before: 1rem;
            margin-block-start: 1rem;
  }
}

.p-fv-btn__wrap {
  position: absolute;
  bottom: 8.1944444444vw;
  left: 3.6111111111vw;
  z-index: 2;
  opacity: 0;
  -webkit-animation: 1.5s 2s ease forwards fadeInBtn;
          animation: 1.5s 2s ease forwards fadeInBtn;
}
@-webkit-keyframes fadeInBtn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeInBtn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@media (min-width: 2000px) {
  .p-fv-btn__wrap {
    top: 663px;
    left: 50%;
    translate: -931px;
  }
}
@media screen and (max-width: 767px) {
  .p-fv-btn__wrap {
    bottom: 2.375rem;
    left: 50%;
    translate: -50%;
    text-align: center;
  }
}

.p-fv__popup {
  color: #274b66;
  font-size: 1.3888888889vw;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 1px;
  -webkit-margin-start: 4.8611111111vw;
          margin-inline-start: 4.8611111111vw;
  -webkit-margin-after: 0.2083333333vw;
          margin-block-end: 0.2083333333vw;
  -webkit-animation: 0.5s 5s ease forwards 3 animationPopup;
          animation: 0.5s 5s ease forwards 3 animationPopup;
}
@-webkit-keyframes animationPopup {
  0% {
    scale: 1;
  }
  50% {
    scale: 1.1;
  }
  100% {
    scale: 1;
  }
}
@keyframes animationPopup {
  0% {
    scale: 1;
  }
  50% {
    scale: 1.1;
  }
  100% {
    scale: 1;
  }
}
@media (min-width: 2000px) {
  .p-fv__popup {
    font-size: 27px;
    -webkit-margin-start: 97px;
            margin-inline-start: 97px;
  }
}
@media screen and (max-width: 767px) {
  .p-fv__popup {
    font-size: 1.125rem;
    white-space: nowrap;
    -webkit-margin-start: unset;
            margin-inline-start: unset;
    -webkit-margin-after: 0.1875rem;
            margin-block-end: 0.1875rem;
  }
}

.p-btn__large {
  width: 24.4444444444vw;
  padding: 1.25vw 0px;
  margin-inline: auto;
  letter-spacing: 1px;
}
@media (min-width: 2000px) {
  .p-btn__large {
    width: 489px;
    padding-block: 25px;
  }
}
@media screen and (max-width: 767px) {
  .p-btn__large {
    padding-block: 1.1875rem;
    width: 18.9375rem;
  }
}

.p-btn-large__letter-icon {
  width: 1.6666666667vw;
  height: auto;
}
@media (min-width: 2000px) {
  .p-btn-large__letter-icon {
    width: 33px;
  }
}
@media screen and (max-width: 767px) {
  .p-btn-large__letter-icon {
    width: 1.5rem;
  }
}

.p-btn-large__text {
  font-size: 1.3888888889vw;
  margin-inline: 0.625vw;
}
@media (min-width: 2000px) {
  .p-btn-large__text {
    font-size: 27px;
    margin-inline: 12px;
  }
}
@media screen and (max-width: 767px) {
  .p-btn-large__text {
    font-size: 1.125rem;
    margin-inline: 0.5625rem;
  }
}

.p-btn-large__arrow-icon {
  width: 1.5277777778vw;
  height: auto;
}
@media screen and (max-width: 767px) {
  .p-btn-large__arrow-icon {
    width: 1.375rem;
  }
}

.p-fv__swiper-container,
.p-fv__swiper,
.p-fv__swiper-wrapper,
.p-fv__swiper-slide {
  position: relative;
  overflow: hidden;
}

.p-fv__swiper-container {
  overflow: hidden;
}

.p-fv__swiper {
  overflow: hidden;
}

.p-fv__swiper-wrapper {
  overflow: hidden;
}

.p-fv__swiper-slide {
  -o-object-fit: cover;
     object-fit: cover;
  text-align: center;
  clip-path: circle(0 at 75% 50%);
  overflow: hidden;
  -webkit-animation: 2s 1s ease forwards clipFv;
          animation: 2s 1s ease forwards clipFv;
}
@-webkit-keyframes clipFv {
  0% {
    clip-path: circle(0 at 75% 50%);
  }
  100% {
    clip-path: circle(100% at 50% 50%);
  }
}
@keyframes clipFv {
  0% {
    clip-path: circle(0 at 75% 50%);
  }
  100% {
    clip-path: circle(100% at 50% 50%);
  }
}

.p-fv__swiper-slide-img-wrap {
  width: 69.4444444444vw;
  aspect-ratio: 1000/650;
  border-radius: 0 0 0 20px;
  -webkit-margin-start: 30.5555555556vw;
          margin-inline-start: 30.5555555556vw;
  overflow: hidden;
  position: relative;
}
@media (min-width: 2000px) {
  .p-fv__swiper-slide-img-wrap {
    -webkit-margin-start: 611px;
            margin-inline-start: 611px;
    width: 1388px;
  }
}
@media screen and (max-width: 767px) {
  .p-fv__swiper-slide-img-wrap {
    width: 20.9375rem;
    height: 14.254375rem;
    border-radius: 0 0 0 7.018px;
    -webkit-margin-start: unset;
            margin-inline-start: unset;
  }
}
.p-fv__swiper-slide-img-wrap img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  -webkit-transform: scale(1.15);
          transform: scale(1.15);
  -webkit-transition: -webkit-transform 3s ease-out;
  transition: -webkit-transform 3s ease-out;
  transition: transform 3s ease-out;
  transition: transform 3s ease-out, -webkit-transform 3s ease-out;
}

.p-fv__swiper-slide.swiper-slide-active img {
  -webkit-transform: scale(1);
          transform: scale(1);
}

.p-fv__swiper-button-prev,
.p-fv__swiper-button-next,
.p-fv__swiper-pagination-bullets.swiper-pagination-horizontal {
  top: unset;
  bottom: unset;
  left: unset;
  right: unset;
  margin: 0;
  padding: 0;
}

.swiper-button-prev::after,
.swiper-button-next::after {
  content: "";
}

.p-fv__swiper-button-prev,
.p-fv__swiper-button-next {
  display: none;
}

.swiper-pagination-bullets.swiper-pagination-horizontal {
  position: absolute;
  bottom: -5%;
  left: -32.5%;
}
@media screen and (max-width: 767px) {
  .swiper-pagination-bullets.swiper-pagination-horizontal {
    bottom: -9%;
    left: -41.5%;
  }
}

.swiper-pagination-bullets.swiper-pagination-horizontal .swiper-pagination-bullet {
  opacity: 1;
  width: 10px;
  height: auto;
  aspect-ratio: 1;
  border-radius: 50%;
  background: transparent;
  border: 1px solid #66b1c5;
  margin-inline: 5.5px;
}

.swiper-pagination-bullets.swiper-pagination-horizontal .swiper-pagination-bullet-active {
  background: #66b1c5;
}

.p-mission__description {
  -webkit-margin-before: 24px;
          margin-block-start: 24px;
  margin-inline: auto;
  color: #274b66;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.8px;
  width: 496px;
  -moz-text-align-last: left;
       text-align-last: left;
}
@media screen and (max-width: 767px) {
  .p-mission__description {
    max-width: 335px;
    width: 100%;
    font-size: 15px;
    letter-spacing: 0.75px;
  }
}

.p-mission__items {
  -webkit-margin-before: 60px;
          margin-block-start: 60px;
  padding-inline: 42px;
  display: grid;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  grid-template-columns: repeat(4, 1fr);
  width: 1240px;
  margin-inline: auto;
}
@media (max-width: 1240px) {
  .p-mission__items {
    grid-template-columns: repeat(2, 1fr);
    width: 100%;
    max-width: 728px;
    margin-inline: auto;
  }
}
@media (max-width: 900px) {
  .p-mission__items {
    -webkit-margin-before: 20px;
            margin-block-start: 20px;
    grid-template-columns: repeat(1, 1fr);
    max-width: 311px;
    width: 100%;
    padding-inline: unset;
  }
}

.p-cta1__bg {
  display: block;
  height: 508px;
}
@media screen and (max-width: 767px) {
  .p-cta1__bg {
    height: 496px;
  }
}
.p-cta1__bg img {
  width: 100%;
  height: calc(100% + 200px);
  -o-object-fit: cover;
     object-fit: cover;
}
.p-cta1__textbox {
  color: #ffffff;
}

.p-cta1__title {
  font-size: 35px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 1.75px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-cta1__title {
    font-size: 26px;
    letter-spacing: 1.3px;
  }
}

.p-cta1__text {
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.8px;
  -webkit-margin-before: 24px;
          margin-block-start: 24px;
  padding-inline: 83px;
}
@media screen and (max-width: 767px) {
  .p-cta1__text {
    font-size: 15px;
    letter-spacing: 0.75px;
    padding-inline: unset;
    -webkit-margin-before: 20px;
            margin-block-start: 20px;
  }
}

.p-cta1-btn__wrap {
  -webkit-margin-before: 32px;
          margin-block-start: 32px;
  text-align: center;
}

.p-reason-title__wrap {
  position: sticky;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  top: 100px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 26px;
     -moz-column-gap: 26px;
          column-gap: 26px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media (max-width: 1100px) {
  .p-reason-title__wrap {
    position: static;
  }
}
@media screen and (max-width: 767px) {
  .p-reason-title__wrap {
    width: 100%;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}

@media screen and (max-width: 767px) {
  .p-reason__title {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    -webkit-padding-before: 3rem;
            padding-block-start: 3rem;
  }
}

@media screen and (max-width: 767px) {
  .p-reason-title__icon {
    width: 3.5rem;
    height: 7.8125rem;
    -webkit-margin-end: 0.9375rem;
            margin-inline-end: 0.9375rem;
  }
}

.p-reason__items {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  row-gap: 2.5rem;
  grid-auto-rows: 1fr;
}
@media (max-width: 1100px) {
  .p-reason__items {
    grid-template-columns: repeat(2, 1fr);
    -webkit-column-gap: 40px;
       -moz-column-gap: 40px;
            column-gap: 40px;
    row-gap: 40px;
    grid-auto-rows: 1fr;
  }
}
@media screen and (max-width: 767px) {
  .p-reason__items {
    grid-template-rows: auto;
    grid-template-rows: repeat(1, 1fr);
    grid-template-columns: repeat(1, 1fr);
    row-gap: 2.625rem;
    -webkit-margin-before: 1.5625rem;
            margin-block-start: 1.5625rem;
    grid-auto-rows: auto;
  }
}

@-moz-document url-prefix() {
  .p-reason__items {
    row-gap: 2.6875rem;
  }
}
.p-teacher__swiper-container,
.p-teacher__swiper,
.p-teacher__swiper-wrapper,
.p-teacher__swiper-slide {
  position: relative;
}

.p-teacher__swiper-container {
  -webkit-margin-before: 60px;
          margin-block-start: 60px;
}
@media screen and (max-width: 767px) {
  .p-teacher__swiper-container {
    -webkit-margin-before: 40px;
            margin-block-start: 40px;
  }
}

.p-teacher__swiper {
  overflow: visible;
  left: 337px;
}
@media screen and (max-width: 767px) {
  .p-teacher__swiper {
    left: -7px;
  }
}
@media (max-width: 320px) {
  .p-teacher__swiper {
    left: 12px;
  }
}

.p-teacher__swiper-slide {
  width: 352px;
}
@media screen and (max-width: 767px) {
  .p-teacher__swiper-slide {
    width: 320px;
  }
}

.p-teacher__swiper-button-prev,
.p-teacher__swiper-button-next,
.p-teacher__swiper-pagination-bullets.swiper-pagination-horizontal {
  top: unset;
  bottom: unset;
  left: unset;
  right: unset;
  margin: 0;
  padding: 0;
}

.swiper-button-prev::after,
.swiper-button-next::after {
  content: "";
}

.p-teacher__swiper-button-prev,
.p-teacher__swiper-button-next {
  top: calc(100% + 62px);
  width: 39px;
  height: 39px;
}
@media screen and (max-width: 767px) {
  .p-teacher__swiper-button-prev,
  .p-teacher__swiper-button-next {
    top: calc(100% + 25px);
  }
}

.p-teacher__swiper-button-prev {
  right: 60px;
}
@media screen and (max-width: 767px) {
  .p-teacher__swiper-button-prev {
    right: 65px;
  }
}

.p-teacher__swiper-button-next {
  right: 0;
}
@media screen and (max-width: 767px) {
  .p-teacher__swiper-button-next {
    right: 3px;
  }
}

.swiper-pagination-bullets.swiper-pagination-horizontal .swiper-pagination-bullet {
  opacity: 1;
}

.swiper-pagination-progressbar.swiper-pagination-horizontal {
  top: calc(100% + 77px);
  left: 0;
  text-align: left;
  width: 28.125rem;
  height: 8px;
  border-radius: 10px;
  background: rgba(180, 173, 173, 0.5);
}
@media screen and (max-width: 767px) {
  .swiper-pagination-progressbar.swiper-pagination-horizontal {
    width: 9.375rem;
    top: calc(100% + 39px);
  }
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  border-radius: 10px;
  background: #66b1c5;
}

.p-cta2__bg {
  display: block;
  height: 514px;
}
@media screen and (max-width: 767px) {
  .p-cta2__bg {
    height: 571px;
  }
}
.p-cta2__bg img {
  height: calc(100% + 200px);
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-cta2__item {
  border-radius: 20px;
  background: #ffffff;
  padding-block: 31px 33px;
}
@media screen and (max-width: 767px) {
  .p-cta2__item {
    padding-block: 37px;
  }
}

.p-cta2__title {
  -webkit-margin-before: 6px;
          margin-block-start: 6px;
  color: #274b66;
  text-align: center;
  font-size: 35px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 1.75px;
}
@media screen and (max-width: 767px) {
  .p-cta2__title {
    font-size: 26px;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 1.3px;
  }
}

.p-cta2-item__bottom {
  -webkit-margin-before: 34px;
          margin-block-start: 34px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-column-gap: 2.5rem;
     -moz-column-gap: 2.5rem;
          column-gap: 2.5rem;
  color: #274b66;
}
@media screen and (max-width: 767px) {
  .p-cta2-item__bottom {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-margin-before: 14px;
            margin-block-start: 14px;
    row-gap: 38px;
  }
}

.p-cta2-tel__text {
  text-align: center;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.8px;
}
@media screen and (max-width: 767px) {
  .p-cta2-tel__text {
    font-size: 15px;
    letter-spacing: 0.75px;
  }
}

.p-cta2-tel__num {
  color: #66b1c5;
  font-family: "Montserrat", sans-serif;
  font-size: 35px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 1.75px;
}
@media screen and (max-width: 767px) {
  .p-cta2-tel__num {
    text-align: center;
  }
}
@media (max-width: 355px) {
  .p-cta2-tel__num {
    font-size: 30px;
  }
}

.p-cta2-tel__icon {
  width: 22.354px;
  height: 32.999px;
}

.p-cta2-tel__time {
  text-align: center;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.6px;
}

.p-cta2-btn__wrap {
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 1px;
}

.p-cta2-btn__popup {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 1px;
}
@media screen and (max-width: 767px) {
  .p-cta2-btn__popup {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: 0.9px;
  }
}

.p-cta2-btn__large {
  -webkit-margin-before: 4px;
          margin-block-start: 4px;
  width: 355px;
}
@media screen and (max-width: 767px) {
  .p-cta2-btn__large {
    width: 100%;
    max-width: 306px;
    height: 69px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    margin-inline: auto;
  }
}
@media (max-width: 365px) {
  .p-cta2-btn__large {
    width: 267px;
    padding-block: 14px;
    height: 60px;
  }
}

@media screen and (max-width: 767px) {
  .p-course__title {
    text-align: left;
  }
}

.p-course__icon-wrap {
  position: absolute;
  bottom: 63px;
  left: -77px;
  z-index: 1;
  width: 73px;
  height: 101px;
}
@media (max-width: 1150px) {
  .p-course__icon-wrap {
    left: 64px;
  }
}
@media (max-width: 950px) {
  .p-course__icon-wrap {
    top: -34px;
    left: calc(100% - 177px);
  }
}
@media screen and (max-width: 767px) {
  .p-course__icon-wrap {
    top: -0.6875rem;
    left: 17rem;
  }
}

@media screen and (max-width: 767px) {
  .p-course__icon {
    width: 4.5625rem;
    height: 6.3125rem;
  }
}

.p-course__list {
  border-radius: 10px 10px 0 0;
  -webkit-margin-before: 60px;
          margin-block-start: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}
@media screen and (max-width: 767px) {
  .p-course__list {
    -webkit-margin-before: 2.5rem;
            margin-block-start: 2.5rem;
  }
}

.p-course__item {
  width: 50%;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.8px;
}
@media screen and (max-width: 767px) {
  .p-course__item {
    font-size: 1rem;
  }
}
.p-course__item[aria-selected=true] {
  height: 69px;
  padding-block: 20px;
  border-radius: 10px 10px 0 0;
  background: #ffffff;
  color: #66b1c5;
}
@media screen and (max-width: 767px) {
  .p-course__item[aria-selected=true] {
    height: 4.3125rem;
  }
}
.p-course__item[aria-selected=false] {
  height: 60px;
  padding-block: 10px;
  color: #b4adad;
  background: #f7f7f7;
  border-radius: 10px 10px 0 0;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}
@media screen and (max-width: 767px) {
  .p-course__item[aria-selected=false] {
    height: 3.75rem;
  }
}
@media (any-hover: hover) {
  .p-course__item[aria-selected=false]:hover {
    cursor: pointer;
    opacity: 0.7;
  }
}

.p-course-tabs__contents {
  background: #fff;
  padding-block: 40px;
  border-radius: 0 0 10px 10px;
}
@media screen and (max-width: 767px) {
  .p-course-tabs__contents {
    padding: 2rem 1rem;
  }
}

.p-course-tabs__content-wrap {
  background: #ffffff;
  opacity: 0;
  visibility: hidden;
  height: 0;
  translate: 0 20px;
  -webkit-transition: opacity 0.3s ease, translate 0.3s ease;
  transition: opacity 0.3s ease, translate 0.3s ease;
}
.p-course-tabs__content-wrap.js-show {
  opacity: 1;
  visibility: visible;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  translate: 0;
}

.p-course__items {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 24px;
  width: 100%;
  max-width: 584px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .p-course__items {
    row-gap: 2rem;
  }
}

.p-course-btn__wrap {
  text-align: center;
  -webkit-margin-before: 36px;
          margin-block-start: 36px;
}
@media screen and (max-width: 767px) {
  .p-course-btn__wrap {
    -webkit-margin-before: 1.875rem;
            margin-block-start: 1.875rem;
  }
}

@media screen and (max-width: 767px) {
  .p-course-btn {
    font-size: 1rem;
    padding: 0.5rem 1.625rem;
    letter-spacing: 0.03rem;
    width: 13.75rem;
  }
}

@media screen and (max-width: 767px) {
  .p-course-btn__text {
    margin-inline: 0 0.375rem;
    font-size: 1.125rem;
    letter-spacing: 0.05625rem;
    text-align: center;
  }
}

@media screen and (max-width: 767px) {
  .p-course-btn__arrow-icon {
    width: 1.125rem;
    height: 1.125rem;
  }
}

/* 初期設定 */
button {
  background: none;
}

:where(dialog) {
  width: unset;
  max-width: unset;
  /* height: unset;
  max-height: unset; */
  padding: unset;
  color: unset;
  background-color: unset;
  border: unset;
  overflow: unset;
}

body:has(dialog[open]) {
  overflow: hidden;
}

/* モーダルのスタイル ============ */
dialog::-ms-backdrop {
  opacity: 0;
  -ms-transition: background 0.3s ease-in-out;
  transition: background 0.3s ease-in-out;
}
dialog::backdrop {
  opacity: 0;
  -webkit-transition: background 0.3s ease-in-out;
  transition: background 0.3s ease-in-out;
}
dialog.js-show.p-modal__content {
  opacity: 1;
}
dialog.js-show::-ms-backdrop {
  opacity: 1;
  /* 背景画像 */
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(6px);
}
dialog.js-show::backdrop {
  opacity: 1;
  /* 背景画像 */
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(6px);
}

.p-modal__content {
  overflow: hidden;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease-in-out;
  transition: opacity 0.3s ease-in-out;
  /* モーダル枠組みのスタイル */
  width: min(905px, 95%);
  max-height: 80vh;
  background: #ffffff;
  border-radius: 30px;
}

.p-modal__inner {
  overflow-y: auto;
  height: inherit;
  max-height: inherit;
  position: relative;
  padding-block: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 40px;
}
@media screen and (max-width: 767px) {
  .p-modal__inner {
    padding-inline: 16px;
  }
}

.p-modal__body {
  height: inherit;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 50px;
     -moz-column-gap: 50px;
          column-gap: 50px;
}

/* 閉じるボタンのスタイル ========== */
.p-modal__close-btn {
  position: absolute;
  z-index: 2;
  top: 36px;
  right: 36px;
}
@media (max-width: 350px) {
  .p-modal__close-btn {
    top: 22px;
    right: 22px;
  }
}

.p-faq__icon-wrap {
  position: absolute;
  bottom: -70px;
  left: calc(100% + 20px);
  width: 137px;
  height: 153px;
}
@media (max-width: 1300px) {
  .p-faq__icon-wrap {
    top: -56px;
    left: calc(100% - 184px);
  }
}
@media screen and (max-width: 767px) {
  .p-faq__icon-wrap {
    width: 77px;
    height: 86px;
    top: -10px;
    left: calc(100% - 107px);
  }
}

.p-faq__icon {
  width: 137px;
  height: 153px;
}
@media screen and (max-width: 767px) {
  .p-faq__icon {
    width: 77px;
    height: 86px;
  }
}

@media screen and (max-width: 767px) {
  .p-faq__title {
    text-align: left;
  }
}

.p-faq__items {
  -webkit-margin-before: 60px;
          margin-block-start: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 32px;
}
@media screen and (max-width: 767px) {
  .p-faq__items {
    -webkit-margin-before: 40px;
            margin-block-start: 40px;
  }
}

input[type=text],
input[type=email],
input[type=tel],
select,
textarea {
  border-radius: 8px;
  width: 100%;
  border: none;
  padding: 16px;
  background: #f7f7f7;
  font-size: 14px;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.56px;
  -webkit-margin-before: 8px;
          margin-block-start: 8px;
  color: #274b66;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  input[type=text],
  input[type=email],
  input[type=tel],
  select,
  textarea {
    padding-block: 17px;
  }
}
@media (any-hover: hover) {
  input[type=text]:hover,
  input[type=email]:hover,
  input[type=tel]:hover,
  select:hover,
  textarea:hover {
    cursor: pointer;
  }
}
input[type=text]::-webkit-input-placeholder, input[type=email]::-webkit-input-placeholder, input[type=tel]::-webkit-input-placeholder, select::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #b4adad;
}
input[type=text]::-moz-placeholder, input[type=email]::-moz-placeholder, input[type=tel]::-moz-placeholder, select::-moz-placeholder, textarea::-moz-placeholder {
  color: #b4adad;
}
input[type=text]:-ms-input-placeholder, input[type=email]:-ms-input-placeholder, input[type=tel]:-ms-input-placeholder, select:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #b4adad;
}
input[type=text]::-ms-input-placeholder, input[type=email]::-ms-input-placeholder, input[type=tel]::-ms-input-placeholder, select::-ms-input-placeholder, textarea::-ms-input-placeholder {
  color: #b4adad;
}
input[type=text]::placeholder,
input[type=email]::placeholder,
input[type=tel]::placeholder,
select::placeholder,
textarea::placeholder {
  color: #b4adad;
}
input[type=text].invalid,
input[type=email].invalid,
input[type=tel].invalid,
select.invalid,
textarea.invalid {
  border: 1px solid #dc5d5c;
  background: #f4d9d9;
}
input[type=text]:focus,
input[type=email]:focus,
input[type=tel]:focus,
select:focus,
textarea:focus {
  border-color: #66b1c5;
  outline: none;
}
input[type=text]:focus:not(.invalid),
input[type=email]:focus:not(.invalid),
input[type=tel]:focus:not(.invalid),
select:focus:not(.invalid),
textarea:focus:not(.invalid) {
  border: 1px solid #66b1c5;
  background: #f7f7f7;
  outline: none;
}
input[type=text]:not(:focus):not(.invalid),
input[type=email]:not(:focus):not(.invalid),
input[type=tel]:not(:focus):not(.invalid),
select:not(:focus):not(.invalid),
textarea:not(:focus):not(.invalid) {
  background: #f7f7f7;
  border: none;
}
input[type=text].has-value:not(.invalid):not(:focus),
input[type=email].has-value:not(.invalid):not(:focus),
input[type=tel].has-value:not(.invalid):not(:focus),
select.has-value:not(.invalid):not(:focus),
textarea.has-value:not(.invalid):not(:focus) {
  border: 1px solid #66b1c5;
  background: #f7f7f7;
}

textarea {
  resize: vertical;
  height: 240px;
}

select {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
}

.p-contact__select-wrap {
  position: relative;
}
.p-contact__select-wrap svg {
  position: absolute;
  top: 50%;
  translate: 0 -33%;
  right: 16px;
  width: 24px;
  height: 24px;
  pointer-events: none;
}

.p-your-select {
  color: #b4adad;
}
.p-your-select:has(option:checked:not([value=""])) {
  color: #274b66;
}

input[type=checkbox] {
  width: 1px;
  height: 1px;
  position: absolute;
  clip: rect(0, 0, 0, 0);
}

input[type=checkbox]:checked + span::after {
  opacity: 1;
}

.p-contact__data-checkbox {
  -webkit-margin-before: 8px;
          margin-block-start: 8px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 40px;
     -moz-column-gap: 40px;
          column-gap: 40px;
}
@media screen and (max-width: 767px) {
  .p-contact__data-checkbox {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    row-gap: 15px;
  }
}
.p-contact__data-checkbox span {
  display: inline-block;
  color: #274b66;
  font-size: 14px;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.56px;
  -webkit-padding-start: 32px;
          padding-inline-start: 32px;
  position: relative;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (any-hover: hover) {
  .p-contact__data-checkbox span:hover {
    cursor: pointer;
  }
}
.p-contact__data-checkbox span::before {
  content: "";
  position: absolute;
  top: 2.5px;
  left: 0;
  width: 20px;
  height: 20px;
  border-radius: 4px;
  border: 1px solid #b4adad;
  background: #f7f7f7;
}
.p-contact__data-checkbox span::after {
  content: "";
  position: absolute;
  top: 5px;
  left: 7px;
  width: 6px;
  height: 12px;
  rotate: 45deg;
  -webkit-border-end: 1px solid #66b1c5;
          border-inline-end: 1px solid #66b1c5;
  -webkit-border-after: 1px solid #66b1c5;
          border-block-end: 1px solid #66b1c5;
  opacity: 0;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.p-contact__data.invalid .p-contact__data-checkbox span::before {
  border: 1px solid #dc5d5c;
  background: #f4d9d9;
}

.p-contact__acceptance.invalid span::before {
  border: 1px solid #dc5d5c;
  background: #f4d9d9;
}

.p-contact__data-checkbox label:focus-within span::before {
  border-color: #66b1c5;
}

@-moz-document url-prefix() {
  @media screen and (max-width: 767px) {
    .p-contact__data-checkbox {
      row-gap: 11px;
    }
  }
}
.p-contact-checkbox__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 40px;
     -moz-column-gap: 40px;
          column-gap: 40px;
}
@media (max-width: 335px) {
  .p-contact-checkbox__content {
    -webkit-column-gap: 26px;
       -moz-column-gap: 26px;
            column-gap: 26px;
  }
}

.p-contact__acceptance {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-margin-before: -8px;
          margin-block-start: -8px;
}
@media screen and (max-width: 767px) {
  .p-contact__acceptance {
    -webkit-margin-before: 4px;
            margin-block-start: 4px;
    text-align: center;
  }
}

.p-contact__acceptance-text {
  font-size: 16px !important;
}

input[type=radio] {
  width: 1px;
  height: 1px;
  position: absolute;
  clip: rect(0, 0, 0, 0);
}

.contact__data-radio span {
  display: inline-block;
  position: relative;
}
.contact__data-radio span::before {
  content: "";
  position: absolute;
}
.contact__data-radio span::after {
  content: "";
  position: absolute;
  opacity: 0;
}

input[type=submit],
input[type=button] {
  border-radius: 0px;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  -moz-appearance: button;
       appearance: button;
  border: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  cursor: pointer;
  background: transparent;
}

input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}

.row.jc-center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.p-contact__submit {
  position: relative;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .p-contact__submit {
    height: 50px;
  }
}
.p-contact__submit input[type=submit] {
  font-size: 16px;
  color: #ffffff;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0.48px;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.p-contact__btn {
  border-radius: 10px;
  background: #66b1c5;
  border: 2px solid #66b1c5;
  margin-inline: auto;
  padding-inline: unset;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (any-hover: hover) {
  .p-contact__btn:hover input[type=submit] {
    color: #66b1c5;
  }
  .p-contact__btn:hover .p-contact__btn-icon circle {
    fill: #66b1c5;
  }
  .p-contact__btn:hover .p-contact__btn-icon path {
    fill: #ffffff;
  }
}

.p-contact__btn-icon circle,
.p-contact__btn-icon path {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.p-contact__submit {
  -webkit-margin-before: 3px;
          margin-block-start: 3px;
}
@media screen and (max-width: 767px) {
  .p-contact__submit {
    -webkit-margin-before: -11px;
            margin-block-start: -11px;
  }
}

.p-contact__form {
  -webkit-margin-before: 60px;
          margin-block-start: 60px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: 29px;
}
@media screen and (max-width: 767px) {
  .p-contact__form {
    -webkit-margin-before: 40px;
            margin-block-start: 40px;
    row-gap: 26px;
  }
}

@-moz-document url-prefix() {
  .p-contact__form {
    row-gap: 28px;
  }
  @media screen and (max-width: 767px) {
    .p-contact__form {
      row-gap: 25px;
    }
  }
}
.p-contact__head {
  color: #274b66;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.8px;
}
@media screen and (max-width: 767px) {
  .p-contact__head {
    font-size: 15px;
  }
}
.p-contact__head span {
  color: #dc5d5c;
}

.p-contact__data-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 2.5rem;
     -moz-column-gap: 2.5rem;
          column-gap: 2.5rem;
}
@media screen and (max-width: 767px) {
  .p-contact__data-wrapper {
    -webkit-column-gap: 0.9375rem;
       -moz-column-gap: 0.9375rem;
            column-gap: 0.9375rem;
  }
}

.p-contact__data-wrap {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.p-contact__row-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 40px;
     -moz-column-gap: 40px;
          column-gap: 40px;
}
@media screen and (max-width: 767px) {
  .p-contact__row-wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    row-gap: 46px;
  }
}
.p-contact__row-wrapper .p-contact__row {
  width: 50%;
}
@media screen and (max-width: 767px) {
  .p-contact__row-wrapper .p-contact__row {
    width: 100%;
  }
}

.p-contact__error-message {
  color: #dc5d5c;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.6px;
}

.p-footer__top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .p-footer__top {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    row-gap: 40px;
  }
}

.p-footer__logo {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (any-hover: hover) {
  .p-footer__logo:hover {
    opacity: 0.7;
    cursor: pointer;
  }
}
@media screen and (max-width: 767px) {
  .p-footer__logo img {
    width: 14.0625rem;
    height: 2.25rem;
  }
}

.p-footer-tel-info__num {
  font-size: 1.5rem;
}

@media screen and (max-width: 767px) {
  .p-footer-tel-info__icon {
    width: 1.9375rem;
    height: 2.5625rem;
  }
}

.p-footer-tel-info__text {
  font-size: 0.75rem;
}

.p-footer__nav {
  padding-block: 25px 32px;
  -webkit-border-after: 1px solid #274b66;
          border-block-end: 1px solid #274b66;
}
@media screen and (max-width: 767px) {
  .p-footer__nav {
    padding-block: 2.75rem 1.9375rem;
  }
}

@-moz-document url-prefix() {
  .p-footer__nav {
    padding-block-end: 30px;
  }
}
.p-footer-nav__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 24px;
     -moz-column-gap: 24px;
          column-gap: 24px;
  color: #274b66;
  font-size: 14px;
  font-weight: 500;
  line-height: normal;
  letter-spacing: 0.56px;
}
@media screen and (max-width: 767px) {
  .p-footer-nav__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    row-gap: 2.4375rem;
    font-size: 0.875rem;
  }
}

@-moz-document url-prefix() {
  @media screen and (max-width: 767px) {
    .p-footer-nav__list {
      row-gap: 2.3125rem;
    }
  }
}
.p-footer-nav__item {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (any-hover: hover) {
  .p-footer-nav__item:hover {
    opacity: 0.7;
    cursor: pointer;
  }
}

.p-footer__bottom {
  -webkit-margin-before: 32px;
          margin-block-start: 32px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .p-footer__bottom {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    row-gap: 1rem;
    -webkit-margin-before: 2rem;
            margin-block-start: 2rem;
  }
}

.p-footer__copy {
  color: #274b66;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.6px;
}
@media screen and (max-width: 767px) {
  .p-footer__copy {
    font-size: 0.75rem;
  }
}

.p-footer-sns__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 16px;
     -moz-column-gap: 16px;
          column-gap: 16px;
}
@media screen and (max-width: 767px) {
  .p-footer-sns__list {
    -webkit-column-gap: 1rem;
       -moz-column-gap: 1rem;
            column-gap: 1rem;
  }
}

.p-footer-sns__link {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
@media (any-hover: hover) {
  .p-footer-sns__link:hover {
    opacity: 0.7;
    cursor: pointer;
  }
}
.p-footer-sns__link .p-footer-sns__icon {
  width: 40px;
  height: 40px;
}
@media screen and (max-width: 767px) {
  .p-footer-sns__link {
    width: 2.5rem;
    height: 2.5rem;
  }
}

.u-vertical-align-middle {
  vertical-align: middle;
}

.u-separate {
  margin-block: 24px;
}

@media screen and (max-width: 767px) {
  .u-sp__hidden {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .u-pc__hidden {
    display: none;
  }
}
.u-animation-fade {
  opacity: 0;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
.u-animation-fade.is-show {
  opacity: 1;
}

.u-animation-left {
  clip-path: inset(0 100% 0 0);
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}
.u-animation-left.is-show {
  clip-path: inset(0 0 0 0);
}