@charset "UTF-8";
/* CSS Document */
/******************************************************************************
パーツ
******************************************************************************/

.p-philosophyBox {
  padding: 3.75em 1.25em 1.875em;
  box-sizing: border-box;
  border-radius: 5px;
  height: 80%;
  overflow-y: scroll;
}
@media screen and (max-width: 1070px) {
  .p-philosophyBox h2 {
    width: 60%;
    margin: 0 auto;
  }
}

/*basicinfo*/
.p-basicinfo_table {
  border-top: none;
  border-bottom: none;
  font-size: 1.125em;
}
@media screen and (max-width: 1070px) {
  .p-basicinfo_table {
    margin-bottom: 0;
  }
  .p-basicinfo_table td:last-child {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    border-bottom: 0;
  }
}
/*テキストアイコン*/
.p-icon_box {
  margin-left: 0.5em;
}
.p-icon_box__item {
  padding: 0.2em 0.5em;
  border: solid 1px;
  border-radius: 5px;
}
.p-icon_box__item:not(:last-child) {
  margin-right: 0.3em;
}
.p-basicinfo_table_big {
  font-size: 1.444em;
}
.p-basicinfo_table_small {
  font-size: 0.778em;
}
.p-basicinfo__item {
  box-sizing: border-box;
}
.p-basicinfo__sns {
  padding-left: 1.25em;
  padding-top: 2.5em;
}
@media screen and (max-width: 1070px) and (min-width: 768px) {
  .p-basicinfo__item {
    width: 100% !important;
    display: flex;
    align-items: center;
    border-right: solid 1px #ccc;
  }
  .p-basicinfo_table {
    width: 100% !important;
    border-top: solid 1px #ccc;
  }
  .p-basicinfo__sns {
    padding-top: 0;
  }
  .p-philosophyBox {
    font-size: 90%;
  }
}
.p-basicinfo_sns-line {
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .p-basicinfo__item {
    width: 100% !important;
    border-right: solid 1px #ccc;
    border-top: solid 1px #ccc;
  }
  .p-basicinfo_table {
    width: 100% !important;
    border-top: solid 1px #ccc;
    font-size: 90%;
  }

  .p-basicinfo__sns {
    position: relative;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: space-around;
    flex-wrap: wrap;
  }
  .p-basicinfo_sns-line {
    width: 100%;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
  }

  .o-sns-item {
    margin-bottom: 0.625em;
  }
}
/*care*/
.p-care__item {
  width: 25%;
}
@media screen and (max-width: 1070px) and (min-width: 480px) {
  .p-care__item {
    width: 30%;
  }
}
@media screen and (max-width: 767px) {
  .p-care__item {
    width: 48%;
    padding-bottom: 1.5em;
  }
}
/*アレンジ*/
.p-imgBox__item img {
  width: 100%;
}

/*expenses*/
.p-expenses__table {
  border: solid 1px #ccc;
}
.p-admissionFee_block {
  width: 16%;
}
.p-monthlyFee_block {
  width: 84%;
}
.p-monthlyFee__total {
  width: 90%;
}
.p-monthlyFee__breakdown {
  width: 10%;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}
.p-monthlyFee__definitionTtl {
  width: 30%;
}
.p-monthlyFee__price {
  width: 70%;
}

/*qa*/
.p-qa__box {
  padding: 1.875em;
}
.p-qa__ttl {
  display: flex;
  align-items: center;
  font-size: 1.25em;
  padding-bottom: 0.25em;
}
.p-qa__ttlimg {
  padding-right: 1em;
  display: block;
}
.p-qa__quwstion {
  padding-left: 1.875em;
  margin-bottom: 1.25em;
  background-image: url("../images/question.png");
  background-repeat: no-repeat;
  background-size: 1em auto;
  background-position: left center;
}
.p-qa__answer {
  padding-left: 1.875em;
  background-image: url("../images/answer.png");
  background-repeat: no-repeat;
  background-size: 1em auto;
  background-position: left top 0.4em;
}
/*access*/
.p-access__wrap {
  background-image: url("../images/access_bg.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: top center;
  padding-top: 5em;
  padding-bottom: 9.375em;
  margin-bottom: 9.375em;
}
.p-addressBox__tel {
  font-size: 1.125em; /*18*/
  line-height: 1.333;
}
.p-addressBox__tel .small {
  font-size: 0.778em; /*14*/
}
.p-access__block {
  padding: 2.188em 2.5em;
  box-sizing: border-box;
  border-radius: 5px;
}
.p-access__route_box {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.p-access__route_item {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3",
    "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-weight: 500;
  line-height: 1.667;
  text-align: right;
}
.p-access__route_item:nth-child(odd) {
  margin-right: 5em;
}
.p-access__wrap .p-access__route_list {
  padding-bottom: 8.125em;
}
.p-access__ttl {
  margin-bottom: 0.5em;
}
@media screen and (max-width: 1070px) {
  .p-access__wrap {
    padding-bottom: 3em;
    margin-bottom: 3em;
  }
  .p-access__block {
    padding: 2em 0.5em;
    box-sizing: border-box;
    border-radius: 5px;
  }
  .p-access__ttl {
    margin-bottom: 1em;
    font-size: 1.5em;
    text-align: center;
  }
  .p-access__wrap .p-access__route_list {
    padding-bottom: 4em;
  }
  .p-access__route_item:nth-child(odd) {
    margin-right: 0;
  }
  .p-access__route_box {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    flex-direction: column;
  }
}

@media screen and (max-width: 375px) {
  .p-access__route_box {
    font-size: 85%;
  }
}

/*medicalCare*/
.p-medicalCare {
  margin-bottom: 9.375em;
}
.p-note__item {
  line-height: 1;
  font-size: 1.125em;
  font-weight: 700;
  display: flex;
  align-items: center;
}
.p-note__icon {
  margin-right: 0.5em;
}
.p-note__item:not(:last-child) {
  margin-right: 2em;
}
@media screen and (max-width: 1070px) {
  .p-medicalCare {
    margin-bottom: 4em;
  }
}
@media screen and (max-width: 375px) {
  .p-access__route_box {
    font-size: 85%;
  }
  .p-medicalCare {
    margin-bottom: 3em;
  }
}
.p-note__item:not(:last-child) {
  margin-right: 0.5em;
}
.p-yesNo_item {
  width: 18%;
}
.p-yesNo_icon {
  border: solid 1px #ccc;
  border-radius: 30px;
  padding: 0.5em;
  font-weight: 600;
  display: flex;
  align-items: center;
  position: relative;
  margin-bottom: 1.25em;
}
.p-yesNo_icon::after {
  display: inline-block;
  content: "";
  background-repeat: no-repeat;
  background-size: 55% 55%;
  background-position: center;
  background-color: #ccc;
  width: 1.818em;
  height: 1.818em;
  border-radius: 50%;
  text-align: center;
  line-height: 1.818em;
  position: absolute;
  right: 0.3em;
}
.p-yesNo_icon__circle::after {
  background-image: url("../images/circle.png");
}
.p-yesNo_icon__triangle::after {
  background-image: url("../images/triangle.png");
}
.p-yesNo_icon__building::after {
  background-image: url("../images/building.png");
}
@media screen and (max-width: 1070px) {
  .p-yesNo_item {
    width: 33%;
  }
}
@media screen and (max-width: 768px) {
  .p-yesNo_item {
    width: 48%;
  }
  @media screen and (max-width: 375px) {
    .p-yesNo_list {
      font-size: 85%;
    }
  }
}

/*contact*/
.p-contactInfo {
  width: 42.86%;
}
@media screen and (max-width: 1070px) {
  .p-contactInfo {
    width: 100%;
  }
}
@media screen and (max-width: 789px) {
  .p-contactInfo {
    width: 100%;
  }
}
.qr {
  margin-bottom: 0.5em;
}
.qr a {
  display: block;
}
/*CV*/
.cv {
  position: fixed;
}
.p-L_area_wrap {
  position: fixed;
  overflow-y: scroll;
}
.p-L_area {
  position: fixed;
  z-index: 100000;
  bottom: 0;
  right: 0;
  verflow: scroll;
  max-height: 75%;
  overflow-y: scroll;
}
.p-L_area .inner {
  border: solid 1px #ea3e0a;
  border-radius: 20px 20px 0 0;
}
.p-L_area_body {
  background: #f99a00;
  padding: 0.5em 0 1em;
}
.p-L_area_head {
  background: #f97300;
  padding: 1em 0.3em;
  border: solid 1px #ea3e0a;
  display: flex;
  padding-bottom: 0.5em;
  border-radius: 20px 20px 0 0;
}
.p-L_area_btn {
  background: #fff;
  border-radius: 30px;
  padding: 0.5em;
  width: 85%;
  margin: 0 auto 0.5em;
}
.small {
  font-size: 50%;
  display: block;
}
.L-tel {
  line-height: 1.4;
  margin-bottom: 0.5em;
}

.p-M_area {
  position: fixed;
  z-index: 999;
  bottom: 0;
  right: 0;
  background-image: url("../images/cv/cv_bg.png");
  background-repeat: repeat;
  border-radius: 20px 20px 0 0;
  padding: 1em 0.3em;
  text-align: center;
}

.p-L_area {
  z-index: 999;
}
.p-M_area .batu {
  width: 1em;
  height: 1em;
  line-height: 1em;
  text-align: center;
  background: #ea3e0a;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  z-index: 1000;
  right: 0.8em;
  top: 1em;
}
.p-L_area .batu {
  width: 1em;
  height: 1em;
  line-height: 1em;
  text-align: center;
  border: solid 2px #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  z-index: 1000;
  right: 0.8em;
  top: 1em;
}
.p-L_area_ttl {
  width: 85%;
  margin: 0 auto 1em;
  border-bottom: solid 1px #000;
}
.p-L_area_ttl01 {
  margin: 0 auto 0.5em;
}
.p-S_area {
  position: fixed;
  bottom: 0;
  right: 0;
}
.maill_btn {
  width: 70%;
  margin: 0 auto;
  border: solid 1px #fff;
  font-weight: 600;
  background-color: #f86900;
}
.maill_btn a {
  color: #fff;
  display: block;
}
#visitTrial {
  margin-bottom: 3em;
}
@media screen and (max-width: 1070px) and (min-width: 768px) {
  .p-L_area {
    height: 60%;
  }
}
@media screen and (max-width: 768px) {
  #visitTrial {
    margin-bottom: 1.5em;
  }

  .p_maillmbox {
    padding-bottom: 2.5em;
  }
  .p-L_area_btn img {
    width: 60%;
  }
  .p-L_area .batu {
    padding: 0.2em;
  }
  .p-M_area .batu {
    padding: 0.2em;
  }
  .maill_btn a {
    color: #fff;
    display: block;
    padding: 0.8em;
    box-sizing: border-box;
  }
}
@media screen and (max-width: 480px) {
  .p-L_area,
  .p-M_area,
  .p-S_area {
    width: 70%;
  }
}
.p-gmap {
  display: flex;
  width: 100%;
  justify-content: space-between;
}
.p-table_5 th,
.p-table_5 td {
  width: 20%;
  border-right: 1px solid #ccc;
}
@media screen and (max-width: 767px) {
  .p-table_5 th,
  .p-table_5 td {
    width: 100%;
    border-right: none;
  }
}
.p-expenses_table_ttl {
  text-align: center;
}
@media screen and (max-width: 1070px) {
  .p-expenses_table {
    text-align: center;
  }
  .p-expenses_table th {
    background-color: #ccc;
  }
  .p-expenses_table td {
    border-right: none;
  }
  .breakdown {
    background: #999;
  }
  .table_spnone {
    display: none !important;
  }
  .p-expenses_table_ttl {
    text-align: center;
  }
  .p-expenses_table_ttl:before {
    content: attr(data-label);
    display: block;
    font-weight: bold;
    padding: 0.667em;
    background-color: #f0f0f0;
    margin-bottom: 1em;
    text-align: left;
    border-bottom: solid 1px #ccc;
    border-top: solid 1px #ccc;
  }
  .p-expenses_table_ttlinner {
    padding: 0.625em; /*10*/
  }
}
@media screen and (max-width: 1070px) {
  .tel {
    width: 80%;
    margin: 0 auto;
  }
}
.tel a {
  display: block;
}

@media screen and (max-width: 1070px) {
  .friend a {
    display: block;
  }
  .friend a img {
    width: 100%;
    height: auto !important;
  }
  .friend {
    width: 30%;
  }
}
