@charset "UTF-8";
/* ---------------------------------------------------------
@extend (継承用)
--------------------------------------------------------- */
.montserrat {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
}

.notoM {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}

.notoB {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
}

main {
  padding-top: 93px;
}
@media all and (max-width: 768px) {
  main {
    padding-top: 64px;
  }
}
@media all and (max-width: 768px) {
  main {
    padding-top: 64px;
  }
}

.page .wrap2 {
  max-width: 927px;
}
.page h3 {
  font-weight: 400;
}
.page article {
  margin-bottom: 80px;
}
.page .pagination {
  margin-bottom: 70px;
}

/*----------------------------------------------------------------------
写真 + テキスト
----------------------------------------------------------------------*/
.media_box {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: 70px;
}
.media_box .photo_img {
  width: 41%;
  border-radius: 37px;
}
.media_box .photo_img:before {
  padding-top: 52.4781341108%;
}
.media_box .photo_img img {
  border-radius: 37px;
}
.media_box article {
  width: 59%;
  padding-left: 25px;
}
.media_box article h3 {
  margin-bottom: 20px;
  font-size: 16px;
  font-size: 1rem;
}
.media_box article p {
  font-size: 14px;
  font-size: 0.875rem;
}
@media all and (max-width: 768px) {
  .media_box {
    margin-bottom: 60px;
  }
  .media_box .photo_img {
    width: 100%;
    margin-bottom: 15px;
    border-radius: 20px;
  }
  .media_box .photo_img img {
    border-radius: 20px !important;
  }
  .media_box article {
    width: 100%;
    padding-left: 0;
  }
}
@media all and (max-width: 768px) {
  .media_box {
    margin-bottom: 60px;
  }
  .media_box .photo_img {
    width: 100%;
    margin-bottom: 15px;
    border-radius: 20px;
  }
  .media_box .photo_img img {
    border-radius: 20px;
  }
  .media_box article {
    width: 100%;
    padding-left: 0;
  }
}

.media_box.photo_right .photo_img {
  order: 2;
  margin-left: auto;
}
.media_box.photo_right article,
.media_box.photo_right .text {
  order: 1;
}
@media all and (max-width: 768px) {
  .media_box.photo_right .photo_img {
    order: 1;
  }
  .media_box.photo_right article,
  .media_box.photo_right .text {
    order: 2;
  }
}
@media all and (max-width: 768px) {
  .media_box.photo_right .photo_img {
    order: 1;
  }
  .media_box.photo_right article,
  .media_box.photo_right .text {
    order: 2;
  }
}

/*----------------------------------------------------------------------
見出し
----------------------------------------------------------------------*/
.title_h {
  position: relative;
}
.title_h:before {
  display: block;
  content: "";
  position: absolute;
  left: 0;
  width: 50%;
  height: 100%;
  background: #fffbac;
}

.page_visual {
  position: relative;
  padding: 32px 0;
  background: #fffbac;
}
.page_visual figure:before {
  padding-top: 23%;
}
.page_visual .wrap2 {
  position: relative;
}
.page_visual article {
  max-width: 840px;
  margin: auto;
}
.page_visual article h1 {
  display: inline-block;
  font-size: 27px;
  font-size: 1.6875rem;
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
}
.page_visual article h1 b {
  color: #efe743;
}
.page_visual article h1 small {
  display: block;
  font-weight: 400;
  font-size: 16px;
  font-size: 1rem;
  font-family: "Noto Sans JP", sans-serif;
}
@media all and (max-width: 768px) {
  .page_visual {
    margin-top: 0;
  }
  .page_visual .photo_img {
    height: auto;
  }
  .page_visual .photo_img:before {
    padding-top: 23.4666666667%;
  }
  .page_visual article h1 {
    padding: 8px 40px;
    font-size: 24px;
    font-size: 1.5rem;
  }
}
@media all and (max-width: 768px) {
  .page_visual {
    margin-top: 0;
  }
  .page_visual .photo_img {
    height: auto;
  }
  .page_visual .photo_img:before {
    padding-top: 23.4666666667%;
  }
  .page_visual article h1 {
    padding: 8px 40px;
    font-size: 24px;
    font-size: 1.5rem;
  }
}

/*-------------------------------------------------------
各ページのインポート
-------------------------------------------------------*/
/* ---------------------------------------------------------
@extend (継承用)
--------------------------------------------------------- */
.montserrat {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
}

.notoM {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}

.notoB {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
}

/*----------------------------------------------------------------------
ABOUT US
----------------------------------------------------------------------*/
.page_about h2 {
  margin-bottom: 37px;
}
.page_about h3 {
  font-size: 16px;
  font-size: 1rem;
}
.page_about h3 small {
  display: block;
  margin-top: 10px;
  font-weight: 400;
}
.page_about p {
  font-size: 14px;
  font-size: 0.875rem;
}

.about_intro {
  margin-bottom: 90px;
}
.about_intro .h_line {
  font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
  font-weight: 400;
  font-size: 49px;
  font-size: 3.0625rem;
}
.about_intro .h_line:after {
  margin-left: 1em;
  width: 33%;
}
.about_intro .media_box {
  flex-wrap: nowrap;
}
.about_intro .media_box .photo_img {
  width: 100%;
  border-radius: inherit;
  /* width: 65vw;
  margin-left: calc(50% - 50vw);
  margin-right: 40px;
  border-radius: 0 70px 0 0; */
}
.about_intro .media_box .photo_img:before {
  padding-top: 57.9545454545%;
}
.about_intro .media_box .photo_img img {
  border-radius: 100px 0 100px 0;
}
.about_intro .media_box ul {
  width: 110%;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: 20px;
}
.about_intro p {
  margin-bottom: 1.5em;
  font-size: 18px;
  font-size: 1.125rem;
}
.about_intro p + .photo_img:before {
  padding-top: 28%;
}
@media all and (max-width: 768px) {
  .about_intro .media_box {
    flex-direction: column;
    margin-bottom: 40px;
  }
  .about_intro .media_box .photo_img {
    width: 100vw;
    margin-bottom: 20px;
    margin-right: 20px;
  }
  .about_intro .media_box ul {
    width: 100%;
  }
}
@media all and (max-width: 768px) {
  .about_intro .media_box {
    flex-direction: column;
    margin-bottom: 40px;
  }
  .about_intro .media_box .photo_img {
    width: 100vw;
    margin-bottom: 20px;
    margin-right: 20px;
  }
  .about_intro .media_box ul {
    width: 100%;
  }
}

.profile {
  padding-bottom: 65px;
}
.profile .photo_img {
  width: 65vw;
  margin-bottom: 37px;
  margin-right: calc(50% - 50vw);
  margin-left: auto;
  border-radius: 0 0 0 70px;
}
.profile .photo_img:before {
  padding-top: 57.9545454545%;
}
.profile .text {
  margin-left: 25vw;
}
.profile .text h3 {
  margin-bottom: 20px;
}
@media all and (max-width: 768px) {
  .profile .photo_img {
    width: 100vw;
  }
  .profile .text {
    margin-left: 0;
  }
}
@media all and (max-width: 768px) {
  .profile .photo_img {
    width: 100vw;
  }
  .profile .text {
    margin-left: 0;
  }
}

.message {
  margin-bottom: 80px;
  padding: 45px 0 76px;
  background: #fffbac;
}
.message h3 {
  margin-bottom: 53px;
}

.staff {
  margin-bottom: 100px;
}

.company {
  padding: 66px 0;
  background: #283237;
  color: #fff;
}

.dl_table dl {
  display: flex;
  margin-bottom: 36px;
}
.dl_table dl:last-child {
  margin-bottom: 0;
}
.dl_table dl dt {
  width: 8em;
}
.dl_table dl dd {
  width: calc(100% - 8em);
}
@media all and (max-width: 768px) {
  .dl_table dl dt {
    width: 6em;
  }
}
@media all and (max-width: 768px) {
  .dl_table dl dt {
    width: 6em;
  }
}

/* ---------------------------------------------------------
@extend (継承用)
--------------------------------------------------------- */
.montserrat {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
}

.notoM {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}

.notoB {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
}

/*----------------------------------------------------------------------
SERVICE
----------------------------------------------------------------------*/
.page_service h2 {
  margin-bottom: 37px;
}
.page_service h3 {
  margin-bottom: 30px;
  font-size: 16px;
  font-size: 1rem;
}
.page_service h4 {
  margin-bottom: 10px;
  font-weight: 600;
  font-size: 16px;
  font-size: 1rem;
}
.page_service p {
  font-size: 14px;
  font-size: 0.875rem;
}
.page_service .photo_img::before {
  padding-top: 63.4730538922%;
}
.page_service .landscape {
  margin-bottom: 35px;
}
.page_service .landscape:before {
  padding-top: 28%;
}
.page_service article {
  margin-bottom: 67px;
  padding: 0 32px;
}
.page_service .page_visual article {
  margin-bottom: 0;
}
.page_service .service_content {
  margin-bottom: 122px;
}
.page_service .service_content .landscape {
  margin-bottom: 66px;
}
@media all and (max-width: 768px) {
  .page_service article {
    padding: 0 0;
  }
  .page_service .service_content {
    margin-bottom: 60px;
  }
}
@media all and (max-width: 768px) {
  .page_service article {
    padding: 0 0;
  }
  .page_service .service_content {
    margin-bottom: 60px;
  }
}

/*----------------------------------------------------------------------
Bポジ
----------------------------------------------------------------------*/
.b-posi .photo_right .photo_img::before {
  padding-top: 100%;
}
.b-posi .landscape {
  margin: 0 34px 57px;
}
.b-posi .col_3 {
  margin-left: -40px;
}
.b-posi .col_3 > * {
  margin-left: 40px;
  width: calc(33.33333% - 40px);
}
.b-posi .item {
  text-align: center;
  margin-bottom: 50px;
}
.b-posi .item img {
  margin-bottom: 12px;
}
.b-posi .item figcaption {
  font-size: 14px;
  font-size: 0.875rem;
}
@media all and (max-width: 768px) {
  .b-posi .landscape {
    margin: 0 0 30px;
  }
  .b-posi .col_3 {
    margin-left: 0;
  }
  .b-posi .col_3 > * {
    margin-left: 0;
    width: 100%;
  }
}
@media all and (max-width: 768px) {
  .b-posi .landscape {
    margin: 0 0 30px;
  }
  .b-posi .col_3 {
    margin-left: 0;
  }
  .b-posi .col_3 > * {
    margin-left: 0;
    width: 100%;
  }
}

.teacher {
  padding: 54px 0 105px;
  background: #e8ebe2;
}
.teacher h3 {
  text-align: center;
}
.teacher p {
  margin-bottom: 98px;
}
.teacher .col {
  margin-bottom: 40px;
}
.teacher .item {
  text-align: center;
}
.teacher .item figure img {
  max-width: 147px;
  margin-bottom: 20px;
}
.teacher .item figcaption {
  font-weight: 600;
  font-size: 14px;
  font-size: 0.875rem;
}
.teacher .btn_area {
  text-align: center;
}

/* ---------------------------------------------------------
@extend (継承用)
--------------------------------------------------------- */
.montserrat {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
}

.notoM {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}

.notoB {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
}

/*----------------------------------------------------------------------
VOICE
----------------------------------------------------------------------*/
.page_voice .content {
  padding: 0 0 72px;
}
.page_voice .col_3 {
  margin-left: -68px;
}
.page_voice .col_3 > * {
  margin-left: 68px;
  width: calc(33.33333% - 68px);
}

@media all and (max-width: 768px) {
  .page_voice .col_3 {
    margin-left: 0;
  }
  .page_voice .col_3 > * {
    margin-left: 0;
    width: 100%;
  }
}
@media all and (max-width: 768px) {
  .page_voice .col_3 {
    margin-left: 0;
  }
  .page_voice .col_3 > * {
    margin-left: 0;
    width: 100%;
  }
}
.page_voice .item {
  margin-bottom: 75px;
}
.page_voice .item .photo_img {
  margin-bottom: 12px;
  border-radius: 16px;
}
.page_voice .item .photo_img::before {
  padding-top: 68.669527897%;
}
.page_voice .item .photo_img img {
  border-radius: 16px;
}
.page_voice .item time {
  display: block;
  margin-bottom: 12px;
  font-size: 14px;
  font-size: 0.875rem;
}
.page_voice .item h2 {
  font-size: 16px;
  font-size: 1rem;
}
@media all and (max-width: 768px) {
  .page_voice .item {
    margin-bottom: 54px;
  }
  .page_voice .item h2 {
    margin-bottom: 0;
  }
}

.single time {
  display: block;
  margin-bottom: 16px;
  font-size: 14px;
  font-size: 0.875rem;
}
.single h2 {
  font-size: 16px;
  font-size: 1rem;
}
.single .thumbnail {
  margin-bottom: 42px;
  border-radius: 16px;
}
.single .thumbnail::before {
  padding-top: 75%;
}
.single .thumbnail img {
  border-radius: 16px;
}
.single article {
  padding-bottom: 46px;
}
.single article p {
  margin-bottom: 1em;
}
.single .pagination {
  padding-bottom: 67px;
}

/* ---------------------------------------------------------
@extend (継承用)
--------------------------------------------------------- */
.montserrat {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
}

.notoM {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
}

.notoB {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
}

/*-------------------------------------------------
お問い合せ
-------------------------------------------------*/
.mw_wp_form .horizontal-item + .horizontal-item {
  display: inline-block;
  margin-left: 0;
  margin-right: 10px;
  margin-bottom: 1em;
}

.att {
  color: #fe0808;
}

.tel_box {
  margin: 0 0 57px;
  padding: 25px 0;
  text-align: center;
  border: 1px solid #999999;
}
.tel_box h3 {
  margin: 0 0 0;
  font-weight: 700;
  font-size: 20px;
  font-size: 1.25rem;
}
.tel_box p strong {
  font-weight: 700;
  font-size: 40px;
  font-size: 2.5rem;
}
@media all and (max-width: 768px) {
  .tel_box h3 {
    font-size: 16px;
    font-size: 1rem;
  }
  .tel_box p strong {
    font-size: 26px;
    font-size: 1.625rem;
  }
}
@media all and (max-width: 768px) {
  .tel_box h3 {
    font-size: 16px;
    font-size: 1rem;
  }
  .tel_box p strong {
    font-size: 26px;
    font-size: 1.625rem;
  }
}

.form {
  max-width: 827px;
  margin: 0 auto;
  /*
  .wpcf7-list-item-label {
  	box-sizing: border-box;
  	position: relative;
  	display: inline-block;
  	margin: 0 20px 0 0;
  	padding: 0 0 0 20px;
  	vertical-align: middle;
  	cursor: pointer;
  	&:after {
  		position: absolute;
  		top: 50%;
  		left: 0;
  		display: block;
  		margin-top: -8px;
  		width: 14px;
  		height: 14px;
  		background : #fff;
  		border : 1px solid #818A8E;
  		content: '';
  		z-index: 1;
  	}
  	&:before {
  		position: absolute;
  		top: 50%;
  		left: 5px;
  		display: block;
  		margin-top: -8px;
  		width: 6px;
  		height: 9px;
  		border-right: 2px solid #014A88;
  		border-bottom: 2px solid #014A88;
  		transform: rotate(45deg);
  		content: '';
  		opacity: 0;
  		z-index: 10;
  	}
  }
  */
}
.form p {
  margin-bottom: 2em;
}
.form dl {
  width: 100%;
  padding: 15px 0;
}
.form dt {
  margin: 0 0 25px;
  padding: 11px 10px;
  font-weight: bold;
  font-size: 16px;
  font-size: 1rem;
  background: #f2f2f2;
}
.form dt a {
  color: #007ec4;
}
.form dt em {
  display: inline-block;
  margin-right: 17px;
  padding: 4px 10px;
  font-size: 14px;
  font-size: 0.875rem;
  color: #222;
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  background: #ede34e;
}
.form dd {
  margin: 0 0 40px;
}
.form dd em {
  margin-left: 23px;
  color: #999999;
  font-size: 16px;
  font-size: 1rem;
  line-height: 2.5;
}
.form dd textarea {
  padding: 1em;
  width: 100%;
  border: 1px solid #b1b1b1;
}
.form dd textarea + em {
  width: 100%;
}
.form .mwform-checkbox-field {
  white-space: nowrap;
}
.form .att {
  margin: 1em 0 2em;
  font-size: 12px;
  font-size: 0.75rem;
  line-height: 2;
}
.form input,
.form textarea {
  font-size: 16px;
  font-size: 1rem;
}
.form input[type=text],
.form input[type=email],
.form input[type=tel] {
  width: 50%;
  padding: 12px 1em;
  border: 1px solid #b1b1b1;
}
.form .wpcf7-form-control-wrap + .att {
  margin: 0.5em 0 0;
}
.form .select-wrap {
  display: inline-block;
  width: auto;
  margin-right: 10px;
}
.form .select-wrap select {
  height: auto;
  padding: 12px 3em 12px 1em;
  color: #363636;
}
.form .select-wrap:nth-child(n+2) {
  margin-left: 10px;
}
.form input[disabled] {
  background: #efefef;
  border: none;
  color: #3c3c3c;
  -webkit-text-fill-color: black;
  opacity: 1;
}
.form .btn_area {
  display: flex;
  justify-content: center;
  padding: 36px 0 64px;
}
.form .btn_area .btn {
  width: auto;
  min-width: auto;
  padding: 2px 10px;
  font-weight: 400;
  color: #333;
  border-radius: 40px;
  background: #efe743;
  height: auto;
  line-height: 1;
  font-size: 14px;
  font-size: 0.875rem;
}
.form input[type=submit] {
  -moz-appearance: none;
       appearance: none;
  -webkit-appearance: none;
  font-size: 14px;
  font-size: 0.875rem;
  min-width: 87px;
}
.form input[type=submit] {
  display: inline-block;
  padding: 2px 10px;
  font-weight: 400;
  color: #333;
  border-radius: 40px;
  background: #efe743;
  cursor: pointer;
}
.form input[type=submit].back_btn {
  max-width: 50%;
  margin-right: 30px;
  color: #222222;
  background: #dbdbdb;
}
.form #mail {
  margin-bottom: 5px;
}
.form .mwform-checkbox-field-text {
  font-weight: bold;
}
@media all and (max-width: 768px) {
  .form dt {
    font-size: 14px;
    font-size: 0.875rem;
  }
  .form dt em {
    margin-right: 9px;
    font-size: 12px;
    font-size: 0.75rem;
  }
  .form dd {
    width: 100%;
  }
  .form dd em {
    display: block;
    margin: 0;
    font-size: 12px;
    font-size: 0.75rem;
  }
  .form input[type=text],
  .form input[type=email],
  .form input[type=tel] {
    width: 100%;
  }
  .form .select-wrap {
    margin-bottom: 10px;
  }
  .form .select-wrap:nth-child(n+2) {
    margin-left: 0;
  }
  .form .btn_area {
    padding: 40px 0 80px;
  }
  .form input[type=radio] + label {
    display: inline-block;
    margin-bottom: 12px;
  }
  .form input[type=submit] {
    display: inline-block;
    width: 100%;
    padding: 23px 0;
  }
}
@media all and (max-width: 768px) {
  .form dt {
    font-size: 14px;
    font-size: 0.875rem;
  }
  .form dt em {
    margin-right: 9px;
    font-size: 12px;
    font-size: 0.75rem;
  }
  .form dd {
    width: 100%;
  }
  .form dd em {
    display: block;
    margin: 0;
    font-size: 12px;
    font-size: 0.75rem;
  }
  .form input[type=text],
  .form input[type=email],
  .form input[type=tel] {
    width: 100%;
  }
  .form .select-wrap {
    margin-bottom: 10px;
  }
  .form .select-wrap:nth-child(n+2) {
    margin-left: 0;
  }
  .form .btn_area {
    padding: 40px 0 80px;
  }
  .form input[type=radio] + label {
    display: inline-block;
    margin-bottom: 12px;
  }
  .form input[type=submit] {
    display: inline-block;
    width: 100%;
    padding: 23px 0;
  }
}
.form #formbtn {
  min-width: 400px;
  position: relative;
  display: inline-block;
  padding: 20px 60px;
  font-size: 18px;
  font-size: 1.125rem;
  text-align: center;
  line-height: 1;
  z-index: 1;
  font-weight: bold;
  overflow: hidden;
  color: #fff;
  background: #014a88;
  border-radius: 5px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.16);
  cursor: pointer;
}
@media all and (max-width: 768px) {
  .form #formbtn {
    width: 100%;
    min-width: 100%;
  }
}
@media all and (max-width: 768px) {
  .form #formbtn {
    width: 100%;
    min-width: 100%;
  }
}

.mw_wp_form_confirm .form dd em {
  display: none;
}
.mw_wp_form_confirm .form dd .confirm {
  display: none;
}
.mw_wp_form_confirm .form dd.text_c {
  text-align: left;
}
.single .thumbnail {
  text-align: center;
}
/*# sourceMappingURL=page.css.map */

