@charset "UTF-8";
/*
Theme Name: child
Theme URI:
Description:
Template: twentytwentyone
Author: makesview
Author URI: https://makes-view.co.jp/
Version: 1.0.0
*/
/* フォント */
@font-face {
  font-family: "AozoraMincho";
  src: url(./font/AozoraMinchoMedium.woff2) format("woff2");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "AozoraMincho";
  src: url(./font/AozoraMincho-bold.woff2) format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "AozoraMincho";
  src: url(./font/AozoraMinchoHeavy.woff2) format("woff2");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
:root {
  --main-color: #000;
  --sub-color: #fff;
}

html,
button,
input,
select,
textarea {
  font-family: "AozoraMincho", sans-serif;
}

html {
  min-width: 1440px;
  scroll-behavior: smooth;
}

body {
  color: #333333;
  font-size: 16px;
  line-height: 1.5;
  min-width: 1440px;
}

.wrap {
  width: 1140px;
  margin: 0 auto;
}

.wrap.mid {
  width: 1240px;
}

.wrap.lr {
  width: 1340px;
}

/* PC固定ページ 共通設定 */
.common_page_main {
  padding: 200px 0 42px;
  position: relative;
  z-index: 1;
}

.common_page_main .bg_image {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-image: url("./image/page_mv_bg02.webp");
  background-size: cover;
  background-position: bottom;
  background-repeat: no-repeat;
  z-index: -1;
}

.common_page_main .bg_image::before {
  content: "";
  width: 100%;
  height: 100%;
  background-image: url("./image/page_mv_bg01.webp");
  background-size: cover;
  background-position: bottom;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
}

.common_page_main .bg_image::after {
  content: "";
  width: 100%;
  height: 100%;
  background-image: url("./image/page_mv.webp");
  background-size: cover;
  background-position: bottom;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
}

.common_page_main .title_box {
  margin-bottom: 70px;
}

.common_page_main .title_box .title {
  font-size: 36px;
  letter-spacing: 0.16em;
  font-weight: 700;
  color: #fff;
}

.common_page_wrap {
  padding: 100px 0;
}

.not_found .text {
  text-align: center;
}

.reserve_text {
  text-align: center;
  font-size: 30px;
}

/* パンくず */
.breadcrumb {
  font-size: 12px;
  color: #333;
  letter-spacing: 0.09em;
  text-align: right;
}

.breadcrumb a {
  text-decoration: none;
  color: #afafaf;
}

/* PC固定ページ お問い合わせ */
.contact_form_disc {
  color: #3e3e3e;
  letter-spacing: 0.08em;
  font-weight: 400;
  text-align: center;
  margin-block: 0 3.8em;
}

.contact_form_disc .text {
  font-size: 16px;
  margin-block: 0 1em;
}

.contact_form_disc .caution {
  font-size: 14px;
}

.common_contact_form .form_box {
  margin-block: 0 50px;
}

.common_contact_form .form_box dl {
  display: grid;
  grid-template-columns: 26.5% 1fr;
  align-items: center;
  gap: 80px;
}

.common_contact_form .form_box dl.start {
  align-items: flex-start;
}

.common_contact_form .form_box dl + dl {
  margin-block: 1.6em 0;
}

.common_contact_form .form_box dl dt {
  display: flex;
  align-items: center;
  gap: 1.3em;
  font-size: 16px;
  letter-spacing: 0.08em;
  font-weight: 700;
  padding-inline: 0 0.5em;
  position: relative;
}

.common_contact_form .form_box dl dt .label {
  flex-shrink: 0;
  color: #3e3e3e;
  font-size: 12px;
  letter-spacing: 0.2em;
  font-weight: 700;
  border-radius: 100vmax;
  padding: 0.2em 0.9em;
}

.common_contact_form .form_box dl dt .label.hissu {
  background: #c70000;
  color: #fff;
}

.common_contact_form .form_box dl dt .label.ninni {
  background: #e0e0e0;
}

.common_contact_form .form_box dl dt::after {
  content: "";
  width: 1px;
  height: 30px;
  background: #aaa;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}

.common_contact_form input[type=text],
.common_contact_form input[type=email],
.common_contact_form #zip {
  width: 100%;
  background: #f8f8f8;
  border: 1px solid #e6e6e6;
  border-radius: 4px;
  font-size: 14px;
  letter-spacing: 0.08em;
  font-weight: 400;
  padding: 0.8em 1em;
}

.common_contact_form textarea {
  width: 100%;
  height: 180px;
  background: #f8f8f8;
  border: 1px solid #e6e6e6;
  border-radius: 4px;
  padding: 1em;
  font-size: 14px;
  letter-spacing: 0.08em;
  font-weight: 400;
}

.common_contact_form input::-moz-placeholder, .common_contact_form textarea::-moz-placeholder {
  color: #c7c4c4;
}

.common_contact_form input::placeholder,
.common_contact_form textarea::placeholder {
  color: #c7c4c4;
}

.common_contact_form select {
  width: 47.5%;
  background: #f8f8f8;
  border: 1px solid #e6e6e6;
  border-radius: 4px;
  font-size: 14px;
  letter-spacing: 0.08em;
  padding: 1.1em 1em;
}

.common_contact_form select.empty {
  color: #c7c4c4;
}

.page_contact #btn_wrap {
  justify-content: center;
  text-align: right;
  width: 74%;
  margin: auto;
}

.page_contact #btn_wrap button {
  background-color: #6fb92d;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  color: #fff;
  display: block;
  width: 310px;
  line-height: 60px;
  font-size: 18px;
  font-weight: 900;
  transition: 0.3s;
  text-align: center;
  letter-spacing: 0.08em;
  margin: auto;
}

.page_contact #btn_wrap button[name=submitBack] {
  background: #333;
  margin-top: 20px;
}

.page_contact #btn_wrap button:hover {
  opacity: 0.8;
}

.privacy_term_outer .privacy_term_inner {
  height: 138px;
  margin: auto;
  overflow: auto;
}

.privacy_term_outer .privacy_term_inner .privacy_index {
  font-size: 14px;
}

.privacy_term_outer .privacy_term_inner .main_text {
  font-size: 13px;
  margin-bottom: 25px;
}

.privacy_term_outer .privacy_term_inner dl dt {
  font-size: 13px;
  border-left: solid 3px #ccc;
  padding-left: 1em;
  margin-bottom: 5px;
}

.privacy_term_outer .privacy_term_inner dl dd {
  font-size: 13px;
}

.privacy_term_outer .privacy_term_inner dl + dl {
  margin-top: 30px;
}

.privacy_term_outer .privacy_term_inner::-webkit-scrollbar {
  width: 8px;
}

.privacy_term_outer .privacy_term_inner::-webkit-scrollbar-track {
  background: transparent;
}

.privacy_term_outer .privacy_term_inner::-webkit-scrollbar-thumb {
  background-color: #333;
  border-radius: 10px;
}

.privacy_term_outer {
  border-top: solid 1px #e3e3e3;
  padding: 30px 0;
  border-bottom: solid 1px #e3e3e3;
  width: 60%;
  margin: 0 auto 50px;
}

.privacy_check_list .mwform-checkbox-field-text {
  padding-right: 0;
}

.privacy_check_list .error {
  font-size: 12px;
}

.privacy_term_detail {
  text-align: center;
  font-size: 13px;
  margin: 20px 0;
  position: relative;
  font-weight: 600;
}

.privacy_term_detail::after {
  content: "";
  margin: 5px auto 0;
  border: solid #333;
  border-width: 2px 2px 0 0;
  width: 10px;
  aspect-ratio: 1/1;
  min-width: 0;
  rotate: 135deg;
  display: block;
}

.mw_wp_form_confirm .privacy_check_list,
.mw_wp_form_confirm .privacy_term_detail {
  display: none;
}

/* ラジオボタン デザイン */
.radio_btns,
.checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5em 1.5em;
  padding: 0.5em 0;
}

/* ラジオボタンを隠す */
.radio_btns input[type=radio].radio_btns__item {
  display: none;
}

.radio_btns label {
  display: inline-block;
  cursor: pointer;
}

/* spanの左側にボタンを配置するスペースを作る */
.radio_btns .radio_btns__item + span {
  color: #3e3e3e;
  font-size: 15px;
  letter-spacing: 0.08em;
  font-weight: 600;
  padding-left: 2em;
  display: inline-block;
  position: relative;
}

/* 各パーツを作成 */
.radio_btns .radio_btns__item + span::before,
.radio_btns .radio_btns__item + span::after {
  content: "";
  display: block;
  position: absolute;
  border: 1px solid #e6e6e6;
  background: #f8f8f8;
  border-radius: 50%;
  width: 20px;
  aspect-ratio: 1;
  min-width: 0;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
}

/* after上書き */
.radio_btns .radio_btns__item + span::after {
  width: 10px;
  aspect-ratio: 1;
  min-width: 0;
  top: 0px;
  left: 5px;
  border: none;
  background: #5a5a5a;
  transform: scale(0);
  transition: all 0.3s;
}

/*
  checked状態
  文字のcolorとボタンのopacityを変更
*/
.radio_btns .radio_btns__item:checked + span::after {
  transform: scale(1);
}

/* チェックボックス デザイン */
.page_contact input[type=checkbox] {
  /* デフォルトcheckボックス非表示*/
  display: none;
}

.mwform-checkbox-field label {
  cursor: pointer;
}

.mwform-checkbox-field-text {
  color: #3e3e3e;
  font-size: 15px;
  letter-spacing: 0.08em;
  font-weight: 600;
  display: inline-block;
  position: relative;
  padding: 0 0 0 30px;
}

.mwform-checkbox-field-text::before,
.mwform-checkbox-field-text::after {
  content: "";
  position: absolute;
  display: block;
}

.mwform-checkbox-field-text::before {
  background: #f8f8f8;
  border: 1px solid #e6e6e6;
  border-radius: 2px;
  width: 20px;
  aspect-ratio: 1/1;
  min-width: 0;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}

.mwform-checkbox-field-text::after {
  border-width: 3px;
  border-color: transparent transparent #333 #333;
  border-style: solid;
  width: 20px;
  aspect-ratio: 2/1;
  min-width: 0;
  margin-top: -0.2em;
  top: 50%;
  left: 0;
  transform: translateY(-50%) rotate(-45deg);
  opacity: 0;
}

input[type=checkbox]:checked + .mwform-checkbox-field-text::after {
  opacity: 1;
}

.mw_wp_form .horizontal-item {
  display: inline-block;
}

.mw_wp_form .horizontal-item + .horizontal-item {
  margin-left: 0 !important;
}

/* サンクスページ */
.page_contact .thanks_textArea .name {
  font-size: 16px;
  line-height: 2;
  text-align: center;
  margin-bottom: 20px;
}

.page_contact .thanks_textArea .contact_text {
  margin: 0 auto 50px;
  width: 62%;
}

.page_contact .thanks_textArea .ichiran_link {
  background-color: var(--main-color);
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  color: #fff;
  display: block;
  width: 300px;
  line-height: 50px;
  border-radius: 4px;
  font-size: 16px;
  transition: 0.3s;
  margin: 0 auto;
  text-decoration: none;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-align: center;
}

.page_contact .thanks_textArea .ichiran_link:hover {
  opacity: 0.8;
}

.page_contact .thanks_textArea .contact_text .space {
  display: block;
}

.page_contact .thanks_textArea .contact_text .space {
  display: block;
  margin-top: 10px;
}

/* ステップバー デザイン */
.page_contact .progressbar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5.6em;
  margin-block: 0 3em;
}

.page_contact .progressbar .item {
  color: #3e3e3e;
  font-size: 14px;
  letter-spacing: 0.08em;
  font-weight: 400;
  text-align: center;
  line-height: 1.5;
  position: relative;
}

.page_contact .progressbar .item + .item::before {
  content: "";
  width: 50px;
  height: 1px;
  background: #e6e6e6;
  position: absolute;
  top: 64%;
  left: -5em;
}

.page_contact .progressbar .item .mark {
  width: 36px;
  aspect-ratio: 1;
  background: #fff;
  border: 1px solid #afafaf;
  border-radius: 50%;
  display: block;
  margin: 0 auto 0.5em;
  position: relative;
}

.page_contact .progressbar .item .mark::before {
  content: "";
  width: 41%;
  aspect-ratio: 1;
  background: #5a5a5a;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
  opacity: 0;
}

.page_contact .progressbar .item.active .mark::before {
  opacity: 1;
}

.page_contact .progressbar .item .en {
  display: block;
  color: #a7a7a7;
  letter-spacing: 0;
  font-family: "Helvetica", "Arial", sans-serif;
}

.privacy_check_list {
  justify-content: center;
  align-items: center;
  margin-bottom: 25px;
}

.privacy_check_list .hissu {
  background: #c70200;
  color: #fff;
  padding: 2px 15px;
  font-size: 10px;
  letter-spacing: 0.08em;
  border-radius: 30px;
  font-weight: 600;
}

.mw_wp_form .privacy_check_list .horizontal-item {
  margin: 0;
}

/* PC固定ページ 404ページ */
#page_404 {
  text-align: center;
}

#page_404 .num {
  font-size: 100px;
  font-family: "Montserrat", "Noto Sans JP", sans-serif;
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

#page_404 .text {
  margin-bottom: 1em;
  font-size: 16px;
}

/* PC固定ページ アーカイブページ */
/* 投稿リスト表示 */
.archive_page_list > article {
  padding-bottom: 15px;
  padding-top: 15px;
  border-bottom: 1px dashed #eee;
  padding-right: 30px;
}

.archive_page_list > article:after {
  content: "";
  position: absolute;
  width: 10px;
  height: 10px;
  top: 0;
  right: 5px;
  bottom: 0;
  margin: auto;
  border: solid #ccc;
  border-width: 2px 2px 0 0;
  transform: rotate(45deg);
}

.archive_page_list > article .date {
  font-weight: bold;
  font-size: 80%;
  width: 100px;
}

.archive_page_list > article .content_area {
  width: calc(100% - 100px);
}

.archive_page_list > article .content_area .ttl {
  font-weight: bold;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}

.archive_page_list > article .content_area .content {
  font-size: 80%;
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}

/* wp-pagenavi base */
.wp-pagenavi {
  text-align: center;
  margin-top: 50px;
}

.wp-pagenavi a,
.wp-pagenavi span {
  display: inline-block;
  color: #999;
  background-color: #fff;
  border: solid 1px #e0e0d2;
  padding: 8px 15px;
  margin: 0 2px;
  border-radius: 3px;
  transition: 0.2s ease-in-out;
  text-align: center;
  text-decoration: none;
}

.wp-pagenavi a:hover {
  color: #fff;
  background-color: var(--main-color);
  border-color: var(--main-color);
}

.wp-pagenavi .current {
  color: #fff;
  background-color: var(--main-color);
  border-color: var(--main-color);
  font-weight: bold;
}

/*----------------------------------------
   トップページ
----------------------------------------*/
/* pc_header
----------------------------------------*/
#pc_header.header {
  background: #fff;
  border-radius: 50px;
  padding: 0 50px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.16);
  position: fixed;
  top: 30px;
  left: 50px;
  width: calc(100% - 100px);
  min-width: 1340px;
  height: 80px;
  z-index: 9999;
}

#pc_header.header .inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1240px;
  margin: 0 auto;
  height: 100%;
}

#pc_header.header .logo_box {
  display: flex;
  align-items: center;
  gap: 30px;
}

#pc_header.header .logo_box .image_box {
  width: 142px;
  height: auto;
}

#pc_header.header .logo_box .image {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

#pc_header.header .logo_box .title {
  font-size: 14px;
  font-weight: 700;
  font-family: "Zen Kaku Gothic New", sans-serif;
  color: #333;
  letter-spacing: 0.1em;
}

#pc_header.header .nav {
  display: flex;
  align-items: center;
}

#pc_header.header .nav .list {
  display: flex;
  align-items: center;
  gap: 36px;
  list-style: none;
  margin: 0;
  padding: 0;
}

#pc_header.header .nav .list .item {
  margin: 0;
}

#pc_header.header .nav .list .item .link {
  font-size: 15px;
  font-weight: 700;
  color: #333;
  font-family: "Zen Kaku Gothic New", sans-serif;
  text-decoration: none;
  transition: all 0.3s;
  letter-spacing: 0.14em;
}

.fixed_box {
  position: fixed;
  top: 420px;
  right: 0;
  z-index: 9999;
}

.fixed_box .btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 240px;
  border-radius: 6px 0 0 6px;
  position: relative;
  transition: all 0.3s;
  text-decoration: none;
  z-index: 1;
  background-color: #6fb92d;
  box-shadow: 0 6px 0 #539815;
}

.fixed_box .btn .btn_text {
  color: #ffffff;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.34em;
  position: relative;
  z-index: 1;
  writing-mode: vertical-rl;
}

/* mv
----------------------------------------*/
.mv {
  position: relative;
  height: 748px;
  width: 100%;
  z-index: 1;
  overflow: hidden;
}

.mv .bg01 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
}

.mv .bg01 .image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: bottom;
     object-position: bottom;
}

.mv .bg02 {
  position: absolute;
  top: 30px;
  right: -256px;
  width: 1391px;
  height: 699px;
  z-index: -1;
}

@media (min-width: 1440px) {
  .mv .bg02 {
    right: -17.77vw;
    width: 96.59vw;
  }
}
.mv .bg02 .image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: bottom;
     object-position: bottom;
}

.mv .slider {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 748px;
  z-index: 1;
}

.mv .slider .slick-list {
  height: 748px;
}

.mv .slider .slick-track {
  height: 748px;
}

.mv .slider .item {
  height: 748px;
  outline: none;
}

.mv .slider .item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
  -o-object-position: bottom;
     object-position: bottom;
}

.mv .slick-dots {
  position: absolute;
  bottom: 45px;
  right: 150px;
  width: auto;
  display: flex;
  justify-content: flex-end;
  gap: 34px;
  list-style: none;
  margin: 0;
  padding: 0;
  z-index: 100;
}

.mv .slick-dots li {
  margin: 0;
  width: 14px;
  height: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mv .slick-dots li button {
  width: 14px;
  height: 14px;
  padding: 0;
  border: none;
  background: #fff;
  border-radius: 50%;
  cursor: pointer;
  font-size: 0;
  line-height: 0;
  display: block;
  transition: all 0.3s;
  position: relative;
  z-index: 1;
}

.mv .slick-dots li button:before {
  display: none;
}

.mv .slick-dots li.slick-active button:before {
  display: none;
}

.mv .slick-dots li.slick-active {
  position: relative;
}

.mv .slick-dots li.slick-active::before {
  content: "";
  width: 30px;
  height: 30px;
  background: #c5e3a9;
  border-radius: 50%;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 0;
}

.mv .slick-dots li.slick-active button {
  background: #5b9823;
  width: 14px;
  height: 14px;
  position: relative;
  z-index: 1;
}

/* MVコンテンツ */
.mv .content {
  position: relative;
  z-index: 10;
  padding-top: 197px;
}

.mv .content .text {
  color: #fff;
  font-weight: 700;
  line-height: 1;
}

.mv .content .text.ls14 {
  letter-spacing: 0.14em;
}

.mv .content .text.ls17 {
  letter-spacing: 0.17em;
}

.mv .content .text.ls16 {
  letter-spacing: 0.16em;
}

.mv .content .text .fz33 {
  font-size: 33px;
}

.mv .content .text .mfz23 {
  font-size: 23px;
}

.mv .content .text .fz70 {
  font-size: 70px;
  font-family: minion-pro, serif;
  font-weight: 500;
}

.mv .content .text .fz34 {
  font-size: 34px;
}

.mv .content .text .highlight {
  color: #f2e90b;
}

.mv .content .text .fz56 {
  font-size: 56px;
}

.mv .content .text .fz36 {
  font-size: 36px;
}

.mv .content .text .fz22 {
  font-size: 22px;
}

.mv .content .text.fukidashi {
  position: relative;
  z-index: 1;
  margin-top: 14px;
  padding-left: 27px;
}

.mv .content .text.fukidashi::before {
  content: "";
  width: 353px;
  height: 39px;
  position: absolute;
  bottom: -24px;
  left: 0;
  background-image: url("././image/fukidashi.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  z-index: -1;
}

.mv .content .text.middle {
  margin-top: 34px;
}

.mv .content .text.bottom {
  margin-top: 18px;
}

.mv .content .btn_area {
  display: flex;
  gap: 30px;
}

.mv .content .btn_area {
  margin-top: 85px;
}

.mv .content .btn_area .btn_box {
  position: relative;
}

.mv .content .btn_area .btn_box .label {
  position: absolute;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: 16px;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.14em;
  white-space: nowrap;
}

.mv .content .btn_area .btn_box .label::before {
  content: "";
  width: 2px;
  height: 18px;
  background-color: #fff;
  position: absolute;
  top: 5px;
  left: -15px;
  transform: skew(20deg);
}

.mv .content .btn_area .btn_box .label::after {
  content: "";
  width: 2px;
  height: 18px;
  background-color: #fff;
  position: absolute;
  top: 5px;
  right: -15px;
  transform: skew(-20deg);
}

.mv .content .btn_area .btn_box .btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 30px;
  width: 360px;
  height: 70px;
  border-radius: 10px;
  position: relative;
  transition: all 0.3s;
  text-decoration: none;
  z-index: 1;
}

.mv .content .btn_area .btn_box .btn_reserve {
  background-color: #6fb92d;
  box-shadow: 0 6px 0 #539815;
}

.mv .content .btn_area .btn_box .btn_contact {
  background-color: #ab7326;
  box-shadow: 0 6px 0 #9b5f16;
}

.mv .content .btn_area .btn_box .btn .btn_text {
  color: #ffffff;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.14em;
  position: relative;
  z-index: 1;
}

.mv .content .btn_area .btn_box .btn .btn_icon {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mv .content .btn_area .btn_box .btn.btn_reserve .btn_icon {
  width: 20px;
  height: 20px;
}

.mv .content .btn_area .btn_box .btn.btn_contact .btn_icon {
  width: 10px;
  height: 18px;
}

.mv .content .btn_area .btn_box .btn .btn_icon .image {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.mv .content .disclaimer {
  font-size: 13px;
  color: #fff;
  font-weight: 700;
  font-family: "Zen Kaku Gothic New", sans-serif;
  letter-spacing: 0.07em;
  margin-top: 17px;
}

/* service
----------------------------------------*/
.service {
  padding: 170px 0 155px;
  overflow: hidden;
}

.service .title {
  font-size: 34px;
  font-weight: 500;
  text-align: center;
  letter-spacing: 0.26em;
  margin: 0 0 33px 0;
  position: relative;
}

.service .title::before {
  content: "";
  position: absolute;
  width: 111px;
  height: 51px;
  top: -82px;
  left: 50%;
  transform: translateX(-50%);
  background-image: url("././image/service_illust01.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.service .cards {
  display: flex;
  justify-content: center;
  gap: 20px;
  margin: 0 0 50px 0;
  flex-wrap: wrap;
}

.service .card {
  width: 212px;
  background: #eff7e9;
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  box-sizing: border-box;
  padding: 27px 0 15px;
}

.service .icon {
  width: 120px;
  height: 120px;
  margin: 0 0 25px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: #fff;
}

.service .icon .image {
  width: 75px;
  height: 75px;
  -o-object-fit: contain;
     object-fit: contain;
}

.service .text {
  font-size: 16px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.12em;
}

.service .description {
  text-align: center;
  letter-spacing: 0.14em;
  font-weight: 700;
}

.service .description .fz20 {
  font-size: 20px;
  display: block;
}

.service .description .fz28 {
  font-size: 28px;
}

.service .description .highlight {
  color: #5b9823;
  position: relative;
}

.service .description .highlight::before {
  content: "※";
  position: absolute;
  bottom: -6px;
  right: -19px;
  font-size: 19px;
  color: #5b9823;
  font-weight: 700;
  letter-spacing: 0.14em;
}

.service .description .fz36 {
  font-size: 36px;
}

.service .disclaimer {
  font-size: 14px;
  text-align: right;
  margin: 15px 0 64px 0;
  letter-spacing: 0.09em;
  font-weight: 700;
}

.service .service_slider {
  overflow: visible;
  pointer-events: none;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
}

.service .service_slider .slick-list {
  margin: 0 -15px;
  overflow: visible;
  padding: 20px 0;
}

.service .service_slider .slick-slide {
  padding: 0 10px;
  height: auto;
}

.service .service_slider .slick-slide:nth-of-type(2n) {
  transform: translateY(20px);
}

.service .service_slide {
  outline: none;
}

.service .service_slide img {
  width: 300px;
  height: 220px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 8px;
  display: block;
}

/* price 
----------------------------------------*/
.price {
  padding: 120px 0 60px;
  background: #faf9f2;
}

.price .banner {
  background: #ac8550;
  padding: 12px 31px;
  text-align: center;
  color: #fff;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 20px;
  border-radius: 23px;
  font-size: 22px;
  letter-spacing: 0.14em;
  line-height: 1;
  position: relative;
}

.price .banner::before {
  content: "";
  position: absolute;
  bottom: -10px;
  left: 50%;
  transform: translateX(-50%);
  width: 29px;
  height: 11px;
  background: #ac8550;
  -webkit-clip-path: polygon(0 0, 100% 0%, 50% 100%);
          clip-path: polygon(0 0, 100% 0%, 50% 100%);
}

.price .title {
  font-size: 42px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.25em;
  margin: 0 0 50px 0;
}

.price .points {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 15px;
  margin: 0 0 20px 0;
}

.price .point {
  background: #fffdef;
  border-radius: 14px;
  border: 2px solid #e6e6aa;
  padding: 20px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
}

.price .point .label_box {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
}

.price .point .label_box .label_text {
  font-size: 24px;
  font-weight: 600;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
  font-style: italic;
}

.price .point .label_box .label_number {
  font-size: 34px;
  font-weight: 600;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
  font-style: italic;
  color: #a59900;
}

.price .point .point_text {
  font-weight: 700;
  letter-spacing: 0.14em;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.price .point .point_text .fz22 {
  font-size: 22px;
}

.price .point .point_text .fz28 {
  font-size: 28px;
}

.price .point .point_text .highlight {
  color: #5ea221;
}

.price .point .point_text .fz47 {
  font-size: 47px;
  font-weight: 500;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
  color: #5ea221;
  line-height: 1;
}

.price .details {
  margin: 0 0 0 0;
  background-color: #fff;
  border-radius: 14px;
  padding: 30px 40px 25px;
  position: relative;
}

.price .details::before {
  content: "";
  position: absolute;
  bottom: -60px;
  left: 0;
  width: 100%;
  height: 3px;
  background-image: url("././image/dashed_line.svg");
  background-size: contain;
  background-repeat: repeat-x;
}

.price .item_box {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.price .item {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.price .item .badge {
  width: 130px;
  height: 130px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: 0.17em;
}

.price .item.basic .badge {
  background: #6fb92d;
  color: #fff;
}

.price .item.extension .badge {
  background: #e2e2e2;
  color: #8d8d8d;
}

.price .item.basic .note {
  background-color: #f5f3d6;
  border-radius: 6px;
  padding: 6px 18px 4px;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.14em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.price .item.basic .note .fz30 {
  font-size: 30px;
  font-weight: 500;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
  line-height: 1;
}

.price .item.extension .note {
  background-color: #959595;
  border-radius: 6px;
  padding: 6px 21px 4px;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.14em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: #fff;
}

.price .item.extension .note .fz30 {
  font-size: 30px;
  font-weight: 500;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
  line-height: 1;
}

.price .item .amount {
  font-weight: 700;
  letter-spacing: 0.14em;
  margin-top: 10px;
}

.price .item .amount .fz80 {
  font-size: 80px;
  font-weight: 700;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
  line-height: 1;
}

.price .item .amount .fz36 {
  font-size: 36px;
}

.price .item .amount .highlight {
  color: #5b9823;
}

.price .item .amount .fz20 {
  font-size: 20px;
  color: #676767;
  position: relative;
}

.price .item .amount .fz20::before {
  content: "※";
  position: absolute;
  bottom: -5px;
  right: -16px;
  font-size: 14px;
  color: #676767;
  font-weight: 700;
  letter-spacing: 0.14em;
}

.price .item .amount .fz60 {
  font-size: 60px;
  font-weight: 700;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
  line-height: 1;
  color: #b1b1b1;
}

.price .item .amount .fz30 {
  font-size: 30px;
  color: #b1b1b1;
}

.price .item .amount .fz16 {
  font-size: 16px;
  color: #b1b1b1;
}

.price .disclaimer {
  font-size: 18px;
  color: #676767;
  text-align: right;
  margin: 15px 0 0 0;
  letter-spacing: 0.14em;
  font-weight: 700;
}

.price .disclaimer .fz14 {
  font-size: 14px;
}

.price .disclaimer .fz26 {
  font-size: 26px;
  font-family: minion-pro, serif;
  font-weight: 600;
  letter-spacing: 0.06em;
}

/* usage
----------------------------------------*/
.usage {
  padding: 60px 0 110px;
  background: #faf9f2;
}

.usage .title {
  font-size: 28px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.25em;
  margin: 0 0 20px 0;
}

.usage .items {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 30px 24px;
}

.usage .item {
  width: 558px;
}

.usage .item .banner {
  font-size: 17px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.14em;
  padding: 9px 34px 12px;
  background-color: #5b9823;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 29px;
  color: #fff;
  margin: 0 auto -25px;
  line-height: 1;
  position: relative;
}

.usage .item .banner .fz29 {
  font-size: 29px;
  margin: 0 -4px;
}

.usage .item .card {
  background: #ffffff;
  align-items: center;
  justify-content: space-between;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.16);
  border-radius: 10px;
  width: 558px;
  display: grid;
  grid-template-columns: 168px 1fr;
  gap: 40px;
  padding: 55px 40px 30px;
}

.usage .item .card .image_box {
  border-radius: 6px;
  overflow: hidden;
}

.usage .item .card .image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.usage .item .card .content {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.usage .item .card .content .price_box {
  display: flex;
  flex-direction: column;
}

.usage .item .card .content .price_box .period {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.14em;
  background-color: #f5f3d6;
  border-radius: 4px;
  width: 100%;
  text-align: center;
  padding: 7px 0 3px;
}

.usage .item .card .content .price_box .period .fz26 {
  font-size: 26px;
  font-weight: 500;
  font-family: minion-pro, serif;
  line-height: 1;
  letter-spacing: 0.06em;
  margin: 0 -4px;
}

.usage .item .card .content .price_box .amount {
  font-weight: 700;
  letter-spacing: 0.04em;
}

.usage .item .card .content .price_box .amount .highlight {
  color: #ab7326;
}

.usage .item .card .content .price_box .amount .fz42 {
  font-size: 42px;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
}

.usage .item .card .content .price_box .amount .fz20 {
  font-size: 20px;
}

.usage .item .card .content .price_box .amount .fz16 {
  font-size: 16px;
  color: #676767;
}

.usage .item .card .content .breakdown .breakdown_title {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.14em;
  position: relative;
  margin-bottom: 10px;
}

.usage .item .card .content .breakdown .breakdown_title::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 198px;
  height: 1px;
  background-image: url("././image/dashed_line02.svg");
  background-size: contain;
  background-repeat: repeat-x;
}

.usage .item .card .content .breakdown .breakdown_amount {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.14em;
  display: flex;
  align-items: last baseline;
  line-height: 1;
}

.usage .item .card .content .breakdown .breakdown_amount + .breakdown_amount {
  margin-top: 5px;
}

.usage .item .card .content .breakdown .breakdown_amount .fz22 {
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
  line-height: 1;
  transform: translateY(2px);
}

.usage .item .card .content .breakdown .breakdown_amount .fz18 {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.14em;
  font-family: adobe-caslon-pro, serif;
}

.usage .item .card .content .breakdown .breakdown_amount .fz14 {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.06em;
  font-family: adobe-caslon-pro, serif;
}

.usage .conclusion {
  text-align: center;
  margin: 60px 0 0 0;
}

.usage .conclusion .text {
  font-size: 23px;
  font-weight: 700;
  letter-spacing: 0.23em;
}

.usage .conclusion .conclusion_text {
  font-size: 38px;
  font-weight: 700;
  letter-spacing: 0.23em;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  z-index: 1;
}

.usage .conclusion .conclusion_text::before {
  content: "";
  position: absolute;
  bottom: 5px;
  left: 0;
  width: 100%;
  height: 17px;
  background-color: #f8f1b7;
  z-index: -1;
}

/* flow
----------------------------------------*/
.flow {
  padding: 190px 0 40px;
}

.flow .title {
  font-size: 32px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.25em;
  margin: 0 0 60px 0;
}

.flow .steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  position: relative;
  z-index: 1;
}

.flow .steps::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #6fb92d;
  z-index: -1;
}

.flow .step {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: #ffffff;
  padding: 0 20px 20px;
  border-radius: 8px;
  width: 100%;
  height: 100%;
  border: 1px solid #6fb92d;
}

.flow .step .label_box {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 5px;
  font-weight: 700;
  padding: 5.5px 13px 6.5px;
  background-color: #5b9823;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 29px;
  color: #fff;
  margin: -18px 0 20px 0;
}

.flow .step .label_box .label_text {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: 0.08em;
  font-family: minion-pro, serif;
  line-height: 1;
}

.flow .step .label_box .label_number {
  font-size: 23px;
  font-weight: 700;
  letter-spacing: 0.08em;
  font-family: minion-pro, serif;
  line-height: 1;
}

.flow .step .step_image {
  width: 110px;
  height: 110px;
  margin: 0 auto 20px;
  border-radius: 50%;
  overflow: hidden;
}

.flow .step .step_image .image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.flow .step .step_title {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.18em;
  padding-bottom: 15px;
  position: relative;
  width: 100%;
  text-align: center;
}

.flow .step .step_title::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-image: url("././image/dashed_line02.svg");
  background-size: contain;
  background-repeat: repeat-x;
}

.flow .step .step_description {
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.07em;
  margin-top: 15px;
  font-family: "Zen Kaku Gothic New", serif;
  text-align: center;
}

.flow .btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 30px;
  width: 330px;
  height: 60px;
  border-radius: 10px;
  position: relative;
  transition: all 0.3s;
  text-decoration: none;
  z-index: 1;
  background-color: #6fb92d;
  box-shadow: 0 6px 0 #539815;
  margin: 50px auto;
}

.flow .btn .btn_text {
  color: #ffffff;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.24em;
  position: relative;
  z-index: 1;
}

/* target
----------------------------------------*/
.target {
  padding: 115px 0 90px;
  background: linear-gradient(to bottom, #ffffff 0%, #f8fff2 60%, #fffff2 100%);
}

.target .sub_title {
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.24em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto 35px;
  position: relative;
}

.target .sub_title::after {
  content: "";
  position: absolute;
  width: 420px;
  height: 15px;
  bottom: -22px;
  left: 50%;
  transform: translateX(-50%);
  background-image: url("././image/target_illust.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.target .title {
  font-size: 44px;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.24em;
  margin: 0 0 30px 0;
}

.target .title .highlight {
  color: #6fb92d;
}

.target .cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin: 0 0 85px 0;
}

.target .card {
  background: #ffffff;
  border-radius: 8px;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.16);
  position: relative;
  overflow: hidden;
}

.target .card:nth-of-type(2) {
  transform: translateY(40px);
}

.target .card:nth-of-type(3) {
  transform: translateY(20px);
}

.target .card .image_box {
  width: 100%;
  height: 195px;
}

.target .card .image_box img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.target .card .card_title {
  font-size: 20px;
  font-weight: 700;
  margin: 20px 0 25px 20px;
  letter-spacing: 0.14em;
  padding-left: 20px;
  position: relative;
}

.target .card .card_title::before {
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  width: 8px;
  height: 30px;
  border-radius: 4px;
  background-color: #6fb92d;
}

.target .card .card_text {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 0.05em;
  padding: 0 20px 40px;
  font-family: "Zen Kaku Gothic New", serif;
}

.target .target_cta {
  text-align: center;
}

.target .target_cta .cta_highlight {
  font-size: 32px;
  font-weight: 700;
  letter-spacing: 0.14em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  position: relative;
}

.target .target_cta .cta_highlight::before {
  content: "";
  position: absolute;
  bottom: -5px;
  left: 0;
  width: 100%;
  height: 3px;
  background-image: url("././image/dashed_line03.svg");
}

.target .target_cta .cta_highlight .fz54 {
  font-size: 54px;
  font-weight: 500;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
  line-height: 1;
}

.target .target_cta .cta_text {
  font-size: 34px;
  font-weight: 700;
  letter-spacing: 0.14em;
  margin: 20px 0 0 0;
}

/* cta
----------------------------------------*/
.cta {
  position: relative;
  padding: 100px 0;
  overflow: hidden;
  z-index: 1;
}

.cta::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.3);
  z-index: -1;
}

.cta::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("././image/cta_bg.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: -2;
}

.cta .cta_intro {
  font-size: 36px;
  font-weight: 700;
  text-align: center;
  margin: 0 0 10px 0;
  letter-spacing: 0.14em;
  color: #fff;
}

.cta .cta_intro .fz61 {
  font-size: 61px;
  font-weight: 600;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
  line-height: 1;
  position: relative;
}

.cta .cta_intro .fz61::before {
  content: "";
  position: absolute;
  top: -4px;
  left: -4px;
  width: 24px;
  height: 21px;
  background-image: url("././image/cta_illust.webp");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.cta .cta_intro .highlight {
  color: #def2b1;
}

.cta_banner {
  background: #fff258;
  padding: 12px 40px;
  border-radius: 23px;
  text-align: center;
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.14em;
  line-height: 1;
  position: relative;
  z-index: 1;
}

.cta_banner .fz18 {
  font-size: 18px;
  margin: 0 8px;
}

.cta_inner {
  width: 780px;
  margin: -23px auto 0;
  background-color: #fff;
  padding: 77px 0 15px;
  border-radius: 10px;
}

.cta_inner .cta_box {
  display: flex;
  justify-content: center;
  gap: 20px;
}

.cta_inner .cta_box .btn_box {
  position: relative;
}

.cta_inner .cta_box .btn_box .label {
  position: absolute;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: 16px;
  top: -30px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.14em;
  white-space: nowrap;
}

.cta_inner .cta_box .btn_box .label::before {
  content: "";
  width: 2px;
  height: 18px;
  background-color: #333;
  position: absolute;
  top: 5px;
  left: -15px;
  transform: skew(20deg);
}

.cta_inner .cta_box .btn_box .label::after {
  content: "";
  width: 2px;
  height: 18px;
  background-color: #333;
  position: absolute;
  top: 5px;
  right: -15px;
  transform: skew(-20deg);
}

.cta_inner .cta_box .btn_box .btn {
  display: flex;
  align-items: center;
  padding: 0 30px;
  width: 340px;
  height: 70px;
  border-radius: 10px;
  position: relative;
  transition: all 0.3s;
  text-decoration: none;
  z-index: 1;
}

.cta_inner .cta_box .btn_box .btn_reserve {
  justify-content: space-between;
}

.cta_inner .cta_box .btn_box .btn_reserve {
  background-color: #6fb92d;
  box-shadow: 0 10px 0 #539815;
}

.cta_inner .cta_box .btn_box .btn_contact {
  background-color: #ab7326;
  box-shadow: 0 10px 0 #9b5f16;
}

.cta_inner .cta_box .btn_box .btn .btn_text {
  color: #ffffff;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.14em;
  position: relative;
  z-index: 1;
}

.cta_inner .cta_box .btn_box .btn .btn_icon {
  width: 20px;
  height: 20px;
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.cta_inner .cta_box .btn_box .btn .btn_icon.contact {
  width: 25px;
  height: 20px;
  margin-right: 20px;
}

.cta_inner .cta_box .btn_box .btn .btn_icon.arrow {
  width: 10px;
  height: 18px;
  margin-left: auto;
}

.cta_inner .cta_box .btn_box .btn .btn_icon .image {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.cta_inner .disclaimer {
  font-size: 13px;
  font-weight: 700;
  font-family: "Zen Kaku Gothic New", sans-serif;
  letter-spacing: 0.07em;
  margin: 15px 0 0 40px;
}

/* reason
----------------------------------------*/
.reason {
  padding: 140px 0;
}

.reason .title_area {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 0 0 10px 0;
}

.reason .title_area .number {
  font-size: 160px;
  font-weight: 700;
  color: #6fb92d;
  font-family: minion-pro, serif;
  line-height: 1;
}

.reason .title_area .title_text {
  flex: 1;
  padding-top: 26px;
}

.reason .title_area .title_text .title_line1 {
  font-size: 24px;
  font-weight: 700;
  margin: 0 0 25px 0;
  letter-spacing: 0.21em;
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.reason .title_area .title_text .title_line1::before {
  content: "";
  position: absolute;
  bottom: -15px;
  left: 50%;
  transform: translateX(-50%);
  width: 325px;
  height: 16px;
  background-image: url("././image/reason_illust.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.reason .title_area .title_text .title_line2 {
  font-size: 50px;
  font-weight: 700;
  color: #6fb92d;
  letter-spacing: 0.24em;
  line-height: 1;
}

.reason .items {
  display: grid;
  grid-template-columns: repeat(5, 210px);
  justify-content: space-between;
}

.reason .item {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.reason .item .icon {
  width: 210px;
  height: 210px;
  margin: 0 auto 20px;
  background: #f8ffe8;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #beef93;
}

.reason .item .icon .image {
  width: 95px;
  height: 95px;
  -o-object-fit: contain;
     object-fit: contain;
}

.reason .item .text {
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.14em;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.reason .item .text .line03 {
  line-height: 1;
}

.reason .item .text .fz23 {
  font-size: 23px;
  font-weight: 600;
  letter-spacing: 0.06em;
  font-family: minion-pro, serif;
  line-height: 1;
}

.reason .item .text .fz16 {
  font-size: 16px;
}

.reason .item .text .fz14 {
  font-size: 14px;
  letter-spacing: 0.03em;
}

/* faq
----------------------------------------*/
.faq {
  padding: 115px 0 130px;
  background-color: #faf9f2;
}

.faq .title {
  text-align: center;
  font-size: 44px;
  font-weight: 700;
  letter-spacing: 0.24em;
  margin: 0 0 54px 0;
}

.faq .items {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin: 0 auto 50px;
}

.faq .item {
  background: #ffffff;
  border-radius: 14px;
  padding: 30px;
}

.faq .item .question {
  display: flex;
  align-items: center;
  gap: 20px;
  padding-bottom: 20px;
  position: relative;
}

.faq .item .question::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-image: url("././image/dashed_line04.svg");
  background-size: contain;
  background-repeat: repeat-x;
}

.faq .item .question .icon {
  width: 40px;
  height: 40px;
  background: #6fb92d;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.faq .item .question .icon .image {
  width: 14px;
  height: 18px;
  -o-object-fit: contain;
     object-fit: contain;
}

.faq .item .question .text {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.14em;
  flex: 1;
}

.faq .item .answer {
  margin-top: 16px;
}

.faq .item .answer .text {
  font-size: 16px;
  color: #646464;
  letter-spacing: 0.09em;
  font-family: "Zen Kaku Gothic New", sans-serif;
}

.faq .btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 30px;
  width: 240px;
  height: 60px;
  border-radius: 10px;
  position: relative;
  transition: all 0.3s;
  text-decoration: none;
  z-index: 1;
  background-color: #6fb92d;
  box-shadow: 0 6px 0 #539815;
  margin: 50px auto;
}

.faq .btn .btn_text {
  color: #ffffff;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.24em;
  position: relative;
  z-index: 1;
}

/* about
----------------------------------------*/
.about {
  padding: 120px 0 120px;
}

.about .inner {
  display: grid;
  grid-template-columns: 510px 1fr;
  gap: 60px;
  align-items: center;
}

.about .images {
  position: relative;
  height: 510px;
}

.about .images .main_image {
  position: absolute;
  top: 0;
  right: 0;
  width: 450px;
  height: 480px;
  border-radius: 8px;
  overflow: hidden;
}

.about .images .main_image .image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.about .images .sub_image {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 170px;
  height: 190px;
  border-radius: 8px;
  overflow: hidden;
}

.about .images .sub_image .image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.about .inner .content {
  flex: 1;
  padding-top: 20px;
}

.about .inner .content .title {
  font-size: 20px;
  font-weight: 700;
  color: #5b9823;
  margin: 0 0 20px 0;
  letter-spacing: 0.24em;
}

.about .inner .content .subtitle {
  font-size: 24px;
  font-weight: 700;
  margin: 0 0 35px 0;
  letter-spacing: 0.14em;
}

.about .inner .content .description {
  font-size: 15px;
  margin: 0 0 45px 0;
  font-weight: 700;
  letter-spacing: 0.14em;
  font-family: "Zen Kaku Gothic New", sans-serif;
}

.about .inner .content .btn {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 30px;
  width: 240px;
  height: 60px;
  border-radius: 10px;
  position: relative;
  transition: all 0.3s;
  text-decoration: none;
  z-index: 1;
  background-color: #6fb92d;
  box-shadow: 0 6px 0 #539815;
}

.about .inner .content .btn .btn_text {
  color: #ffffff;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.24em;
  position: relative;
  z-index: 1;
}

/* footer
----------------------------------------*/
.footer {
  padding: 75px 0 55px;
  background-color: #6fb92d;
}

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

.footer .top .left {
  margin-top: 50px;
}

.footer .top .left .image_box {
  width: 172px;
  height: auto;
}

.footer .top .left .image .image {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.footer .top .left .address {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: #ffffff;
  margin-top: 20px;
}

.footer .nav_list {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 60px;
}

.footer .nav_list .nav_item .nav_link {
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: #ffffff;
  transition: all 0.3s;
}

.footer .list {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 60px;
  gap: 16px;
  margin-bottom: 20px;
}

.footer .list .item {
  position: relative;
}

.footer .list .item::after {
  content: "";
  position: absolute;
  top: 8px;
  right: -8px;
  width: 1px;
  height: 12px;
  background-color: #ffffff;
}

.footer .list .item:last-child::after {
  display: none;
}

.footer .list .item .link {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  color: #ffffff;
  transition: all 0.3s;
}

.footer .copyright {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: #ffffff;
  text-align: center;
  padding-top: 20px;
  border-top: 1px solid #ffffff;
}

/*----------------------------------------
   サービスの流れ
----------------------------------------*/
.page_flow .common_page_wrap {
  padding: 80px 0 130px;
}

.page_flow .intro {
  font-size: 16px;
  text-align: center;
  margin: 0 0 50px 0;
  letter-spacing: 0.09em;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 700;
}

.page_flow .steps {
  display: flex;
  flex-direction: column;
  gap: 30px;
  position: relative;
  margin: 0 auto;
}

.page_flow .steps::before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 2px;
  height: 100%;
  background-color: #6fb92d;
  z-index: 0;
}

.page_flow .step {
  position: relative;
  background: #ffffff;
  border: 1px solid #6fb92d;
  border-radius: 8px;
  padding: 30px 40px 30px 30px;
  z-index: 1;
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 40px;
}

.page_flow .step .step_icon {
  width: 160px;
  height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  overflow: hidden;
}

.page_flow .step .step_icon .image {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.page_flow .step .step_content {
  display: flex;
  flex-direction: column;
}

.page_flow .step .step_content .step_header {
  display: flex;
  align-items: center;
  gap: 20px;
  padding-bottom: 16px;
  position: relative;
}

.page_flow .step .step_header::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  background-image: url("././image/dashed_line02.svg");
}

.page_flow .step .label_box {
  background-color: #5b9823;
  color: #ffffff;
  font-size: 14px;
  font-weight: 700;
  width: 100px;
  height: 36px;
  display: flex;
  align-items: baseline;
  justify-content: center;
  border-radius: 29px;
  gap: 5px;
  padding-top: 6px;
}

.page_flow .step .label_box .label_text {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: 0.08em;
  font-family: minion-pro, serif;
  line-height: 1;
}

.page_flow .step .label_box .label_number {
  font-size: 23px;
  font-weight: 700;
  letter-spacing: 0.08em;
  font-family: minion-pro, serif;
  line-height: 1;
}

.page_flow .step .step_title {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.18em;
}

.page_flow .step .step_text {
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.07em;
  font-family: "Zen Kaku Gothic New", sans-serif;
  margin-top: 16px;
}

/*----------------------------------------
   よくある質問
----------------------------------------*/
.page_faq {
  position: relative;
}

.page_faq::before {
  content: "";
  position: absolute;
  top: -120px;
  left: 0;
  width: 100%;
  height: calc(100% + 120px);
  background-color: #faf9f2;
  z-index: -1;
}

.page_faq .common_page_wrap {
  padding: 80px 0 130px;
}

.page_faq .items {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin: 0 auto 0;
}

.page_faq .item {
  background: #ffffff;
  border-radius: 14px;
  padding: 30px;
}

.page_faq .item .question {
  display: flex;
  align-items: center;
  gap: 20px;
  padding-bottom: 20px;
  position: relative;
}

.page_faq .item .question::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-image: url("././image/dashed_line04.svg");
  background-size: contain;
  background-repeat: repeat-x;
}

.page_faq .item .question .icon {
  width: 40px;
  height: 40px;
  background: #6fb92d;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.page_faq .item .question .icon .image {
  width: 14px;
  height: 18px;
  -o-object-fit: contain;
     object-fit: contain;
}

.page_faq .item .question .text {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.14em;
  flex: 1;
}

.page_faq .item .answer {
  margin-top: 16px;
}

.page_faq .item .answer .text {
  font-size: 16px;
  color: #646464;
  letter-spacing: 0.09em;
  font-family: "Zen Kaku Gothic New", sans-serif;
}

/*----------------------------------------
   会社概要
----------------------------------------*/
.page_company .common_page_wrap {
  padding: 90px 0 140px;
}

.company_profile_sec .cont .message_box {
  max-width: 800px;
  margin: 0 auto 80px;
}

.company_profile_sec .cont .message_box .message_text {
  font-size: 20px;
  letter-spacing: 0.08em;
  font-weight: 500;
  font-family: "Zen Kaku Gothic New", sans-serif;
}

.company_profile_sec .cont .message_box .name_box {
  display: flex;
  gap: 16px;
  margin-top: 20px;
  justify-content: flex-end;
  align-items: baseline;
}

.company_profile_sec .cont .message_box .name_box .position {
  font-size: 20px;
  letter-spacing: 0.08em;
  font-weight: 700;
}

.company_profile_sec .cont .message_box .name_box .name {
  font-size: 24px;
  letter-spacing: 0.08em;
  font-weight: 700;
}

.company_profile_sec .cont .detail .item {
  border-top: 1px solid #afafaf;
}

.company_profile_sec .cont .detail .item .inbox {
  display: flex;
  gap: 0 1em;
}

.company_profile_sec .cont .detail .item .inbox .head {
  flex-shrink: 0;
  width: 28%;
  font-size: 20px;
  letter-spacing: 0.08em;
  font-weight: 700;
  line-height: 1.5;
  padding: 1.3em 0 0 1.3em;
  border-top: 3px solid #5b9823;
}

.company_profile_sec .cont .detail .item .inbox .text_area {
  width: 100%;
  font-size: 16px;
  letter-spacing: 0.08em;
  line-height: 1.5;
  padding: 1.9em 0;
}

/* 会社概要ページの電話番号・FAX番号の自動リンク化を無効化 */
.company_profile_sec .cont .detail .item .inbox .text_area a[href^="tel:"],
.company_profile_sec .cont .detail .item .inbox .text_area a[href^="fax:"] {
  color: inherit;
  text-decoration: none;
  pointer-events: none;
  cursor: default;
}

.company_profile_sec .cont .detail .item .map {
  width: 95%;
  height: 240px;
  margin-top: 1em;
}

.company_profile_sec .cont .detail .item .map iframe {
  width: 100%;
  height: 100%;
  max-height: 100% !important;
}

/*----------------------------------------
   ホバー
----------------------------------------*/
@media (min-width: 751px) {
  #pc_header.header .nav .list .item .link:hover {
    color: #5fa323;
  }
  .fixed_box .btn:hover {
    transform: translateY(6px);
    box-shadow: 0 0 0 #539815;
  }
  .mv .content .btn_area .btn_box .btn:hover {
    transform: translateY(6px);
  }
  .mv .content .btn_area .btn_box .btn_reserve:hover {
    box-shadow: 0 0 0 #539815;
  }
  .mv .content .btn_area .btn_box .btn_contact:hover {
    box-shadow: 0 0 0 #9b5f16;
  }
  .flow .btn:hover {
    transform: translateY(6px);
    box-shadow: 0 0 0 #539815;
  }
  .cta_inner .cta_box .btn_box .btn:hover {
    transform: translateY(10px);
  }
  .cta_inner .cta_box .btn_box .btn_reserve:hover {
    box-shadow: 0 0 0 #539815;
  }
  .cta_inner .cta_box .btn_box .btn_contact:hover {
    box-shadow: 0 0 0 #9b5f16;
  }
  .faq .btn:hover {
    transform: translateY(6px);
    box-shadow: 0 0 0 #539815;
  }
  .about .inner .content .btn:hover {
    transform: translateY(6px);
    box-shadow: 0 0 0 #539815;
  }
  .footer .nav_list .nav_item .nav_link:hover {
    opacity: 0.7;
  }
  .footer .list .item .link:hover {
    opacity: 0.7;
  }
}
/*----------------------------------------
   メディアクエリ
----------------------------------------*/
@media (max-width: 750px) {
  html {
    min-width: auto;
  }
  body {
    min-width: auto;
  }
  .wrap {
    width: auto;
    max-width: 90%;
  }
  a[href$=".pdf"]::before {
    width: 7vw;
    height: 8vw;
    margin-right: 2.5vw;
  }
  a[href$=".pdf"]:hover {
    text-decoration: underline;
  }
  body {
    font-size: 13px;
  }
  /* SP固定ページ 共通設定 */
  .common_page_main {
    padding: 37.69vw 0 12.56vw;
  }
  .common_page_main .bg_image {
    background-image: url("./image/page_mv_bg02_sp.webp");
  }
  .common_page_main .bg_image::before {
    background-image: url("./image/page_mv_bg01_sp.webp");
  }
  .common_page_main .bg_image::after {
    background-image: url("./image/page_mv_sp.webp");
  }
  .common_page_main .title_box {
    margin-bottom: 0;
  }
  .common_page_main .title_box .title {
    font-size: 6.15vw;
  }
  .common_page_wrap {
    padding: 20vw 0;
  }
  .reserve_text {
    font-size: 6vw;
  }
  /* パンくず */
  .breadcrumb {
    font-size: 3vw;
  }
  /* SP固定ページ お問い合わせ */
  .contact_form_disc {
    margin-block: 0 2em;
  }
  .contact_form_disc .text {
    font-size: 3.6vw;
    margin-block: 0 0.8em;
  }
  .contact_form_disc .caution {
    font-size: 3.1vw;
    letter-spacing: 0.06em;
  }
  .common_contact_form .form_box {
    margin-block: 0 10vw;
  }
  .common_contact_form .form_box dl {
    grid-template-columns: 1fr;
    gap: 0.6em;
  }
  .common_contact_form .form_box dl + dl {
    margin-block: 1.3em 0;
  }
  .common_contact_form .form_box dl dt {
    flex-direction: row-reverse;
    justify-content: space-between;
    font-size: 4.1vw;
    padding-inline: 0;
  }
  .common_contact_form .form_box dl dt .label {
    font-size: 3.1vw;
  }
  .common_contact_form .form_box dl dt::after {
    content: none;
  }
  .common_contact_form input[type=text],
.common_contact_form input[type=email],
.common_contact_form #zip {
    font-size: 3.6vw;
  }
  .common_contact_form select {
    width: 100%;
    font-size: 3.6vw;
  }
  .common_contact_form textarea {
    height: 33vw;
    font-size: 3.6vw;
  }
  .radio_btns,
.checkboxes {
    gap: 0.5em 2.5em;
  }
  .page_contact #btn_wrap button {
    width: 83%;
    line-height: 15.5vw;
    font-size: 4.6vw;
  }
  .page_contact #btn_wrap button[name=submitBack] {
    margin-top: 4vw;
  }
  .mwform-checkbox-field.horizontal-item {
    display: block;
  }
  .page_contact #btn_wrap {
    width: 100%;
    text-align: center;
  }
  .privacy_check_list .mwform-checkbox-field-text {
    font-size: 3.8vw;
    padding-left: 11vw;
  }
  .mw_wp_form .privacy_check_list .horizontal-item {
    margin-right: 4vw;
  }
  .privacy_check_list .hissu {
    padding: 0.3vw 4vw;
  }
  .privacy_check_list {
    margin-bottom: 6vw;
  }
  .privacy_term_detail {
    font-size: 3.4vw;
    margin: 5vw 0;
  }
  .privacy_term_outer {
    width: 96%;
    padding: 5vw 0;
  }
  .privacy_term_outer .privacy_term_inner .main_text {
    font-size: 3.4vw;
    line-height: 1.6;
    margin-bottom: 5vw;
  }
  .privacy_term_outer .privacy_term_inner dl dt {
    font-size: 3.5vw;
    margin-bottom: 1.5vw;
  }
  .privacy_term_outer .privacy_term_inner dl dd {
    font-size: 3.5vw;
    line-height: 1.6;
  }
  .privacy_term_outer .privacy_term_inner dl + dl {
    margin-top: 7vw;
  }
  .privacy_term_detail::after {
    width: 2.5vw;
    margin: 1.5vw auto 0;
  }
  /* サンクスページ */
  .page_contact .thanks_textArea .name {
    font-size: 4vw;
    margin-bottom: 3vw;
  }
  .page_contact .thanks_textArea .contact_text {
    font-size: 3.5vw;
    margin-bottom: 2em;
    width: 100%;
  }
  .page_contact .thanks_textArea .ichiran_link {
    width: 80%;
    line-height: 12vw;
    font-size: 4vw;
  }
  /* ステップバー デザイン */
  .page_contact .progressbar {
    gap: 4.5em;
    margin-block: 0 2.5em;
  }
  .page_contact .progressbar .item {
    font-size: 3.1vw;
  }
  .page_contact .progressbar .item + .item::before {
    width: 5.7vw;
    top: 63%;
    left: -3.3em;
  }
  .page_contact .progressbar .item .mark {
    width: 7.7vw;
    margin: 0 auto 0.4em;
  }
  /* SP固定ページ 404ページ */
  #page_404 .num {
    font-size: 20vw;
    line-height: 1.5;
  }
  #page_404 .text {
    font-size: 3.5vw;
  }
  /* SP投稿ページ アーカイブページ */
  .archive_page_list > article {
    padding-right: 20px;
  }
  .archive_page_list > article .date {
    width: 80px;
  }
  .archive_page_list > article .content_area {
    width: calc(100% - 80px);
  }
  .archive_page_list > article:after {
    width: 7px;
    height: 7px;
  }
  /* SP固定ページ サイトマップ */
  ul#sitemap_list li {
    margin: 0;
  }
  body #sitemap_list li a {
    font-size: 4vw;
    padding: 1vw 2vw;
    line-height: 9vw;
    margin-bottom: 1vw;
  }
  body #sitemap_list li.home-item {
    margin-bottom: 4vw;
  }
  body #sitemap_list {
    padding: 0;
  }
  /*----------------------------------------
      トップページ
  ----------------------------------------*/
  /* sp_header
  ----------------------------------------*/
  #sp_header {
    position: fixed;
    left: 20px;
    top: 20px;
    width: calc(100% - 40px);
    background: #fff;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.16);
    border-radius: 50px;
    z-index: 100000;
    height: 70px;
  }
  #sp_header .logo {
    position: absolute;
    left: 20px;
    top: 14px;
    width: 102px;
    height: auto;
    line-height: 0;
  }
  #sp_header .logo .image {
    width: 100%;
    height: 100%;
    -o-object-fit: contain;
       object-fit: contain;
  }
  /* mv
  ----------------------------------------*/
  .mv {
    height: auto;
  }
  .mv .bg01 {
    height: 84.62vw;
  }
  .mv .bg02 {
    top: 5.13vw;
    right: unset;
    left: 0;
    width: 100%;
    height: 84.62vw;
  }
  .mv .slider {
    height: 84.62vw;
  }
  .mv .slider .slick-list {
    height: 84.62vw;
  }
  .mv .slider .slick-track {
    height: 84.62vw;
  }
  .mv .slider .item {
    height: 84.62vw;
  }
  .mv .slick-dots {
    bottom: unset;
    top: 82.05vw;
    right: 13.33vw;
    gap: 7.69vw;
  }
  .mv .slick-dots li {
    width: 2.56vw;
    height: 2.56vw;
  }
  .mv .slick-dots li button {
    width: 2.56vw;
    height: 2.56vw;
  }
  .mv .slick-dots li.slick-active::before {
    width: 5.13vw;
    height: 5.13vw;
  }
  .mv .slick-dots li.slick-active button {
    width: 2.56vw;
    height: 2.56vw;
  }
  /* MVコンテンツ */
  .mv .content {
    padding-top: 98.46vw;
  }
  .mv .content .text {
    color: #333;
  }
  .mv .content .text .fz33 {
    font-size: 4.62vw;
  }
  .mv .content .text .fz70 {
    font-size: 12.82vw;
    transform: translateX(6px);
    display: inline-block;
  }
  .mv .content .text .fz34 {
    font-size: 5.13vw;
  }
  .mv .content .text .highlight {
    color: #6fb92d;
  }
  .mv .content .text .fz56 {
    font-size: 11.28vw;
  }
  .mv .content .text .fz36 {
    font-size: 7.69vw;
  }
  .mv .content .text .fz22 {
    font-size: 3.59vw;
  }
  .mv .content .text.fukidashi {
    margin-top: 2.56vw;
    padding-left: 0;
  }
  .mv .content .text.fukidashi::before {
    width: 48.21vw;
    height: 5.9vw;
    bottom: -3.85vw;
    left: 0;
    background-image: url("././image/fukidashi_sp.webp");
  }
  .mv .content .text.middle {
    margin-top: 4.36vw;
    line-height: 1.2;
    letter-spacing: 0.4em;
  }
  .mv .content .text.bottom {
    margin-top: 4.62vw;
  }
  .mv .content .btn_area {
    flex-direction: column;
    gap: 4.1vw;
  }
  .mv .content .btn_area {
    margin-top: 6.41vw;
  }
  .mv .content .btn_area .btn_box .btn {
    width: 100%;
    height: 15.38vw;
    border-radius: 8px;
  }
  .mv .content .btn_area .btn_box .btn .btn_text {
    font-size: 4.1vw;
  }
  .mv .content .btn_area .btn_box .btn.btn_reserve .btn_text {
    position: relative;
  }
  .mv .content .btn_area .btn_box .btn.btn_reserve .btn_text:after {
    content: "※";
    position: absolute;
    top: 0.77vw;
    right: -3.08vw;
    font-size: 2.56vw;
    color: #fff;
    font-weight: 900;
    letter-spacing: 0.14em;
  }
  .mv .content .btn_area .btn_box .btn.btn_reserve .btn_icon {
    width: 5.13vw;
    height: 5.13vw;
  }
  .mv .content .btn_area .btn_box .btn.btn_contact .btn_icon {
    width: 2.56vw;
    height: 4.62vw;
  }
  .mv .content .disclaimer {
    font-size: 3.33vw;
    color: #333;
    margin-top: 4.36vw;
    text-align: right;
  }
  /* service
  ----------------------------------------*/
  .service {
    padding: 30.77vw 0 17.95vw;
  }
  .service .title {
    font-size: 6.15vw;
    margin: 0 0 6.15vw 0;
  }
  .service .title::before {
    width: 19.23vw;
    height: 8.97vw;
    top: -15.38vw;
  }
  .service .cards {
    gap: 2.56vw;
    margin: 0 0 12.82vw 0;
  }
  .service .card {
    width: calc((100% - 2.56vw) / 2);
    padding: 3.85vw 0 4.62vw;
  }
  .service .icon {
    width: 25.64vw;
    height: 25.64vw;
    margin: 0 0 5.13vw 0;
  }
  .service .icon .image {
    width: 15.38vw;
    height: 15.38vw;
  }
  .service .text {
    font-size: 4.1vw;
    letter-spacing: 0.06em;
  }
  .service .description .fz20 {
    font-size: 3.85vw;
    letter-spacing: 0.04em;
  }
  .service .description .fz28 {
    font-size: 5.38vw;
    display: block;
    letter-spacing: 0.16em;
    margin-top: 1.28vw;
  }
  .service .description .highlight::before {
    top: -1.28vw;
    right: -2.56vw;
    font-size: 3.59vw;
  }
  .service .description .fz36 {
    font-size: 7.18vw;
    letter-spacing: 0.16em;
  }
  .service .disclaimer {
    font-size: 3.08vw;
    text-align: right;
    margin: 3.85vw 0 5.13vw 0;
  }
  .service .service_slider .slick-list {
    margin: 0 -1.28vw;
    padding: 5.13vw 0;
  }
  .service .service_slider .slick-slide {
    padding: 0 1.28vw;
  }
  .service .service_slider .slick-slide:nth-of-type(2n) {
    transform: translateY(2.56vw);
  }
  .service .service_slide img {
    width: 46.15vw;
    height: 35.9vw;
  }
  /* price 
  ----------------------------------------*/
  .price {
    padding: 19.23vw 0 10.26vw;
  }
  .price .banner {
    padding: 3.33vw 5.13vw 2.82vw;
    margin: 0 auto 5.13vw;
    font-size: 4.1vw;
  }
  .price .banner::before {
    bottom: -2.56vw;
    width: 5.38vw;
    height: 2.82vw;
  }
  .price .title {
    font-size: 6.67vw;
    letter-spacing: 0.19em;
    margin: 0 0 6.67vw 0;
  }
  .price .points {
    grid-template-columns: 1fr;
    gap: 2.05vw;
    margin: 0 0 3.59vw 0;
  }
  .price .point {
    border-radius: 10px;
    padding: 3.59vw 5.13vw 1.79vw;
    flex-direction: row;
    justify-content: start;
    gap: 5.13vw;
  }
  .price .point .label_box {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 0;
  }
  .price .point .label_box .label_text {
    font-size: 4.62vw;
    line-height: 1;
  }
  .price .point .label_box .label_number {
    font-size: 8.21vw;
    line-height: 1;
  }
  .price .point .point_text {
    flex-direction: row;
    align-items: baseline;
  }
  .price .point .point_text .fz22 {
    font-size: 4.1vw;
  }
  .price .point .point_text .fz28 {
    font-size: 5.64vw;
  }
  .price .point .point_text .fz47 {
    font-size: 8.97vw;
  }
  .price .details {
    padding: 5.13vw 5.13vw 3.85vw;
  }
  .price .details::before {
    bottom: -10.26vw;
    height: 3px;
    background-image: url("././image/dashed_line_sp.svg");
  }
  .price .item_box {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 7.69vw;
  }
  .price .item {
    flex-direction: column;
    gap: 3.59vw;
  }
  .price .item .content {
    display: flex;
    align-items: center;
    gap: 3.59vw;
  }
  .price .item .badge {
    width: 17.95vw;
    height: 17.95vw;
    border-radius: 6px;
    font-size: 5.13vw;
    line-height: 1.2;
  }
  .price .item.basic .note {
    padding: 2.05vw 4.62vw 1.03vw;
    font-size: 4.62vw;
  }
  .price .item.basic .note .fz30 {
    font-size: 7.18vw;
  }
  .price .item.extension .note {
    padding: 2.05vw 5.38vw 1.03vw;
    font-size: 4.62vw;
  }
  .price .item.extension .note .fz30 {
    font-size: 7.18vw;
  }
  .price .item .amount {
    margin-top: 1.28vw;
    display: flex;
    align-items: last baseline;
    white-space: nowrap;
  }
  .price .item .amount .amount_box {
    display: flex;
    flex-direction: column;
  }
  .price .item .amount .amount_text {
    line-height: 1;
  }
  .price .item .amount .fz80 {
    font-size: 15.38vw;
    letter-spacing: 0.04em;
  }
  .price .item .amount .fz36 {
    font-size: 7.18vw;
  }
  .price .item .amount .fz20 {
    font-size: 3.59vw;
    color: #676767;
    position: relative;
  }
  .price .item .amount .fz20::before {
    display: none;
  }
  .price .item .amount .amount_text .fz20::after {
    content: "※";
    position: absolute;
    top: 0;
    right: -2.05vw;
    font-size: 1.79vw;
    color: #676767;
    font-weight: 700;
    letter-spacing: 0.14em;
  }
  .price .item .amount .fz60 {
    font-size: 15.38vw;
    letter-spacing: 0.04em;
  }
  .price .item .amount .fz30 {
    font-size: 7.18vw;
  }
  .price .item .amount .fz16 {
    font-size: 3.59vw;
  }
  .price .disclaimer {
    font-size: 3.08vw;
    margin: 3.85vw 0 0 0;
    text-align: left;
  }
  .price .disclaimer .fz14 {
    font-size: 3.08vw;
  }
  .price .disclaimer .fz26 {
    font-size: 3.08vw;
  }
  /* usage
  ----------------------------------------*/
  .usage {
    padding: 10.26vw 0 19.23vw;
  }
  .usage .title {
    font-size: 5.64vw;
    margin: 0 0 6.15vw 0;
  }
  .usage .items {
    display: flex;
    flex-direction: column;
    gap: 5.13vw;
  }
  .usage .item {
    width: 100%;
  }
  .usage .item .banner {
    font-size: 4.1vw;
    letter-spacing: 0.09em;
    padding: 2.05vw 0 0 0;
    width: 78.21vw;
    height: 10.26vw;
    margin: 0 auto -5.13vw;
    display: flex;
    align-items: baseline;
    justify-content: center;
  }
  .usage .item .banner .fz29 {
    font-size: 6.15vw;
    margin: 0;
  }
  .usage .item .card {
    align-items: center;
    justify-content: space-between;
    border-radius: 10px;
    width: 100%;
    display: grid;
    grid-template-columns: 1fr;
    gap: 4.1vw;
    padding: 8.72vw 5.13vw 5.13vw;
  }
  .usage .item .card .content {
    display: grid;
    grid-template-columns: 32.05vw 1fr;
    gap: 3.85vw;
    align-items: center;
  }
  .usage .item .card .image_box {
    aspect-ratio: 1/1;
    border-radius: 4px;
  }
  .usage .item .card .content .price_box {
    gap: 1.28vw;
  }
  .usage .item .card .content .price_box .period {
    font-size: 4.1vw;
    border-radius: 4px;
    width: 100%;
    padding: 1.28vw 0 1.03vw;
  }
  .usage .item .card .content .price_box .period .fz26 {
    font-size: 6.15vw;
    margin: 0 -1.03vw;
  }
  .usage .item .card .content .price_box .amount .fz42 {
    font-size: 8.72vw;
  }
  .usage .item .card .content .price_box .amount .fz20 {
    font-size: 4.62vw;
  }
  .usage .item .card .content .price_box .amount .fz16 {
    font-size: 3.08vw;
  }
  .usage .item .card .breakdown .breakdown_title {
    font-size: 3.59vw;
    font-weight: 700;
    letter-spacing: 0.14em;
    position: relative;
    margin-bottom: 2.56vw;
  }
  .usage .item .card .breakdown .breakdown_title::before {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 61.03vw;
    height: 1px;
    background-image: url("././image/dashed_line02.svg");
    background-size: contain;
    background-repeat: repeat-x;
  }
  .usage .item .card .breakdown .breakdown_amount {
    font-size: 3.59vw;
    font-weight: 700;
    letter-spacing: 0.14em;
    display: flex;
    align-items: last baseline;
    line-height: 1;
  }
  .usage .item .card .breakdown .breakdown_amount + .breakdown_amount {
    margin-top: 1.28vw;
  }
  .usage .item .card .breakdown .breakdown_amount .fz22 {
    font-size: 5.64vw;
    font-weight: 600;
    letter-spacing: 0.06em;
    font-family: minion-pro, serif;
    line-height: 1;
    transform: translateY(2px);
  }
  .usage .item .card .breakdown .breakdown_amount .fz18 {
    font-size: 4.62vw;
    font-weight: 600;
    letter-spacing: 0.14em;
    font-family: adobe-caslon-pro, serif;
  }
  .usage .item .card .breakdown .breakdown_amount .fz14 {
    font-size: 3.59vw;
    font-weight: 600;
    letter-spacing: 0.06em;
    font-family: adobe-caslon-pro, serif;
  }
  .usage .conclusion {
    text-align: center;
    margin: 8.21vw 0 0 0;
  }
  .usage .conclusion .text {
    font-size: 3.85vw;
    font-weight: 700;
    letter-spacing: 0.08em;
  }
  .usage .conclusion .conclusion_text {
    font-size: 6.15vw;
    letter-spacing: 0.16em;
    margin-top: 3.85vw;
  }
  .usage .conclusion .conclusion_text::before {
    display: none;
  }
  .usage .conclusion .conclusion_text .highlight {
    position: relative;
  }
  .usage .conclusion .conclusion_text .highlight::before {
    content: "";
    position: absolute;
    bottom: -0.77vw;
    left: 0;
    width: 100%;
    height: 3.33vw;
    background-color: #f8f1b7;
    z-index: -1;
  }
  /* flow
  ----------------------------------------*/
  .flow {
    padding: 17.95vw 0 16.67vw;
  }
  .flow .title {
    font-size: 6.15vw;
    letter-spacing: 0.19em;
    margin: 0 0 7.69vw 0;
  }
  .flow .steps {
    grid-template-columns: 1fr;
    gap: 2.56vw;
  }
  .flow .steps::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 0.51vw;
    height: 100%;
    background-color: #6fb92d;
    z-index: -1;
  }
  .flow .step {
    padding: 6.41vw 5.13vw;
    align-items: flex-start;
  }
  .flow .step .label_box {
    display: none;
  }
  .flow .step .step_image {
    display: none;
  }
  .flow .step .step_title {
    font-size: 4.1vw;
    letter-spacing: 0.12em;
    padding-bottom: 0;
    text-align: left;
  }
  .flow .step .step_title::before {
    display: none;
  }
  .flow .step .step_description {
    font-size: 3.33vw;
    margin-top: 3.85vw;
    text-align: left;
  }
  .flow .btn {
    width: 66.67vw;
    height: 15.38vw;
    border-radius: 6px;
    margin: 8.72vw auto;
  }
  .flow .btn .btn_text {
    font-size: 3.85vw;
  }
  /* target
  ----------------------------------------*/
  .target {
    padding: 10.26vw 0 15.38vw;
  }
  .target .sub_title {
    font-size: 4.1vw;
    letter-spacing: 0.21em;
    margin: 0 auto 10.26vw;
  }
  .target .sub_title::after {
    width: 62.56vw;
    height: 2.56vw;
    bottom: -5.13vw;
  }
  .target .title {
    font-size: 6.67vw;
    letter-spacing: 0.16em;
    margin: 0 0 5.64vw 0;
  }
  .target .cards {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3.59vw;
    margin: 0 0 10.26vw 0;
  }
  .target .card {
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.16);
    position: relative;
    overflow: hidden;
    padding: 5.13vw;
  }
  .target .card:nth-of-type(2) {
    transform: translateY(0);
  }
  .target .card:nth-of-type(3) {
    transform: translateY(0);
  }
  .target .card .content {
    display: flex;
    align-items: center;
    gap: 5.13vw;
  }
  .target .card .image_box {
    width: 25.64vw;
    height: 25.64vw;
    border-radius: 50%;
    overflow: hidden;
  }
  .target .card .card_title {
    font-size: 4.62vw;
    margin: 0;
    padding-left: 0;
    padding-bottom: 2.56vw;
    width: fit-content;
  }
  .target .card .card_title::before {
    top: unset;
    transform: translateY(0);
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1.03vw;
    border-radius: 4px;
  }
  .target .card .card_text {
    font-size: 3.59vw;
    padding: 0;
    margin-top: 3.59vw;
  }
  .target .target_cta {
    text-align: center;
  }
  .target .target_cta .cta_highlight {
    font-size: 5.13vw;
  }
  .target .target_cta .cta_highlight::before {
    bottom: -0.77vw;
    height: 0.51vw;
  }
  .target .target_cta .cta_highlight .fz54 {
    font-size: 8.72vw;
  }
  .target .target_cta .cta_text {
    font-size: 6.15vw;
    letter-spacing: 0.18em;
    margin: 5.13vw 0 0 0;
  }
  /* cta
  ----------------------------------------*/
  .cta {
    padding: 14.36vw 0;
  }
  .cta::after {
    background-image: url("././image/cta_bg_sp.webp");
  }
  .cta .cta_intro {
    font-size: 6.15vw;
    margin: 0 0 2.56vw 0;
  }
  .cta .cta_intro .fz61 {
    font-size: 9.74vw;
  }
  .cta .cta_intro .fz61::before {
    top: -1.03vw;
    left: -1.03vw;
    width: 4.62vw;
    height: 4.1vw;
  }
  .cta_banner {
    padding: 2.56vw 0 0 0;
    width: 79.49vw;
    height: 15.9vw;
    border-radius: 31px;
    text-align: center;
    font-size: 4.62vw;
    letter-spacing: 0.2em;
    line-height: 1.2;
  }
  .cta_banner .fz18 {
    font-size: 4.62vw;
    margin: 0;
  }
  .cta_inner {
    width: 100%;
    margin: 5.13vw auto 0;
    padding: 15.38vw 5.13vw 5.13vw;
    border-radius: 2.56vw;
  }
  .cta_inner .cta_box {
    flex-direction: column;
    gap: 13.85vw;
  }
  .cta_inner .cta_box .btn_box .label {
    height: 4.1vw;
    top: -7.69vw;
    font-size: 4.1vw;
  }
  .cta_inner .cta_box .btn_box .label::before {
    height: 4.62vw;
    top: 1.28vw;
    left: -2.56vw;
  }
  .cta_inner .cta_box .btn_box .label::after {
    height: 4.62vw;
    top: 1.28vw;
    right: -2.56vw;
  }
  .cta_inner .cta_box .btn_box .btn {
    padding: 0 7.69vw;
    width: 100%;
    height: 15.38vw;
    border-radius: 10px;
  }
  .cta_inner .cta_box .btn_box .btn_reserve {
    box-shadow: 0 6px 0 #539815;
  }
  .cta_inner .cta_box .btn_box .btn_contact {
    box-shadow: 0 6px 0 #9b5f16;
  }
  .cta_inner .cta_box .btn_box .btn .btn_text {
    font-size: 4.1vw;
    position: relative;
  }
  .cta_inner .cta_box .btn_box .btn.btn_reserve .btn_text::before {
    content: "※";
    position: absolute;
    top: 0.77vw;
    right: -3.08vw;
    font-size: 2.56vw;
    color: #fff;
    font-weight: 900;
    letter-spacing: 0.14em;
  }
  .cta_inner .cta_box .btn_box .btn .btn_icon {
    width: 5.13vw;
    height: 5.13vw;
  }
  .cta_inner .cta_box .btn_box .btn .btn_icon.contact {
    display: none;
  }
  .cta_inner .cta_box .btn_box .btn .btn_icon.arrow {
    width: 2.56vw;
    height: 4.62vw;
  }
  .cta_inner .disclaimer {
    font-size: 3.33vw;
    margin: 3.85vw 0 0 0;
    text-align: right;
  }
  /* reason
  ----------------------------------------*/
  .reason {
    padding: 20.51vw 0;
  }
  .reason .title_area {
    gap: 1.28vw;
    margin: 0;
  }
  .reason .title_area .number {
    font-size: 30.77vw;
  }
  .reason .title_area .title_text {
    padding-top: 4.62vw;
  }
  .reason .title_area .title_text .title_line1 {
    font-size: 4.62vw;
    margin: 0 0 5.13vw 0;
  }
  .reason .title_area .title_text .title_line1::before {
    bottom: -3.85vw;
    width: 62.56vw;
    height: 3.08vw;
  }
  .reason .title_area .title_text .title_line2 {
    font-size: 8.97vw;
  }
  .reason .items {
    grid-template-columns: 1fr;
    gap: 2.05vw;
  }
  .reason .item {
    display: grid;
    grid-template-columns: 28.72vw 1fr;
    align-items: center;
    background-color: #f8ffe8;
    border: 1px solid #beef93;
    border-radius: 6px;
    height: 20.51vw;
  }
  .reason .item .icon {
    width: 100%;
    height: 100%;
    margin: 0;
    background: unset;
    border-radius: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border: unset;
  }
  .reason .item .icon .image {
    width: 13.85vw;
    height: 13.85vw;
    -o-object-fit: contain;
       object-fit: contain;
  }
  .reason .item .text {
    text-align: left;
    font-size: 4.1vw;
    font-weight: 700;
    letter-spacing: 0.14em;
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    padding-left: 7.69vw;
    position: relative;
  }
  .reason .item .text::before {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
    width: 1px;
    height: 10.26vw;
    background-color: #333;
  }
  .reason .item .text .fz23 {
    font-size: 5.13vw;
  }
  .reason .item .text.privacy {
    flex-direction: row;
    justify-content: start;
  }
  .reason .item .text .fz16 {
    font-size: 3.08vw;
  }
  .reason .item .text .fz14 {
    font-size: 3.59vw;
  }
  /* faq
  ----------------------------------------*/
  .faq {
    padding: 20.51vw 0 16.67vw;
  }
  .faq .title {
    font-size: 6.15vw;
    letter-spacing: 0.19em;
    margin: 0 0 8.97vw 0;
  }
  .faq .items {
    display: flex;
    flex-direction: column;
    gap: 3.08vw;
    margin: 0 auto 10.26vw;
  }
  .faq .item {
    border-radius: 8px;
    padding: 5.13vw;
  }
  .faq .item .question {
    gap: 5.13vw;
    padding-bottom: 5.13vw;
  }
  .faq .item .question::after {
    height: 1px;
    background-image: url("././image/dashed_line04_sp.svg");
  }
  .faq .item .question .icon {
    width: 10.26vw;
    height: 10.26vw;
  }
  .faq .item .question .icon .image {
    width: 3.59vw;
    height: 4.62vw;
  }
  .faq .item .question .text {
    font-size: 4.1vw;
  }
  .faq .item .answer {
    margin-top: 4.1vw;
  }
  .faq .item .answer .text {
    font-size: 3.59vw;
  }
  .faq .btn {
    width: 66.67vw;
    height: 15.38vw;
    border-radius: 6px;
  }
  .faq .btn .btn_text {
    font-size: 3.85vw;
  }
  /* about
  ----------------------------------------*/
  .about {
    padding: 17.95vw 0 17.95vw;
  }
  .about .inner {
    display: grid;
    grid-template-columns: 1fr;
    gap: 4.1vw;
    align-items: center;
  }
  .about .images {
    position: relative;
    height: 64.1vw;
  }
  .about .images .main_image {
    position: absolute;
    top: 0;
    right: unset;
    left: 0;
    width: 84.62vw;
    height: 53.85vw;
    border-radius: 0 8px 8px 0;
  }
  .about .images .sub_image {
    position: absolute;
    bottom: 0;
    left: unset;
    right: 5.13vw;
    width: 35.9vw;
    height: 30.77vw;
    border-radius: 8px;
  }
  .about .inner .content {
    padding-top: 0;
    width: 100%;
  }
  .about .inner .content .title {
    font-size: 3.85vw;
    margin: 0 0 3.59vw 0;
  }
  .about .inner .content .subtitle {
    font-size: 4.62vw;
    margin: 0 0 6.67vw 0;
  }
  .about .inner .content .description {
    font-size: 3.59vw;
    margin: 0 0 8.72vw 0;
  }
  .about .inner .content .btn {
    width: 66.67vw;
    height: 15.38vw;
    border-radius: 6px;
    margin: 0 auto;
  }
  .about .inner .content .btn .btn_text {
    font-size: 3.85vw;
  }
  /* footer
  ----------------------------------------*/
  .footer {
    padding: 15.38vw 0 43.59vw;
    background-color: #6fb92d;
  }
  .footer .top {
    display: flex;
    flex-direction: column;
    gap: 0;
  }
  .footer .top .left {
    margin-top: 0;
  }
  .footer .top .left .image_box {
    width: 36.67vw;
    margin: 0 auto;
  }
  .footer .nav_list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin-top: 8.97vw;
  }
  .footer .nav_list .nav_item {
    width: calc((100% - 2.56vw) / 2);
    padding: 6.15vw 0 1.79vw;
    border-bottom: 1px solid #ffffff;
  }
  .footer .nav_list .nav_item:first-child,
.footer .nav_list .nav_item:nth-child(2) {
    padding: 0 0 1.79vw;
  }
  .footer .nav_list .nav_item .nav_link {
    font-size: 3.59vw;
  }
  .footer .address {
    font-size: 3.59vw;
    margin-top: 5.13vw;
    text-align: center;
    letter-spacing: 0.14em;
    color: #ffffff;
    margin-top: 9.74vw;
  }
  .footer .list {
    margin-top: 7.69vw;
    gap: 4.1vw;
    margin-bottom: 6.92vw;
  }
  .footer .list .item::after {
    top: 50%;
    transform: translateY(-50%);
    right: -2.05vw;
    height: 3.08vw;
  }
  .footer .list .item .link {
    font-size: 3.08vw;
  }
  .footer .copyright {
    font-size: 3.08vw;
    padding-top: 5.13vw;
  }
  /* fixed_footer
  ----------------------------------------*/
  .fixed_footer {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 30.77vw;
    z-index: 9999;
    opacity: 0;
    transform: translateY(100%);
    transition: opacity 0.3s ease, transform 0.3s ease;
    pointer-events: none;
  }
  .fixed_footer.is_visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
  .fixed_footer .fixed_banner {
    width: 94.87vw;
    height: 10.26vw;
    background-color: #fff258;
    border-radius: 23px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4.1vw;
    font-weight: 700;
    letter-spacing: 0.14em;
    color: #333333;
    position: relative;
    margin: 0 auto;
  }
  .fixed_footer .fixed_btn {
    width: 100%;
    height: 25.64vw;
    background-color: #fffee6;
    border-radius: 10px;
    margin-top: -5.13vw;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 2.56vw;
    padding: 7.69vw 2.56vw 0;
  }
  .fixed_footer .fixed_btn .btn {
    display: block;
    width: 100%;
    height: 15.38vw;
    border-radius: 6px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .fixed_footer .fixed_btn .btn.btn_reserve {
    background-color: #6fb92d;
  }
  .fixed_footer .fixed_btn .btn.btn_contact {
    background-color: #ab7326;
  }
  .fixed_footer .fixed_btn .btn .btn_text {
    color: #fff;
    font-size: 4.1vw;
    font-weight: 700;
    letter-spacing: 0.09em;
  }
  /*----------------------------------------
     サービスの流れ
  ----------------------------------------*/
  .page_flow .common_page_wrap {
    padding: 7.69vw 0 15.38vw;
  }
  .page_flow .intro {
    font-size: 3.59vw;
    margin: 0 0 7.69vw 0;
  }
  .page_flow .steps {
    gap: 5.13vw;
  }
  .page_flow .step {
    padding: 6.67vw 5.13vw;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
  }
  .page_flow .step .step_icon {
    display: none;
  }
  .page_flow .step .step_content {
    display: flex;
    flex-direction: column;
  }
  .page_flow .step .step_content .step_header {
    padding-bottom: 0;
  }
  .page_flow .step .step_header::after {
    display: none;
  }
  .page_flow .step .label_box {
    display: none;
  }
  .page_flow .step .step_title {
    font-size: 4.1vw;
    letter-spacing: 0.12em;
  }
  .page_flow .step .step_text {
    font-size: 3.33vw;
    margin-top: 5.38vw;
  }
  /*----------------------------------------
     よくある質問
  ----------------------------------------*/
  .page_faq::before {
    content: "";
    position: absolute;
    top: -12.82vw;
    left: 0;
    width: 100%;
    height: calc(100% + 12.82vw);
    background-color: #faf9f2;
    z-index: -1;
  }
  .page_faq .common_page_wrap {
    padding: 7.69vw 0 15.38vw;
  }
  .page_faq .items {
    display: flex;
    flex-direction: column;
    gap: 3.08vw;
    margin: 0 auto 0;
  }
  .page_faq .item {
    border-radius: 8px;
    padding: 5.13vw;
  }
  .page_faq .item .question {
    gap: 5.13vw;
    padding-bottom: 5.13vw;
  }
  .page_faq .item .question::after {
    height: 1px;
    background-image: url("././image/dashed_line04_sp.svg");
  }
  .page_faq .item .question .icon {
    width: 10.26vw;
    height: 10.26vw;
  }
  .page_faq .item .question .icon .image {
    width: 3.59vw;
    height: 4.62vw;
  }
  .page_faq .item .question .text {
    font-size: 4.1vw;
  }
  .page_faq .item .answer {
    margin-top: 4.1vw;
  }
  .page_faq .item .answer .text {
    font-size: 3.59vw;
  }
  /*----------------------------------------
     会社概要
  ----------------------------------------*/
  .page_company .common_page_wrap {
    padding: 13vw 0 18vw;
  }
  .company_profile_sec .cont .message_box {
    max-width: auto;
    margin: 0 auto 10.26vw;
  }
  .company_profile_sec .cont .message_box .message_text {
    font-size: 4.1vw;
  }
  .company_profile_sec .cont .message_box .name_box {
    gap: 2.56vw;
    margin-top: 3.85vw;
  }
  .company_profile_sec .cont .message_box .name_box .position {
    font-size: 4.1vw;
  }
  .company_profile_sec .cont .message_box .name_box .name {
    font-size: 4.62vw;
  }
  .company_profile_sec .cont .detail .item {
    padding: 0;
  }
  .company_profile_sec .cont .detail .item .inbox .head {
    width: 23vw;
    font-size: 3.6vw;
    padding: 1.9em 0;
  }
  .company_profile_sec .cont .detail .item .inbox .text_area {
    font-size: 3.6vw;
    padding: 1.9em 0;
  }
  .company_profile_sec .cont .detail .item .map {
    width: 100%;
    height: 55vw;
    padding-bottom: 1.9em;
    margin-top: 0;
  }
}
/*# sourceMappingURL=style.css.map */