@charset "UTF-8";
/* =======================================
共通設定
======================================= */
html {
  font-size: 1.3333333333vw;
}

body {
  width: 100%;
  height: auto;
  background: #ffffff;
  font-size: 2.4rem;
  line-height: 1.8;
  color: #000000;
}

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

img {
  height: auto;
}

#container {
  width: 100%;
}

.pc {
  display: none !important;
}

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

.wrap_in {
  width: 69rem;
  height: auto;
  margin: 0 auto;
  padding: 0 2.5rem;
}

/* 横並びリスト */
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;
}

.table_block.sp_tate {
  display: block;
  table-layout: auto;
}

.table_block.sp_tate > .cell_block {
  display: block;
  width: 100%;
}

/* スクローラー */
#scroller {
  position: fixed;
  bottom: 14rem;
  right: 2rem;
  display: block;
  width: 8rem;
  height: 8rem;
  z-index: 1000;
}

#scroller.pagescroller {
  bottom: 2rem;
}

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

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

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

#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: center;
  /*横方向（Safari用）*/
  justify-content: center;
  /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  width: 100%;
  position: absolute;
  bottom: 2.6rem;
  left: 0;
  text-align: center;
  z-index: 1;
  gap: 3.2rem;
}

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

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

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

.ttl_h1 {
  width: 64rem;
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateY(0) translateX(-50%);
  transform: translateY(0) translateX(-50%);
  padding-top: 32.8rem;
  padding-left: .4rem;
  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;
  /*24.3rem;*/
  margin-bottom: 7.2rem;
  /*9.2rem*/
  margin-left: -1.2rem;
}

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

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

#footer.home_foter {
  height: 42rem;
  padding-bottom: 12rem;
}

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

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

.ttl_img_h2 {
  margin-bottom: 4.5rem;
}

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

.news_wrap {
  width: 100%;
  padding: 8rem 2.5rem;
  position: relative;
  border-bottom: 1px solid #000;
  background-color: #fff;
}

.news_wrap .ttl_img_h2 {
  position: absolute;
  top: -5.4rem;
  left: 2.5rem;
}

.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-bottom: 5.3rem;
  border-bottom: 1px solid #dcdcdc;
}

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

.fx_news > .flex_block_child.blockA {
  width: 17rem;
  font-size: 2.4rem;
  line-height: 1.5;
  text-align: left;
  padding-left: 1rem;
}

.fx_news > .flex_block_child.blockB {
  width: calc(100% - 17rem);
  font-size: 2.4rem;
  line-height: 1.5;
}

.news_wrap_inner {
  width: 100%;
  overflow-y: auto;
  max-height: 30rem;
}

/* home_01
------------------------------- */
.home_01 {
  padding: 12rem 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: 4rem;
}

.fx_home_01 > .flex_block_child {
  position: relative;
  width: 100%;
}

.fx_home_01 > .flex_block_child p {
  position: absolute;
  top: 45.65rem;
  left: 0;
  width: 100%;
  font-size: 3.6rem;
  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: 10.95rem;
}

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

.home_01_p {
  font-size: 2.4rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: 0;
  text-align: center;
  margin-top: 4.85rem;
}

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

.ttl_img_h2.add_logo::after {
  content: "";
  display: block;
  width: 26rem;
  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: -2rem;
}

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

.home_02, .home_07 {
  padding-top: 13.8rem;
  padding-bottom: 19rem;
  position: relative;
  z-index: 2;
  overflow: hidden;
}

.home_02::before, .home_07::before {
  content: "";
  display: block;
  width: 64rem;
  height: 100%;
  background-color: #fbf8f1;
  position: absolute;
  top: 18rem;
  left: 0;
  z-index: -1;
}

.home_02::after, .home_07::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-color: #f7f3eb;
  position: absolute;
  top: 35.4rem;
  left: 0;
  z-index: -1;
}

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

.fx_home_02 > .flex_block_child.blockA {
  width: 100%;
}

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

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

.fx_home_02 > .flex_block_child.blockB {
  width: 100%;
}

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

.fx_home_02_child > .flex_block_child {
  width: 100%;
  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: 4rem;
  font-size: 2.4rem;
  font-weight: 400;
  line-height: 2;
  letter-spacing: .1em;
  color: #fff;
  text-align: justify;
  text-justify: inter-ideograph;
}

.btn_wrapA {
  width: 100%;
  padding: 13rem 0;
  margin: 11.8rem auto 0;
  position: relative;
  background-color: #fff;
}

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

.btn_more {
  display: block;
  width: 50rem;
  height: 12rem;
  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: 2.8rem;
  font-weight: 600;
  line-height: 1.4;
  letter-spacing: .2em;
  text-align: center;
  background-color: #ffe9df;
  border: 1px solid #000;
  -webkit-border-radius: 1rem;
  border-radius: 1rem;
  margin: 0 auto;
  position: relative;
}

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

/* home_03
------------------------------- */
.home_03 {
  background-color: #fbf8f1;
  position: relative;
  z-index: 2;
}

.home_03 .wrap_in {
  position: relative;
  padding: 36.5rem 0 14rem;
  position: relative;
}

.home_03 .wrap_in .ttl_img_h2 {
  position: absolute;
  top: -5.4rem;
  left: 0;
  z-index: 1;
  margin: 0;
}

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

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

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

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

.fx_home_03 > .flex_block_child.blockA {
  width: 100%;
}

.fx_home_03 > .flex_block_child.blockB {
  margin-top: 2.3rem;
  width: 100%;
}

.tbb_home_03 {
  font-size: 2rem;
  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: 6.5rem;
  font-weight: 700;
}

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

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

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

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

.oval_chip {
  display: inline-block;
  width: 16rem;
  height: calc(2.642rem + 2px);
  background-color: #fff;
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  line-height: 2.642rem;
  color: #fc3359;
  border: 1px solid #fc3359;
  -webkit-border-radius: 2.642rem;
  border-radius: 2.642rem;
  margin-left: .8rem;
}

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

.fx_home_03_child > .flex_block_child {
  width: calc( (100% - 2.4rem - 1px) / 2 );
}

.fx_home_03_child > .fx_home_03_p {
  width: 100%;
  padding-left: 2.4rem;
}

.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: 9.924rem;
  text-align: center;
  background-color: #fff;
}

.fx_home_03_child_p span {
  font-size: 2rem;
  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: 2rem;
  font-weight: 400;
  line-height: 2;
}

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

.home_04::after {
  content: "";
  display: block;
  width: 100%;
  height: auto;
  position: absolute;
  top: 34.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;
  /*横方向*/
  flex-direction: column-reverse;
  padding: 0;
}

.fx_home_04 > .flex_block_child.blockA {
  width: 100%;
}

.fx_home_04 > .flex_block_child.blockB {
  width: 100%;
}

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

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

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

.fx_home_04_child > .flex_block_child {
  width: 100%;
  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.5rem;
}

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

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

/* home_05
------------------------------- */
.home_05 {
  padding-top: 34.6rem;
  padding-bottom: 15rem;
  background-color: #f7f3eb;
}

.home_05 .wrap_in {
  position: relative;
  padding: 17rem 2.5rem 3.2rem;
  position: relative;
  background-color: #fff;
}

.home_05 .wrap_in .ttl_img_h2 {
  position: absolute;
  top: -22rem;
  left: 0;
  z-index: 1;
  margin: 0;
}

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

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

.aco_ttl {
  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;
  min-height: 14.0rem;
  font-weight: 400;
  line-height: 1.4;
  padding: 3.2rem 10.8rem 3.2rem 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: 5rem;
  right: 4.8rem;
}

.aco_box p {
  padding: 3.9rem 4.4rem 4.7rem 7.4rem;
  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: center;
  /*横方向（Safari用）*/
  justify-content: center;
  /*横方向*/
  width: 100%;
}

.fx_home_06 > .flex_block_child.blockA {
  width: 100%;
  padding-top: 15.3rem;
  padding-bottom: 9.9rem;
  padding-left: 5rem;
  padding-right: 5rem;
}

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

.fx_home_06 > .flex_block_child.blockB {
  width: 100%;
  height: 73.3rem;
}

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

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

.address_home_06 h3 {
  font-weight: 600;
}

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

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

/* フローティングバナー
------------------------------- */
.fl_bur_wrap {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 999;
  width: 100%;
  display: -webkit-flex;
  display: flex;
  -webkit-align-items: flex-end;
  /*縦方向（Safari用）*/
  align-items: flex-end;
  /* 縦方向*/
  -webkit-justify-content: center;
  /*横方向（Safari用）*/
  justify-content: center;
  /*横方向*/
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

.fl_bur_wrap a {
  display: block;
  width: 50%;
}

.fl_bur_wrap a img {
  display: block;
  width: 100%;
}

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

下層

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

#page_header .ttl_h1 {
  position: absolute;
  top: auto;
  bottom: -10rem;
  left: 50%;
  width: 25.5rem;
  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: 33.8rem;
}

.page_container::before {
  content: '';
  display: block;
  width: 100%;
  background-color: #f7f3eb;
  position: absolute;
  top: 0;
  bottom: 14.8rem;
  left: 0;
  z-index: -1;
}

.page_container::after {
  content: '';
  display: block;
  width: 150rem;
  background-color: #fbf8f1;
  position: absolute;
  top: 14.8rem;
  bottom: 0;
  right: 0;
  z-index: -1;
}

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

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

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

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

.page_inner_child {
  background-color: #fbf8f1;
  padding: 4.85rem 0 7.55rem;
}

.page_inner_child .p_page_inner_child {
  margin-left: -1em;
  margin-right: -1em;
}

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

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

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

.img_page_inner_child_02 {
  display: block;
  width: 60rem;
  margin-left: auto;
  margin-right: auto;
}

.p_page_inner_child {
  font-size: 2.4rem;
  font-weight: 400;
  line-height: 2;
  text-align: center;
  margin-top: 6.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_sp.jpg");
  padding-top: 11.45rem;
}

.page_02 .ttl_h2_page {
  margin-bottom: 8.9rem;
}

.page_02 .page_01_p {
  font-size: 2.3rem;
  margin-bottom: 4.45rem;
}

.page_02 .page_inner_child:nth-last-child(2), .page_02 .page_inner_child:nth-last-child(3) {
  padding-bottom: 2.5rem;
}

.page_02 .page_inner_child:last-child {
  padding-top: 2.35rem;
}

.page_02 .page_inner_child:last-child .p_page_inner_child {
  margin-top: 3.55rem;
}

.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 2.3rem;
  padding-left: 2.5rem;
  padding-right: 2.5rem;
}

.fx_page_02_01 > .flex_block_child {
  width: calc((100% - 2.3rem - 1px) / 2 );
  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: 21rem;
  left: 0;
  width: 100%;
  font-size: 1.935rem;
  font-weight: 400;
  line-height: 1.5;
  padding-left: 2.6rem;
  padding-right: 2.6rem;
  text-align: justify;
  text-justify: inter-ideograph;
}

.page_02 .ttl_h3_page_inner_child {
  margin-top: 2.5rem;
}

.page_02 .ttl_h3_page_inner_child + .p_page_inner_child {
  margin-top: 5.3rem;
  margin-bottom: 4.6rem;
  margin-left: -1em;
  margin-right: -1em;
  font-size: 2.3rem;
}

.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: 2rem;
  padding-left: 2.0rem;
  padding-right: 2.0rem;
}

.fx_page_02_02 > .flex_block_child {
  width: 100%;
  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: 0;
  right: 0;
  z-index: 1;
  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: 29rem;
  height: 100%;
  font-size: 2.4rem;
  font-weight: 400;
  line-height: 1.5;
  text-align: justify;
  text-justify: inter-ideograph;
  padding-right: 1.6rem;
}

.fx_page_02_02 + .p_page_inner_child {
  margin-top: 3.9rem;
}

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

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

23.05.02 改修

---------------------------------------- */
/* home_07
------------------------------- */
.home_07 {
  padding-top: 13rem !important;
  padding-bottom: 6.6rem !important;
}

.home_07 .wrap_in {
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

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

.home_07 .ttl_img_h2 .ttl_img {
  height: 7rem;
  margin: 0 auto;
}

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

.home_07::before {
  width: 100%;
  height: 100%;
  background-color: #fbf8f1;
  left: 0;
  top: 0;
}

.home_07::after {
  width: 70.4rem;
  height: auto;
  background-color: #f7f3eb;
  margin-left: 0;
  margin-right: 0;
  right: 0;
  left: auto;
  bottom: 0;
  top: 36.2rem;
  -webkit-transform: translateY(0) translateX(0);
  transform: translateY(0) translateX(0);
}

.fx_home_07 {
  -webkit-align-items: flex-start;
  /*縦方向（Safari用）*/
  align-items: flex-start;
  /* 縦方向*/
  -webkit-justify-content: flex-end;
  /*横方向（Safari用）*/
  justify-content: flex-end;
  /*横方向*/
  padding-right: 4.2rem;
  gap: 7.1rem 0;
}

.fx_home_07 > .flex_block_child {
  width: 63.3rem;
  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: 21.3rem;
  height: 21.3rem;
  padding-left: 1em;
  font-size: 1.68rem;
  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: 62rem;
  margin: 2.4rem 2.9rem 0 auto;
  position: relative;
  z-index: 1;
}

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

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

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

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

.caption_05 {
  bottom: 0;
  left: 21rem;
}

.caption_06 {
  top: 52.1rem;
  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: 25.8rem;
  font-feature-settings: "palt";
}
._ver230908 .ttl_h1 small {
  display: block;
  font-size: .8em;
  margin-bottom: 1.8rem;
}
._ver230908 .fx_news > .flex_block_child.blockB {
  font-feature-settings: "palt";
}

/* 料金表
------------------------------- */
._ver230908 .fx_home_03 {
  position: relative;
}

.pricing_table {
  display: block;
  width: 64.8rem;
  max-width: none;
  margin-left: .6rem;
}

.pricing_table_fuki {
  display: block;
  width: 14.7rem;
  position: absolute;
  right: 0rem;
  bottom: 54rem;
  z-index: 1;
}

/* cta_block
------------------------------- */
.cta_block {
  min-height: 54rem;
  border: 1px solid #000;
  background-color: #f9ede3;
  background-image: url("../img/home/ver_230908/cta_bg_sp.png");
  background-size: 100% auto;
  background-position: center center;
  background-repeat: no-repeat;
}
.cta_block .wrap_in {
  width: 100%;
  position: relative;
  padding-top: 21rem;
}
.cta_block--ttl {
  font-size: 3.6rem;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0.15em;
  color: #0e0405;
  text-align: center;
  margin-bottom: 3.2rem;
  padding-left: .4em;
}
.cta_block--img {
  display: block;
  width: 17.4rem;
  position: absolute;
  top: 1.4rem;
  left: 3.3rem;
}

/* home_01
------------------------------- */
._ver230908 .home_01 {
  padding-bottom: 15rem;
}
._ver230908 .home_01 .home_cp231031 {
  display: block;
  width: 100%;
  margin: 0 auto;
}

/* home_02
------------------------------- */
._ver230908 .fx_home_02 > .flex_block_child.blockA p {
  font-feature-settings: "palt";
  letter-spacing: .05em;
}

._ver230908 .fx_home_02_child > .flex_block_child p {
  font-feature-settings: "palt";
  letter-spacing: .15em;
}

/* home_08
------------------------------- */
.home_08 {
  padding-top: 8.7rem;
  padding-bottom: 14rem;
  background-image: url("../img/home/ver_230908/home_08_bg_sp.png");
  background-size: 69rem auto;
  background-position: center 39.5rem;
  background-repeat: no-repeat;
  background-color: #f7f3eb;
}
.home_08 .ttl_img_h2 {
  margin-bottom: 0;
}
.home_08 .ttl_img_h2 .ttl_img {
  height: 9.536rem;
  position: relative;
}
.home_08--block {
  width: 60rem;
  margin-top: -1.5rem;
  margin-left: auto;
  margin-right: auto;
}
.home_08--block-child {
  width: 100%;
}
.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: 4.3rem;
}
.home_08--block-ttl {
  font-size: 4.8rem;
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: 0;
  margin-bottom: 2.2rem;
  color: #f15459;
}
.home_08--block-p {
  font-size: 3.2rem;
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: .03em;
  font-feature-settings: "palt";
  padding-left: 4rem;
  margin-top: 1.1rem;
  margin-right: -1em;
  background-image: url("../img/home/ver_230908/ico_check.png");
  background-size: 2.8rem auto;
  background-position: 0 1.5rem;
  background-repeat: no-repeat;
}
.home_08--block-p strong {
  color: #8f1919;
  font-weight: 700;
}

/* home_09
------------------------------- */
.home_09 {
  padding: 5.3rem 0 .1rem;
}
.home_09--ttl_h2 {
  margin-bottom: 7.7rem;
  position: relative;
  z-index: 1;
}
.home_09--ttl_h2 img {
  display: block;
  width: 18.7rem;
  margin: 0 auto;
}
.home_09--in {
  background-image: url("../img/home/ver_230908/home_09_bg_sp.png");
  background-repeat: no-repeat;
  background-size: 69.5rem auto;
  margin-bottom: 6rem;
}
.home_09--in:nth-of-type(odd) {
  background-position: left 10rem;
}
.home_09--in:nth-of-type(even) {
  background-position: right 10rem;
}
.home_09--block {
  width: 69rem;
  margin: 0 auto;
}
.home_09--block-child._blockA {
  width: 60rem;
  height: 45rem;
  margin: 0 auto -22.5rem;
  position: relative;
  z-index: 1;
}
.home_09--block-child._blockA img {
  display: block;
  width: 100%;
  height: 100%;
}
.home_09--block-child._blockB {
  width: 100%;
  padding: 30rem 4rem 7rem;
  background-color: #f7f3eb;
}
.home_09--block-child._blockB h3 img {
  display: block;
  width: auto;
  height: 9.109rem;
  margin: 0 auto 0 0;
}
.home_09--block-child._blockB p {
  font-size: 2.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: 2.4rem;
}

/* home_05
------------------------------- */
._ver230908 .home_05 {
  margin-top: 8.5rem;
}
