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

/*==================================================================

	box

==================================================================*/

.box01 {
  position: relative;
  min-width: 128rem;
  max-width: 160rem;
  margin: 0 auto 20rem;
  padding: 0 10rem;
  box-sizing: border-box;
}

.box02 {
  position: relative;
  width: 100%;
  margin: 0 auto 18rem;
}

.box03 {
  position: relative;
  min-width: 128rem;
  max-width: 140rem;
  margin: 0 auto 20rem;
  padding: 0 4rem;
  box-sizing: border-box;
}

.box04 {
  position: relative;
  width: 800px;
  margin: 0 auto 20rem;
}

.text01 {
  position: relative;
  margin-bottom: 10rem;
}

.text01 p {
  margin-bottom: 2rem;
}

.text01:last-child {
  margin-bottom: 0;
}

/*==================================================================

	タイトル

==================================================================*/

.h3_tit01 {
  position: relative;
  margin-bottom: 5.45rem;
  margin-left: -0.2rem;
  letter-spacing: 0.13em;
  line-height: 1.5;
  font-size: 1.3rem;
  font-weight: bold;
  z-index: 5;
}

.h3_tit01_ja {
  display: block;
  margin-top: 1.2rem;
  position: relative;
  color: #333839;
  font-size: 3.4rem;
  letter-spacing: 0.05em;
}

/* 飾りの英語 */

.h3_tit01_en {
  position: relative;
  padding-left: 6.0rem;
  color: #41A884;
  font-size: 1.2rem;
  font-family: "brandon-grotesque", sans-serif;
  font-weight: 500;
  letter-spacing: 0.07em;
}

.h3_tit01_en::before {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  width: 5.2rem;
  height: 1px;
  margin: auto;
  background-color: #41A884;
  content: "";
}

.h3_tit01_sub {
  display: flex;
  justify-content: flex-start;
  margin-bottom: 1.8rem;
  color: #41A884;
}

.h3_tit01_sub_ja {
  position: relative;
  margin-right: 2.45rem;
  padding-right: 1.8rem;
  font-size: 1.5rem;
  font-weight: bold;
  letter-spacing: 0.05em;
}

.h3_tit01_sub_ja:before {
  position: absolute;
  top: -1.4rem;
  bottom: 0;
  right: 0;
  width: 1px;
  height: 16px;
  margin: auto;
  transform: rotate(8deg);
  content: "/";
}

.h3_tit01_sub_en {
  font-family: 'Montserrat', sans-serif;
  font-size: 1.55rem;
  font-weight: 600;
  letter-spacing: 0.1em;
}

.h3_tit01_min {
  margin-bottom: 1.3rem;
}

.h3_tit01_en_min {
  display: block;
  margin-bottom: 0.2rem;
  color: #41A884;
  font-size: 1.3rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  letter-spacing: 0.128rem;
}

.h3_tit01_en_number {
  padding-right: 0.3rem;
}

.h3_tit01_ja_min {
  font-size: 2.4rem;
  font-weight: bold;
}

/* 下層ページ用 */

.h3_tit02 {
  position: relative;
  margin-bottom: 5rem;
  padding-top: 4.8rem;
  letter-spacing: 0.05em;
  font-size: 3.4rem;
  font-weight: bold;
  line-height: 1.5;
  text-align: left;
}

.h3_tit02::before {
  position: absolute;
  top: 0;
  left: 0.4rem;
  width: 10rem;
  height: 1px;
  background-color: #41A884;
  content: "";
}

/* アイコンの余白 */

.h3_tit02 i {
  margin-right: 7px;
}

/* 飾りの英語 */

.h3_tit02_en {
  display: inline-block;
  position: relative;
  color: #C0AB9A;
  font-size: 14px;
  font-family: "Times New Roman", Times, serif;
  font-weight: 400;
  z-index: 2;
}

/* 下層ページ用 */

.h3_tit03 {
  display: flex;
  justify-content: flex-start;
  position: relative;
  margin-bottom: 4rem;
}

.h3_tit03_ja {
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.05em;
  ;
  text-align: left;
}

.h3_tit03_en {
  padding-left: 2.2rem;
  color: #41A884;
  font-size: 1.2rem;
  line-height: 3;
  font-family: "brandon-grotesque", sans-serif;
  font-weight: 500;
}

.h3_tit04 {
  display: inline-block;
  line-height: 1.5;
  font-weight: bold;
  letter-spacing: 0.05em;
  border-bottom: 1px solid rgba(106, 97, 89, 0.15);
  font-size: 4.45rem;
  padding-bottom: 1rem;
  margin-bottom: 7rem;
}

.h3_tit04_s {
  font-weight: 500;
  font-size: 1.5rem;
  display: block;
}

.h3_tit04_s2 {
  font-size: 1.8rem;
  letter-spacing: 0.02em;
  display: block;
  color: #BB92D1;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 400;
}

.h3_tit04_s3 {
  font-weight: 500;
  font-size: 1.5rem;
}

.h3_tit04_s4 {
  font-weight: 500;
  font-size: 1.9rem;
}

.h3_tit04 em {
  color: #BB92D1;
}

.h3_tit05 {
  position: relative;
  margin-bottom: 4.5rem;
  font-size: 3.07rem;
  line-height: 1.5;
  font-weight: bold;
}

.h3_tit06 {
  display: inline-block;
  line-height: 1.5;
  font-weight: bold;
  letter-spacing: 0.05em;
  font-size: 3.07rem;
  margin-bottom: 2rem;
}

.h3_tit07 {
  text-align: center;
  margin-bottom: 7.5rem;
}

.h3_tit07_s {
  font-size: 1.7rem;
  font-weight: bold;
  display: block;
  padding-bottom: 0.1rem;
}

.h3_tit07_ja {
  padding-bottom: 1.4rem;
  font-size: 3.4rem;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.05em;
  border-bottom: 1px solid rgba(106, 97, 89, 0.15);
}

.h4_tit01 {
  position: relative;
  margin-bottom: 3.0rem;
  font-size: 2.75rem;
  letter-spacing: 0.05em;
  line-height: 1.5;
  font-weight: bold;
}

.h4_tit01_en {
  display: block;
  font-size: 1.8rem;
  letter-spacing: 0.02em;
  color: #BB92D1;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 400;
}

.h4_tit01_sub {
  display: block;
  font-size: 1.3rem;
  font-weight: 500;
}

.h4_tit01_s {
  display: block;
  font-size: 1.4rem;
  color: #B7A58D;
  padding-bottom: 1rem;
}

.h4_tit01_s-en {
  display: block;
  font-size: 1.6rem;
  color: #B7A58D;
  font-family: "brandon-grotesque", sans-serif;
  font-weight: 500;
}

.h4_tit01_s em {
  font-family: brandon-grotesque, sans-serif;
  font-size: 1.6rem;
  margin-left: 0.5rem;
  font-weight: 500;
}

.h4_tit02 {
  position: relative;
  margin-bottom: 6.3rem;
  font-size: 2.4rem;
  letter-spacing: 0.05em;
  line-height: 1.7;
  font-weight: bold;
}

.h4_tit03 {
  position: relative;
  margin-bottom: 0;
  font-size: 2.1rem;
  letter-spacing: 0.05em;
  line-height: 1.7;
  font-weight: bold;
}

.h5_tit01 {
  position: relative;
  margin-bottom: 3.0rem;
  font-size: 2.4rem;
  letter-spacing: 0.05em;
  line-height: 1.4;
  font-weight: bold;
}

.h5_tit01_en {
  padding-right: 1rem;
  font-size: 3rem;
  font-family: kiro, sans-serif;
  font-weight: 400;
  font-style: normal;
}

.h6_tit01 {
  font-size: 2.0rem;
  font-weight: bold;
  margin-bottom: 0.8rem;
}

.h6_tit01_en {
  padding-right: 0.6rem;
  font-size: 2.4rem;
  font-family: kiro, sans-serif;
  font-weight: 400;
  font-style: normal;
}

/*==================================================================

	共通

==================================================================*/

/*院長略歴*/

.list01 {
  margin: 0 0 15px;
  padding: 0;
  border-width: 0 1px 1px;
}

.list01 dt {
  margin: 0;
  padding: 14px 3px 0px;
}

.list01 dd {
  margin: -38px 0 0;
  padding: 12px 4px 10px 100px;
  border-bottom: 1px dotted #ACACAC;
}

/*院長略歴　年月無し*/

.list02 {
  margin: 0 0 15px;
  border-width: 0 1px 1px;
}

.list02 li {
  margin: 0 0px 0px;
  padding: 6px 4px 6px 0;
  border-bottom: 1px dotted #ddd;
}

/*まる*/

.list03 {
  margin-top: 3.2rem;
}

.list03 li {
  position: relative;
  margin-bottom: 1rem;
  padding-left: 15px;
  letter-spacing: 0.03em;
}

.list03 li:last-child {
  margin-bottom: 0;
}

.list03 li:before {
  display: block;
  position: absolute;
  top: 1rem;
  left: -0.2rem;
  width: 0.7rem;
  height: 0.7rem;
  background-color: rgba(106, 97, 89, 0.2);
  content: '';
}

.list03 li i {
  margin-right: 8px;
}

/*さんかく*/

.list04 li {
  position: relative;
  margin-bottom: 15px;
  padding-left: 22px;
  color: #223a70;
}

.list04 li:before {
  position: absolute;
  top: 0.5em;
  left: 7px;
  width: 0;
  height: 0;
  border: 5px solid transparent;
  border-left: 5px solid #4A577F;
  content: "";
}

/*やじるし*/

.list05 li {
  position: relative;
  margin-bottom: 10px;
  line-height: 1;
  padding-left: 15px;
}

.list05 li:before {
  position: absolute;
  left: 0;
  top: 0.3em;
  height: 5px;
  width: 5px;
  transform: rotate(45deg);
  background-color: transparent;
  border-top: 1px solid #333;
  border-right: 1px solid #333;
  content: "";
}

/* まる & 背景 */

.list06 {
  padding: 35px 15px 25px 45px;
  background-color: #f7f7f7;
}

.list06:after {
  display: block;
  clear: both;
  content: "";
}

.list06 li {
  position: relative;
  float: left;
  margin-bottom: 15px;
  padding-left: 0.9em;
  padding-right: 5%;
}

.list06 li:before {
  display: block;
  content: '';
  position: absolute;
  top: 10px;
  left: 0;
  width: 3px;
  height: 3px;
  background-color: #DAC58B;
  border: 1px solid #DAC58B;
  border-radius: 100%;
}

/*まる & 枠 */

.list07 {
  border: 3px solid #eee;
  padding: 30px;
  font-size: 14.5px;
}

.list07 li {
  padding-left: 0.9em;
  margin-bottom: 10px;
  position: relative;
}

.list07 li:last-child {
  margin-bottom: 0;
}

.list07 li:before {
  display: block;
  content: '';
  position: absolute;
  top: 10px;
  left: 0;
  width: 3px;
  height: 3px;
  background-color: #E0D0BF;
  border: 1px solid #E0D0BF;
  border-radius: 100%;
}

.list07 li i {
  margin-right: 8px;
}

/*チェック*/

.list08 {
  margin-bottom: 30px;
  padding: 8rem 7rem 5rem;
  border: 1px solid rgba(106, 97, 89, 0.4);
  border-radius: 1rem;
}

.list08 li {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  margin-right: 5%;
  padding-left: 3rem;
  margin-bottom: 2rem;
  line-height: 1.5;
}

.list08 li:before {
  position: absolute;
  top: 0.4rem;
  left: 0;
  content: "";
  width: 1.8rem;
  height: 1.3rem;
  background-image: url(../images/check01.svg);
  background-size: 1.8rem 1.3rem;
}

.list10 {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  margin-top: 6rem;
  padding: 8rem 7rem 5rem;
  border: 1px solid rgba(106, 97, 89, 0.2);
  border-radius: 1rem;
  text-align: center;
}

.list10_title {
  position: absolute;
  left: 6.3rem;
  margin: auto;
  width: -moz-fit-content;
  display: inline-block;
  top: -3px;
  padding: 0 40px 22px;
  text-align: center;
  line-height: 1.5;
  background-color: #FAF8F5;
  background-image: url(../images/list10_title_l.html), url(../images/list10_title_r.html);
  background-size: 27px 46px;
  background-repeat: no-repeat;
  background-position: left, right;
  height: 46px;
  box-sizing: border-box;
}

.list10_title::before {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: calc(100% - 54px);
  height: 1px;
  background-color: rgba(106, 97, 89, 0.4);
  content: "";
}

.list10_title::before {}

.list10_title::after {}

.list10_title_ja {
  display: block;
  margin-top: -1.4rem;
  font-size: 1.9rem;
  font-weight: bold;
}

.list10_title_en {
  display: block;
  font-size: 1.1rem;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 300;
  opacity: 0.8;
  line-height: 1;
}

.list10 dd {
  position: relative;
  text-align: left;
  width: calc(50% - 2rem);
  box-sizing: border-box;
  padding-left: 3rem;
  line-height: 1.5;
  margin-bottom: 2rem;
  font-size: 1.5rem;
}

.list10 dd:nth-child(even) {
  padding-right: 3rem;
}

.list10 dd:nth-child(odd) {
  margin-left: 3rem;
}

.list10 dd::before {
  position: absolute;
  top: 0.4rem;
  left: 0;
  content: "";
  width: 1.8rem;
  height: 1.3rem;
  background-image: url(../images/check01.svg);
  background-size: 1.8rem 1.3rem;
}

.list11 {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  margin-top: 6rem;
  padding: 8rem 7rem 5rem;
  border: 1px solid rgba(106, 97, 89, 0.4);
  border-radius: 1rem;
  text-align: center;
}

.list11_title {
  position: absolute;
  left: 6.3rem;
  margin: auto;
  width: -moz-fit-content;
  display: inline-block;
  top: -3px;
  padding: 0 40px 22px;
  text-align: center;
  line-height: 1.5;
  background-color: #FAF8F5;
  background-image: url(../images/list10_title_l.html), url(../images/list10_title_r.html);
  background-size: 27px 46px;
  background-repeat: no-repeat;
  background-position: left, right;
  height: 46px;
  box-sizing: border-box;
}

.list11_title::before {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: calc(100% - 54px);
  height: 1px;
  background-color: rgba(106, 97, 89, 0.4);
  content: "";
}

.list11_title::before {}

.list11_title::after {}

.list11_title_ja {
  display: block;
  margin-top: -1.4rem;
  font-size: 1.9rem;
  font-weight: bold;
}

.list11_title_en {
  display: block;
  font-size: 1.1rem;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 300;
  opacity: 0.8;
  line-height: 1;
}

.list11 dd {
  position: relative;
  text-align: left;
  width: calc(50% - 2rem);
  box-sizing: border-box;
  padding-left: 2rem;
  line-height: 1.5;
  margin-bottom: 2rem;
  font-size: 1.5rem;
}

.list11 dd:nth-child(even) {
  padding-right: 2rem;
}

.list11 dd:nth-child(odd) {
  margin-left: 2rem;
}

.list11 dd::before {
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
  content: "";
  width: 0.6rem;
  height: 0.6rem;
  background-color: rgba(106, 97, 89, 0.4);
  border-radius: 100%;
}

.list12 {
  display: flex;
  flex-wrap: wrap;
  position: relative;
  margin-top: 6rem;
  padding: 8rem 7rem 5rem;
  border: 1px solid rgba(106, 97, 89, 0.4);
  border-radius: 1rem;
  text-align: center;
}

.list12_title {
  position: absolute;
  left: 6.3rem;
  margin: auto;
  width: -moz-fit-content;
  display: inline-block;
  top: -3px;
  padding: 0 40px 22px;
  text-align: center;
  line-height: 1.5;
  background-color: #FAF8F5;
  background-image: url(../images/list10_title_l.html), url(../images/list10_title_r.html);
  background-size: 27px 46px;
  background-repeat: no-repeat;
  background-position: left, right;
  height: 46px;
  box-sizing: border-box;
}

.list12_title::before {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: calc(100% - 54px);
  height: 1px;
  background-color: rgba(106, 97, 89, 0.4);
  content: "";
}

.list12_title_ja {
  display: block;
  margin-top: -1.4rem;
  font-size: 1.9rem;
  font-weight: bold;
}

.list12_title_en {
  display: block;
  font-size: 1.1rem;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 300;
  opacity: 0.8;
  line-height: 1;
}

.list12 div {
  width: calc(50% - 2rem);
}

.list12 dd {
  display: flex;
  position: relative;
  text-align: left;
  box-sizing: border-box;
  line-height: 1.5;
  margin-bottom: 2rem;
  font-size: 1.5rem;
}

.list12 div:nth-child(odd) {
  margin-left: 4rem;
}

.list12 dd span {
  display: block;
}

.list12 dd span:first-child {
  width: 5em;
}

.list13 {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  margin-bottom: -3.2rem;
}

.list13 li {
  position: relative;
  width: calc((100% - 3rem) / 3);
  margin-right: 1.5rem;
  font-weight: bold;
  padding: 4rem;
  border: 1px solid rgba(106, 97, 89, .25);
  box-sizing: border-box;
  letter-spacing: 0.03em;
  line-height: 1.5;
  margin-bottom: 3.2rem;
}

.list13 li:nth-child(3n) {
  margin-right: 0;
}

.list13 li::before {
  position: absolute;
  top: -0.8rem;
  left: 4rem;
  width: 2rem;
  height: 1.5rem;
  background-image: url(../images/quotation01.svg);
  background-size: cover;
  content: "";
}

.list14 {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  margin-top: 4rem;
}

.list14 li {
  position: relative;
  width: calc((100% - 3rem) / 3);
  margin-right: 1.5rem;
  padding: 3.2rem;
  border: 1px solid rgba(106, 97, 89, .25);
  box-sizing: border-box;
  margin-bottom: 3.2rem;
}

.list14 li:nth-child(3n) {
  margin-right: 0;
}

.list14_title {
  margin-bottom: 0.8rem;
  font-weight: bold;
  letter-spacing: 0.0em;
  line-height: 1.5;
}

.list14_text {
  font-size: 1.5rem;
  line-height: 1.5;
}

.list14 li::before {
  position: absolute;
  top: -1.2rem;
  left: 3.2rem;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 300;
  font-size: 2.4rem;
  letter-spacing: 0.03em;
  text-shadow: 2px 2px 0 #FAF8F5, -2px -2px 0 #FAF8F5, -2px 2px 0 #FAF8F5, 1px -2px 0 #FAF8F5, 0px 2px 0 #FAF8F5, 0-2px 0 #FAF8F5, -2px 0 0 #FAF8F5, 2px 0 0 #FAF8F5;
  line-height: 1;
  content: "";
}

.list14 li:nth-child(1)::before {
  content: "01.";
}

.list14 li:nth-child(2)::before {
  content: "02.";
}

.list14 li:nth-child(3)::before {
  content: "03.";
}

.list14 li:nth-child(4)::before {
  content: "04.";
}

.list14 li:nth-child(5)::before {
  content: "05.";
}

.list14 li:nth-child(6)::before {
  content: "06.";
}

.list14 li:nth-child(7)::before {
  content: "07.";
}

.list14 li:nth-child(8)::before {
  content: "08.";
}

.list14 li:nth-child(9)::before {
  content: "09.";
}

.list15 {
  display: flex;
  flex-wrap: wrap;
  margin-top: 3.2rem;
}

.list15 dt {
  width: 10rem;
  box-sizing: border-box;
}

.list15 dd {
  width: calc(100% - 10rem);
  box-sizing: border-box;
  padding-left: 0.7rem;
  margin-bottom: 1.6rem;
}

.list15 li {
  width: 100%;
  margin-bottom: 1.1rem;
  letter-spacing: 0.05em;
}

.list15_title_ja {
  display: block;
  margin-top: -1.4rem;
  font-size: 2.1rem;
  font-weight: bold;
  margin-bottom: 0.2rem;
}

.list15_title_en {
  display: block;
  font-size: 1.5rem;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 400;
  opacity: 0.5;
  line-height: 1;
}

.list16 {
  display: flex;
  justify-content: flex-start;
  margin-top: 1.2rem;
  margin-bottom: 2.5rem;
}

.list16 li {
  position: relative;
  margin-bottom: 1rem;
  margin-right: 5.4rem;
  padding-left: 1.5rem;
  letter-spacing: 0.03em;
}

.list16 li:last-child {}

.list16 li:before {
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: -0.2rem;
  width: 0.7rem;
  height: 0.7rem;
  margin: auto;
  background-color: #DFD9D3;
  content: '';
}

.list16 li i {
  margin-right: 8px;
}

/*ボタン ゴースト*/

.btn01 {
  position: relative;
}

.btn01 a {
  display: inline-block;
  position: relative;
  padding: 0;
  text-align: center;
  color: rgba(65, 168, 132, 1);
  font-weight: bold;
  letter-spacing: 0.03em;
  line-height: 1.7;
}

.btn01_border {
  position: relative;
}

.btn01_border::before, .btn01_border::after {
  position: absolute;
  left: 0;
  bottom: 0;
  content: "";
  width: 100%;
  height: 1px;
  background-color: rgba(65, 168, 132, 0.5);
}

.btn01_arrow {
  position: absolute;
  /* width: 2.0rem; */
  height: 1px;
  background-color: rgba(65, 168, 132, 1);
  transform: scale(0, 1) translate(0, 0);
  transform-origin: right;
  top: 0;
  bottom: 0;
  right: -2.0rem;
  margin: auto;
  margin-left: 0;
  pointer-events: none;
}

.btn01_arrow::after {
  transform: rotate(45deg) translate(0, 0) scale(0, 1);
}

.btn01_arrow::before {
  transform: rotate(-45deg) translate(0, 0) scale(0, 1);
}

.btn01_arrow::after, .btn01_arrow::before {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  height: 1px;
  margin: auto;
  width: 0.8rem;
  content: "";
  background-color: rgba(65, 168, 132, 1);
  transform-origin: right;
}

.btn01_arrow::before, .btn01_arrow::after, .btn01_arrow {
  transition-timing-function: cubic-bezier(.165, .84, .44, 1);
  transition-duration: 0.2s;
  transition-delay: 0.1s;
}

.btn01 a:hover .btn01_arrow {
  background-size: 100% 100%;
  transform: scale(1, 1) translate(0, 0);
}

.btn01 a:hover .btn01_arrow::after {
  background-size: 100% 100%;
  transform: rotate(45deg) translate(-0, 0) scale(1, 1);
}

.btn01 a:hover .btn01_arrow::before {
  background-size: 100% 100%;
  transform: rotate(-45deg) translate(-0, 0) scale(1, 1);
}

.btn01 a:hover .btn01_arrow {
  background-size: 100% 100%;
}

.btn01 a::before {
  transition: .16s cubic-bezier(.166, .74, .49, 1);
}

.btn01 a::before, .btn01 a::after {
  right: -7.2rem;
  width: 10.5rem;
  height: 10.5rem;
  border-radius: 100%;
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
}

.btn01 a::before {
  background-color: rgba(65, 168, 132, 0.15);
}

.btn01 a::after {}

.btn01 a:hover .btn01_border::before {
  animation-name: btn01_border_01;
  animation-duration: .36s;
  animation-timing-function: cubic-bezier(.166, .74, .49, 1);
  animation-iteration-count: 1;
  animation-fill-mode: both;
}

@keyframes btn01_border_01 {
  from {
    width: 100%;
  }
  100% {
    width: 0%;
    left: 100%;
  }
}

.btn01 a:hover .btn01_border::after {
  animation-name: btn01_border_02;
  animation-duration: .36s;
  animation-timing-function: cubic-bezier(.166, .74, .49, 1);
  animation-iteration-count: 1;
  animation-fill-mode: both;
  animation-delay: .26s;
}

@keyframes btn01_border_02 {
  from {
    width: 0;
    left: 0;
  }
  100% {
    width: 100%;
    left: 0;
  }
}

.btn01 a:hover .btn01_border {
  color: rgba(65, 168, 132, 1);
}

.btn01 a:hover::before {
  transform: scale(0, 0);
}

.btn01_default {
  position: relative;
  top: 0;
  left: 0;
  white-space: nowrap;
}

.btn01_default span {
  display: inline-block;
  position: relative;
  top: 0;
}

.btn01 a:hover .btn01_default span {
  animation-name: btn01_default;
  animation-duration: .25s;
  animation-timing-function: cubic-bezier(.166, .74, .49, 1);
  animation-iteration-count: 1;
  animation-fill-mode: both;
}

.btn01 a:hover .btn01_default span:nth-child(1) {
  animation-delay: 0s;
}

.btn01 a:hover .btn01_default span:nth-child(2) {
  animation-delay: 0.02s;
}

.btn01 a:hover .btn01_default span:nth-child(3) {
  animation-delay: 0.04s;
}

.btn01 a:hover .btn01_default span:nth-child(4) {
  animation-delay: 0.06s;
}

.btn01 a:hover .btn01_default span:nth-child(5) {
  animation-delay: 0.08s;
}

.btn01 a:hover .btn01_default span:nth-child(6) {
  animation-delay: 0.1s;
}

.btn01 a:hover .btn01_default span:nth-child(7) {
  animation-delay: 0.12s;
}

.btn01 a:hover .btn01_default span:nth-child(8) {
  animation-delay: 0.14s;
}

.btn01 a:hover .btn01_default span:nth-child(9) {
  animation-delay: 0.16s;
}

.btn01 a:hover .btn01_default span:nth-child(10) {
  animation-delay: 0.18s;
}

@keyframes btn01_default {
  from {}
  20% {
    opacity: 1;
  }
  100% {
    transform: translateY(-1.2rem);
    opacity: 0;
  }
}

.btn01_hover {
  position: absolute;
  top: 0;
  left: 0;
  white-space: nowrap;
}

.btn01_hover span {
  display: inline-block;
  transform: translateY(1.2rem);
  visibility: hidden;
  opacity: 0;
  transition-duration: 0.25s;
  transition-timing-function: cubic-bezier(.165, .84, .44, 1);
  transition-property: transform, opacity;
}

.btn01 a:hover .btn01_hover span {
  transform: translateY(0);
  opacity: 1;
  visibility: visible;
}

.btn01 a:hover .btn01_hover span:nth-child(1) {
  transition-delay: 0.25s;
}

.btn01 a:hover .btn01_hover span:nth-child(2) {
  transition-delay: 0.27s;
}

.btn01 a:hover .btn01_hover span:nth-child(3) {
  transition-delay: 0.29s;
}

.btn01 a:hover .btn01_hover span:nth-child(4) {
  transition-delay: 0.31s;
}

.btn01 a:hover .btn01_hover span:nth-child(5) {
  transition-delay: 0.32s;
}

.btn01 a:hover .btn01_hover span:nth-child(6) {
  transition-delay: 0.33s;
}

.btn01 a:hover .btn01_hover span:nth-child(7) {
  transition-delay: 0.35s;
}

.btn01 a:hover .btn01_hover span:nth-child(8) {
  transition-delay: 0.37s;
}

.btn01 a:hover .btn01_hover span:nth-child(9) {
  transition-delay: 0.39s;
}

.btn01 a:hover .btn01_hover span:nth-child(10) {
  transition-delay: 0.41s;
}

/*ボタン 白抜き*/

.btn02 {
  position: relative;
}

.btn02 a {
  display: inline-block;
  position: relative;
  right: 2.8rem;
  padding: 0;
  text-align: center;
  color: #fff;
  font-weight: bold;
  letter-spacing: 0.03em;
  line-height: 2;
}

.btn02 a::before {
  position: absolute;
  top: 0;
  bottom: 0;
  right: -7.1rem;
  width: 9rem;
  height: 9rem;
  margin: auto;
  border-radius: 100%;
  background-color: rgba(255, 255, 255, 0.15);
  content: "";
  transition: .16s cubic-bezier(.166, .74, .49, 1);
}

.btn02 a::after {
  position: absolute;
  top: 0;
  bottom: 0;
  right: -7.1rem;
  width: 9rem;
  height: 9rem;
  margin: auto;
  border-radius: 100%;
  content: "";
}

.btn02_border {
  position: relative;
}

.btn02_border::before, .btn02_border::after {
  position: absolute;
  left: 0;
  bottom: -2px;
  content: "";
  width: 100%;
  height: 1px;
  background-color: rgba(255, 255, 255, 1);
}

.btn02_arrow {
  position: absolute;
  width: 2.0rem;
  height: 1px;
  background-color: #fff;
  transform: scale(0, 1) translate(0, 0);
  transform-origin: right;
  top: 0;
  bottom: 0;
  right: -2.6rem;
  margin: auto;
  margin-left: 0;
  pointer-events: none;
}

.btn02_arrow::after {
  transform: rotate(45deg) translate(0, 0) scale(0, 1);
}

.btn02_arrow::before {
  transform: rotate(-45deg) translate(0, 0) scale(0, 1);
}

.btn02_arrow::after, .btn02_arrow::before {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  height: 1px;
  margin: auto;
  width: 6px;
  content: "";
  background-color: #fff;
  transform-origin: right;
}

.btn02_arrow::before, .btn02_arrow::after, .btn02_arrow {
  transition: .16s cubic-bezier(.166, .74, .49, 1);
  transition-delay: 0.1s;
}

.btn02 a:hover .btn02_border::before {
  animation-name: btn02_border_01;
  animation-duration: .16s;
  animation-timing-function: cubic-bezier(.166, .74, .49, 1);
  animation-iteration-count: 1;
  animation-fill-mode: both;
}

@keyframes btn02_border_01 {
  from {
    width: 100%;
  }
  100% {
    width: 0%;
    left: 100%;
  }
}

.btn02 a:hover .btn02_border::after {
  animation-name: btn02_border_02;
  animation-duration: .16s;
  animation-timing-function: cubic-bezier(.166, .74, .49, 1);
  animation-iteration-count: 1;
  animation-fill-mode: both;
  animation-delay: .16s;
}

@keyframes btn02_border_02 {
  from {
    width: 0;
    left: 0;
  }
  100% {
    width: 100%;
    left: 0;
  }
}

.btn02 a:hover .btn02_border {
  color: #fff;
}

.btn02 a:hover::before {
  transform: scale(0, 0);
}

.btn02 a:hover .btn02_arrow {
  background-size: 100% 100%;
  transform: scale(1, 1) translate(0, 0);
}

.btn02 a:hover .btn02_arrow::after {
  background-size: 100% 100%;
  transform: rotate(45deg) translate(-0, 0) scale(1, 1);
}

.btn02 a:hover .btn02_arrow::before {
  background-size: 100% 100%;
  transform: rotate(-45deg) translate(-0, 0) scale(1, 1);
}

.btn02 a:hover .btn02_arrow {
  background-size: 100% 100%;
}

/*ボタン 小*/

.btn03 {
  position: relative;
}

.btn03 a {
  display: inline-block;
  position: relative;
  color: #BB92D1;
  line-height: 28px;
  font-size: 1.5rem;
  font-weight: bold;
  transition: ease-in-out 0.1s;
}

.btn03 a::after {
  display: inline-block;
  position: absolute;
  top: 11px;
  right: 8px;
  width: 15px;
  height: 6px;
  background-image: url(../images/arrow01.html);
  background-size: cover;
  transition: 0.2s ease-in-out;
  content: "";
}

.btn03 a:hover::after {
  right: 0px;
}

.btn_blank {
  position: relative;
  font-size: 1.5rem;
  letter-spacing: 0.03em;
}

/* .btn_blank::before {
    position: absolute;
    bottom: 0;
    top: 0.15rem;
    left: -2rem;
    width: 1.1rem;
    height: 0.9rem;
    margin: auto;
    background-image: url(../images/icon_blank.svg);
    background-repeat: no-repeat;
    content: "";
    border-right: none;
    border-top: none;
    opacity: 1;
} */

.btn_blank a {
  position: relative;
  display: inline;
  vertical-align: middle;
  background-image: linear-gradient(#41A884, #41A884);
  transition: background-size .2s cubic-bezier(.165, .84, .44, 1);
  background-repeat: no-repeat;
  background-position: 0 100%;
  background-size: 100% 1px;
  text-decoration: none;
}

.btn_blank a:hover {
  background-position: 100% 100%;
  background-size: 0% 1px;
  color: #41A884;
}

/* 画像を右寄せ　※画像サイズはhtmlで調整 */

.img_fr {
  display: block;
  position: relative;
  float: right;
  margin-left: 30px;
  margin-bottom: 0 !important;
  text-align: center;
}

.img_fr img {
  border-radius: 3px;
  margin-bottom: 7px;
}

/* 画像に対して説明文がある場合は、dlで囲い、dtに画像を、ddにテキストを使う */

.img_fr dd {
  padding-left: 20px;
  line-height: 1.3;
  font-size: 15px;
  font-weight: bold;
  color: #1F2774;
  text-align: left;
}

.contents_img {
  margin-bottom: 4rem;
  overflow: hidden;
}

.contents_img img {
  position: relative;
  width: auto;
  height: auto;
  min-width: 100%;
  min-height: 100%;
  max-width: inherit;
}

.link_text a {
  color: #41A884;
  text-decoration: none;
  background-image: linear-gradient(#41A884, #41A884);
  transition: background-size .5s cubic-bezier(.165, .84, .44, 1);
  background-repeat: no-repeat;
  background-position: 0 100%;
  background-size: 100% 1px;
  font-weight: bold;
  font-size: 1.7rem;
}

.link_text a:hover {
  color: #C0AB9A;
  background-position: 100% 100%;
  background-size: 0% 1px;
  text-decoration: none;
}

/*四角3つ並び*/

.box_list03 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.box_list03_inner {
  width: 30.4%;
  margin-bottom: 10rem;
}

.box_list03_img {
  position: relative;
  width: 100%;
  margin-bottom: 2.54rem;
}

.box_list03_img img {
  width: 100%;
}

.box_list03_title {
  margin-bottom: 0.6rem;
}

.box_list03_title .h3_tit01_ja_min {
  font-size: 2.04rem;
  letter-spacing: 0.05em;
}

.box_list03_text {
  padding-top: 0.3rem;
  line-height: 1.9;
}

.box_list04 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.box_list04_inner {
  width: calc((100% / 3) - 3.2rem);
  margin-bottom: 9rem;
}

.box_list04_img {
  position: relative;
  width: 100%;
  margin-bottom: 1.85rem;
}

.box_list04_img img {
  width: 100%;
}

.box_list04_title {
  margin-bottom: 1.0rem;
}

.box_list04_title .h3_tit01_ja_min {
  font-size: 2.4rem;
  letter-spacing: 0.125em;
}

.box_list04_title_num {
  position: absolute;
  bottom: -4.6rem;
  right: 3.1rem;
  color: #65ABFF;
  font-family: din-2014, sans-serif;
  font-weight: 200;
  font-style: italic;
  font-size: 5rem;
  letter-spacing: 0.02em;
  mix-blend-mode: multiply;
}

.box_list04_text {
  text-align: left;
  letter-spacing: 0.125em;
}

/*四角2つ並び*/

.box_list05 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: -9rem;
}

.box_list05_inner {
  width: calc((100% / 2) - 0.3rem);
  margin-bottom: 9rem;
}

.box_list05_img {
  position: relative;
  width: 100%;
  margin-bottom: 0.8rem;
}

.box_list05_img img {
  width: 100%;
}

.box_list05_title {
  margin-bottom: 0;
}

.box_list05_title .h3_tit01_ja_min {
  font-size: 1.7rem;
}

.box_list05_title_num {
  position: absolute;
  bottom: -4.6rem;
  right: 3.1rem;
  color: #65ABFF;
  font-family: din-2014, sans-serif;
  font-weight: 200;
  font-style: italic;
  font-size: 5rem;
  letter-spacing: 0.02em;
  mix-blend-mode: multiply;
}

/*四角3つ並び*/

.box_list06 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-bottom: -9rem;
}

.box_list06_inner {
  width: calc((100% / 3) - 0.3rem);
  margin-bottom: 6rem;
}

.box_list06_img {
  position: relative;
  width: 100%;
  margin-bottom: 0.8rem;
}

.box_list06_img img {
  width: 100%;
}

.box_list06_title {
  margin-bottom: 0;
}

.box_list06_title .h3_tit01_ja_min {
  font-size: 1.7rem;
}

.box_list06_title_num {
  position: absolute;
  bottom: -4.6rem;
  right: 3.1rem;
  color: #65ABFF;
  font-family: din-2014, sans-serif;
  font-weight: 200;
  font-style: italic;
  font-size: 5rem;
  letter-spacing: 0.02em;
  mix-blend-mode: multiply;
}

/*==================================================================

	table

==================================================================*/

.nowrap {
  white-space: nowrap;
}

/*診療時間風*/

.tb01 {
  border-spacing: 0;
  border-collapse: collapse;
}

.tb01 td, .tb01 th {
  border-bottom: 1px solid #DFD9D3;
  vertical-align: middle;
  padding: 0.4rem 0.865rem;
  font-size: 1.4rem;
  line-height: 1.75;
  letter-spacing: 0.05em;
  text-align: center;
}

.pr005 {
  position: relative;
  top: -0.05rem;
}

.pr01 {
  position: relative;
  top: -0.1rem;
}

.pr02 {
  position: relative;
  top: -0.2rem;
}

.tb01 td:last-child {
  padding-right: 0;
  padding-left: 0.11rem;
}

.tb01 tr:last-child td, .tb01 tr:last-child th {
  border-bottom: none;
}

.tb01 td:last-child {
  border-right: none;
}

.tb01 tr:first-child th {
  padding: 1rem 2.7rem 0.8rem 0.2rem;
  letter-spacing: 0.01em;
  font-weight: bold;
}

.tb01 tr:first-child td {
  color: #333333;
}

.tb01 th {
  padding: 1.2rem 2.3rem 0.95rem 0.2rem;
  line-height: 1;
  text-align: left;
  font-family: 'Heebo', "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.1em;
}

.tb01 td {
  color: #A8A4A0;
  font-weight: bold;
}

.color_natural {
  color: #D9C8AD;
}

.black {
  color: #333839;
}

/*医院概要*/

.tb02 {
  border-spacing: 0;
  text-align: left;
}

.tb02 td, .tb02 th {
  padding: 1.7rem 0;
  border-bottom: #ddd 1px dotted;
  line-height: 1.5;
  letter-spacing: 0.03em;
  vertical-align: top;
}

.tb02 th {
  padding-right: 5.2rem;
  white-space: nowrap;
  text-align: left;
  font-weight: normal;
}

.tb02 td {
  padding-right: 0;
  text-align: left;
}

.tb02 tr:last-child td, .tb02 tr:last-child th {
  border: none;
}

/* 料金表 */

.tb03 {
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse;
  border: 1px solid #E5E1DD;
}

.tb03 tr {
  border: 1px solid #E5E1DD;
  border-style: solid;
}

.tb03 td, .tb03 th {
  padding: 3.2rem 3.6rem;
  border: 1px solid #E5E1DD;
}

.tb03_cal2 th {
  padding: 4.5rem 3.4rem 4.2rem 3.6rem !important;
}

.tb03_cal2 .txt_s {
  padding-top: 1.4rem !important;
}

.tb03_price {
  width: 11%;
  text-align: right;
}

.tb03_price_b {
  font-size: 2.04rem;
  font-weight: bold;
  letter-spacing: 0.05em;
}

.tb03 th {
  width: 25.2%;
  padding: 4.45rem 3rem 4.45rem 3.6rem;
  font-size: 2.04rem;
  font-weight: bold;
  text-align: left;
  letter-spacing: 0.05em;
  line-height: 1.755;
  vertical-align: top;
}

.tb03 th span {}

.tb03 td {
  width: 52%;
  padding: 4.4rem 3.6rem 4.9rem 3.6rem;
  font-weight: bold;
  text-align: left;
}

.tb03 td:last-child {
  width: 22%;
  text-align: right;
  font-family: 'Heebo', sans-serif;
  font-size: 2.1rem;
  font-weight: 400;
  letter-spacing: 0.03em;
  vertical-align: top;
}

.tb03 .txt_s {
  margin: 0;
  padding-top: 1rem;
  font-weight: 500;
  font-size: 1.7rem;
  line-height: 1.9;
  letter-spacing: 0.075em;
}

.tb03 th .txt_s {
  font-size: 1.5rem;
}

.tb03 .tb03_cal2 th .txt_s {
  font-size: 1.7rem;
}

.tb03_money {
  padding-right: 0.3rem;
  font-weight: 500;
  font-size: 1.5rem;
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
  letter-spacing: 0.05em;
}

.tb03_tax {
  display: block;
  margin-right: -1rem;
  font-size: 1.5rem;
  font-family: "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
  line-height: 1;
}

.tb04 {
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse;
  margin-bottom: 4rem;
}

.tb04 tr {
  border-bottom: 1px solid rgba(106, 97, 89, .15);
}

.tb04 td, .tb04 th {
  padding: 1.2rem 0;
}

.tb04 tr:last-child {
  border: none;
}

.tb04 th {
  width: 35%;
  font-weight: bold;
  white-space: nowrap;
  text-align: left;
}

.tb04 th span {
  font-size: 1.3rem;
}

.tb04 td {}

.tb04 td:last-child {
  padding-left: 2rem;
}

/* 診療案内2個並び */

.tb05 {
  width: 100%;
  border-spacing: 0;
  border-collapse: collapse;
  margin-bottom: 2rem;
}

.tb05 tr {
  border-top: 1px solid rgba(106, 97, 89, .15);
  border-bottom: 1px solid rgba(106, 97, 89, .15);
}

.tb05 td, .tb05 th {
  padding: 1.2rem 3.6rem;
}

.tb05 th {
  position: relative;
  font-weight: bold;
  white-space: nowrap;
  text-align: left;
}

.tb05 th::after {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  content: "";
  height: 60%;
  width: 1px;
  background-color: rgba(106, 97, 89, .15);
}

.tb05 th span {
  font-size: 1.3rem;
}

.tb05 td {}

.tb05 td:last-child {}

/*診療時間風*/

.tb06 {
  border-spacing: 0;
  border-collapse: collapse;
  border: 1px solid #DFD9D3;
  width: 100%;
  font-size: 1.6rem;
}

.tb06 td, .tb06 th {
  border-bottom: 1px solid #DFD9D3;
  border-right: 1px solid #DFD9D3;
  vertical-align: middle;
  padding: 2rem 1rem;
  letter-spacing: 0.05em;
  text-align: center;
}

.tb06 td:last-child {}

.tb06 tr:last-child td, .tb06 tr:last-child th {
  border-bottom: 1px solid #DFD9D3;
  border-right: 1px solid #DFD9D3;
}

.tb06 tr:first-child th {
  letter-spacing: 0.01em;
  font-weight: bold;
  text-align: center;
}

.tb06 tr:first-child td {
  color: #333333;
}

.tb06 th {
  line-height: 1;
  font-weight: 400;
  font-style: normal;
  letter-spacing: 0.08em;
  font-family: "Heebo", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
}

.tb06 td {
  color: #A8A4A0;
}

/*==================================================================

	アンカーリンンク

==================================================================*/

/* 4個並び */

.ank01 {
  margin: 0 auto 100px;
}

.ank01 li {
  display: table;
  position: relative;
  float: left;
  width: 24%;
  height: 66px;
  margin-bottom: 1.5%;
  margin-left: 1.33%;
  line-height: 1.4;
}

.ank01 li:nth-child(1), .ank01 li:nth-child(5), .ank01 li:nth-child(9) {
  margin-left: 0;
}

.ank01 li a {
  display: table-cell;
  padding: 12px 5px 15px;
  border: 1px solid #00408f;
  font-weight: bold;
  font-size: 13px;
  color: #00408f;
  text-align: center;
  vertical-align: middle;
  transition: 0.1s ease-in-out;
}

.ank01 li a:hover {
  background-color: #00408f;
  color: #fff;
}

.ank01 li i {
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 4px;
  margin: auto;
}

/*==================================================================

	.layout

==================================================================*/

/* 1つ並びのレイアウト。画像は無し、左にタイトル、右に文章 */

.layout01 {
  display: flex;
  margin-bottom: 6rem;
}

.layout01_img {
  padding: 4rem;
  background-color: #fff;
  margin-right: 4rem;
}

.layout01_text_title {
  position: relative;
  margin-bottom: 0.5rem;
  font-size: 3.07rem;
  line-height: 1.5;
  font-weight: bold;
}

.layout01_text_title em {
  display: inline-block;
  margin-right: 1.2rem;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 200;
  font-size: 3.8rem;
  letter-spacing: 0.03em;
}

.layout01_text {
  display: flex;
  align-items: center;
  margin-bottom: 2rem;
}

.text .layout01 p {
  margin-bottom: 0;
}

.layout02 {
  display: flex;
  margin-bottom: 1rem;
}

.layout02::after {
  display: block;
  clear: both;
  content: "";
}

.layout02_img {
  margin-right: 4rem;
  margin-bottom: 1rem;
  background-color: #fff;
}

.layout02_text h4 {
  position: relative;
  margin-bottom: 0.5rem;
  font-size: 3.07rem;
  line-height: 1.5;
  font-weight: bold;
}

.layout03 {
  display: flex;
  align-items: center;
  margin-bottom: 1rem;
}

.layout03 h6 {
  padding-right: 2rem;
  margin-right: 2rem;
  border-right: 1px solid rgba(106, 97, 69, 0.15);
  line-height: 1;
}

.layout03 p {
  margin-bottom: 0;
}

.layout04 {
  display: block;
  margin-bottom: 4rem;
}

.layout04::after {
  display: block;
  clear: both;
  content: "";
}

.layout04_img {
  float: left;
  margin-right: 4rem;
  margin-bottom: 4rem;
}

.layout04_text h4 {
  position: relative;
  margin-bottom: 0.5rem;
  font-size: 3.07rem;
  line-height: 1.5;
  font-weight: bold;
}

/* 1つ並びで3列に区切られたレイアウト。画像が左、画像の下にタイトル、右に文章 */

.layout05 {
  padding-bottom: 20px;
}

.layout05 dl {
  display: table;
  position: relative;
  margin-bottom: 20px;
  background-color: #f7f7f7;
  padding: 2%;
  font-size: 14px;
}

.layout05 dt, .layout05 dd {
  display: table-cell;
  box-sizing: border-box;
}

.layout05 dt {
  width: 25%;
  background-color: #fff;
  text-align: center;
  vertical-align: middle;
}

.layout05 dt img {
  width: 100%;
  padding-bottom: 10px;
}

.layout05 dd {
  padding: 1% 3%;
  vertical-align: top;
}

.layout05 dd:nth-child(2) {
  width: 36.5%;
}

.layout05 dd:nth-child(3) {
  width: 38.5%;
  border-left: 1px solid #e2e2e2;
}

.layout05 dd h5 em {
  margin-right: 10px;
  color: #BDA087;
  font-family: "Times New Roman", Times, serif;
  font-size: 30px;
  font-weight: normal;
}

.layout05 dd h5 {
  font-size: 15px;
  font-weight: bold;
}

.layout05_text1 {}

.layout05_text1 ul {
  margin-bottom: 15px;
}

.layout05_text1 ul li {
  text-indent: -1em;
  margin-left: 1em;
}

/* 1つ並びで3列に区切られたレイアウト。左がタイトル、真ん中と右に文章 */

.layout06 {
  padding-bottom: 20px;
}

.layout06 dl {
  display: table;
  position: relative;
  padding-bottom: 5px;
  font-size: 14px;
}

.layout06 dl:before {
  position: absolute;
  top: -3px;
  left: 0;
  width: 100%;
  border-top: 1px solid #ededed;
  content: "";
}

.layout06 dl:last-child:after {
  position: absolute;
  bottom: -3px;
  left: 0;
  width: 100%;
  border-top: 1px solid #f0f0f0;
  content: "";
}

.layout06 dt, .layout06 dd {
  display: table-cell;
  box-sizing: border-box;
}

.layout06 dt {
  min-width: 28%;
  padding: 0 3%;
  background-color: #F7F7F7;
  letter-spacing: 0.1em;
  color: #1F2774;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  vertical-align: middle;
}

/* 数字 */

.layout06 dt em {
  display: block;
  line-height: 1;
  margin: 0 8px;
  font-family: "Times New Roman", Times, serif;
  font-size: 38px;
  font-weight: normal;
  color: #C3AF97;
}

.layout06 dd {
  padding: 2% 3%;
  vertical-align: top;
}

.layout06 dd:nth-child(2) {
  width: 40%;
}

.layout06 dd:nth-child(3) {
  width: 35%;
  border-left: 1px solid #e2e2e2;
}

.layout06 dd h5 {
  font-size: 15px;
  font-weight: bold;
}

.layout06_text1 {}

.layout06_text1 ul {
  margin-bottom: 15px;
}

.layout06_text1 ul li span {
  display: block;
}

/* 3つ並びのレイアウト。 */

.layout07 {}

.layout07::after {
  display: block;
  clear: both;
  content: "";
}

.layout07 dl {
  float: left;
  width: 26%;
  margin-right: 2%;
  margin-bottom: 20px;
  padding: 3%;
  border-radius: 10px;
  background-color: #F7F7F7;
}

.layout07 dl:nth-child(3n) {
  margin-right: 0;
}

.layout07 dl dt {
  margin-bottom: 7px;
  padding-bottom: 7px;
  border-bottom: 1px dashed #ddd;
  font-size: 17px;
  font-weight: bold;
  text-align: center;
}

.layout07 dl dt em {
  margin-right: 8px;
  font-size: 24px;
  font-family: 'Quicksand', sans-serif;
}

.layout07 dl dd {
  line-height: 1.5;
}

/* 3つ並びのレイアウト。矢印付き */

.layout08 {
  overflow: hidden;
}

.layout08 dl {
  position: relative;
  float: left;
  width: 24.6%;
  margin-right: 4.1%;
  margin-bottom: 25px;
  padding: 3%;
  border-radius: 10px;
  background-color: #F7F7F7;
}

.layout08 dl::before {
  position: absolute;
  right: -17px;
  top: 0;
  height: 7px;
  width: 7px;
  transform: rotate(45deg);
  background-color: transparent;
  border-top: 2px solid #33409A;
  border-right: 2px solid #33409A;
  content: "";
  bottom: 0;
  margin: auto;
}

.layout08 dl:nth-child(3n) {
  margin-right: 0;
}

.layout08 dl dt {
  margin-bottom: 7px;
  padding-bottom: 7px;
  border-bottom: 1px dashed #ddd;
  font-size: 17px;
  font-weight: bold;
  text-align: center;
}

.layout08 dl dt em {
  margin-right: 8px;
  font-size: 24px;
  font-family: 'Quicksand', sans-serif;
}

.layout08 dl dd {
  line-height: 1.5;
}

.layout09 {}

.layout09_inner {}

.layout09_inner_list {}

.layout09_inner_list li {
  display: flex;
  align-items: center;
  position: relative;
  padding: 1rem 0;
  margin-right: 2rem;
  /* 	box-shadow: 0 4.4rem 2.4rem -1.2rem rgba(217,200,173,.15)
 */
}

.layout09_inner_list li:last-child {
  margin-right: 0;
}

.layout09_inner_list_text {}

.layout09_inner_list_title {
  font-size: 2.1rem;
  font-weight: bold;
  margin-bottom: 0.8rem;
}

.layout09_inner_list_num {
  position: absolute;
  top: 0rem;
  left: 2rem;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 300;
  font-size: 2.4rem;
  letter-spacing: 0.03em;
  line-height: 1;
}

.layout09_inner_list_img {
  padding: 2rem;
  background-color: #fff;
  margin-right: 4rem;
}

.layout09_inner_list_desc {
  text-align: left;
  line-height: 1.7;
}

.layout09_inner_list_title_num01 {
  margin-right: 1rem;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 300;
  font-size: 2.4rem;
  letter-spacing: 0.03em;
  line-height: 1;
}

.layout09_inner_list_text_s {
  font-size: 1.5rem;
  font-weight: 500;
}

/* 
.layout09_inner_list_hoverarea{
	position:absolute;
	top:0;
	left:0;
	width:100%;
	height:100%;
}

.layout09_inner_list_details{

    align-items: center;
    transform: scale(0.8, 0.8);
    position: absolute;
    top: 17rem;
    width: 46rem;
    padding: 4.4rem 5.5rem ;
		text-align:left;
    box-sizing: border-box;
    background-color: #fff;
    box-shadow: 0 0px 84px -12px rgba(0,5,30,.1);
    transition: 0.2s cubic-bezier(0.260, 0.005, 0.000, 1.035);
    transition-property: transform, opacity;
    opacity: 0;

    z-index: 100;
}
.layout09_inner_list_details::before {
    position: absolute;
    right: 215px;
    top: -14px;
    border-top: 0 solid #fff;
    border-right: 10px solid transparent;
    border-bottom: 17px solid #fff;
    border-left: 10px solid transparent;
    box-shadow: 0 54px 44px -12px rgba(0,5,30,.1);
    transition: 0.20s cubic-bezier(0.260, 0.005, 0.000, 1.035);
    content: "";
    z-index: 99;
}




.layout09_inner_list_title,
.layout09_inner_list_num,
.layout09_inner_list_details{
	 pointer-events: none;
}


.layout09_inner_list_details.layout09_details_active{
    opacity: 1;
    pointer-events: none;
    transform: scale(1, 1);
}


.layout09_inner_list_details_title{
		font-weight:bold;
	font-size:1.9rem;
	margin-bottom:1rem;
}
.layout09_inner_list_details p{
	font-size:1.5rem;
	margin-bottom:0;
}

 */

.layout10 {}

.layout10_inner {}

.layout10_inner_list {
  display: flex;
  justify-content: space-between;
}

.layout10_inner_list li {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: calc(100% / 4);
  min-height: 18.6rem;
  background-color: #fff;
  padding: 1rem 1rem;
  margin-right: 2rem;
  text-align: center;
  box-shadow: 0 4.4rem 2.4rem -1.2rem rgba(217, 200, 173, .15);
  box-sizing: border-box;
  border-radius: 6px;
}

.layout10_inner_list_box {
  text-align: center;
}

.layout10_inner_list li:last-child {
  margin-right: 0;
}

.layout10_inner_list_box {}

.layout10_inner_list_title {
  font-size: 1.9rem;
  font-weight: bold;
}

.layout10_inner_list_img {
  padding-top: 0.8rem;
  margin-bottom: 1rem;
}

.layout10_inner_list_num {
  position: absolute;
  top: -1rem;
  left: 2rem;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 300;
  font-size: 2.4rem;
  letter-spacing: 0.03em;
  line-height: 1;
}

.layout10_inner_list_num_sp {
  display: none;
}

.layout10_inner_list_desc {
  font-size: 1.7rem;
  text-align: left;
  line-height: 1.5;
}

.layout10_inner_list_hoverarea {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.layout10_inner_list_details {
  display: flex;
  align-items: center;
  transform: scale(0.8, 0.8);
  position: absolute;
  top: 17rem;
  width: 80rem;
  padding: 4.4rem 5.5rem;
  text-align: left;
  box-sizing: border-box;
  background-color: #fff;
  box-shadow: 0 0px 84px -12px rgba(0, 5, 30, .1);
  transition: 0.2s cubic-bezier(0.260, 0.005, 0.000, 1.035);
  transition-property: transform, opacity;
  opacity: 0;
  z-index: 100;
}

.layout10_inner_list_details::before {
  position: absolute;
  right: 580px;
  top: -14px;
  border-top: 0 solid #fff;
  border-right: 10px solid transparent;
  border-bottom: 17px solid #fff;
  border-left: 10px solid transparent;
  box-shadow: 0 54px 44px -12px rgba(0, 5, 30, .1);
  transition: 0.20s cubic-bezier(0.260, 0.005, 0.000, 1.035);
  content: "";
  z-index: 99;
}

.layout10_inner_list li:nth-child(3) .layout10_inner_list_details::before, .layout10_inner_list li:nth-child(4) .layout10_inner_list_details::before, .layout10_inner_list li:nth-child(5) .layout10_inner_list_details::before {
  right: 280px;
}

.layout10_inner_list_title, .layout10_inner_list_num, .layout10_inner_list_details {
  pointer-events: none;
}

.layout10_inner_list_details_img {
  margin-right: 4rem;
}

.layout10_inner_list_details_img img {
  width: 18rem;
  height: 18rem;
  border-radius: 6px;
}

.layout10_inner_list_details.layout10_details_active {
  opacity: 1;
  pointer-events: none;
  transform: scale(1, 1);
}

.layout10_inner_list_details_text {}

.layout10_inner_list_details_title {
  font-weight: bold;
  font-size: 2.1rem;
  margin-bottom: 1rem;
}

.layout10_inner_list_details p {
  font-size: 1.9rem;
  margin-bottom: 0;
}

.layout11 {
  padding: 4rem 5rem;
  box-sizing: border-box;
  border: 1px solid rgba(106, 97, 69, 0.15);
}

.layout11_inner {
  display: flex;
  justify-content: space-between;
}

.layout11_box {
  width: 50%;
}

.layout11_box:nth-child(1) {
  padding-right: 4rem;
}

.layout11_box:nth-child(2) {
  padding-left: 3rem;
}

.layout11_title {
  margin-bottom: 1.6rem;
  font-size: 1.7rem;
  font-weight: bold;
  letter-spacing: 0.05em;
}

.layout11_list {}

.layout11_list li {
  position: relative;
  margin-bottom: 0.8rem;
  padding-left: 1.5rem;
}

.layout11_list li::before {
  display: block;
  position: absolute;
  top: 1.5rem;
  left: 0;
  width: 0.3rem;
  height: 0.3rem;
  background-color: rgba(106, 97, 89, 0.3);
  border: 1px solid rgba(106, 97, 89, 0.3);
  border-radius: 100%;
  content: '';
}

.layout11_list li:last-child {
  margin-bottom: 0;
}

.layout12 {}

.layout12_inner {}

.layout12_inner_list {}

.layout12_inner_list li {
  display: flex;
  position: relative;
  padding: 0;
  margin-right: 2rem;
}

.layout12_inner_list li:last-child {
  margin-right: 0;
}

.layout12_inner_list_text {
  margin-left: 4rem;
}

.layout12_inner_list_title {
  font-size: 2.1rem;
  font-weight: bold;
  margin-bottom: 0.8rem;
}

.layout12_inner_list_num {
  position: absolute;
  top: 0rem;
  left: 2rem;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 300;
  font-size: 2.4rem;
  letter-spacing: 0.03em;
  line-height: 1;
}

.layout12_inner_list_img {
  padding: 2rem;
  background-color: #fff;
}

.layout12_inner_list_desc {
  text-align: left;
  line-height: 1.7;
}

.layout12_inner_list_title_num01 {
  margin-right: 1rem;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 300;
  font-size: 2.4rem;
  letter-spacing: 0.03em;
  line-height: 1;
}

.layout13 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-left: 1px solid rgba(106, 97, 69, 0.15);
  width: 100%;
  counter-reset: meritnum;
  margin-top: 40px;
  box-sizing: border-box;
}

.layout13+* {
  margin-top: 40px;
}

.layout13.col-5 li {
  width: 20%;
}

.layout13.col-3 li {
  width: 33.3%;
}

.layout13 li {
  border-right: 1px solid rgba(106, 97, 69, 0.15);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  box-sizing: border-box;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  counter-increment: meritnum;
  padding-top: 1rem;
  line-height: 1.5;
}

.layout13 li div {
  text-align: center;
  font-weight: bold;
  margin-top: 0;
}

.layout13 li div::before {
  content: "0"counter(meritnum);
  color: #B7A58D;
  display: block;
  font-family: brandon-grotesque, sans-serif;
  font-weight: 400;
  font-size: 1.8rem;
  margin-bottom: 0.4rem;
}

.layout13 li+* {
  margin-top: 1rem;
}

.layout14 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  counter-reset: meritnum;
  margin-top: 6.7rem;
  margin-bottom: 3rem;
  box-sizing: border-box;
}

.layout14_img {
  padding-right: 4.4rem;
}

.layout14_text {}

.layout14_text_title {
  margin-bottom: 2.1rem;
  font-size: 2.04rem;
  font-weight: bold;
  line-height: 1.45;
}