@charset "UTF-8";
/* =======================================
共通設定
======================================= */
@media (max-width: 1260px) {
  html {
    font-size: 0.7936507937vw;
  }
}
body {
  width: 100%;
  height: auto;
  background: #ffffff;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #000000;
}

a:link, a:visited, a:active {
  text-decoration: none;
  color: inherit;
}

img {
  height: auto;
}

#container {
  width: 100%;
}

.sp {
  display: none !important;
}

.wrap_out a:not(.nohover):hover, .wrap_in a:not(.nohover):hover {
  opacity: .7;
  -webkit-transition: 0.6s;
  transition: 0.6s;
}

/* 基本ボックス設定 */
.wrap_out, .wrap_main {
  width: 100%;
  height: auto;
}

.wrap_in {
  max-width: 100%;
  width: 120rem;
  height: auto;
  margin: 0 auto;
}

/* 横並びリスト */
ul {
  /* 2カラム横並びリスト */
  /* 3カラム横並びリスト */
}

ul.many_rows {
  display: block;
  height: auto;
  overflow: hidden;
}

ul.many_rows > li {
  display: block;
  height: auto;
  float: left;
}

ul.two_rows {
  display: block;
  height: auto;
  overflow: hidden;
}

ul.two_rows > li {
  display: block;
  height: auto;
  float: left;
}

ul.two_rows > li:nth-child(2n+2) {
  float: right;
}

ul.three_rows {
  display: block;
  height: auto;
  overflow: hidden;
}

ul.three_rows > li {
  display: block;
  height: auto;
  float: left;
}

ul.three_rows > li:nth-child(3n+2) {
  margin-right: 0;
}

ul.three_rows > li:nth-child(3n+3) {
  float: right;
  margin-right: 0;
}

/*テーブルブロック*/
.table_block {
  display: table;
  table-layout: fixed;
  width: 100%;
}

.table_block > .cell_block {
  display: table-cell;
  width: 50%;
  text-align: center;
  vertical-align: middle;
}

/* スクローラー */
#scroller {
  position: fixed;
  bottom: 3rem;
  right: 3rem;
  z-index: 1000;
}

/*その他*/
.tk_shdw {
  text-shadow: 1px 1px 5px rgba(0, 0, 0, 0.5), 1px 0px 5px rgba(0, 0, 0, 0.5), 0px 1px 5px rgba(0, 0, 0, 0.5), 0px 0px 5px rgba(0, 0, 0, 0.5), -1px -1px 5px rgba(0, 0, 0, 0.5), -1px 0px 5px rgba(0, 0, 0, 0.5), 0px -1px 5px rgba(0, 0, 0, 0.5);
}

.tk_shdw_1 {
  text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.5), 1px 0px 3px rgba(0, 0, 0, 0.5), 0px 1px 3px rgba(0, 0, 0, 0.5), 0px 0px 3px rgba(0, 0, 0, 0.5), -1px -1px 3px rgba(0, 0, 0, 0.5), -1px 0px 3px rgba(0, 0, 0, 0.5), 0px -1px 3px rgba(0, 0, 0, 0.5);
}

/* header
------------------------------- */
#header {
  width: 100%;
  height: 80rem;
  overflow: hidden;
  position: relative;
}

#slider {
  width: 100%;
  height: 100%;
}

#slider .slide_in {
  width: 100vw;
  height: 80rem;
}

#slider .slide_in a {
  display: block;
  width: 100%;
  height: 100%;
}

#slider .slide_in img {
  display: block;
  width: 100%;
  height: 100%;
}

#slider .slick-dots {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  /*縦方向（Safari用）*/
  align-items: center;
  /* 縦方向*/
  -webkit-justify-content: flex-start;
  /*横方向（Safari用）*/
  justify-content: flex-start;
  /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 110rem;
  position: absolute;
  top: 51.4rem;
  left: 50%;
  -webkit-transform: translateY(0) translateX(-50%);
  transform: translateY(0) translateX(-50%);
  text-align: left;
  padding-left: 5.6rem;
  z-index: 1;
  gap: 1.6rem;
}

#slider .slick-dots li {
  display: inline;
}

#slider .slick-dots li button {
  display: block;
  width: 1.8rem;
  aspect-ratio: 1 / 1;
  -webkit-border-radius: 1.8rem;
  border-radius: 1.8rem;
  font-size: 0;
  background-color: #999999;
  border: .4rem solid #999999;
}

#slider .slick-dots li.slick-active button {
  background-color: #000;
}

.ttl_h1 {
  width: 110rem;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateY(0) translateX(-50%);
  transform: translateY(0) translateX(-50%);
  padding-top: 12.7rem;
  padding-left: 5rem;
  font-size: 5rem;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: .2em;
  text-align: left;
  z-index: 1;
}

.ttl_h1 img {
  display: block;
  width: 30rem;
  /*230529　16.1rem*/
  margin-bottom: 4.6rem;
}

/* footer
------------------------------- */
#footer {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  /*縦方向（Safari用）*/
  align-items: center;
  /* 縦方向*/
  -webkit-justify-content: center;
  /*横方向（Safari用）*/
  justify-content: center;
  /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  height: 19.7rem;
  gap: 7rem;
}

.footer_link {
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.2;
}

/* container
------------------------------- */
.container {
  overflow: hidden;
}

.ttl_img {
  display: block;
  width: auto;
  height: 5.9rem;
}

.ttl_img_h2 {
  margin-bottom: 5rem;
}

/* news
------------------------------- */
.sec_news {
  position: relative;
  padding: 0;
  margin: 0;
}

.news_wrap {
  width: calc(110rem + ( ( 100% - 110rem ) / 2) );
  min-height: 16.5rem;
  max-height: 20rem;
  padding: 4.2rem 0 4.2rem 16rem;
  position: absolute;
  top: 50%;
  left: calc( ( 100% - 110rem ) / 2);
  -webkit-transform: translateY(-50%) translateX(0);
  transform: translateY(-50%) translateX(0);
  border: 1px solid #000;
  border-right: 0;
  border-top-left-radius: 8.25rem;
  border-bottom-left-radius: 8.25rem;
  background-color: #fff;
}

.news_wrap .ttl_img_h2 {
  position: absolute;
  top: -2.8rem;
  left: 5rem;
  margin-bottom: 0;
}

.fx_news {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: flex-start;
  /*横方向（Safari用）*/
  justify-content: flex-start;
  /*横方向*/
  width: 100%;
  padding-top: 1.1rem;
  padding-bottom: 1.1rem;
  /*padding-bottom: 1.6rem;*/
  border-bottom: 1px solid #dcdcdc;
}

.fx_news > .flex_block_child {
  letter-spacing: .1em;
}

.fx_news > .flex_block_child.blockA {
  width: 11.5rem;
  font-size: 1.4rem;
  line-height: 1.5;
  text-align: left;
}

.fx_news > .flex_block_child.blockB {
  width: calc(100% - 11.5rem);
  font-size: 1.2rem;
  line-height: 1.5;
  padding-top: .2rem;
}

.news_wrap_inner {
  width: 78rem;
  overflow-y: auto;
  max-height: 11.6rem;
}

/* home_01
------------------------------- */
.home_01 {
  padding: 18.4rem 0 0;
  background-color: #f7f3eb;
}

.home_01 .ttl_img_h2 .ttl_img {
  margin-left: auto;
  margin-right: auto;
}

.fx_home_01 {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: center;
  /*横方向（Safari用）*/
  justify-content: center;
  /*横方向*/
  gap: 2rem;
}

.fx_home_01 > .flex_block_child {
  position: relative;
  width: 35.3rem;
}

.fx_home_01 > .flex_block_child p {
  position: absolute;
  top: 25.1rem;
  left: 0;
  width: 100%;
  font-size: 2rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: .1em;
  text-align: center;
}

.fx_home_01 > .flex_block_child img {
  display: block;
  width: 100%;
}

.fx_home_01B {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: center;
  /*横方向（Safari用）*/
  justify-content: center;
  /*横方向*/
  margin-top: 12.15rem;
}

.fx_home_01B > .flex_block_child {
  display: block;
  width: 33.3333333333%;
}

.home_01_p {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 2;
  text-align: center;
  margin-top: 3.25rem;
}

/* home_02
------------------------------- */
.ttl_img_h2.add_logo {
  margin-bottom: 2.85rem;
}

.ttl_img_h2.add_logo::after {
  content: "";
  display: block;
  width: 13rem;
  aspect-ratio: 322 / 354;
  background-image: url("../img/home/logo.png");
  background-size: 100% auto;
  background-position: 0 0;
  background-repeat: no-repeat;
  margin-top: -1rem;
}

.ttl_img_h2.al_c .ttl_img {
  margin-left: auto;
  margin-right: auto;
  height: 6.65rem;
}

.home_02, .home_07 {
  padding-top: 12rem;
  padding-bottom: 10rem;
  position: relative;
  z-index: 2;
}

.home_02::before, .home_07::before {
  content: "";
  display: block;
  max-width: calc(100% - 11rem);
  width: 161rem;
  height: 64.4rem;
  background-color: #fbf8f1;
  position: absolute;
  bottom: 10rem;
  right: 50%;
  -webkit-transform: translateY(0) translateX(50%);
  transform: translateY(0) translateX(50%);
  margin-right: -5.5rem;
  z-index: -1;
}

.home_02::after, .home_07::after {
  content: "";
  display: block;
  width: 161rem;
  max-width: calc(100% - 11rem);
  height: 57.8rem;
  background-color: #f7f3eb;
  position: absolute;
  bottom: 0;
  left: 50%;
  -webkit-transform: translateY(0) translateX(-50%);
  transform: translateY(0) translateX(-50%);
  margin-left: -5.5rem;
  z-index: -1;
}

.fx_home_02 {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: space-between;
  /*横方向（Safari用）*/
  justify-content: space-between;
  /*横方向*/
  gap: 3rem;
}

.fx_home_02 > .flex_block_child.blockA {
  width: 27rem;
}

.fx_home_02 > .flex_block_child.blockA .ttl_img_h2 {
  margin-top: 0;
}

.fx_home_02 > .flex_block_child.blockA p {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 2;
  text-align: justify;
  text-justify: inter-ideograph;
}

.fx_home_02 > .flex_block_child.blockB {
  width: calc( 100% - 27rem - 3rem - 1px );
}

.fx_home_02_child {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: space-between;
  /*横方向（Safari用）*/
  justify-content: space-between;
  /*横方向*/
}

.fx_home_02_child > .flex_block_child {
  width: calc( ( 100% - ( 1.5rem * 2 ) ) / 3 );
  position: relative;
}

.fx_home_02_child > .flex_block_child img {
  display: block;
  width: 100%;
}

.fx_home_02_child > .flex_block_child p {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  padding: 2rem;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: .1em;
  color: #fff;
  text-align: justify;
  text-justify: inter-ideograph;
}

.btn_wrapA {
  width: 80rem;
  padding: 6.5rem;
  margin: 7.8rem auto 0;
  position: relative;
  background-color: #fff;
}

.btn_wrapA .ttl_img_h2 {
  margin: -3rem 0 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

.btn_more {
  display: block;
  width: 25rem;
  height: 6rem;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  /*縦方向（Safari用）*/
  align-items: center;
  /* 縦方向*/
  -webkit-justify-content: center;
  /*横方向（Safari用）*/
  justify-content: center;
  /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: .2em;
  text-align: center;
  background-color: #ffe9df;
  border: 1px solid #000;
  -webkit-border-radius: .5rem;
  border-radius: .5rem;
  margin: 0 auto;
  position: relative;
}

.btn_more::after {
  content: "";
  display: block;
  width: 4rem;
  border-bottom: 1px solid #000;
  position: absolute;
  right: 0;
  top: 50%;
  margin-right: -2rem;
  margin-top: -.05rem;
}

/* home_03
------------------------------- */
.home_03 {
  padding-top: 13rem;
}

.home_03 .wrap_in {
  width: 130rem;
  max-width: 100%;
  background-color: #fbf8f1;
  position: relative;
  padding: 9.5rem 0 10rem;
  position: relative;
}

.home_03 .wrap_in .ttl_img_h2 {
  position: absolute;
  top: -2.7rem;
  left: 50%;
  margin-left: -59.4rem !important;
  z-index: 1;
  margin: 0;
}

.home_03 .btn_wrapA {
  padding: 0;
  margin-top: 5.8rem;
  background-color: transparent;
}

.home_03 .btn_wrapA .btn_more {
  background-color: #fff;
}

.ttl_h3_home_03 {
  height: 6rem;
  background-color: #ede7db;
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 6rem;
  letter-spacing: .1em;
  text-align: center;
  margin-bottom: .6rem;
}

.fx_home_03 {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: space-between;
  /*横方向（Safari用）*/
  justify-content: space-between;
  /*横方向*/
  width: 110.2rem;
  margin-left: auto;
  margin-right: auto;
}

.fx_home_03 > .flex_block_child.blockA {
  width: 78.5rem;
}

.fx_home_03 > .flex_block_child.blockB {
  width: 30rem;
}

.tbb_home_03 {
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: .1em;
}

.tbb_home_03 .callA, .tbb_home_03 .callB {
  background-color: #fff;
  vertical-align: middle;
}

.tbb_home_03 .callB {
  text-align: center;
  border-left: 1px solid #f1ece8;
}

.tbb_home_03 .callC {
  background-color: #ffe9df;
  color: #fc3359;
  text-align: center;
  vertical-align: middle;
  border-left: 1px solid #f1ece8;
}

.tbb_home_03 > tbody > tr th {
  text-align: center;
  height: 6rem;
  font-weight: 700;
}

.tbb_home_03 > tbody > tr td {
  height: 7rem;
  border-top: 1px solid #f1ece8;
}

.tbb_home_03 > tbody > tr td.callA {
  padding-left: 2.8rem;
  font-weight: 700;
  width: 37rem;
}

.tbb_home_03 > tbody > tr td.callB {
  font-weight: 400;
}

.tbb_home_03 > tbody > tr td.callC {
  width: 27.4rem;
  font-weight: 700;
  border-top: 1px solid #f1e1d7;
}

.oval_chip {
  display: inline-block;
  width: 12rem;
  height: 2.4rem;
  background-color: #fff;
  text-align: center;
  font-size: 1.2rem;
  font-weight: 700;
  line-height: calc(2.4rem - 3px);
  color: #fc3359;
  border: 1px solid #fc3359;
  -webkit-border-radius: 2.4rem;
  border-radius: 2.4rem;
  margin-left: 2.2rem;
}

.fx_home_03_child {
  gap: 2.4rem;
}

.fx_home_03_child > .flex_block_child {
  width: 100%;
}

.fx_home_03_child > .fx_home_03_p {
  width: 100%;
}

.fx_home_03_child_p {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  /*縦方向（Safari用）*/
  align-items: center;
  /* 縦方向*/
  -webkit-justify-content: center;
  /*横方向（Safari用）*/
  justify-content: center;
  /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  height: 9rem;
  text-align: center;
  background-color: #fff;
}

.fx_home_03_child_p span {
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 2;
  letter-spacing: .1em;
  text-align: center;
}

.fx_home_03_child_p span strong {
  color: #fc3359;
}

.fx_home_03_p {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 2;
}

/* home_04
------------------------------- */
.home_04 {
  padding-top: 15rem;
  position: relative;
  z-index: 2;
}

.home_04::after {
  content: "";
  display: block;
  width: 100%;
  height: auto;
  position: absolute;
  top: 27.2rem;
  bottom: 0;
  left: 0;
  z-index: -1;
  background-color: #f7f3eb;
}

.fx_home_04 {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: space-between;
  /*横方向（Safari用）*/
  justify-content: space-between;
  /*横方向*/
  padding: 0;
}

.fx_home_04 > .flex_block_child.blockA {
  width: 93rem;
}

.fx_home_04 > .flex_block_child.blockB {
  width: auto;
}

.fx_home_04 > .flex_block_child.blockB .ttl_img_h2 {
  margin-bottom: 1.65rem;
}

.fx_home_04 > .flex_block_child.blockB p {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: .1em;
  text-align: right;
}

.fx_home_04_child {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: space-between;
  /*横方向（Safari用）*/
  justify-content: space-between;
  /*横方向*/
}

.fx_home_04_child > .flex_block_child {
  width: 45.75rem;
  position: relative;
}

.fx_home_04_child > .flex_block_child img {
  display: block;
  width: 100%;
}

.fx_home_04_child > .flex_block_child .inner {
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  color: #fff;
  padding: 2.4rem;
}

.fx_home_04_child > .flex_block_child .inner h3 {
  font-size: 1.4rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: .1em;
  margin-bottom: .6rem;
}

.fx_home_04_child > .flex_block_child .inner p {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: .03em;
  text-align: justify;
  text-justify: inter-ideograph;
}

/* home_05
------------------------------- */
.home_05 {
  padding-top: 14.5rem;
  padding-bottom: 14rem;
  background-color: #f7f3eb;
  position: relative;
  z-index: 2;
}

.home_05::after {
  content: '';
  display: block;
  width: 171rem;
  max-width: calc(100% - 7rem);
  height: 21.8rem;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
  background-color: #fbf8f1;
}

.home_05 .wrap_in {
  width: 130rem;
  max-width: 100%;
  background-color: #fff;
  position: relative;
  padding: 5rem  0 7rem;
}

.home_05 .wrap_in .ttl_img_h2 {
  position: absolute;
  top: -2.7rem;
  left: 50%;
  z-index: 1;
  margin: 0 0 0 -59.4rem;
}

.home_05 + .fx_home_01B {
  margin-top: 0;
}

.faq_wrap {
  width: 80rem;
  margin: 0 auto;
  font-size: 1.4rem;
  font-weight: 400;
  letter-spacing: .1em;
}

.aco_ttl {
  min-height: 7.2rem;
  font-weight: 400;
  line-height: 1.4;
  padding: 2.5rem 5.4rem 2.5rem 0;
  border-top: 1px solid #d0c5c5;
  position: relative;
  cursor: pointer;
  text-align: justify;
  text-justify: inter-ideograph;
}

.aco_ttl:first-child {
  border-top: 0;
}

.aco_ttl::after {
  content: "+";
  font-weight: 300;
  position: absolute;
  top: 2.5rem;
  right: 2.4rem;
}

.aco_box p {
  padding: 1.95rem 5.2rem 2.35rem;
  line-height: 2;
  font-weight: 700;
  background-color: #fbf8f1;
  text-indent: -1.5em;
  text-align: justify;
  text-justify: inter-ideograph;
}

.aco_box p::before {
  content: "A. ";
}

/* home_06
------------------------------- */
.home_06 {
  background-color: #fbf8f1;
  padding: 0;
}

.fx_home_06 {
  -webkit-align-items: stretch;
  /*縦方向（Safari用）*/
  align-items: stretch;
  /* 縦方向*/
  -webkit-justify-content: flex-start;
  /*横方向（Safari用）*/
  justify-content: flex-start;
  /*横方向*/
  width: calc(100% - (( 100% - 100rem ) / 2));
  margin: 0 0 0 auto;
}

.fx_home_06 > .flex_block_child.blockA {
  width: 50rem;
  padding-top: 9rem;
  padding-bottom: 9rem;
  padding-left: 5rem;
}

.fx_home_06 > .flex_block_child.blockA .ttl_img_h2 {
  margin-left: -.9rem;
  margin-top: 0;
  margin-bottom: 2.85rem;
}

.fx_home_06 > .flex_block_child.blockB {
  width: calc( 100% - 50rem );
}

.fx_home_06 > .flex_block_child.blockB iframe {
  display: block;
  width: 100%;
  height: 100%;
}

.address_home_06 {
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 2;
  margin-bottom: 3.55rem;
}

.address_home_06 h3 {
  font-weight: 600;
}

.address_home_06 p {
  padding-left: 1em;
}

.bnr_line {
  display: block;
  width: 27.3rem;
}

/* フローティングバナー
------------------------------- */
.fl_bur_wrap {
  position: fixed;
  top: 50%;
  right: 0;
  z-index: 100;
  -webkit-transform: translateY(-50%) translateX(0);
  transform: translateY(-50%) translateX(0);
  width: 0;
  height: 70rem;
}

.f_bnr_01 {
  display: block;
  width: 10rem;
  background-color: #fff;
  position: absolute;
  top: 0;
  right: -.5rem;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

.f_bnr_01 img {
  display: block;
  width: 100%;
}

.f_bnr_01:hover {
  right: 0;
}

.f_bnr_02 {
  display: block;
  width: 30rem;
  position: absolute;
  right: -20.5rem;
  bottom: 0;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

.f_bnr_02 img {
  display: block;
  width: 100%;
}

.f_bnr_02:hover {
  right: 0;
}

/* ----------------------------------------

下層

---------------------------------------- */
/* header
------------------------------- */
#page_header {
  height: 10.3rem;
  position: relative;
  z-index: 10;
  width: 100%;
}

#page_header .ttl_h1 {
  position: absolute;
  top: auto;
  bottom: -5rem;
  left: 50%;
  width: 12.9rem;
  margin: 0;
  padding: 0;
}

#page_header .ttl_h1 img {
  width: 100%;
  margin: 0 !important;
}

/* page_container
------------------------------- */
.page_container {
  position: relative;
  z-index: 2;
  padding-top: 15rem;
}

.page_container::before {
  content: '';
  display: block;
  width: 150rem;
  max-width: calc(100% - 3.7rem);
  background-color: #f7f3eb;
  position: absolute;
  top: 0;
  bottom: 6.7rem;
  left: 50%;
  -webkit-transform: translateY(0) translateX(-50%);
  transform: translateY(0) translateX(-50%);
  margin-left: 3.7rem;
  z-index: -1;
}

.page_container::after {
  content: '';
  display: block;
  width: 150rem;
  max-width: calc(100% - 3.7rem);
  background-color: #fbf8f1;
  position: absolute;
  top: 6.7rem;
  bottom: 0;
  right: 50%;
  -webkit-transform: translateY(0) translateX(50%);
  transform: translateY(0) translateX(50%);
  margin-right: 3.7rem;
  z-index: -1;
}

/* page_01
------------------------------- */
.page_01, .page_02 {
  width: 120rem;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  background-image: url("../img/page/img_01.jpg");
  background-size: 100% auto;
  background-position: center 0;
  background-repeat: no-repeat;
  padding-top: 9.25rem;
  padding-bottom: 10rem;
}

.ttl_h2_page {
  text-align: center;
  font-size: 2.4rem;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: .2em;
  margin-bottom: 3.5rem;
}

.page_01_p {
  text-align: center;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 2;
  margin-bottom: 4.25rem;
}

.page_inner {
  width: 80rem;
  padding: 5rem;
  background-color: #fff;
  border: 1px solid #000;
}

.page_inner_child {
  background-color: #fbf8f1;
  padding: 4.25rem 8rem;
}

.page_inner_child + .page_inner_child {
  margin-top: 2.5rem;
}

.ttl_h3_page_inner_child {
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: .1em;
  text-align: center;
  margin-bottom: 1.85rem;
  color: #e73759;
}

.img_page_inner_child_01, .img_page_inner_child_02 {
  display: block;
  width: 100%;
}

.p_page_inner_child {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 2;
  text-align: center;
  margin-top: 1.65rem;
}

.p_page_inner_child .linemk {
  padding-left: .5em;
  padding-right: .5em;
  font-weight: 700;
}

/* page_02
------------------------------- */
.page_02 {
  background-image: url("../img/page/img_04.jpg");
}

.fx_page_02_01 {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: flex-start;
  /*横方向（Safari用）*/
  justify-content: flex-start;
  /*横方向*/
  gap: 1rem .8rem;
  margin-bottom: .75rem;
}

.fx_page_02_01 > .flex_block_child {
  width: calc((100% - (.8rem * 2 ) - 1px) / 3 );
  position: relative;
}

.fx_page_02_01 > .flex_block_child img {
  display: block;
  width: 100%;
}

.fx_page_02_01 > .flex_block_child .p_fx_page_02_01 {
  position: absolute;
  top: 13rem;
  left: 0;
  width: 100%;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.5;
  padding-left: 1.6rem;
  padding-right: 1.6rem;
  text-align: justify;
  text-justify: inter-ideograph;
}

.page_02 .ttl_h3_page_inner_child + .p_page_inner_child {
  margin-top: 1.9rem;
  margin-bottom: 3.05rem;
  margin-left: -1em;
  margin-right: -1em;
}

.fx_page_02_02 {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: flex-start;
  /*横方向（Safari用）*/
  justify-content: flex-start;
  /*横方向*/
  gap: .8rem;
}

.fx_page_02_02 > .flex_block_child {
  width: calc((100% - (.8rem * 2 ) - 1px) / 3 );
  position: relative;
}

.fx_page_02_02 > .flex_block_child img {
  display: block;
  width: 100%;
}

.fx_page_02_02 > .flex_block_child .p_fx_page_02_02 {
  position: absolute;
  top: 16.75rem;
  left: 0;
  z-index: 1;
  width: 100%;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.5;
  text-align: justify;
  text-justify: inter-ideograph;
  padding-left: 1.6rem;
  padding-right: 1.6rem;
}

.p_page_inner_child small {
  font-size: 1rem;
}

/* ----------------------------------------

23.05.02 改修

---------------------------------------- */
/* home_07
------------------------------- */
.home_07 {
  margin-top: 20.8rem !important;
  padding-top: 10.7rem !important;
  padding-bottom: 5.8rem !important;
}

.home_07 .ttl_img_h2 {
  text-align: center;
  margin-bottom: 0;
}

.home_07 .ttl_img_h2 .ttl_img {
  margin: 0 auto;
}

.home_07 .ttl_img_h2 + p {
  text-align: center;
  font-size: 2.4rem;
  letter-spacing: .01em;
  font-weight: 400;
  line-height: 1.6;
  margin-top: 1.0rem;
  margin-bottom: -.7rem;
}

.home_07::before {
  height: 108.5rem;
  background-color: #fbf8f1;
  margin-right: auto;
  margin-left: -5.5rem;
  right: auto;
  left: 50%;
  -webkit-transform: translateY(0) translateX(-50%);
  transform: translateY(0) translateX(-50%);
}

.home_07::after {
  height: 90rem;
  background-color: #f7f3eb;
  margin-left: auto;
  margin-right: -5.5rem;
  right: 50%;
  left: auto;
  -webkit-transform: translateY(0) translateX(50%);
  transform: translateY(0) translateX(50%);
}

.fx_home_07 {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: space-between;
  /*横方向（Safari用）*/
  justify-content: space-between;
  /*横方向*/
}

.fx_home_07 > .flex_block_child {
  width: 56.5rem;
  position: relative;
}

.fx_home_07 > .flex_block_child p {
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: center;
  /*縦方向（Safari用）*/
  align-items: center;
  /* 縦方向*/
  -webkit-justify-content: center;
  /*横方向（Safari用）*/
  justify-content: center;
  /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 19rem;
  height: 19rem;
  padding-left: 1em;
  font-size: 1.5rem;
  line-height: 1.5;
  letter-spacing: -.05em;
  font-weight: 500;
  color: #c64153;
  position: absolute;
  z-index: 1;
  text-align: left;
}

.ver_230502_img_right, .ver_230502_img_left, .ver_230502_img_btm {
  display: block;
  width: 100%;
}

.home_07_bottm {
  width: 55.2rem;
  margin: -10.4rem auto 0;
  position: relative;
  z-index: 1;
  -webkit-transform: translateY(0) translateX(1.4rem);
  transform: translateY(0) translateX(0.4rem);
}

.caption_01 {
  top: 8.9rem;
  left: 0;
}

.caption_02 {
  top: 0;
  left: 18.7rem;
}

.caption_03 {
  top: 8.9rem;
  right: 0;
  -webkit-justify-content: flex-end;
  /*横方向（Safari用）*/
  justify-content: flex-end;
  /*横方向*/
  padding-left: 0;
  padding-right: 1em;
}

.caption_04 {
  top: 46.4rem;
  left: 0;
}

.caption_05 {
  top: 55.4rem;
  left: 18.7rem;
}

.caption_06 {
  top: 46.4rem;
  right: 0;
  -webkit-justify-content: flex-end;
  /*横方向（Safari用）*/
  justify-content: flex-end;
  /*横方向*/
  padding-left: 0;
  padding-right: 1em;
}

/* ----------------------------------------

23.09.08 改修

---------------------------------------- */
/* MV
------------------------------- */
._ver230908 .ttl_h1 {
  padding-top: 8.7rem;
  padding-left: 5.3rem;
  letter-spacing: .2em;
  font-feature-settings: "palt";
  padding-left: 6rem;
}
._ver230908 .ttl_h1 small {
  display: block;
  font-size: 3.6rem;
  font-feature-settings: "palt";
  letter-spacing: .2em;
  margin-bottom: 1.8rem;
}
._ver230908 .ttl_h1 img {
  display: block;
  width: 26.4rem;
  margin-bottom: 4.6rem;
  margin-left: -0.7rem;
}
._ver230908 .news_wrap {
  padding: 3.7rem 0 3.7rem 16rem;
  -webkit-transform: translateY(-37.9%) translateX(0);
  transform: translateY(-37.9%) translateX(0);
}
._ver230908 .fx_news > .flex_block_child.blockB {
  font-feature-settings: "palt";
}

/* 料金表
------------------------------- */
._ver230908 .home_03 {
  margin-bottom: 6.1rem;
  padding-top: 11rem;
}

._ver230908 .fx_home_03 {
  position: relative;
}

.pricing_table {
  display: block;
  width: 100%;
}

.pricing_table_fuki {
  display: block;
  width: 14.5rem;
  position: absolute;
  right: -12rem;
  bottom: 15rem;
  z-index: 1;
}

/* cta_block
------------------------------- */
.cta_block {
  min-height: 42.5rem;
  border: 1px solid #000;
  background-color: #f9ede3;
  background-image: url("../img/home/ver_230908/cta_bg.png");
  background-size: 152rem auto;
  background-position: center center;
  background-repeat: no-repeat;
}
.cta_block .wrap_in {
  position: relative;
  padding-top: 12.8rem;
}
.cta_block--ttl {
  font-size: 3rem;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.15em;
  color: #0e0405;
  text-align: center;
  margin-bottom: 4.5rem;
  padding-left: 4.3rem;
}
.cta_block--img {
  display: block;
  width: 14.6rem;
  position: absolute;
  top: 3.8rem;
  left: 27rem;
}

/* home_01
------------------------------- */
._ver230908 .home_01 {
  padding-top: 19rem;
  padding-bottom: 8.8rem;
}
._ver230908 .home_01 .home_cp231031 {
  display: block;
  width: 110rem;
  margin: 0 auto;
}

/* home_08
------------------------------- */
.home_08 {
  padding-top: 8.9rem;
  padding-bottom: 2.6rem;
  background-image: url("../img/home/ver_230908/home_08_bg.png");
  background-size: 140rem auto;
  background-position: center 16.6rem;
  background-repeat: no-repeat;
  background-color: #f7f3eb;
}
.home_08 .ttl_img_h2 {
  margin-bottom: 0;
}
.home_08 .ttl_img_h2 .ttl_img {
  height: 5.719rem;
  left: -1rem;
  position: relative;
}
.home_08--block {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: flex-start;
  /*横方向（Safari用）*/
  justify-content: flex-start;
  /*横方向*/
  width: 100%;
  margin-top: -3.2rem;
}
.home_08--block-child {
  width: 50%;
}
.home_08--block-child._blockA {
  height: 45rem;
}
.home_08--block-child._blockA img {
  display: block;
  width: 100%;
  height: 100%;
}
.home_08--block-child._blockB {
  padding-top: 7.8rem;
  padding-left: 4.5rem;
}
.home_08--block-ttl {
  font-size: 3.6rem;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0;
  margin-bottom: 2rem;
  color: #f15459;
}
.home_08--block-p {
  font-size: 2.4rem;
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: .03em;
  padding-left: 2.5rem;
  margin-top: 0rem;
  margin-left: 4rem;
  background-image: url("../img/home/ver_230908/ico_check.png");
  background-size: 1.4rem auto;
  background-position: 0 1.4rem;
  background-repeat: no-repeat;
}
.home_08--block-p strong {
  color: #8f1919;
  font-weight: 700;
}

/* home_02
------------------------------- */
._ver230908 .home_02 {
  background-color: #f7f3eb;
  background-image: url("../img/home/ver_230908/home_02_bg.png");
  background-size: 100% auto;
  background-position: 0 58rem;
  background-repeat: no-repeat;
  margin-bottom: 8.8rem;
}
._ver230908 .home_02 .btn_wrapA {
  padding: 6.5rem 0 5.5rem;
}

._ver230908 .fx_home_02 > .flex_block_child.blockA {
  width: 24rem;
}
._ver230908 .fx_home_02 > .flex_block_child.blockA p {
  font-feature-settings: "palt";
}
._ver230908 .fx_home_02 > .flex_block_child.blockB {
  width: calc( 100% - 24rem - 3rem - 1px );
}

/* home_09
------------------------------- */
.home_09 {
  padding: 8.6rem 0 4.8rem;
}
.home_09--ttl_h2 {
  margin-bottom: -.6rem;
  position: relative;
  z-index: 1;
}
.home_09--ttl_h2 img {
  display: block;
  width: 13rem;
  margin: 0 auto;
}
.home_09--in {
  background-position: center 5rem;
  background-repeat: no-repeat;
  margin-bottom: 5rem;
}
.home_09--in:nth-of-type(odd) {
  background-image: url("../img/home/ver_230908/home_09_bgA.png");
  background-size: 140rem auto;
}
.home_09--in:nth-of-type(even) {
  background-image: url("../img/home/ver_230908/home_09_bgB.png");
  background-size: 139.4rem auto;
}
.home_09--in:nth-of-type(even) .home_09--block {
  flex-direction: row-reverse;
}
.home_09--block {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: flex-start;
  /*横方向（Safari用）*/
  justify-content: flex-start;
  /*横方向*/
  width: 120rem;
  margin: 0 auto;
}
.home_09--block-child {
  width: 50%;
}
.home_09--block-child._blockA {
  height: 45rem;
}
.home_09--block-child._blockA img {
  display: block;
  width: 100%;
  height: 100%;
}
.home_09--block-child._blockB {
  padding-top: 9.2rem;
  padding-left: 5rem;
}
.home_09--block-child._blockB h3 img {
  display: block;
  width: auto;
  height: 5.694rem;
  margin: 0 auto 0 0;
}
.home_09--block-child._blockB p {
  font-size: 1.8rem;
  font-weight: 400;
  letter-spacing: .03em;
  font-feature-settings: "palt";
  line-height: 1.5;
  margin-top: 1.6rem;
}
.home_09--block-child._blockB p span {
  display: block;
  margin-top: 1.4em;
}
.home_09--block-child._blockB p span._s {
  font-size: 1.4rem;
}

/* home_07
------------------------------- */
._ver230908 .home_07 {
  margin-top: 9.4rem !important;
}

/* home_05
------------------------------- */
._ver230908 .home_05 {
  margin-top: 7.5rem;
  padding-top: 9.3rem;
}

/* fx_home_01B
------------------------------- */
._ver230908 .fx_home_01B > .flex_block_child {
  display: block;
  width: 25%;
}

/* 中 middle
------------------------------- */
._ver230908 .fl_bur_wrap {
  height: 90.15rem;
}


@media (min-width: 769px) {
  .space_x{height:150px;}
}