@charset "UTF-8";
header#global_header {
  min-width: 0 !important;
  width: 100%;
}

#contents_wrap {
  min-width: 0 !important;
  width: 100%;
}

#contents {
  width: 100%;
}

#main {
  width: 100%;
}

#main #col_main {
  float: none;
  width: 100%;
  max-width: 1200px;
  margin-right: auto;
  margin-left: auto;
  padding-left: 40px;
  padding-right: 40px;
}
@media screen and (max-width: 834px) {
  #main #col_main {
    padding: 0 20px;
  }
}

footer#global_footer {
  min-width: 0;
}

* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

html {
  overflow-x: hidden;
}

body {
  position: relative;
}

body *:not(table *, i) {
  /* 
        font-weightは<b>タグが機能しなくなるので指定しない。
        line-heightは余計に高さが効いてしまうので指定しない。 => bxi.cssで効いてる可能性あり。
    */
  margin: 0;
}

i {
  line-height: 1;
}

img {
  vertical-align: bottom;
}

body a {
  text-decoration: none;
}
body button {
  padding: 0;
  border: none;
  background-color: transparent;
}
body b {
  color: inherit;
  font-family: inherit;
  font-size: inherit;
}
body span {
  color: inherit;
  font-size: inherit;
  font-family: inherit;
  font-weight: inherit;
}

html {
  font-size: 10px;
}

body {
  font-family: "Roboto", sans-serif;
  font-family: "Klee One", cursive;
  font-family: "Noto Serif JP", serif;
  color: #393939;
  counter-reset: number 0;
  letter-spacing: 0.05rem;
}

a {
  text-decoration: none;
}

li {
  list-style: none;
}

h3 {
  display: none;
}

img.imgL {
  margin-right: 0;
}
@media screen and (max-width: 640px) {
  img.imgL {
    max-width: 100%;
  }
}

.header {
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
  padding-right: 40px;
  padding-left: 40px;
  background-color: #fcf6f6;
}
@media screen and (max-width: 834px) {
  .header {
    padding-right: 20px;
    padding-left: 20px;
  }
}
.header__inner {
  max-width: 1180px;
  margin: 0 auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.header-logo__p {
  width: 70px;
}
.header-logo__img {
  width: 100%;
}
.header__nav {
  margin-left: 45px;
  -webkit-transition: 0.7s;
  transition: 0.7s;
}
@media screen and (max-width: 834px) {
  .header__nav {
    background-color: #fcf6f6;
    position: fixed;
    z-index: 90;
    width: 100vw;
    height: 100vh;
    left: -110%;
    top: 0;
    overflow-y: auto;
    margin-left: 0;
  }
}
.header__nav.active {
  left: 0;
  -webkit-transition: 0.7s;
  transition: 0.7s;
}
.header__ul {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin-left: 5px;
}
@media screen and (max-width: 834px) {
  .header__ul {
    display: block;
    position: relative;
    margin-top: 200px;
    margin-left: 0;
  }
}
@media screen and (max-width: 834px) {
  .header__ul::before {
    position: absolute;
    content: url(../images/footer/logo_new100.png);
    top: -150px;
    right: 0;
    left: 0;
    margin: 0 auto;
  }
}
.header__li {
  font-size: 1.6rem;
  margin-right: 10px;
  margin-top: 40px;
  position: relative;
}
@media screen and (max-width: 1000px) {
  .header__li {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 834px) {
  .header__li {
    margin-right: 0;
    font-size: 1.9rem;
  }
}
.header__li > a:link, .header__li > a:visited {
  color: #393939;
}
.header__li::after {
  position: absolute;
  content: "/";
  margin: 0 2px;
}
@media screen and (max-width: 834px) {
  .header__li::after {
    display: none;
  }
}
.header__li:last-child::after {
  display: none;
}
.header__fixbox, .header__fixbox-mail {
  position: fixed;
  z-index: 100;
}
.header__fixbox {
  top: 30px;
  right: 20px;
  background-color: rgba(192, 184, 154, 0.8);
  padding-left: 20px;
  padding-right: 20px;
}
@media screen and (max-width: 1400px) {
  .header__fixbox {
    top: 100px;
    right: 0;
    padding: 10px;
  }
}
@media screen and (max-width: 640px) {
  .header__fixbox {
    top: auto;
    right: auto;
    bottom: 0;
    left: 0;
    width: 50vw;
    background-color: rgba(192, 184, 154, 0.9450980392);
  }
}
.header__fixbox a > p {
  font-size: 2.4rem;
  line-height: 2;
  color: #393939;
  letter-spacing: 0.075em;
}
.header__fixbox a > p:last-child {
  font-family: "Roboto";
  font-size: 3rem;
  font-weight: 600;
}
@media screen and (max-width: 1400px) {
  .header__fixbox a > p {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    text-orientation: upright;
    font-size: 2rem;
  }
  .header__fixbox a > p:last-child {
    display: none;
  }
}
@media screen and (max-width: 640px) {
  .header__fixbox a > p {
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
  }
}
.header__fixbox a > p > a:link > p, .header__fixbox a > p > a:visited > p {
  color: #393939;
}
.header__fixbox-mail {
  top: 30px;
  right: 300px;
  background-color: rgba(63, 77, 112, 0.8);
  padding: 30px 20px;
}
@media screen and (max-width: 1400px) {
  .header__fixbox-mail {
    top: 350px;
    right: 0;
    padding: 10px;
  }
}
@media screen and (max-width: 640px) {
  .header__fixbox-mail {
    top: auto;
    right: auto;
    bottom: 0;
    right: 0;
    width: 50vw;
    background-color: rgba(63, 77, 112, 0.9450980392);
  }
}
.header__fixbox-mail a > p {
  font-size: 2.4rem;
  line-height: 2;
  color: #fbf9f9;
  letter-spacing: 0.075em;
}
@media screen and (max-width: 1400px) {
  .header__fixbox-mail a > p {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    text-orientation: upright;
    font-size: 2rem;
  }
}
@media screen and (max-width: 640px) {
  .header__fixbox-mail a > p {
    -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
            writing-mode: horizontal-tb;
  }
}
.header__fixbox-mail a > p > a:link > p, .header__fixbox-mail a > p > a:visited > p {
  color: #fbf9f9;
}

.hm-button {
  position: fixed;
  top: 10px;
  right: 20px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  height: 50px;
  width: 50px;
  z-index: 100;
  background-color: rgba(192, 184, 154, 0.6901960784);
  border-radius: 5px;
  display: none;
}
@media screen and (max-width: 834px) {
  .hm-button {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
}
@media screen and (max-width: 640px) {
  .hm-button {
    right: 10px;
  }
}
.hm-button__span, .hm-button__span::before, .hm-button__span::after {
  content: "";
  display: block;
  height: 3px;
  width: 28px;
  border-radius: 3px;
  background-color: #ffffff;
  position: absolute;
}
.hm-button__span::before {
  bottom: 10px;
}
.hm-button__span::after {
  top: 10px;
}
.hm-button__span.active {
  background-color: rgba(255, 255, 255, 0);
}
.hm-button__span.active::before {
  bottom: 0;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.hm-button__span.active::after {
  top: 0;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

#global_footer {
  background-repeat: repeat-y;
}

.footer {
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
  padding-right: 40px;
  padding-left: 40px;
}
@media screen and (max-width: 834px) {
  .footer {
    padding-right: 20px;
    padding-left: 20px;
  }
}
.footer__inner {
  max-width: 1180px;
  margin: 0 auto;
}
.footer__h2 {
  font-size: 3rem;
  font-weight: 500;
  letter-spacing: 0.075em;
  color: #fcf5f5;
  padding-top: 60px;
}
@media screen and (max-width: 640px) {
  .footer__h2 {
    font-size: 2.6rem;
  }
}
.footer__subh2 {
  font-size: 1.8rem;
  letter-spacing: 0.075em;
  color: #fcf5f5;
  margin-top: 10px;
}
.footer-contact {
  margin-top: 50px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (max-width: 834px) {
  .footer-contact {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
.footer-contact__div {
  width: calc((100% - 60px) / 2);
  max-width: 400px;
  margin-right: 60px;
}
.footer-contact__div:last-child {
  margin-right: 0;
}
@media screen and (max-width: 834px) {
  .footer-contact__div {
    width: 90%;
    margin-right: 0;
    margin-bottom: 20px;
  }
  .footer-contact__div:last-child {
    margin-bottom: 0;
  }
}
.footer-contact__tel, .footer-contact__mail {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 640px) {
  .footer-contact__tel, .footer-contact__mail {
    padding: 25px 10px;
  }
}
.footer-contact__tel {
  font-size: 3rem;
  font-weight: 600;
  font-family: "Roboto", sans-serif;
  background-color: #c3bfb0;
  padding: 25px 30px;
}
@media screen and (max-width: 640px) {
  .footer-contact__tel {
    font-size: 2.3rem;
  }
}
.footer-contact__tel:link, .footer-contact__tel:visited {
  color: #000000;
}
.footer-contact__mail {
  font-size: 2.4rem;
  background-color: #fbeabb;
  padding: 30px 30px;
}
@media screen and (max-width: 640px) {
  .footer-contact__mail {
    font-size: 1.8rem;
  }
}
.footer-contact__mail:link, .footer-contact__mail:visited {
  color: #393939;
}
.footer-contact__tel > img, .footer-contact__mail > img {
  margin-right: 10px;
}
@media screen and (max-width: 640px) {
  .footer-contact__tel > img, .footer-contact__mail > img {
    width: 30px;
    margin-right: 5px;
  }
}
.footer-access {
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #ffffff;
  height: 360px;
  margin-top: 80px;
  padding-left: 40px;
}
@media screen and (max-width: 834px) {
  .footer-access {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    height: auto;
    padding-left: 0;
  }
}
.footer-access__logo {
  width: 32.3636363636%;
  margin-right: 20px;
}
@media screen and (max-width: 834px) {
  .footer-access__logo {
    width: 100%;
    margin: 30px auto;
  }
}
.footer-access__logo > img {
  width: 60%;
}
.footer-access__map {
  width: 67.6363636364%;
  height: 100%;
}
@media screen and (max-width: 834px) {
  .footer-access__map {
    width: 100%;
    height: 360px;
  }
}
.footer-address {
  font-size: 1.8rem;
  line-height: 30px;
  color: #fcf5f5;
  margin-top: 25px;
  padding-bottom: 120px;
}
.footer-address > p:last-child {
  font-size: 1.3rem;
  margin-top: 25px;
}

.mv {
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
}
.mv > img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.c-concept {
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
}
.c-concept__inner {
  max-width: 1180px;
  padding-right: 40px;
  padding-left: 40px;
  margin: 0 auto;
}
@media screen and (max-width: 834px) {
  .c-concept__inner {
    padding-right: 20px;
    padding-left: 20px;
  }
}
.c-concept__h2 {
  text-align: center;
}
.c-concept__h2 > article > h2 {
  font-size: 3rem;
  font-weight: 700;
  letter-spacing: 0.075em;
}
.c-concept__h2 > article > div {
  font-size: 1.8rem;
  line-height: 30px;
  letter-spacing: 0.075em;
}
.c-concept-main {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 90px;
}
@media screen and (max-width: 1000px) {
  .c-concept-main {
    gap: 70px;
  }
}
@media screen and (max-width: 834px) {
  .c-concept-main {
    margin-top: 20px;
    gap: 30px;
  }
}
@media screen and (max-width: 640px) {
  .c-concept-main {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 15px;
  }
}
.c-concept-main > img {
  width: 45%;
}
.c-concept-main > div {
  font-size: 1.6rem;
  line-height: 30px;
  letter-spacing: 0.075em;
}
.c-concept__flex {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: stretch;
  -webkit-align-items: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  gap: 10px;
}
@media screen and (max-width: 834px) {
  .c-concept__flex {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 20px;
  }
}
.c-concept__flex > div {
  width: calc((100% - 20px) / 3);
  text-align: center;
  background-color: #fbf9f9;
  border: 1px solid #cac8c8;
  padding: 15px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
@media screen and (max-width: 834px) {
  .c-concept__flex > div {
    width: 100%;
  }
}
.c-concept__flex > div > img {
  margin: auto 0;
}
@media screen and (max-width: 834px) {
  .c-concept__flex > div > img {
    margin: 0 auto;
  }
}
.c-concept__flex .box > div {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
}
.c-concept__h3 {
  display: block;
  font-size: 2.4rem;
  letter-spacing: 0.075em;
  font-weight: 700;
  margin-top: auto;
}
.c-concept__subh3 {
  font-size: 2rem;
  line-height: 30px;
  letter-spacing: 0.075em;
  margin-top: 15px;
  margin-bottom: 15px;
}
.c-concept__p {
  font-size: 1.8rem;
  letter-spacing: 0.075em;
  line-height: 30px;
}
.c-concept__btn {
  display: inline-block;
  padding: 10px 45px;
  margin-top: 20px;
  margin-bottom: 15px;
  font-size: 1.8rem;
  letter-spacing: 0.075em;
  border: 1px solid #8d958d;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.c-concept__btn:link, .c-concept__btn:visited {
  color: #3f4d70;
}
.c-concept__btn:hover {
  background-color: #3f4d70;
  color: #fbf9f9;
}

.schedule {
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
  background-repeat: no-repeat;
  background-size: cover;
}
.schedule__inner {
  max-width: 1180px;
  padding-right: 40px;
  padding-left: 40px;
  margin: 0 auto;
}
@media screen and (max-width: 834px) {
  .schedule__inner {
    padding-right: 20px;
    padding-left: 20px;
  }
}

.s-schedule > div {
  margin-top: 80px;
}
.s-schedule > div > article {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 640px) {
  .s-schedule > div > article {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.s-schedule > div > article > div {
  width: calc((100% - 80px) / 2);
  margin-left: 40px;
  text-align: center;
}
@media screen and (max-width: 834px) {
  .s-schedule > div > article > div {
    margin-left: 20px;
  }
}
@media screen and (max-width: 640px) {
  .s-schedule > div > article > div {
    margin-top: 20px;
    margin-left: 0;
    width: 100%;
  }
}
.s-schedule > div > article > img {
  width: calc((100% - 80px) / 2);
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 3/2;
}
@media screen and (max-width: 640px) {
  .s-schedule > div > article > img {
    width: 80%;
  }
}

.s-schedule__h2 {
  font-size: 3rem;
  font-weight: 600;
  letter-spacing: 0.075em;
}
@media screen and (max-width: 1000px) {
  .s-schedule__h2 {
    font-size: 2.6rem;
  }
}
@media screen and (max-width: 834px) {
  .s-schedule__h2 {
    font-size: 2.4rem;
  }
}
.s-schedule__subh2 {
  font-size: 1.8rem;
  line-height: 1;
  margin-top: 5px;
  margin-bottom: 45px;
}
@media screen and (max-width: 1000px) {
  .s-schedule__subh2 {
    font-size: 1.6rem;
  }
}
.s-schedule__p {
  font-size: 2.4rem;
  letter-spacing: 0.075em;
  line-height: 30px;
  text-align: left;
  margin-left: 40px;
}
@media screen and (max-width: 1000px) {
  .s-schedule__p {
    font-size: 2rem;
    line-height: 22px;
  }
}
@media screen and (max-width: 834px) {
  .s-schedule__p {
    font-size: 1.9rem;
    text-align: center;
  }
}
.s-schedule__btn {
  display: inline-block;
  padding: 10px 45px;
  margin-top: 30px;
  margin-bottom: 15px;
  font-size: 1.8rem;
  letter-spacing: 0.075em;
  border: 1px solid #8d958d;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.s-schedule__btn:link, .s-schedule__btn:visited {
  color: #3f4d70;
}
.s-schedule__btn:hover {
  background-color: #3f4d70;
  color: #fbf9f9;
}
.s-schedule > div:nth-child(2n) > article {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}
@media screen and (max-width: 640px) {
  .s-schedule > div:nth-child(2n) > article {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.s-schedule > div:nth-child(2n) > article > div {
  margin-left: 0;
  margin-right: 40px;
}
@media screen and (max-width: 640px) {
  .s-schedule > div:nth-child(2n) > article > div {
    margin-right: 0;
    margin-top: 20px;
  }
}

.i-instagram .sns_list {
  border: none;
}
.i-instagram .sns_list__list {
  display: block;
  border-bottom: none;
  border: none;
}
.i-instagram .sns_list > div {
  border-bottom: none;
}
.i-instagram .sns_list .sns_photo {
  width: 100%;
  padding: 0;
}
.i-instagram .sns_list .sns_photo a {
  display: block;
}
.i-instagram .sns_list .sns_text {
  width: 100%;
  padding: 0;
}
.i-instagram .sns_list .sns_text .caption {
  word-break: break-all;
}
.i-instagram .sns_list .sns_text ul {
  display: none;
}

.i-instagram .sns_list {
  width: 70%;
  margin: 0 auto;
}
.i-instagram .sns_list > div {
  margin-top: 20px;
}
@media screen and (max-width: 834px) {
  .i-instagram .sns_list > div {
    max-width: 400px;
    margin-right: auto;
    margin-left: auto;
    margin-top: 30px;
  }
}
.i-instagram .sns_list .sns_photo {
  width: 30%;
  margin-right: 40px;
  aspect-ratio: 1/1;
  overflow: hidden;
}
@media screen and (max-width: 834px) {
  .i-instagram .sns_list .sns_photo {
    width: 100%;
    margin-right: 0;
  }
}
.i-instagram .sns_list .sns_date {
  font-size: 1.8rem;
  color: #703f3f;
}

.caption {
  font-size: 1.6rem;
  overflow-wrap: break-word;
  color: #393939;
}

.main-link {
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
  background-repeat: no-repeat;
  background-size: cover;
}
.main-link__inner {
  max-width: 1180px;
  padding-right: 40px;
  padding-left: 40px;
  margin: 0 auto;
}
@media screen and (max-width: 834px) {
  .main-link__inner {
    padding-right: 20px;
    padding-left: 20px;
  }
}
.main-link__btn {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.main-link__btn > .box {
  width: calc((100% - 120px) / 2);
  max-width: 415px;
}
@media screen and (max-width: 640px) {
  .main-link__btn > .box {
    width: 80%;
    margin-bottom: 30px;
  }
}
.main-link__btn > .box:first-child {
  margin-right: calc((100% - 415px) / 2);
  margin-left: calc((100% - 415px) / 2);
  margin-bottom: 85px;
}
@media screen and (max-width: 640px) {
  .main-link__btn > .box:first-child {
    margin-bottom: 30px;
  }
}
.main-link__btn > .box:nth-child(2) {
  margin-right: 80px;
  margin-bottom: 85px;
}
@media screen and (max-width: 640px) {
  .main-link__btn > .box:nth-child(2) {
    margin-right: 0;
    margin-bottom: 30px;
  }
}
.main-link__btn > .box > article {
  border: 5px solid #3f4d70;
  overflow: hidden;
  width: 100%;
  max-height: 160px;
  position: relative;
}
.main-link__btn > .box > article > a {
  width: 100%;
  height: 100%;
  opacity: 0.5;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.main-link__btn > .box > article > a:hover {
  opacity: 0.3;
}
.main-link__btn > .box > article > div {
  position: absolute;
  top: 35%;
  width: 100%;
  text-align: center;
  font-size: 2.4rem;
  letter-spacing: 0.075em;
  display: block;
  color: #3f4d70;
  pointer-events: none;
}

#builingual {
  position: fixed;
  bottom: 15px;
  right: 5px;
  z-index: 1;
  padding: 5px 10px !important;
  background: rgba(255, 255, 255, 0.781) !important;
  -webkit-box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);
          box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-pack: justify !important;
  -webkit-justify-content: space-between !important;
      -ms-flex-pack: justify !important;
          justify-content: space-between !important;
}

.language {
  color: #333 !important;
  float: none !important;
  padding: 0 !important;
}

.switch {
  float: none !important;
  width: 33px;
  margin-left: 5px !important;
  display: block !important;
}

.switch input[type=checkbox] {
  display: none;
}

.switch label {
  height: 100%;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 5px 0 8px 0;
  background: #f7f7f7;
  border: 1px solid #ccc;
  border-radius: 3px;
  -webkit-box-shadow: 0 0 2px rgb(182, 182, 182);
          box-shadow: 0 0 2px rgb(182, 182, 182);
  font-size: 18px;
  text-align: center;
  font-weight: bold;
  line-height: 1;
  cursor: pointer;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

div#builingual div.language select {
  margin: 0 !important;
  margin-left: 5px !important;
}

/* ON */
.switch label span:after {
  content: "OFF";
  font-size: 10px;
  font-weight: 500;
  color: #444444;
}

.switch #cmn-toggle-1:checked + label {
  background-color: #c95a4c;
  -webkit-box-shadow: none;
          box-shadow: none;
}

.switch #cmn-toggle-1:checked + label span:after {
  content: "ON";
  color: #fff;
}

@media screen and (max-width: 834px) {
  #builingual select {
    padding: 4px 2px !important;
  }
}
@media screen and (max-width: 640px) {
  #builingual {
    top: auto;
    bottom: 70px;
    right: 0;
    padding: 5px !important;
    background: rgba(255, 255, 255, 0.9) !important;
  }
}
.translate {
  padding: 0 !important;
}

.eyecatch {
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.pankuzu > pan > ul {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
}
.pankuzu > pan > ul > li {
  font-size: 1.8rem;
}

.breadcrumb__li {
  margin: 0 10px;
}
.breadcrumb__li > a:link, .breadcrumb__li > a:visited {
  color: #393939;
}

.concept__h1 {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.concept__h1 > article {
  color: #393939;
}
.concept__h1 > article > h1 {
  font-size: 3.3rem;
  font-weight: 600;
  letter-spacing: 0.075em;
}
.concept__h1 > article > div {
  font-size: 2.6rem;
}

.concept__h2 > article > h2 {
  font-size: 2.8rem;
  font-weight: 700;
}
.concept__h2-p {
  margin-top: 50px;
  font-size: 1.8rem;
}

.concept__h3 > article {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
      -ms-flex-align: end;
          align-items: flex-end;
}
@media screen and (max-width: 834px) {
  .concept__h3 > article {
    display: block;
  }
}
.concept__h3 > article > h3 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  font-size: 2.4rem;
  font-weight: 700;
  color: #c26f6f;
}
@media screen and (max-width: 834px) {
  .concept__h3 > article > h3 {
    font-size: 2rem;
  }
}
.concept__h3 > article > div {
  display: inline-block;
  text-align: center;
  font-size: 1.8rem;
}
@media screen and (max-width: 834px) {
  .concept__h3 > article > div {
    font-size: 1.6rem;
  }
}

.concept-01__img,
.concept-02__img {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 30px;
  width: calc((100% - 30px) / 2);
}
@media screen and (max-width: 640px) {
  .concept-01__img,
  .concept-02__img {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    width: 100%;
  }
}
.concept-01__img > div,
.concept-02__img > div {
  font-size: 1.8rem;
}

.concept-01__p,
.concept-02__p {
  margin-top: 40px;
  font-size: 1.6rem;
}

.concept-01__flex,
.concept-03__flex {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  gap: 50px;
}
@media screen and (max-width: 1000px) {
  .concept-01__flex,
  .concept-03__flex {
    gap: 30px;
  }
}
@media screen and (max-width: 834px) {
  .concept-01__flex,
  .concept-03__flex {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: normal !important;
    -webkit-flex-direction: column !important;
        -ms-flex-direction: column !important;
            flex-direction: column !important;
    gap: 60px;
  }
}
.concept-01__flex > .box,
.concept-03__flex > .box {
  width: calc((100% - 100px) / 3);
}
@media screen and (max-width: 1000px) {
  .concept-01__flex > .box,
  .concept-03__flex > .box {
    width: calc((100% - 60px) / 3);
  }
}
@media screen and (max-width: 834px) {
  .concept-01__flex > .box,
  .concept-03__flex > .box {
    width: 100%;
    text-align: center;
  }
}
.concept-01__flex > .box > div,
.concept-03__flex > .box > div {
  margin-top: 15px;
  font-size: 1.6rem;
  letter-spacing: 0.05em;
  text-align: justify;
  -moz-text-align-last: left;
       text-align-last: left;
}

.concept-03__flex > .box {
  border: 1px solid #cac8c8;
  border-radius: 10px;
  padding: 15px;
}
.concept-03__flex > .box > div {
  margin-top: 0;
}
.concept-03__flex > .box > div > span {
  display: block;
  font-weight: 700;
}

.concept__h4 .box {
  margin-top: 30px;
  position: relative;
}
.concept__h4 .box > div > h4 {
  font-size: 2rem;
  font-weight: 600;
  margin-left: 70px;
  padding: 15px 0;
}
.concept__h4 .box > div > h4:before {
  content: counter(number) "";
  counter-increment: number 1;
  position: absolute;
  top: -6px;
  left: 23px;
  font-size: 4rem;
}
.concept__h4 .box > div > h4:after {
  position: absolute;
  content: "";
  width: 50px;
  height: 50px;
  top: 0px;
  left: 7px;
  border: 2px solid #3f4d70;
  border-radius: 50%;
}
.concept__h4 .box > div > p {
  font-size: 1.6rem;
  letter-spacing: 0.05rem;
}

.concept__cont {
  margin-right: calc(50% - 50vw);
  margin-left: calc(50% - 50vw);
  font-size: 1.8rem;
  line-height: 2;
}

.concept__btn {
  display: inline-block;
  padding: 10px 45px;
  margin-top: 20px;
  margin-bottom: 15px;
  font-size: 1.8rem;
  letter-spacing: 0.075em;
  border: 1px solid #8d958d;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.concept__btn:link, .concept__btn:visited {
  color: #3f4d70;
}
.concept__btn:hover {
  background-color: #3f4d70;
  color: #fbf9f9;
}

.intro__h1 {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.intro__h1 > article {
  color: #393939;
}
.intro__h1 > article > h1 {
  font-size: 3.3rem;
  font-weight: 600;
  letter-spacing: 0.075em;
}
.intro__h1 > article > div {
  font-size: 2.6rem;
}

.intro__img {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  margin: 0 60px;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 834px) {
  .intro__img {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    margin: 0;
  }
}
.intro__img > img {
  -o-object-fit: cover;
     object-fit: cover;
  width: calc((100% - 30px) * 0.4);
}
@media screen and (max-width: 834px) {
  .intro__img > img {
    width: calc((100% - 30px) * 0.6);
  }
}
@media screen and (max-width: 640px) {
  .intro__img > img {
    width: 100%;
  }
}
.intro__img > div {
  font-size: 2rem;
  margin-top: 30px;
  margin-left: 30px;
  width: calc((100% - 30px) * 0.6);
}
@media screen and (max-width: 1000px) {
  .intro__img > div {
    margin-top: 30px;
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 834px) {
  .intro__img > div {
    margin-left: 0;
    width: 100%;
  }
}
.intro__img div > h2 {
  font-size: 3.2rem;
}
@media screen and (max-width: 1000px) {
  .intro__img div > h2 {
    margin-top: 0;
  }
}
@media screen and (max-width: 834px) {
  .intro__img div > h2 {
    font-size: 2.8rem;
  }
}
.intro__img div > h2 > span {
  font-size: 2.6rem;
}
@media screen and (max-width: 834px) {
  .intro__img div > h2 > span {
    font-size: 2.3rem;
  }
}

.intro__dl > dl {
  margin-top: 20px;
}

.form_wrap.intro__dl > dl > dt {
  font-size: 2rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  border: 1px solid #cccccc;
}

.form_wrap.intro__dl > dl > dd {
  font-size: 1.6rem;
  border: 1px solid #cccccc;
}

.intro__link {
  margin: 0 auto;
}
.intro__link > article > h2 {
  font-size: 2.2rem;
  margin-bottom: 30px;
}
.intro__link > article > div {
  font-size: 1.8rem;
  margin-bottom: 30px;
}

.link__btn {
  display: inline-block;
  padding: 10px 35px;
  margin-top: 20px;
  margin-bottom: 15px;
  font-size: 1.8rem;
  letter-spacing: 0.075em;
  border: 1px solid #8d958d;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.link__btn:link, .link__btn:visited {
  color: #3f4d70;
}
.link__btn:hover {
  background-color: #3f4d70;
  color: #fbf9f9;
}

.sche__h1 {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.sche__h1 > article {
  color: #393939;
}
.sche__h1 > article > h1 {
  font-size: 3.3rem;
  font-weight: 600;
  letter-spacing: 0.075em;
}
.sche__h1 > article > div {
  font-size: 2.6rem;
}

.sche__h2 > article > h2 {
  font-size: 2.8rem;
  font-weight: 700;
  margin: auto;
}
.sche__h2 > article > div {
  margin-top: 20px;
  font-size: 1.8rem;
}

.sche__p {
  font-size: 1.8rem;
}

.sche__tb {
  font-size: 1.6rem;
}

.form_wrap.sche__dl {
  max-width: 900px;
  margin-right: auto !important;
  margin-left: auto !important;
}

.form_wrap.sche__dl > dl {
  border-bottom: 1px solid rgba(63, 77, 112, 0.7803921569);
}
@media screen and (max-width: 640px) {
  .form_wrap.sche__dl > dl {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
    border-bottom: none;
  }
}
.form_wrap.sche__dl > dl:last-child > dt, .form_wrap.sche__dl > dl:last-child > dd {
  border-bottom: none;
}
@media screen and (max-width: 640px) {
  .form_wrap.sche__dl > dl:last-child > dt {
    border-bottom: 1px solid rgba(63, 77, 112, 0.7803921569);
  }
}

.form_wrap.sche__dl > dl > dt {
  font-size: 1.8rem;
  font-weight: 600;
  border: none;
}
@media screen and (max-width: 640px) {
  .form_wrap.sche__dl > dl > dt {
    width: 100% !important;
    margin-top: 5px;
    border-bottom: 1px solid rgba(63, 77, 112, 0.7803921569);
    -webkit-border-image: -webkit-gradient(linear, left top, right top, from(rgba(63, 77, 112, 0.7803921569)), color-stop(60%, rgba(63, 77, 112, 0.7803921569)), color-stop(80%, rgba(255, 255, 255, 0)));
    -webkit-border-image: -webkit-linear-gradient(left, rgba(63, 77, 112, 0.7803921569) 0%, rgba(63, 77, 112, 0.7803921569) 60%, rgba(255, 255, 255, 0) 80%);
         -o-border-image: linear-gradient(to right, rgba(63, 77, 112, 0.7803921569) 0%, rgba(63, 77, 112, 0.7803921569) 60%, rgba(255, 255, 255, 0) 80%);
            border-image: -webkit-gradient(linear, left top, right top, from(rgba(63, 77, 112, 0.7803921569)), color-stop(60%, rgba(63, 77, 112, 0.7803921569)), color-stop(80%, rgba(255, 255, 255, 0)));
            border-image: linear-gradient(to right, rgba(63, 77, 112, 0.7803921569) 0%, rgba(63, 77, 112, 0.7803921569) 60%, rgba(255, 255, 255, 0) 80%);
    border-image-slice: 1;
  }
}

.form_wrap.sche__dl > dl > dd {
  font-size: 1.6rem;
  font-weight: 500;
  border: none;
}
@media screen and (max-width: 640px) {
  .form_wrap.sche__dl > dl > dd {
    width: 100% !important;
  }
}

.sche__ex {
  text-align: center;
}
.sche__ex > ul {
  margin: 0 0 0 auto;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  max-width: 1000px;
}
@media screen and (max-width: 834px) {
  .sche__ex > ul {
    max-width: 700px;
  }
}
.sche__ex > ul > li {
  width: 33.3333333333%;
  font-size: 1.6rem;
  margin-top: 10px;
  margin-bottom: 10px;
}
@media screen and (max-width: 834px) {
  .sche__ex > ul > li {
    width: 50%;
  }
}

.voice__h1 {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.voice__h1 > article {
  color: #393939;
}
.voice__h1 > article > h1 {
  font-size: 3.3rem;
  font-weight: 600;
  letter-spacing: 0.075em;
}
.voice__h1 > article > div {
  font-size: 2.6rem;
}

.voice__inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 20px;
}
@media screen and (max-width: 834px) {
  .voice__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (max-width: 640px) {
  .voice__inner {
    gap: 40px;
  }
}

.voice__flex {
  border-radius: 10px;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: calc((100% - 20px) / 2);
}
@media screen and (max-width: 834px) {
  .voice__flex {
    width: 80%;
    margin-right: auto;
    margin-left: auto;
  }
}
@media screen and (max-width: 640px) {
  .voice__flex {
    width: 100%;
  }
}
.voice__flex > .box:first-child > div {
  margin-bottom: 20px;
  font-size: 2.2rem;
  line-height: 2;
  font-weight: 600;
  color: #3f4d70;
}
.voice__flex > .box:not(first-child) {
  font-size: 1.6rem;
}
.voice__flex > .box:last-child > div {
  padding: 14px;
  font-size: 1.6rem;
  text-align: justify;
  margin-top: 20px;
  background-color: #fbf9f9;
  border-radius: 10px;
}

.faq__h1 {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.faq__h1 > article {
  color: #393939;
}
.faq__h1 > article > h1 {
  font-size: 3.3rem;
  font-weight: 600;
  letter-spacing: 0.075em;
}
.faq__h1 > article > div {
  font-size: 2.6rem;
}

.faq__h2 {
  font-size: 2.8rem;
}
@media screen and (max-width: 834px) {
  .faq__h2 {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 640px) {
  .faq__h2 {
    font-size: 2rem;
  }
}

.faq__link > .box {
  margin-right: 20px;
  margin-top: 20px;
  padding: 20px 40px;
  background-color: #3f4d70;
}
@media screen and (max-width: 834px) {
  .faq__link > .box {
    width: 60%;
    text-align: center;
    margin-right: 0;
    margin: 10px auto;
  }
}
@media screen and (max-width: 640px) {
  .faq__link > .box {
    width: 80%;
  }
}
.faq__link > .box:last-child {
  margin-right: 0;
}
@media screen and (max-width: 834px) {
  .faq__link > .box:last-child {
    width: 60%;
    text-align: center;
    margin-right: 0;
    margin: 10px auto;
  }
}
@media screen and (max-width: 640px) {
  .faq__link > .box:last-child {
    width: 80%;
  }
}
.faq__link > .box > div > a {
  font-size: 2rem;
}
.faq__link > .box > div > a:link, .faq__link > .box > div > a:visited {
  color: #fbf9f9;
}

.faq__flex > .box:first-child {
  background-color: rgba(251, 234, 187, 0.8705882353);
  color: #393939;
  margin-top: 15px;
  padding: 15px 25px 15px 45px;
  position: relative;
}
.faq__flex > .box:not(:first-child) {
  font-size: 1.6rem;
  margin: 10px auto 30px 50px;
}
.faq__flex > .box:first-child > div:before {
  position: absolute;
  content: "Q";
  top: 5px;
  left: 20px;
  font-family: "Roboto", sans-serif;
  font-size: 3rem;
  font-weight: 600;
  color: #3f4d70;
}
.faq__flex > .box:first-child > div {
  font-size: 1.8rem;
  font-weight: 600;
}

.contact__h1 {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.contact__h1 > article {
  color: #393939;
}
.contact__h1 > article > h1 {
  font-size: 3.3rem;
  font-weight: 600;
  letter-spacing: 0.075em;
}
.contact__h1 > article > div {
  font-size: 2.6rem;
}

.contact__inner {
  max-width: 1180px;
  margin: 0 auto;
  padding-left: 40px;
  padding-right: 40px;
}
@media screen and (max-width: 834px) {
  .contact__inner {
    padding-left: 20px;
    padding-right: 20px;
  }
}

section form h2.mail.title {
  display: none;
}

.contact__p > div {
  font-size: 1.6rem;
}

.form_wrap.entry.contact__form > dl > dt {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  font-size: 1.8rem;
}

.translate {
  padding: 150px;
  font-size: 1.6rem;
}

.policy__h1 {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.policy__h1 > article {
  color: #393939;
}
.policy__h1 > article > h1 {
  font-size: 3.3rem;
  font-weight: 600;
  letter-spacing: 0.075em;
}
@media screen and (max-width: 640px) {
  .policy__h1 > article > h1 {
    font-size: 2.6rem;
  }
}
.policy__h1 > article > div {
  font-size: 2.6rem;
}

.policy__inner {
  max-width: 1180px;
  margin: 0 auto;
  padding-left: 40px;
  padding-right: 40px;
}
@media screen and (max-width: 834px) {
  .policy__inner {
    padding-left: 20px;
    padding-right: 20px;
  }
}

.policy__h2 {
  font-size: 2rem;
  font-weight: 600;
  margin-top: 40px;
}
@media screen and (max-width: 640px) {
  .policy__h2 {
    font-size: 1.8rem;
  }
}

.policy__p {
  font-size: 1.6rem;
  margin-top: 10px;
}

.error__h1 {
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
.error__h1 > article {
  color: #393939;
}
.error__h1 > article > h1 {
  font-size: 3.3rem;
  font-weight: 600;
  letter-spacing: 0.075em;
}
.error__h1 > article > div {
  font-size: 2.6rem;
}

.error__inner {
  max-width: 1180px;
  margin: 0 auto;
  padding-left: 40px;
  padding-right: 40px;
}
@media screen and (max-width: 834px) {
  .error__inner {
    padding-left: 20px;
    padding-right: 20px;
  }
}

.error__h2 {
  font-size: 2.6rem;
  letter-spacing: 0.1em;
}

.error__p {
  font-size: 1.6rem;
}

.error__btn {
  text-align: center;
}
.error__btn > a {
  display: inline-block;
  padding: 10px 45px;
  margin-top: 20px;
  margin-bottom: 15px;
  font-size: 1.8rem;
  letter-spacing: 0.075em;
  border: 1px solid #8d958d;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}
.error__btn > a:link, .error__btn > a:visited {
  color: #3f4d70;
}
.error__btn > a:hover {
  background-color: #3f4d70;
  color: #fbf9f9;
}/*# sourceMappingURL=common_style.css.map */