@charset "UTF-8";
/*
    Template: swell
    Theme Name: SWELL CHILD
    Theme URI: https://swell-theme.com/
    Description: SWELLの子テーマ
    Version: 1.0.0
    Author: LOOS WEB STUDIO
    Author URI: https://loos-web-studio.com/

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/
:root {
  --swl-font_family: "Shippori Mincho", serif;
}

@font-face {
  font-family: "Holland";
  src: url("fonts/Holland.otf") format("OpenType");
}
.f_ba {
  font-family: "Baskerville", serif;
}

.f_ho {
  font-family: "Holland", sans-serif;
}

html,
button,
input,
select,
textarea {
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
}

body {
  color: #333333;
  font-size: 16px;
  line-height: 1.7;
}

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

.wrap02 {
  width: 1240px;
  margin: 0 auto;
}

.wrap03 {
  width: 1340px;
  margin: 0 auto;
}

#main_header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 997;
  background-color: #fff;
}
#main_header .header_wrap {
  width: 100%;
  padding-left: calc(50vw - 620px);
}
#main_header .header_wrap .cont {
  width: 100%;
  display: flex;
  align-items: center;
}
#main_header .header_wrap .cont .logo {
  flex-shrink: 0;
  width: 160px;
  line-height: 1;
}
#main_header .header_wrap .cont .logo a {
  display: block;
  width: 100%;
  line-height: 1;
}
#main_header .header_wrap .cont .logo a h1, #main_header .header_wrap .cont .logo a div {
  display: block;
  width: 100%;
  line-height: 1;
}
#main_header .header_wrap .cont .logo a img {
  width: 100%;
}
#main_header .header_wrap .cont .link_block {
  display: flex;
  gap: 0 60px;
  align-items: center;
  margin-left: auto;
}
#main_header .header_wrap .cont .link_block .list ul {
  display: flex;
  gap: 0 60px;
}
#main_header .header_wrap .cont .link_block .list ul li {
  line-height: 1;
}
#main_header .header_wrap .cont .link_block .list ul li a {
  position: relative;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.04em;
  line-height: 1;
  color: #333333;
  transition: 0.3s;
}
#main_header .header_wrap .cont .link_block .list ul li a:hover {
  color: #D06880;
}
#main_header .header_wrap .cont .link_block .list ul li a:hover::before {
  opacity: 1;
}
#main_header .header_wrap .cont .link_block .list ul li a::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background-color: #f6ced7;
  opacity: 0;
  filter: blur(8px);
  transition: 0.3s;
}
#main_header .header_wrap .cont .link_block .line_btn {
  flex-shrink: 0;
  width: calc(50vw - 570px);
}
#main_header .header_wrap .cont .link_block .line_btn a {
  display: block;
  width: 100%;
  height: 100px;
  background-color: #A83A69;
  padding-top: 16px;
  text-align: center;
  transition: 0.3s;
}
#main_header .header_wrap .cont .link_block .line_btn a:hover {
  background-color: #BC5D77;
}
#main_header .header_wrap .cont .link_block .line_btn a .icon {
  width: 25px;
  line-height: 1;
  margin: 0 auto 5px;
}
#main_header .header_wrap .cont .link_block .line_btn a .icon img {
  width: 100%;
}
#main_header .header_wrap .cont .link_block .line_btn a .label {
  font-size: 16px;
  letter-spacing: 0.04em;
  font-weight: 500;
  line-height: 1.2;
  color: #fff;
}

.fadeTilt {
  opacity: 0;
}

/* アニメ中 */
.fadeTilt.is-animating {
  animation: fade-tilt 1.5s cubic-bezier(0, 0.25, 1, 1) both;
}

.fadeTilt.Fast.is-animating {
  animation: fade-tilt 1s cubic-bezier(0, 0.25, 1, 1) both;
}

/* アニメ完了後の最終状態 */
.fadeTilt.is-done {
  opacity: 1;
  -webkit-mask-image: none;
  mask-image: none;
  -webkit-mask-size: initial;
  mask-size: initial;
  -webkit-mask-repeat: repeat;
  mask-repeat: repeat;
  -webkit-mask-position: 0 0;
  mask-position: 0 0;
}
@keyframes fade-tilt {
  0% {
    opacity: 0;
    -webkit-mask-image: linear-gradient(135deg, rgb(0, 0, 0) 30%, rgba(0, 0, 0, 0.4) 45%, rgba(0, 0, 0, 0) 55%, rgba(0, 0, 0, 0) 100%);
    mask-image: linear-gradient(135deg, rgb(0, 0, 0) 30%, rgba(0, 0, 0, 0.4) 45%, rgba(0, 0, 0, 0) 55%, rgba(0, 0, 0, 0) 100%);
    -webkit-mask-size: 250% 250%;
    mask-size: 250% 250%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: 130% 130%;
    mask-position: 130% 130%;
  }
  100% {
    opacity: 1;
    -webkit-mask-image: linear-gradient(135deg, rgb(0, 0, 0) 30%, rgba(0, 0, 0, 0.4) 45%, rgba(0, 0, 0, 0) 55%, rgba(0, 0, 0, 0) 100%);
    mask-image: linear-gradient(135deg, rgb(0, 0, 0) 30%, rgba(0, 0, 0, 0.4) 45%, rgba(0, 0, 0, 0) 55%, rgba(0, 0, 0, 0) 100%);
    -webkit-mask-size: 250% 250%;
    mask-size: 250% 250%;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: 0 0;
    mask-position: 0 0;
  }
}
.fadeUp {
  opacity: 0;
  transform: translate3d(0, 1rem, 0);
  transition-property: opacity, transform;
  transition-duration: 0.3s;
  transition-timing-function: cubic-bezier(0, 0.25, 1, 1);
  will-change: opacity, transform;
}

.fadeUp.animated {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.fadeLeft {
  opacity: 0;
  transform: translateX(16px);
  transition: opacity 0.3s cubic-bezier(0, 0.25, 1, 1), transform 0.3s cubic-bezier(0, 0.25, 1, 1);
  will-change: opacity, transform;
}

.fadeLeft.animated {
  opacity: 1;
  transform: translateX(0);
}

.fadeRight {
  opacity: 0;
  transform: translateX(-16px);
  transition: opacity 0.3s cubic-bezier(0, 0.25, 1, 1), transform 0.3s cubic-bezier(0, 0.25, 1, 1);
  will-change: opacity, transform;
}

.fadeRight.animated {
  opacity: 1;
  transform: translateX(0);
}

.fadeInBlur {
  opacity: 0;
  transform: translateY(30px);
  filter: blur(30px);
  transition: opacity 0.8s cubic-bezier(0.27, 0, 0.58, 1), transform 0.8s cubic-bezier(0.27, 0, 0.58, 1), filter 0.8s cubic-bezier(0.27, 0, 0.58, 1);
}

.fadeInBlur:not(.animated) {
  transition: all 0.3s ease 0s !important;
}

.fadeInBlur.animated {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

#top_fv_sec {
  z-index: 2;
  margin-top: 100px;
  padding: 170px 0 71px;
  background-image: url(image/fv_back.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
#top_fv_sec::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(254, 255, 240, 0.5);
  background: linear-gradient(90deg, rgba(254, 255, 240, 0.5) 0%, rgba(255, 255, 255, 0) 100%);
}
#top_fv_sec .cont {
  z-index: 1;
}
#top_fv_sec .cont .text_box {
  margin-bottom: 49px;
}
#top_fv_sec .cont .text_box .label_wrap {
  display: flex;
  gap: 0 35px;
  align-items: center;
  margin-bottom: 20px;
}
#top_fv_sec .cont .text_box .label_wrap .label {
  line-height: 1;
  font-size: 22px;
  letter-spacing: 0.2em;
  font-weight: 500;
}
#top_fv_sec .cont .text_box .label_wrap::after {
  content: "";
  display: block;
  width: 170px;
  height: 1px;
  background-color: #333333;
}
#top_fv_sec .cont .text_box .ttl {
  font-size: 48px;
  font-weight: 600;
  letter-spacing: 0.18em;
  line-height: 1.5;
}
#top_fv_sec .cont .list ul {
  display: flex;
  gap: 0 24px;
}
#top_fv_sec .cont .list ul li {
  width: 160px;
  height: 160px;
}
#top_fv_sec .cont .list ul li:nth-child(1) {
  transition-delay: 0.8s;
}
#top_fv_sec .cont .list ul li:nth-child(2) {
  transition-delay: 0.9s;
}
#top_fv_sec .cont .list ul li:nth-child(3) {
  transition-delay: 1s;
}
#top_fv_sec .cont .list ul li::after {
  content: "";
  position: absolute;
  display: inline-block;
  inset: 0;
  z-index: -1;
  background-color: #fff;
  pointer-events: none;
  filter: blur(8px);
  -webkit-filter: blur(8px);
  border-radius: 50%;
  transform: translateZ(0);
}
#top_fv_sec .cont .list ul li::before {
  content: "";
  position: absolute;
  top: -4px;
  left: -3px;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  border: 1px solid #D06880;
  opacity: 0.2;
  pointer-events: none;
}
#top_fv_sec .cont .list ul li.num_wrap {
  padding-top: 36px;
}
#top_fv_sec .cont .list ul li.num_wrap .label {
  text-align: center;
  font-size: 18px;
  letter-spacing: 0.2em;
  font-weight: bold;
  line-height: 1;
  margin-bottom: -3px;
}
#top_fv_sec .cont .list ul li.num_wrap .num_box {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 0 7px;
}
#top_fv_sec .cont .list ul li.num_wrap .num_box .num {
  z-index: 1;
  font-size: 62px;
  line-height: 1;
  font-weight: 600;
  font-style: italic;
  color: #D14F73;
  transform: translateY(0.11em);
  letter-spacing: -0.04em;
}
#top_fv_sec .cont .list ul li.num_wrap .num_box .num::before {
  content: "";
  position: absolute;
  z-index: -1;
  height: 8px;
  bottom: 0.1em;
  left: 0;
  right: 0;
  background-color: #FFF8AA;
  filter: blur(2px);
}
#top_fv_sec .cont .list ul li.num_wrap .num_box .nin {
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.3;
}
#top_fv_sec .cont .list ul li.per_wrap {
  padding-top: 36px;
}
#top_fv_sec .cont .list ul li.per_wrap .label {
  text-align: center;
  font-size: 18px;
  letter-spacing: 0.2em;
  font-weight: bold;
  line-height: 1;
  margin-bottom: -3px;
}
#top_fv_sec .cont .list ul li.per_wrap .num_box {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  gap: 0 4px;
}
#top_fv_sec .cont .list ul li.per_wrap .num_box .num {
  z-index: 1;
  font-size: 62px;
  line-height: 1;
  font-weight: 600;
  font-style: italic;
  color: #D14F73;
  transform: translateY(0.11em);
  letter-spacing: -0.04em;
}
#top_fv_sec .cont .list ul li.per_wrap .num_box .num::before {
  content: "";
  position: absolute;
  z-index: -1;
  height: 8px;
  bottom: 0.1em;
  left: 0;
  right: 0;
  background-color: #FFF8AA;
  filter: blur(2px);
}
#top_fv_sec .cont .list ul li.per_wrap .num_box .per {
  font-size: 32px;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1;
}
#top_fv_sec .cont .list ul li.support_wrap {
  padding-top: 23px;
  text-align: center;
}
#top_fv_sec .cont .list ul li.support_wrap .num_box {
  margin-bottom: 7px;
  z-index: 1;
  display: inline-flex;
  justify-content: center;
  align-items: flex-end;
  gap: 0 4px;
}
#top_fv_sec .cont .list ul li.support_wrap .num_box::before {
  content: "";
  position: absolute;
  z-index: -1;
  height: 8px;
  bottom: 0.1em;
  left: 0;
  right: 0;
  background-color: #FFF8AA;
  filter: blur(2px);
}
#top_fv_sec .cont .list ul li.support_wrap .num_box .num {
  font-size: 62px;
  line-height: 1;
  font-weight: 600;
  font-style: italic;
  color: #D14F73;
  transform: translateY(0.11em);
  letter-spacing: -0.04em;
}
#top_fv_sec .cont .list ul li.support_wrap .num_box .time {
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.08em;
  line-height: 1;
}
#top_fv_sec .cont .list ul li.support_wrap .support_label {
  font-size: 20px;
  letter-spacing: 0.08em;
  font-weight: bold;
  line-height: 1;
}

#top_about_sec {
  margin-bottom: 205px;
  padding: 158px 0 77px;
  background: #FFFEED;
  background: linear-gradient(0deg, rgb(255, 254, 237) 0%, rgb(255, 255, 255) 100%);
}
#top_about_sec::after {
  content: "";
  position: absolute;
  bottom: -82px;
  width: 100%;
  height: 130px;
  background-color: #FFFEED;
  filter: blur(20px);
}
#top_about_sec .deco {
  position: absolute;
  z-index: 1;
  line-height: 1;
}
#top_about_sec .deco img {
  width: 100%;
}
#top_about_sec .deco.deco1 {
  top: 0;
  left: calc(50vw - 570px + 146px);
  width: 424px;
  height: 424px;
  opacity: 0.15;
}
#top_about_sec .deco.deco2 {
  top: 445px;
  left: calc(50vw - 620px);
  width: 298px;
  height: 298px;
  opacity: 0.1;
}
#top_about_sec .deco.deco3 {
  top: 469px;
  right: calc(50vw - 570px + 45px);
  width: 427px;
  height: 427px;
  opacity: 0.13;
}
#top_about_sec .deco.deco4 {
  bottom: -23px;
  right: calc(50vw - 570px - 220px);
  width: 427px;
  height: 427px;
  opacity: 0.13;
}
#top_about_sec .top_about_main_cont {
  z-index: 2;
  margin-bottom: 85px;
}
#top_about_sec .top_about_main_cont .cont {
  text-align: center;
}
#top_about_sec .top_about_main_cont .cont .top_ttl_box {
  margin-bottom: 40px;
}
#top_about_sec .top_about_main_cont .cont .top_ttl_box .en {
  font-size: 15px;
  line-height: 1;
  margin-bottom: 18px;
  color: #D06880;
}
#top_about_sec .top_about_main_cont .cont .top_ttl_box .ttl {
  font-size: 30px;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.15em;
}
#top_about_sec .top_about_main_cont .cont .lead_text {
  font-size: 38px;
  letter-spacing: 0.21em;
  line-height: 1.5;
  margin-bottom: 43px;
}
#top_about_sec .top_about_main_cont .cont .text {
  font-size: 16px;
  letter-spacing: 0.08em;
  line-height: 1.8;
}
#top_about_sec .top_about_main_cont .cont .text + .text {
  margin-top: 29px;
}
#top_about_sec .top_about_flow_cont {
  z-index: 2;
}
#top_about_sec .top_about_flow_cont .sec_wrap {
  width: 1240px;
  margin: 0 auto;
}
#top_about_sec .top_about_flow_cont .sec_wrap .top_ttl_box {
  margin-bottom: 30px;
}
#top_about_sec .top_about_flow_cont .sec_wrap .top_ttl_box .ttl {
  font-size: 26px;
  letter-spacing: 0.15em;
  line-height: 1;
  font-weight: 600;
}
#top_about_sec .top_about_flow_cont .sec_wrap .top_ttl_box .ttl .small {
  font-size: 20px;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul {
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 0 32px;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 95px;
  left: 0;
  right: 0;
  height: 1px;
  background: repeating-linear-gradient(to right, #D06880 0 3px, transparent 3px 6px);
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li {
  z-index: 1;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li:nth-child(2) {
  transition-delay: 0.1s;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li:nth-child(3) {
  transition-delay: 0.2s;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li:nth-child(4) {
  transition-delay: 0.3s;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li:nth-child(5) {
  transition-delay: 0.4s;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li:nth-child(6) {
  transition-delay: 0.5s;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li .deco {
  position: absolute;
  top: 200px;
  right: 0;
  z-index: -1;
  font-size: 16px;
  line-height: 1;
  color: #CE2A89;
  transform: rotate(-7deg);
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li .en_label {
  font-size: 18px;
  line-height: 1;
  color: #D06880;
  margin-bottom: 12px;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li .img {
  width: 100%;
  height: 130px;
  line-height: 1;
  margin-bottom: 20px;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .ttl_box {
  height: 50px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-bottom: 15px;
  position: relative;
  margin-bottom: 12px;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .ttl_box::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: repeating-linear-gradient(to right, #D0D0D0 0 3px, transparent 3px 6px);
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .ttl_box .ttl {
  font-size: 16px;
  letter-spacing: 0.08em;
  line-height: 1.6;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .text {
  font-size: 14px;
  letter-spacing: 0.08em;
  font-weight: 500;
  line-height: 1.5;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .cur_list .cur {
  display: flex;
  align-items: baseline;
  gap: 0 0.5em;
  font-size: 14px;
  letter-spacing: 0.08em;
  font-weight: 500;
  line-height: 1.2;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .cur_list .cur::before {
  content: "";
  display: block;
  flex-shrink: 0;
  width: 0.2em;
  height: 0.2em;
  border-radius: 50%;
  background-color: #333333;
}
#top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .cur_list .cur + .cur {
  margin-top: 5px;
}

.common_top_ttl_box {
  text-align: center;
}
.common_top_ttl_box .common_ttl_box {
  margin-bottom: 26px;
}
.common_top_ttl_box .text {
  font-size: 14px;
  letter-spacing: 0.15em;
  line-height: 1.6;
}

.common_ttl_box .en {
  font-size: 20px;
  line-height: 1;
  margin-bottom: 10px;
  color: #D06880;
}
.common_ttl_box .ttl {
  font-size: 40px;
  font-weight: 600;
  letter-spacing: 0.15em;
  line-height: 1.6;
}

.common_voice_box {
  width: 360px;
}
.common_voice_box a {
  height: 100%;
  display: flex;
  flex-direction: column;
  background-color: #fff;
  box-shadow: 0 3px 6px rgba(51, 51, 51, 0.11);
}
.common_voice_box a:hover .img_box .img img {
  transform: scale(1.1);
}
.common_voice_box a:hover .voice_cont .com_wrap .com_box .num_box {
  box-shadow: 0 0 0 rgba(0, 0, 0, 0);
}
.common_voice_box a:hover .btn {
  background-color: #D06880;
}
.common_voice_box a .img_box {
  flex-shrink: 0;
  position: relative;
  width: 100%;
  height: 180px;
}
.common_voice_box a .img_box::before {
  content: "";
  position: absolute;
  z-index: 1;
  inset: 5px;
  margin: auto;
  border: 1px solid #fff;
}
.common_voice_box a .img_box .img {
  width: 100%;
  height: 100%;
  line-height: 1;
  overflow: hidden;
}
.common_voice_box a .img_box .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.3s;
}
.common_voice_box a .img_box .name_box {
  position: absolute;
  z-index: 1;
  left: 0;
  bottom: 0;
  display: inline-block;
  padding: 10px 30px 0 30px;
  background-color: #fff;
  font-weight: 500;
}
.common_voice_box a .img_box .name_box .old {
  font-size: 13px;
  line-height: 1;
  letter-spacing: 0.08em;
  color: #A2A2A2;
  margin-bottom: 5px;
}
.common_voice_box a .img_box .name_box .name {
  font-size: 15px;
  letter-spacing: 0.08em;
  line-height: 1;
  color: #676767;
}
.common_voice_box a .voice_cont {
  flex-shrink: 0;
  color: #333333;
  z-index: 1;
  padding: 35px 30px 40px;
}
.common_voice_box a .voice_cont .designs_text {
  position: absolute;
  top: 16px;
  right: 60px;
  z-index: -1;
  font-size: 16px;
  line-height: 1;
  color: #EAC0C9;
  transform: rotate(5deg);
}
.common_voice_box a .voice_cont .lead_text {
  text-align: center;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.08em;
  line-height: 1;
  margin-bottom: 15px;
}
.common_voice_box a .voice_cont .lead_text .color {
  color: #D06880;
}
.common_voice_box a .voice_cont .com_wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 30px;
}
.common_voice_box a .voice_cont .com_wrap .com_box {
  width: 120px;
  flex-shrink: 0;
}
.common_voice_box a .voice_cont .com_wrap .com_box .label {
  width: 100%;
  line-height: 30px;
  text-align: center;
  color: #fff;
  font-size: 16px;
  font-weight: 600;
}
.common_voice_box a .voice_cont .com_wrap .com_box .num_box {
  text-align: center;
  padding: 9px 0 15px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
  transition: 0.3s;
}
.common_voice_box a .voice_cont .com_wrap .com_box .num_box .num {
  font-size: 38px;
  letter-spacing: 0.04em;
  line-height: 1;
  font-weight: 500;
}
.common_voice_box a .voice_cont .com_wrap .com_box .num_box .num .small {
  font-size: 18px;
  color: #333333;
}
.common_voice_box a .voice_cont .com_wrap .com_box.before .label {
  background-color: #383838;
}
.common_voice_box a .voice_cont .com_wrap .com_box.before .num_box {
  background-color: #F7F7F7;
}
.common_voice_box a .voice_cont .com_wrap .com_box.after .label {
  background-color: #D06880;
}
.common_voice_box a .voice_cont .com_wrap .com_box.after .num_box {
  background-color: #FDFAE8;
}
.common_voice_box a .voice_cont .com_wrap .com_box.after .num_box .num {
  color: #D06880;
}
.common_voice_box a .voice_cont .com_wrap .arrow {
  width: 28px;
  line-height: 1;
}
.common_voice_box a .voice_cont .com_wrap .arrow img {
  width: 100%;
}
.common_voice_box a .voice_cont .text_box .ttl {
  font-size: 18px;
  letter-spacing: 0.08em;
  line-height: 1.5;
  font-weight: 600;
  margin-bottom: 10px;
}
.common_voice_box a .voice_cont .text_box .text {
  font-size: 13px;
  letter-spacing: 0.08em;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.common_voice_box a .btn {
  margin-top: auto;
  width: 100%;
  height: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 10px;
  background-color: #BC5D77;
  transition: 0.3s;
}
.common_voice_box a .btn .label {
  font-size: 16px;
  letter-spacing: 0.08em;
  line-height: 1;
  font-weight: 600;
  color: #fff;
}
.common_voice_box a .btn .arrow {
  width: 10.7px;
  line-height: 1;
}
.common_voice_box a .btn .arrow svg {
  width: 100%;
  line-height: 1;
  vertical-align: middle;
}

#top_voice_sec {
  z-index: 3;
  margin-bottom: 160px;
}
#top_voice_sec .common_top_ttl_box {
  margin-bottom: 42px;
}
#top_voice_sec .slider_wrap .slider_guide_box {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: -100px;
  right: -100px;
  display: flex;
  justify-content: space-between;
  pointer-events: none;
}
#top_voice_sec .slider_wrap .slider_guide_box .dots_list {
  display: none;
  pointer-events: auto;
}
#top_voice_sec .slider_wrap .slider_guide_box .arrow {
  pointer-events: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 70px;
  height: 70px;
  border: 1px solid #B4B4B4;
  line-height: 1;
  cursor: pointer;
  border-radius: 50%;
  transition: 0.3s;
  background-color: #fff;
}
#top_voice_sec .slider_wrap .slider_guide_box .arrow:last-child {
  transform: rotateY(180deg);
}
#top_voice_sec .slider_wrap .slider_guide_box .arrow:hover {
  background-color: #D06880;
}
#top_voice_sec .slider_wrap .slider_guide_box .arrow:hover svg path {
  fill: #fff;
}
#top_voice_sec .slider_wrap .slider_guide_box .arrow svg {
  vertical-align: middle;
  width: 12.5px;
  transform: translateX(20%);
}
#top_voice_sec .slider_wrap .slider_guide_box .arrow svg path {
  fill: #B4B4B4;
  transition: 0.3s;
}
#top_voice_sec .slider_wrap .top_voice_slider .slick-list {
  padding: 6px;
  touch-action: pan-y;
}
#top_voice_sec .slider_wrap .top_voice_slider .slick-track {
  display: flex;
}
#top_voice_sec .slider_wrap .top_voice_slider .common_voice_box {
  margin: 0 12px;
  height: auto;
}
#top_voice_sec .slider_wrap .top_voice_slider .common_voice_box a {
  height: 100%;
}
#top_voice_sec .slider_wrap .top_voice_slider .common_voice_box:nth-child(3) {
  transition-delay: 0.1s;
}
#top_voice_sec .slider_wrap .top_voice_slider .common_voice_box:nth-child(4) {
  transition-delay: 0.2s;
}

.common_btn {
  width: 360px;
}
.common_btn a {
  display: flex;
  gap: 0 20px;
  align-items: center;
  width: 100%;
  padding: 15px 20px 15px 40px;
  background-color: #BC5D77;
  border: 1px solid transparent;
  border-radius: 100vmax;
  transition: 0.3s;
}
.common_btn a:hover {
  background-color: #fff;
  border: 1px solid #D06880;
}
.common_btn a:hover .label {
  color: #D06880;
}
.common_btn a:hover .arrow_box {
  background-color: #D06880;
}
.common_btn a:hover .arrow_box .arrow svg path {
  fill: #fff;
}
.common_btn a .label {
  flex-grow: 1;
  font-size: 17px;
  letter-spacing: 0.06em;
  font-weight: 600;
  line-height: 1;
  color: #fff;
  transition: 0.3s;
}
.common_btn a .arrow_box {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background-color: #fff;
  transition: 0.3s;
}
.common_btn a .arrow_box .arrow {
  width: 8px;
  height: 8px;
  line-height: 1;
  transform: translateX(-15%);
}
.common_btn a .arrow_box .arrow svg {
  width: 100%;
  vertical-align: top;
}
.common_btn a .arrow_box .arrow svg path {
  fill: #BC5D77;
  transition: 0.3s;
}

#top_reason_sec {
  padding: 95px 0 135px;
  background-color: #FAFAF5;
  margin-bottom: 180px;
}
#top_reason_sec::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: url(image/reason_back.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  opacity: 0.45;
  mix-blend-mode: multiply;
}
#top_reason_sec .deco {
  pointer-events: none;
  position: absolute;
  z-index: 2;
  line-height: 1;
}
#top_reason_sec .deco.deco1 {
  width: 873px;
  top: -50px;
  right: -261px;
  opacity: 0.4;
}
#top_reason_sec .deco.deco2 {
  width: 403px;
  bottom: 300px;
  left: -111px;
  opacity: 0.3;
}
#top_reason_sec .deco img {
  width: 100%;
}
#top_reason_sec .cont {
  z-index: 3;
}
#top_reason_sec .cont .common_top_ttl_box {
  margin-bottom: 32px;
}
#top_reason_sec .cont .list {
  margin-bottom: 48px;
}
#top_reason_sec .cont .list ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 30px;
}
#top_reason_sec .cont .list ul li:nth-child(2) {
  animation-delay: 0.1s;
}
#top_reason_sec .cont .list ul li:nth-child(3) {
  animation-delay: 0.2s;
}
#top_reason_sec .cont .list ul li .img {
  width: 100%;
  height: 200px;
  line-height: 1;
  margin-bottom: 29.5px;
}
#top_reason_sec .cont .list ul li .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#top_reason_sec .cont .list ul li .text_box .ttl_box {
  padding-left: 15px;
  border-left: 1px solid #D06880;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 57px;
  margin-bottom: 23px;
}
#top_reason_sec .cont .list ul li .text_box .ttl_box .ttl {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1.4;
  color: #D06880;
}
#top_reason_sec .cont .list ul li .text_box .text {
  font-size: 15px;
  letter-spacing: 0.08em;
  line-height: 1.5;
  color: #4E4E4E;
}
#top_reason_sec .cont .common_btn {
  margin: 0 auto;
}

#top_com_sec {
  margin-bottom: 180px;
}
#top_com_sec::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 67px;
  left: calc(50vw - 670px);
  right: calc(50vw - 670px);
  bottom: -292px;
  background: #FFF5F7;
  background: linear-gradient(180deg, rgb(255, 245, 247) 0%, rgb(255, 245, 247) 75%, rgb(255, 255, 255) 100%);
  filter: blur(10px);
}
#top_com_sec .cont .common_top_ttl_box {
  margin-bottom: 42.5px;
}
#top_com_sec .cont .table_cont .table_wrap {
  position: relative;
}
#top_com_sec .cont .table_cont .table_wrap::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 136px;
  left: 0;
  right: 0;
  bottom: 0;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.06);
  background-color: #F4F4F4;
}
#top_com_sec .cont .table_cont .table_wrap .icon_heart {
  width: 15.6px;
  margin-left: 278.7px;
  margin-bottom: 5px;
  line-height: 1;
}
#top_com_sec .cont .table_cont .table_wrap .icon_heart img {
  width: 100%;
}
#top_com_sec .cont .table_cont .table_wrap table {
  width: 100%;
}
#top_com_sec .cont .table_cont .table_wrap table .zoomIn {
  animation-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
}
#top_com_sec .cont .table_cont .table_wrap table thead th {
  vertical-align: bottom;
  text-align: center;
  color: #fff;
  font-size: 22px;
  line-height: 1.1;
  letter-spacing: 0.04em;
  font-weight: 500;
  width: 190px;
}
#top_com_sec .cont .table_cont .table_wrap table thead th .inner {
  border-left: 1px solid #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 80px;
  background-color: #64615F;
}
#top_com_sec .cont .table_cont .table_wrap table thead th .inner .anim_inner {
  display: flex;
  flex-direction: column;
}
#top_com_sec .cont .table_cont .table_wrap table thead th .small {
  margin-top: 4px;
  font-size: 14px;
  display: inline-block;
  line-height: 1.3;
}
#top_com_sec .cont .table_cont .table_wrap table thead th:nth-of-type(1) {
  background-color: transparent;
  width: auto;
}
#top_com_sec .cont .table_cont .table_wrap table thead th:nth-of-type(1) .inner {
  border-left: none;
}
#top_com_sec .cont .table_cont .table_wrap table thead th:nth-of-type(2) {
  border-left: 3px solid #D06880;
  border-right: 3px solid #D06880;
}
#top_com_sec .cont .table_cont .table_wrap table thead th:nth-of-type(2) .inner {
  border-left: none;
}
#top_com_sec .cont .table_cont .table_wrap table thead th:nth-of-type(2) .inner.tall {
  height: 120px;
  background-color: #D06880;
}
#top_com_sec .cont .table_cont .table_wrap table thead th:nth-of-type(3) .inner {
  border-left: none;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr th,
#top_com_sec .cont .table_cont .table_wrap table tbody tr td {
  text-align: center;
  vertical-align: middle;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr th {
  background-color: #F4F4F4;
  border-bottom: 1px solid #DDDDDD;
  font-size: 20px;
  letter-spacing: 0.04em;
  font-weight: 600;
  line-height: 1.3;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr:nth-of-type(1) td {
  height: 180px;
  font-size: 14px;
  letter-spacing: 0.04em;
  font-weight: 600;
  line-height: 1.8;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr:last-of-type td {
  border-bottom: none;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr:last-of-type td:nth-of-type(1) {
  position: relative;
  z-index: 1;
  border-bottom: 3px solid #D06880;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr:last-of-type th {
  border-bottom: none;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr td {
  height: 140px;
  background-color: #fff;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1.2;
  border-bottom: 1px solid #F0F0F0;
  border-left: 1px solid #DDDDDD;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr td .small {
  font-size: 14px;
  letter-spacing: 0.04em;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr td .anim_inner {
  display: inline-block;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr td:nth-of-type(1) {
  background-color: #FFFEF4;
  color: #D06880;
  border-left: 3px solid #D06880;
  border-right: 3px solid #D06880;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr td.love_circle, #top_com_sec .cont .table_cont .table_wrap table tbody tr td.circle, #top_com_sec .cont .table_cont .table_wrap table tbody tr td.x, #top_com_sec .cont .table_cont .table_wrap table tbody tr td.tri {
  background-repeat: no-repeat;
  background-position: center;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr td.love_circle, #top_com_sec .cont .table_cont .table_wrap table tbody tr td.circle, #top_com_sec .cont .table_cont .table_wrap table tbody tr td.x {
  background-size: 60px;
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr td.love_circle {
  background-image: url(image/icon_table_circle_yellow.svg);
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr td.circle {
  background-image: url(image/icon_table_circle_gray.svg);
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr td.x {
  background-image: url(image/icon_table_x_gray.svg);
}
#top_com_sec .cont .table_cont .table_wrap table tbody tr td.tri {
  background-image: url(image/icon_table_tri_gray.svg);
  background-size: 65px;
}

#top_flow_sec {
  z-index: 1;
  margin-bottom: 135px;
}
#top_flow_sec .common_top_ttl_box {
  margin-bottom: 50px;
}
#top_flow_sec .flow_list::before {
  content: "";
  position: absolute;
  top: 64.5px;
  left: 225px;
  right: 225px;
  height: 1px;
  background-color: #D6C0CD;
  z-index: -1;
}
#top_flow_sec .flow_list ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 90px;
}
#top_flow_sec .flow_list ul li {
  display: flex;
  flex-direction: column;
}
#top_flow_sec .flow_list ul li:first-child .icon_wrap::before {
  content: none;
}
#top_flow_sec .flow_list ul li:first-child .icon_wrap .icon {
  width: 46.6px;
}
#top_flow_sec .flow_list ul li:first-child .text_box::before {
  content: none;
}
#top_flow_sec .flow_list ul li:nth-child(2) {
  transition-delay: 0.1s;
}
#top_flow_sec .flow_list ul li:nth-child(2) .icon_wrap .icon {
  width: 58px;
}
#top_flow_sec .flow_list ul li:last-child {
  transition-delay: 0.2s;
}
#top_flow_sec .flow_list ul li:last-child .icon_wrap::after {
  content: none;
}
#top_flow_sec .flow_list ul li:last-child .icon_wrap .icon {
  width: 52.3px;
  position: relative;
  transform: translateX(0.3em);
}
#top_flow_sec .flow_list ul li .icon_wrap {
  width: 130px;
  height: 130px;
  border-radius: 50%;
  border: 1px solid #D06880;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 20px;
  background-color: #fff;
}
#top_flow_sec .flow_list ul li .icon_wrap::before, #top_flow_sec .flow_list ul li .icon_wrap:after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: #D06880;
}
#top_flow_sec .flow_list ul li .icon_wrap::before {
  left: -4px;
}
#top_flow_sec .flow_list ul li .icon_wrap::after {
  right: -4px;
}
#top_flow_sec .flow_list ul li .icon_wrap .step_box {
  position: absolute;
  z-index: 1;
  top: -25px;
  left: 0;
  right: 0;
  margin: 0 auto;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  padding-top: 6px;
  text-align: center;
  background-color: #D06880;
}
#top_flow_sec .flow_list ul li .icon_wrap .step_box .num {
  color: #fff;
  font-size: 16px;
  line-height: 1.1;
}
#top_flow_sec .flow_list ul li .icon_wrap .step_box .num .label {
  font-size: 12px;
  display: inline-block;
}
#top_flow_sec .flow_list ul li .icon_wrap .icon {
  line-height: 1;
}
#top_flow_sec .flow_list ul li .icon_wrap .icon img {
  width: 100%;
}
#top_flow_sec .flow_list ul li .text_box {
  position: relative;
}
#top_flow_sec .flow_list ul li .text_box::before {
  content: "";
  position: absolute;
  top: 0;
  left: -44.5px;
  width: 1px;
  height: 100%;
  background: repeating-linear-gradient(to bottom, #C6C6C6 0 3px, transparent 3px 6px);
}
#top_flow_sec .flow_list ul li .text_box .ttl_box {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 55px;
  margin-bottom: 18px;
}
#top_flow_sec .flow_list ul li .text_box .ttl_box .ttl {
  text-align: center;
  font-size: 20px;
  letter-spacing: 0.04em;
  font-weight: 600;
  line-height: 1.3;
}
#top_flow_sec .flow_list ul li .text_box .text {
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.6;
  color: #4E4E4E;
}

#top_faq_sec {
  padding: 110px 0 195px;
  background: #F5F5F4;
  background: linear-gradient(180deg, rgb(245, 245, 244) 0%, rgb(245, 245, 244) 75%, rgb(255, 255, 255) 100%);
}
#top_faq_sec .deco {
  position: absolute;
  top: -200px;
  left: -88px;
  width: calc(50vw - 570px + 322px);
  line-height: 1;
}
#top_faq_sec .deco img {
  width: 100%;
}
#top_faq_sec .cont {
  z-index: 1;
}
#top_faq_sec .cont .common_top_ttl_box {
  margin-bottom: 64px;
}
#top_faq_sec .cont .common_top_ttl_box .text a {
  color: #333333;
  text-decoration: underline;
}
#top_faq_sec .cont .faq_list ul li {
  cursor: pointer;
  padding: 25px 50px 25px;
  background-color: #fff;
  box-shadow: 0 1px 4px #e8e8df;
}
#top_faq_sec .cont .faq_list ul li + li {
  margin-top: 20px;
}
#top_faq_sec .cont .faq_list ul li.is-open .q_box .icon_box .border:first-child {
  transform: translate(-50%, -50%) rotate(45deg);
}
#top_faq_sec .cont .faq_list ul li.is-open .q_box .icon_box .border:last-child {
  transform: translate(-50%, -50%) rotate(-45deg);
}
#top_faq_sec .cont .faq_list ul li .q_box {
  display: flex;
  align-items: center;
}
#top_faq_sec .cont .faq_list ul li .q_box .en {
  flex-shrink: 0;
  font-size: 24px;
  line-height: 1;
  margin-right: 29px;
  color: #D06880;
}
#top_faq_sec .cont .faq_list ul li .q_box .ttl {
  flex-grow: 1;
  font-size: 18px;
  letter-spacing: 0.04em;
  font-weight: 500;
  line-height: 1.4;
}
#top_faq_sec .cont .faq_list ul li .q_box .icon_box {
  flex-shrink: 0;
  margin-left: 83px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-color: #F0F0F0;
}
#top_faq_sec .cont .faq_list ul li .q_box .icon_box .border {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 15px;
  height: 1.5px;
  background-color: #333333;
  transition: 0.3s;
}
#top_faq_sec .cont .faq_list ul li .q_box .icon_box .border:first-child {
  transform: translate(-50%, -50%) rotate(0deg);
}
#top_faq_sec .cont .faq_list ul li .q_box .icon_box .border:last-child {
  transform: translate(-50%, -50%) rotate(0deg);
}
#top_faq_sec .cont .faq_list ul li .a_box {
  display: none;
  margin-top: 18px;
  padding-top: 24px;
  position: relative;
}
#top_faq_sec .cont .faq_list ul li .a_box::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: repeating-linear-gradient(to right, #E5E5E5 0 4px, transparent 4px 8px);
}
#top_faq_sec .cont .faq_list ul li .a_box .inner {
  display: flex;
  align-items: baseline;
  padding-bottom: 5px;
}
#top_faq_sec .cont .faq_list ul li .a_box .inner .en {
  flex-shrink: 0;
  font-size: 24px;
  line-height: 1;
  margin-right: 35px;
  color: #AA9513;
}
#top_faq_sec .cont .faq_list ul li .a_box .inner .text_box {
  flex-grow: 1;
}
#top_faq_sec .cont .faq_list ul li .a_box .inner .text_box .text {
  font-size: 14px;
  letter-spacing: 0.04em;
  line-height: 1.6;
  color: #4E4E4E;
}

#footer_cta_sec {
  padding: 70px 0;
  background-image: url(image/cta_back_img.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}
#footer_cta_sec .text_box .ttl_box {
  text-align: center;
  margin-bottom: 22px;
}
#footer_cta_sec .text_box .ttl_box .en {
  font-size: 20px;
  line-height: 1;
  margin-bottom: 10px;
  color: #D06880;
}
#footer_cta_sec .text_box .ttl_box .ttl {
  font-size: 36px;
  font-weight: 600;
  letter-spacing: 0.15em;
  line-height: 1.6;
}
#footer_cta_sec .text_box .text {
  text-align: center;
  font-size: 15px;
  letter-spacing: 0.15em;
  line-height: 1.6;
}
#footer_cta_sec .text_box .line_btn {
  width: 420px;
  margin: 50px auto 0;
}
#footer_cta_sec .text_box .line_btn a {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 20px 30px 20px 40px;
  background-color: #A83A69;
  border: 1px solid transparent;
  border-radius: 100vmax;
  transition: 0.3s;
}
#footer_cta_sec .text_box .line_btn a:hover {
  background-color: #fff;
  border: 1px solid #D06880;
}
#footer_cta_sec .text_box .line_btn a:hover .label {
  color: #D06880;
}
#footer_cta_sec .text_box .line_btn a:hover .arrow_box {
  background-color: #D06880;
}
#footer_cta_sec .text_box .line_btn a:hover .arrow_box .arrow svg path {
  fill: #fff;
}
#footer_cta_sec .text_box .line_btn a .icon {
  flex-shrink: 0;
  width: 30px;
  line-height: 1;
  margin-right: 30px;
}
#footer_cta_sec .text_box .line_btn a .icon img {
  width: 100%;
}
#footer_cta_sec .text_box .line_btn a .label {
  flex-grow: 1;
  font-size: 17px;
  letter-spacing: 0.06em;
  font-weight: 600;
  line-height: 1;
  color: #fff;
  transition: 0.3s;
}
#footer_cta_sec .text_box .line_btn a .arrow_box {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background-color: #fff;
  transition: 0.3s;
}
#footer_cta_sec .text_box .line_btn a .arrow_box .arrow {
  width: 8px;
  height: 8px;
  line-height: 1;
  transform: translateX(-15%);
}
#footer_cta_sec .text_box .line_btn a .arrow_box .arrow svg {
  width: 100%;
  vertical-align: top;
}
#footer_cta_sec .text_box .line_btn a .arrow_box .arrow svg path {
  fill: #BC5D77;
  transition: 0.3s;
}

#main_footer {
  padding: 105px 0 75px;
  background-color: #F8F8F8;
  overflow: hidden;
}
#main_footer .deco {
  position: absolute;
  opacity: 0.1;
  line-height: 1;
  width: 328px;
}
#main_footer .deco.deco1 {
  top: 350px;
  right: -38px;
}
#main_footer .deco.deco2 {
  bottom: -500px;
  left: -54px;
}
#main_footer .deco img {
  width: 100%;
}
#main_footer .cont {
  z-index: 1;
}
#main_footer .cont .link_cont {
  display: flex;
  align-items: center;
  margin-bottom: 43px;
  padding-bottom: 54px;
  border-bottom: 1px solid #EDEDED;
}
#main_footer .cont .link_cont .list {
  flex-grow: 1;
}
#main_footer .cont .link_cont .list ul {
  display: flex;
  align-items: center;
  gap: 0 60px;
}
#main_footer .cont .link_cont .list ul li a {
  font-size: 16px;
  letter-spacing: 0.04em;
  line-height: 1;
  font-weight: 500;
  color: #333333;
  transition: 0.3s;
}
#main_footer .cont .link_cont .list ul li a:hover {
  color: #D06880;
}
#main_footer .cont .link_cont .line_btn {
  flex-shrink: 0;
  width: 280px;
}
#main_footer .cont .link_cont .line_btn a {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 13px 20px 13px 30px;
  background-color: #A83A69;
  border: 1px solid transparent;
  border-radius: 100vmax;
  transition: 0.3s;
}
#main_footer .cont .link_cont .line_btn a:hover {
  background-color: #fff;
  border: 1px solid #D06880;
}
#main_footer .cont .link_cont .line_btn a:hover .label {
  color: #D06880;
}
#main_footer .cont .link_cont .line_btn a:hover .arrow_box {
  background-color: #D06880;
}
#main_footer .cont .link_cont .line_btn a:hover .arrow_box .arrow svg path {
  fill: #fff;
}
#main_footer .cont .link_cont .line_btn a .icon {
  flex-shrink: 0;
  width: 20px;
  line-height: 1;
  margin-right: 30px;
}
#main_footer .cont .link_cont .line_btn a .icon img {
  width: 100%;
}
#main_footer .cont .link_cont .line_btn a .label {
  flex-grow: 1;
  font-size: 15px;
  letter-spacing: 0.06em;
  font-weight: 500;
  line-height: 1;
  color: #fff;
  transition: 0.3s;
}
#main_footer .cont .link_cont .line_btn a .arrow_box {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background-color: #fff;
  transition: 0.3s;
}
#main_footer .cont .link_cont .line_btn a .arrow_box .arrow {
  width: 6.5px;
  height: 6.5px;
  line-height: 1;
  transform: translateX(-15%);
}
#main_footer .cont .link_cont .line_btn a .arrow_box .arrow svg {
  width: 100%;
  vertical-align: top;
}
#main_footer .cont .link_cont .line_btn a .arrow_box .arrow svg path {
  fill: #BC5D77;
  transition: 0.3s;
}
#main_footer .cont .data_cont {
  display: flex;
  align-items: flex-end;
}
#main_footer .cont .data_cont .logo {
  display: block;
  width: 231px;
  flex-shrink: 0;
  line-height: 1;
}
#main_footer .cont .data_cont .logo img {
  width: 100%;
}
#main_footer .cont .data_cont .sun_data_block {
  margin-left: auto;
}
#main_footer .cont .data_cont .sun_data_block .list {
  margin-bottom: 22px;
}
#main_footer .cont .data_cont .sun_data_block .list ul {
  display: flex;
  gap: 0 30px;
}
#main_footer .cont .data_cont .sun_data_block .list ul li a {
  font-size: 13px;
  letter-spacing: 0.04em;
  line-height: 1;
  font-weight: 500;
  color: #333333;
}
#main_footer .cont .data_cont .sun_data_block .copy {
  text-align: right;
  font-size: 12px;
  line-height: 1;
}

/* 共通設定 */
.common_page_main {
  padding-top: 100px;
}
.common_page_main .deco {
  pointer-events: none;
  position: absolute;
  line-height: 1;
  width: 614px;
  top: -110px;
  right: -120px;
  opacity: 0.4;
}
.common_page_main .deco img {
  width: 100%;
}
.common_page_main .text_box {
  padding-top: 135px;
  z-index: 1;
}
.common_page_main .text_box .en {
  font-size: 40px;
  line-height: 1;
  margin-bottom: 20px;
  color: #D06880;
  text-transform: capitalize;
}
.common_page_main .text_box .ttl {
  font-size: 48px;
  letter-spacing: 0.18em;
  line-height: 1.3;
  font-weight: 600;
  margin-bottom: 55px;
}
.common_page_main .text_box .breadcrumb {
  text-align: right;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.2;
  color: #8D8D8D;
  margin-bottom: 10px;
}
.common_page_main .text_box .breadcrumb a {
  color: #8D8D8D;
}
.common_page_main .img {
  width: 100%;
  height: 400px;
  line-height: 1;
  overflow: hidden;
}
.common_page_main .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.breadcrumb.single {
  margin-top: 70px;
}

.common_page_wrap {
  padding: 120px 0 180px;
}

.common_single_wrap {
  padding: 100px 0 0;
}

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

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

/* 個人情報保護方針 */
.privacy_cont_sec .main_text {
  font-size: 16px;
  letter-spacing: 0.07em;
  font-weight: 400;
  line-height: 1.8;
  margin-block: 0 40px;
}

.privacy_cont_sec dl + dl {
  margin-block: 40px 0;
}

.privacy_cont_sec dl dt {
  font-size: 18px;
  letter-spacing: 0.07em;
  font-weight: 700;
  line-height: 1.5;
  border-bottom: 1px dotted #707070;
  padding-block: 0 0.6em;
  margin-block: 0 0.8em;
}

.privacy_cont_sec dl dd {
  font-size: 14px;
  letter-spacing: 0.07em;
  font-weight: 400;
}

/* 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: blackscale;
}

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

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

.wp-pagenavi a,
.wp-pagenavi span {
  color: #999;
  background-color: #FFF;
  border: solid 1px #e0e0d2;
  padding: 8px 15px !important;
  margin: 0 2px;
  white-space: nowrap;
  border-radius: 3px;
  transition: 0.2s ease-in-out;
  text-align: center;
  text-decoration: none;
}

.wp-pagenavi a:hover {
  color: #FFF;
  background-color: #D06880;
  border-color: #D06880 !important;
}

.wp-pagenavi .current {
  color: #FFF;
  background-color: #D06880;
  border-color: #D06880 !important;
  font-weight: bold;
}

.common_form_main {
  padding-top: 0;
}

.common_form_page {
  padding: 180px 0 60px;
}
.common_form_page .container {
  flex-wrap: nowrap;
  align-items: flex-start;
}
.common_form_page .container .text_block {
  position: sticky;
  top: 50px;
  left: 0;
  flex-grow: 1;
}
.common_form_page .container .text_block .top_text_box .ttl {
  font-size: 36px;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1.4;
  margin-bottom: 25px;
}
.common_form_page .container .text_block .top_text_box .text {
  font-size: 16px;
  letter-spacing: 0.06em;
  line-height: 1.7;
}
.common_form_page .container .text_block .top_text_box .text a {
  color: #333333;
  text-decoration: underline;
  margin: 0 2px;
}
.common_form_page .container .text_block .top_text_box .text + .text {
  margin-top: 15px;
}
.common_form_page .container .text_block .form_guide_box {
  margin-top: 40px;
}
.common_form_page .container .text_block .form_guide_box .ttl {
  font-size: 20px;
  font-weight: bold;
  padding-bottom: 5px;
  border-bottom: 1px solid #F5F5F5;
}
.common_form_page .container .text_block .form_guide_box .img_list {
  margin-top: 15px;
}
.common_form_page .container .text_block .form_guide_box .img_list ul {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 5px;
}
.common_form_page .container .text_block .form_guide_box .img_list ul li img {
  width: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}
.common_form_page .container .text_block .thum_box {
  display: flex;
  gap: 0 30px;
}
.common_form_page .container .text_block .thum_box .text_box {
  flex-grow: 1;
}
.common_form_page .container .text_block .thum_box .text_box .cont_list {
  margin-top: 15px;
}
.common_form_page .container .text_block .thum_box .text_box .cont_list ul li + li {
  margin-top: 10px;
}
.common_form_page .container .text_block .thum_box .text_box .cont_list ul li {
  font-size: 14px;
  display: flex;
  align-items: center;
  font-weight: 500;
  letter-spacing: 0.06em;
  line-height: 1;
}
.common_form_page .container .text_block .thum_box .text_box .cont_list ul li::before {
  content: "";
  margin-right: 10px;
  display: block;
  flex-shrink: 0;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background-color: #D06880;
}
.common_form_page .container .text_block .thum_box .thum {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 35%;
  border: 1px solid #F5F5F5;
  border-radius: 10px;
  overflow: hidden;
  padding: 15px;
}
.common_form_page .container .text_block .thum_box .thum img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}
.common_form_page .container .form_cont {
  flex-shrink: 0;
  width: 50%;
  margin-left: 50px;
  padding: 45px 25px;
  background-color: #F0F3F6;
  border: 1px solid #F5F5F5;
  border-radius: 20px;
}
.common_form_page .container .form_cont .form_wrap .wp-block-table {
  overflow: visible;
}
.common_form_page .container .form_cont .form_wrap table,
.common_form_page .container .form_cont .form_wrap th,
.common_form_page .container .form_cont .form_wrap td {
  border: none;
  padding: 0;
}
.common_form_page .container .form_cont .form_wrap .form_box {
  margin-bottom: 30px;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li + li {
  margin-top: 25px;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .label {
  font-size: 15px;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1;
  margin-bottom: 8px;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .label .hissu {
  color: red;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box input[type=text] {
  width: 100%;
  background-color: #fff;
  border-radius: 4px;
  border: 1px solid #E3E3E3;
  padding: 12px 15px;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box input[type=text]::-moz-placeholder {
  font-size: 14px;
  letter-spacing: 0.05em;
  color: #B5B5B5;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box input[type=text]::placeholder {
  font-size: 14px;
  letter-spacing: 0.05em;
  color: #B5B5B5;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box.select_box {
  position: relative;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box.select_box::after {
  content: "";
  position: absolute;
  width: 8px;
  height: 8px;
  top: 50%;
  right: 20px;
  transform: translateY(-50%) rotate(45deg);
  border-color: transparent #C7C4C4 #C7C4C4 transparent;
  border-width: 2px;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box.select_box select {
  height: 44px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 100%;
  background: #FAFAFA;
  border: 1px solid #E3E3E3;
  border-radius: 4px;
  font-size: 14px;
  letter-spacing: 0.08em;
  font-weight: 400;
  padding: 0.6em 1em;
  color: #B5B5B5;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box.select_box select.empty {
  color: #231815;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box textarea {
  width: 100%;
  background-color: #fff;
  border-radius: 4px;
  border: 1px solid #E3E3E3;
  padding: 15px;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box textarea::-moz-placeholder {
  font-size: 14px;
  letter-spacing: 0.05em;
  color: #B5B5B5;
}
.common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box textarea::placeholder {
  font-size: 14px;
  letter-spacing: 0.05em;
  color: #B5B5B5;
}
.common_form_page .container .form_cont .form_wrap .btn {
  width: 100%;
}
.common_form_page .container .form_cont .form_wrap .btn button {
  width: 100%;
  line-height: 70px;
  background-color: #D06880;
  border-radius: 6px;
  text-align: center;
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.03em;
  color: #ffffff;
  box-shadow: 0 6px #333333;
  transition: 0.3s;
}
.common_form_page .container .form_cont .form_wrap .btn button:hover {
  transform: translateY(6px);
  box-shadow: none;
}
.common_form_page .container .form_cont .form_wrap button[name=submitBack] {
  background: #272625;
  margin-top: 20px;
  box-shadow: 0 6px #000000;
}
.common_form_page .container .form_cont .form_wrap .thanks_text_box .ttl {
  font-size: 18px;
  font-weight: bold;
  letter-spacing: 0.04em;
  line-height: 1;
  margin-bottom: 18px;
}
.common_form_page .container .form_cont .form_wrap .thanks_text_box .text {
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: 1.7;
}
.common_form_page .container .form_cont .form_wrap .thanks_text_box .text a {
  color: #353536;
  text-decoration: underline;
}
.common_form_page .container .form_cont .form_wrap .thanks_text_box .text + .text {
  margin-top: 10px;
}

.mwform-checkbox-field input,
.mwform-radio-field input {
  display: none;
}

.data_box.check_wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 0 15px;
}

.radio_btns {
  display: flex;
  gap: 0 15px;
}
.radio_btns input[type=radio].radio_btns__item {
  display: none;
}
.radio_btns label {
  display: inline-block;
}
.radio_btns .radio_btns__item + span {
  padding-left: 1.8em;
  display: inline-block;
  position: relative;
  font-size: 14px;
  letter-spacing: 0.03em;
}
.radio_btns .radio_btns__item + span::after, .radio_btns .radio_btns__item + span::before {
  content: "";
  display: block;
  position: absolute;
  background-color: #ccc;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  top: 0;
  left: 0;
  bottom: 0;
  margin: auto;
}
.radio_btns .radio_btns__item + span::after {
  width: 12px;
  height: 12px;
  top: 0;
  left: 4px;
  border: none;
  background: #fff;
  transform: scale(0);
  transition: all 0.3s;
}
.radio_btns .radio_btns__item:checked + span::before {
  background-color: #D06880;
}
.radio_btns .radio_btns__item:checked + span::after {
  transform: scale(1);
}

.radio-btns input[type=radio].radio-btns__item {
  display: none;
}
.radio-btns label {
  display: inline-block;
}
.radio-btns .radio-btns__item + span {
  padding-left: 2em;
  display: inline-block;
  position: relative;
}
.radio-btns .radio-btns__item + span:after, .radio-btns .radio-btns__item + span:before {
  content: "";
  display: block;
  position: absolute;
  border: 1px solid #aaa;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  top: 0;
  left: 0;
}
.radio-btns .radio-btns__item + span:after {
  width: 14px;
  height: 14px;
  top: 3px;
  left: 3px;
  border: none;
  background: #f18800;
  transform: scale(0);
  transition: all 0.3s;
}
.radio-btns .radio-btns__item:checked + span {
  color: #f18800;
}
.radio-btns .radio-btns__item:checked + span:after {
  transform: scale(1);
}

section#page-contact input[type=checkbox] {
  display: none;
}

.mwform-checkbox-field-text {
  display: inline-block;
  position: relative;
  padding-left: 28px;
  font-size: 14px;
}
.mwform-checkbox-field-text:before, .mwform-checkbox-field-text:after {
  content: "";
  position: absolute;
  display: block;
}
.mwform-checkbox-field-text:before {
  background: #fff;
  border: 2px solid #ccc;
  border-radius: 2px;
  width: 20px;
  height: 20px;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
.mwform-checkbox-field-text:after {
  border-width: 3px;
  border-color: transparent transparent #f18800 #f18800;
  border-style: solid;
  width: 20px;
  height: 10px;
  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 共通 */
.mw_wp_form .vertical-item + .vertical-item {
  margin-top: 0;
}
.mw_wp_form .horizontal-item + .horizontal-item {
  margin-left: 0;
}
.mw_wp_form .horizontal-item {
  display: inline-block;
}

#sidebar {
  width: 310px;
}
#sidebar .block + .block {
  margin-top: 30px;
}
#sidebar .common_link_box {
  margin-bottom: 50px;
}
#sidebar .block .top_ttl {
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 0.03em;
  position: relative;
  padding-bottom: 10px;
  border-bottom: 1px solid #ccc;
  margin-bottom: 25px;
}
#sidebar .block .top_ttl::before {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 30%;
  height: 1px;
  background-color: #D06880;
}
#sidebar .block .ranking_list ul li + li {
  margin-top: 25px;
}
#sidebar .block .ranking_list ul li:first-child a .ranking_box {
  background-color: #f7d305;
  background-image: linear-gradient(to top left, #f7bf05, #fcea7f, #fcd700, #f7d305, #eaca12, #ac9303, #f7d305, #fcea7f, #f7e705, #eaca12, #f7bf05);
}
#sidebar .block .ranking_list ul li:nth-child(2) a .ranking_box {
  background-color: #a5a5a5;
  background-image: linear-gradient(to top left, #a5a5a5, #e5e5e5, #ae9c9c, #a5a5a5, #a5a5a5, #7f7f7f, #a5a5a5, #e5e5e5, #a5a5a5, #a5a5a5, #a5a5a5);
}
#sidebar .block .ranking_list ul li:nth-child(3) a .ranking_box {
  background-color: #c47222;
  background-image: linear-gradient(to top left, #c46522, #e8b27d, #d07217, #c47222, #b9722e, #834c17, #c47222, #e8b27d, #c48022, #b9722e, #c46522);
}
#sidebar .block .ranking_list ul li a {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0 11px;
}
#sidebar .block .ranking_list ul li a .ranking_box {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  width: 24px;
  text-align: center;
  background-color: #3c3c3c;
  background-image: repeating-linear-gradient(-45deg, hsla(0, 0%, 100%, 0.1), hsla(0, 0%, 100%, 0.1) 6px, transparent 0, transparent 12px);
  box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.2);
}
#sidebar .block .ranking_list ul li a .ranking_box .num {
  font-size: 14px;
  color: #fff;
  line-height: 24px;
}
#sidebar .block .ranking_list ul li a .img {
  flex-shrink: 0;
  width: 40%;
  aspect-ratio: 16/9;
  line-height: 1;
  overflow: hidden;
}
#sidebar .block .ranking_list ul li a .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.3s;
}
#sidebar .block .ranking_list ul li a .text_box .ttl {
  font-size: 12px;
  font-weight: bold;
  letter-spacing: 0.03em;
  line-height: 1.5;
  color: #231815;
}
#sidebar .block .ranking_list ul li a:hover .img img {
  transform: scale(1.1);
}
#sidebar .block .voice_list ul li + li {
  margin-top: 25px;
}
#sidebar .block .voice_list ul li a {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0 11px;
}
#sidebar .block .voice_list ul li a .img {
  flex-shrink: 0;
  width: 40%;
  aspect-ratio: 16/9;
  line-height: 1;
  overflow: hidden;
}
#sidebar .block .voice_list ul li a .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.3s;
}
#sidebar .block .voice_list ul li a .text_box .date {
  font-size: 11px;
  letter-spacing: 0.03em;
  line-height: 1;
  color: #333333;
  margin-bottom: 7px;
}
#sidebar .block .voice_list ul li a .text_box .ttl {
  font-size: 12px;
  font-weight: bold;
  letter-spacing: 0.03em;
  line-height: 1.5;
  color: #333333;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
}
#sidebar .block .voice_list ul li a:hover .img img {
  transform: scale(1.1);
}

/* 準備中 */
.sorry_sec .text_box .text {
  text-align: center;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.06em;
}
.sorry_sec .text_box .text + .text {
  margin-top: 15px;
}
.sorry_sec .text_box .common_btn {
  margin: 30px auto 0;
}

.single_page_wrap {
  padding-top: 160px;
  padding-bottom: 120px;
  margin-bottom: 0;
}
.single_page_wrap #sidebar .wp-block-latest-posts a {
  color: #333333;
  text-decoration: underline;
}
.single_page_wrap .related_store_block {
  margin-top: 80px;
}
.single_page_wrap .related_store_block .label {
  padding-left: 20px;
  border-left: 2px solid;
  font-size: 20px;
  letter-spacing: 0.08em;
  line-height: 1;
  margin-bottom: 30px;
}
.single_page_wrap .related_store_block .box a {
  display: flex;
  align-items: center;
  gap: 0 35px;
}
.single_page_wrap .related_store_block .box a:hover .img img {
  transform: scale(1.05);
}
.single_page_wrap .related_store_block .box a:hover .text_box .name {
  color: #FFF5F7;
}
.single_page_wrap .related_store_block .box a .img {
  flex-shrink: 0;
  width: 220px;
  aspect-ratio: 4/3;
  border-radius: 8px;
  overflow: hidden;
}
.single_page_wrap .related_store_block .box a .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: 0.3s;
}
.single_page_wrap .related_store_block .box a .text_box {
  flex-grow: 1;
}
.single_page_wrap .related_store_block .box a .text_box .cat {
  font-size: 13px;
  letter-spacing: 0.08em;
  line-height: 1;
  color: #FFF5F7;
  margin-bottom: 18px;
}
.single_page_wrap .related_store_block .box a .text_box .name {
  font-size: 22px;
  letter-spacing: 0.08em;
  line-height: 1;
  color: #333333;
  transition: 0.3s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 20px;
}
.single_page_wrap .related_store_block .box a .text_box .text {
  font-size: 13px;
  font-weight: normal;
  letter-spacing: 0.08em;
  line-height: 1.8;
  color: #41454B;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
}
.single_page_wrap .related_event_block {
  margin-top: 80px;
}
.single_page_wrap .related_event_block .label {
  padding-left: 20px;
  border-left: 2px solid;
  font-size: 20px;
  letter-spacing: 0.08em;
  line-height: 1;
  margin-bottom: 30px;
}
.single_page_wrap .related_event_block .box a {
  display: flex;
  align-items: center;
  gap: 0 35px;
}
.single_page_wrap .related_event_block .box a:hover .img img {
  transform: scale(1.05);
}
.single_page_wrap .related_event_block .box a:hover .text_box .name {
  color: #FFF5F7;
}
.single_page_wrap .related_event_block .box a .img {
  flex-shrink: 0;
  width: 220px;
  aspect-ratio: 4/3;
  border-radius: 8px;
  overflow: hidden;
  background-color: #DEE8F5;
}
.single_page_wrap .related_event_block .box a .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  transition: 0.3s;
}
.single_page_wrap .related_event_block .box a .text_box {
  flex-grow: 1;
}
.single_page_wrap .related_event_block .box a .text_box .name {
  font-size: 22px;
  letter-spacing: 0.08em;
  line-height: 1.5;
  color: #333333;
  transition: 0.3s;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 20px;
}
.single_page_wrap .related_event_block .box a .text_box .date {
  font-size: 13px;
  font-weight: normal;
  letter-spacing: 0.08em;
  line-height: 1;
  color: #D06880;
}

#page_commercial .commercial_outline_sec .cont .table_wrap table {
  width: 100%;
  border-collapse: collapse;
}
#page_commercial .commercial_outline_sec .cont .table_wrap table tr {
  border-top: 1px solid #eeeeee;
  border-right: 1px solid #eeeeee;
  letter-spacing: 0.06em;
}
#page_commercial .commercial_outline_sec .cont .table_wrap table tr:last-child {
  border-bottom: 1px solid #eeeeee;
}
#page_commercial .commercial_outline_sec .cont .table_wrap table tr th {
  font-size: 17px;
  width: 300px;
  background: #eff2f4;
  text-align: center;
  vertical-align: middle;
  border: 1px solid #dfe5e9;
}
#page_commercial .commercial_outline_sec .cont .table_wrap table tr td {
  font-size: 15px;
  padding: 35px 24px;
}

.common_voice_list .list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 70px 30px;
}

#page_service #top_about_sec {
  margin-bottom: 227px;
  padding-top: 170px;
}
#page_service .service_reason_sec {
  margin-bottom: 125px;
}
#page_service .service_reason_sec .deco {
  pointer-events: none;
  position: absolute;
  z-index: 2;
  line-height: 1;
}
#page_service .service_reason_sec .deco.deco1 {
  width: 468px;
  top: 325px;
  right: -90px;
  opacity: 0.3;
}
#page_service .service_reason_sec .deco.deco2 {
  width: 496px;
  bottom: 220px;
  left: -127px;
  opacity: 0.3;
}
#page_service .service_reason_sec .deco img {
  width: 100%;
}
#page_service .service_reason_sec .cont {
  z-index: 3;
}
#page_service .service_reason_sec .cont .common_top_ttl_box {
  margin-bottom: 50px;
}
#page_service .service_reason_sec .cont .list ul li {
  display: flex;
  align-items: center;
  gap: 0 80px;
}
#page_service .service_reason_sec .cont .list ul li:nth-child(odd) {
  flex-direction: row-reverse;
}
#page_service .service_reason_sec .cont .list ul li + li {
  margin-top: 80px;
}
#page_service .service_reason_sec .cont .list ul li .img {
  flex-shrink: 0;
  width: 560px;
  height: 370px;
  line-height: 1;
}
#page_service .service_reason_sec .cont .list ul li .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#page_service .service_reason_sec .cont .list ul li .text_block .ttl_box {
  padding-left: 30px;
  border-left: 1px solid #D06880;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 84px;
  margin-bottom: 30px;
}
#page_service .service_reason_sec .cont .list ul li .text_block .ttl_box .ttl {
  font-size: 30px;
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1.4;
  color: #D06880;
}
#page_service .service_reason_sec .cont .list ul li .text_block .text {
  font-size: 15px;
  letter-spacing: 0.08em;
  line-height: 1.6;
  color: #4E4E4E;
}
#page_service .service_support_sec {
  margin-bottom: 265px;
}
#page_service .service_support_sec .common_top_ttl_box {
  margin-bottom: 40px;
}
#page_service .service_support_sec .list ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px 30px;
}
#page_service .service_support_sec .list ul li {
  display: flex;
  flex-direction: column;
  background-color: #F5F5F4;
  padding: 30px 30px 35px;
}
#page_service .service_support_sec .list ul li .top_cont {
  flex-shrink: 0;
  margin-bottom: 16px;
}
#page_service .service_support_sec .list ul li .top_cont .icon {
  width: 80px;
  line-height: 1;
  margin: 0 auto 16px;
}
#page_service .service_support_sec .list ul li .top_cont .icon img {
  width: 100%;
}
#page_service .service_support_sec .list ul li .top_cont .ttl_box {
  display: flex;
  flex-direction: column;
  height: 56px;
  justify-content: center;
  text-align: center;
}
#page_service .service_support_sec .list ul li .top_cont .ttl_box .ttl {
  font-size: 18px;
  letter-spacing: 0.1em;
  line-height: 1.66;
  font-weight: 600;
}
#page_service .service_support_sec .list ul li .text_box {
  flex-grow: 1;
  text-align: center;
}
#page_service .service_support_sec .list ul li .text_box .text {
  font-size: 14px;
  letter-spacing: 0.15em;
  font-weight: 500;
  line-height: 1.8;
}
#page_service .service_course_sec {
  margin-bottom: 227px;
}
#page_service .service_course_sec::before, #page_service .service_course_sec::after {
  content: "";
  position: absolute;
  top: -45px;
  bottom: -45px;
  left: 0;
  width: calc(50vw - 570px + 960px);
}
#page_service .service_course_sec::before {
  background-color: #FAFAF5;
  z-index: -2;
}
#page_service .service_course_sec::after {
  background-image: url(image/reason_back.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  opacity: 0.45;
  mix-blend-mode: multiply;
  z-index: -1;
}
#page_service .service_course_sec .cont {
  display: flex;
  align-items: center;
  gap: 0 70px;
}
#page_service .service_course_sec .cont .text_block {
  flex-grow: 1;
}
#page_service .service_course_sec .cont .text_block .common_ttl_box {
  margin-bottom: 40px;
}
#page_service .service_course_sec .cont .text_block .text {
  font-size: 16px;
  letter-spacing: 0.15em;
  line-height: 1.5;
}
#page_service .service_course_sec .cont .text_block .text + .text {
  margin-top: 20px;
}
#page_service .service_course_sec .cont .text_block .common_btn {
  margin-top: 50px;
}
#page_service .service_course_sec .cont .img {
  flex-shrink: 0;
  width: 560px;
  height: 510px;
  line-height: 1;
}
#page_service .service_course_sec .cont .img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
#page_service #top_voice_sec {
  margin-bottom: 180px;
}

#page_course {
  padding: 110px 0 210px;
}
#page_course::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  background: #FFF5F7;
  background: linear-gradient(180deg, rgb(255, 245, 247) 0%, rgb(255, 245, 247) 60%, rgb(255, 255, 255) 100%);
  filter: blur(10px);
}
#page_course .course_table_sec .top_text_box {
  margin-bottom: 50px;
  text-align: center;
}
#page_course .course_table_sec .top_text_box .text {
  font-size: 16px;
  letter-spacing: 0.08em;
  line-height: 1.75;
}
#page_course .course_table_sec .table_cont .table_wrap {
  position: relative;
}
#page_course .course_table_sec .table_cont .table_wrap::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 136px;
  left: 0;
  right: 0;
  bottom: 0;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.06);
  background-color: #F4F4F4;
}
#page_course .course_table_sec .table_cont .table_wrap table {
  width: 100%;
}
#page_course .course_table_sec .table_cont .table_wrap table .zoomIn {
  animation-timing-function: cubic-bezier(0.075, 0.82, 0.165, 1);
}
#page_course .course_table_sec .table_cont .table_wrap table thead th {
  vertical-align: bottom;
  text-align: center;
  color: #fff;
  font-size: 22px;
  line-height: 1;
  letter-spacing: 0.04em;
  font-weight: 600;
  width: 310px;
}
#page_course .course_table_sec .table_cont .table_wrap table thead th .inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 80px;
}
#page_course .course_table_sec .table_cont .table_wrap table thead th:nth-of-type(1) {
  width: auto;
}
#page_course .course_table_sec .table_cont .table_wrap table thead th:nth-of-type(2) {
  background-color: #D06880;
}
#page_course .course_table_sec .table_cont .table_wrap table thead th:nth-of-type(3) {
  background-color: #C4506B;
}
#page_course .course_table_sec .table_cont .table_wrap table thead th:nth-of-type(4) {
  background-color: #A03E54;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr th,
#page_course .course_table_sec .table_cont .table_wrap table tbody tr td {
  text-align: center;
  vertical-align: middle;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr th {
  background-color: #F4F4F4;
  border-bottom: 1px solid #DDDDDD;
  font-size: 20px;
  letter-spacing: 0.04em;
  font-weight: 600;
  line-height: 1.3;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr th .small {
  font-size: 14px;
  letter-spacing: 0.04em;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr:nth-of-type(1) td {
  text-align: left;
  padding: 28px 45px;
  font-size: 14px;
  letter-spacing: 0.1em;
  font-weight: 600;
  line-height: 1.8;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr:last-of-type td {
  border-bottom: none;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr:last-of-type th {
  border-bottom: none;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr td {
  height: 100px;
  background-color: #fff;
  border-bottom: 1px solid #F0F0F0;
  border-left: 1px solid #DDDDDD;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr td .icon {
  line-height: 1;
  margin: 0 auto;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr td .icon.circle {
  width: 40px;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr td .icon.x {
  width: 34.1px;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr td .icon img {
  width: 100%;
}
#page_course .course_table_sec .table_cont .table_wrap table tbody tr td .icon_label {
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.04em;
  line-height: 1;
  margin-top: 8px;
}

@media (max-width: 750px) {
  .wrap,
  .wrap02,
  .wrap03 {
    max-width: 90%;
  }
  .sp_line_fixed {
    position: fixed;
    z-index: 999;
    left: 0;
    bottom: 0;
    width: 100%;
    transition: 0.3s;
    opacity: 1;
    visibility: visible;
  }
  .sp_line_fixed.hide {
    opacity: 0;
    visibility: hidden;
  }
  .sp_line_fixed a {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 4vw 6vw 4vw 7vw;
    background-color: #A83A69;
    border: 1px solid transparent;
  }
  .sp_line_fixed a .icon {
    flex-shrink: 0;
    width: 7.5vw;
    line-height: 1;
  }
  .sp_line_fixed a .icon img {
    width: 100%;
  }
  .sp_line_fixed a .label {
    flex-grow: 1;
    text-align: center;
    font-size: 4.3vw;
    letter-spacing: 0.06em;
    font-weight: 600;
    line-height: 1;
    color: #fff;
  }
  .sp_line_fixed a .arrow_box {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 7.5vw;
    height: 7.5vw;
    border-radius: 50%;
    background-color: #fff;
  }
  .sp_line_fixed a .arrow_box .arrow {
    width: 3vw;
    height: 3vw;
    line-height: 1;
    transform: translateX(-15%);
  }
  .sp_line_fixed a .arrow_box .arrow svg {
    width: 100%;
    vertical-align: top;
  }
  .sp_line_fixed a .arrow_box .arrow svg path {
    fill: #BC5D77;
  }
  #sp_header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 70px;
    background-color: #fff;
    z-index: 997;
    transition: 0.3s;
  }
  #sp_header .inner {
    width: 100%;
    height: 100%;
    padding: 0 5vw;
  }
  #sp_header .inner .cont {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
  }
  #sp_header .inner .cont .logo {
    position: relative;
    display: block;
    width: 133px;
    height: 25.5px;
    line-height: 1;
  }
  #sp_header .inner .cont .logo img {
    position: absolute;
    inset: 0;
    margin: auto;
    transition: 0.3s;
  }
  #sp_header .inner .cont .logo img.before {
    opacity: 0;
  }
  #sp_header .inner .cont .ham_btn {
    margin-left: auto;
    width: 30px;
    height: 15px;
  }
  #sp_header .inner .cont .ham_btn span {
    position: absolute;
    inset: 0;
    margin: auto;
    display: block;
    width: 30px;
    height: 1px;
    border-radius: 100vmax;
    background-color: #D06880;
    transition: 0.3s;
  }
  #sp_header .inner .cont .ham_btn span:first-child {
    transform: translateY(-5.5px);
  }
  #sp_header .inner .cont .ham_btn span:nth-child(2) {
    transform: translateY(0);
  }
  #sp_header .inner .cont .ham_btn span:last-child {
    transform: translateY(5.5px);
  }
  #sp_header .inner .cont .ham_btn.active span:first-child, #sp_header .inner .cont .ham_btn.active span:nth-child(2) {
    transform: rotate(342deg);
  }
  #sp_header .inner .cont .ham_btn.active span:last-child {
    transform: rotate(-342deg);
  }
  #sp_header.top_page_header {
    background-color: transparent;
  }
  #sp_header.top_page_header.show, #sp_header.top_page_header.bg {
    background-color: #fff;
  }
  #sp_header.top_page_header.show .inner .cont .logo img.before, #sp_header.top_page_header.bg .inner .cont .logo img.before {
    opacity: 0;
  }
  #sp_header.top_page_header.show .inner .cont .logo img.after, #sp_header.top_page_header.bg .inner .cont .logo img.after {
    opacity: 1;
  }
  #sp_header.top_page_header.show .inner .cont .ham_btn span, #sp_header.top_page_header.bg .inner .cont .ham_btn span {
    background-color: #D06880;
  }
  #sp_header.top_page_header .inner .cont .logo img.before {
    opacity: 1;
  }
  #sp_header.top_page_header .inner .cont .logo img.after {
    opacity: 0;
  }
  #sp_header.top_page_header .inner .cont .ham_btn span {
    background-color: #fff;
  }
  #ham_menu {
    position: fixed;
    top: 70px;
    left: 0;
    width: 100%;
    z-index: 1000;
    transform: translateX(100%);
    transition: 0.3s;
  }
  #ham_menu.active {
    transform: translateX(0);
  }
  #ham_menu .inner {
    width: 100%;
    height: 100dvh;
    overflow-y: scroll;
    overflow-x: hidden;
    background-color: #FAFAF5;
    padding: 16vw 0 28vw;
    position: relative;
  }
  #ham_menu .inner::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100dvh;
    background-image: url(image/sp_header_menu_back.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    mix-blend-mode: multiply;
    opacity: 0.4;
  }
  #ham_menu .deco {
    position: absolute;
    top: -6vw;
    right: -21vw;
    z-index: 1;
    width: 57vw;
    line-height: 1;
  }
  #ham_menu .deco img {
    width: 100%;
  }
  #ham_menu .cont {
    z-index: 2;
  }
  #ham_menu .cont .line_btn {
    width: 100%;
    margin-bottom: 13vw;
  }
  #ham_menu .cont .line_btn a {
    display: flex;
    align-items: center;
    width: 100%;
    padding: 4vw 6vw 4vw 7vw;
    background-color: #A83A69;
    border: 1px solid transparent;
    border-radius: 100vmax;
  }
  #ham_menu .cont .line_btn a .icon {
    flex-shrink: 0;
    width: 7.5vw;
    line-height: 1;
    margin-right: 5.7vw;
  }
  #ham_menu .cont .line_btn a .icon img {
    width: 100%;
  }
  #ham_menu .cont .line_btn a .label {
    flex-grow: 1;
    font-size: 4.3vw;
    letter-spacing: 0.06em;
    font-weight: 600;
    line-height: 1;
    color: #fff;
  }
  #ham_menu .cont .line_btn a .arrow_box {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 7.5vw;
    height: 7.5vw;
    border-radius: 50%;
    background-color: #fff;
  }
  #ham_menu .cont .line_btn a .arrow_box .arrow {
    width: 3vw;
    height: 3vw;
    line-height: 1;
    transform: translateX(-15%);
  }
  #ham_menu .cont .line_btn a .arrow_box .arrow svg {
    width: 100%;
    vertical-align: top;
  }
  #ham_menu .cont .line_btn a .arrow_box .arrow svg path {
    fill: #BC5D77;
  }
  #ham_menu .cont .link_list {
    margin-bottom: 12vw;
  }
  #ham_menu .cont .link_list .top_label {
    text-align: center;
    font-size: 6vw;
    line-height: 1;
    margin-bottom: 9vw;
  }
  #ham_menu .cont .link_list ul li:first-child a {
    padding-top: 0;
  }
  #ham_menu .cont .link_list ul li a {
    display: block;
    position: relative;
    text-align: center;
    padding: 5.5vw 0;
  }
  #ham_menu .cont .link_list ul li a .en_label {
    font-size: 3.7vw;
    color: #D06880;
    line-height: 1;
    margin-bottom: 2vw;
  }
  #ham_menu .cont .link_list ul li a .label {
    font-size: 4.8vw;
    letter-spacing: 0.04em;
    line-height: 1;
    color: #333333;
  }
  #ham_menu .cont .link_list ul li a::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: repeating-linear-gradient(to right, #E0DDCA 0 3px, transparent 3px 6px);
  }
  #ham_menu .cont .copy_cont {
    text-align: center;
  }
  #ham_menu .cont .copy_cont .sub_link_box {
    margin-bottom: 12vw;
  }
  #ham_menu .cont .copy_cont .sub_link_box .sub_link + .sub_link {
    margin-top: 3vw;
  }
  #ham_menu .cont .copy_cont .sub_link_box .sub_link a {
    font-size: 3.5vw;
    letter-spacing: 0.04em;
    line-height: 1;
    font-weight: 500;
    color: #333333;
  }
  #ham_menu .cont .copy_cont .copy {
    font-size: 3.1vw;
    letter-spacing: 0.04em;
    line-height: 1.3;
  }
  body {
    font-size: 3.6vw;
  }
  #top_fv_sec {
    margin-top: 0;
    padding: 85vw 0 10vw;
    background-image: url(image/fv_back_sp.jpg);
  }
  #top_fv_sec::before {
    background: rgba(255, 255, 255, 0);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 10%, rgba(254, 255, 240, 0.5) 75%, rgba(254, 255, 240, 0.5) 100%);
  }
  #top_fv_sec .cont .text_box {
    margin-bottom: 8vw;
  }
  #top_fv_sec .cont .text_box .label_wrap {
    margin-bottom: 4vw;
  }
  #top_fv_sec .cont .text_box .label_wrap .label {
    font-size: 4.8vw;
  }
  #top_fv_sec .cont .text_box .label_wrap::after {
    content: none;
  }
  #top_fv_sec .cont .text_box .ttl {
    font-size: 7.2vw;
    letter-spacing: 0.12em;
    line-height: 1.4;
    white-space: nowrap;
  }
  #top_fv_sec .cont .list ul {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0 3vw;
  }
  #top_fv_sec .cont .list ul li {
    width: 28vw;
    height: 28vw;
  }
  #top_fv_sec .cont .list ul li::before {
    top: -3px;
  }
  #top_fv_sec .cont .list ul li.num_wrap {
    padding-top: 5.8vw;
  }
  #top_fv_sec .cont .list ul li.num_wrap .label {
    font-size: 3.7vw;
    margin-bottom: 0;
  }
  #top_fv_sec .cont .list ul li.num_wrap .num_box {
    gap: 0 1vw;
  }
  #top_fv_sec .cont .list ul li.num_wrap .num_box .num {
    font-size: 10.7vw;
  }
  #top_fv_sec .cont .list ul li.num_wrap .num_box .num::before {
    height: 2vw;
  }
  #top_fv_sec .cont .list ul li.num_wrap .num_box .nin {
    font-size: 3.2vw;
  }
  #top_fv_sec .cont .list ul li.per_wrap {
    padding-top: 5.8vw;
  }
  #top_fv_sec .cont .list ul li.per_wrap .label {
    font-size: 3.7vw;
    margin-bottom: 0;
  }
  #top_fv_sec .cont .list ul li.per_wrap .num_box {
    gap: 0 1vw;
  }
  #top_fv_sec .cont .list ul li.per_wrap .num_box .num {
    font-size: 10.7vw;
  }
  #top_fv_sec .cont .list ul li.per_wrap .num_box .num::before {
    height: 2vw;
  }
  #top_fv_sec .cont .list ul li.per_wrap .num_box .per {
    font-size: 5.3vw;
  }
  #top_fv_sec .cont .list ul li.support_wrap {
    padding-top: 3vw;
  }
  #top_fv_sec .cont .list ul li.support_wrap .num_box {
    margin-bottom: 2vw;
    gap: 0 1vw;
  }
  #top_fv_sec .cont .list ul li.support_wrap .num_box::before {
    height: 2vw;
  }
  #top_fv_sec .cont .list ul li.support_wrap .num_box .num {
    font-size: 10.7vw;
  }
  #top_fv_sec .cont .list ul li.support_wrap .num_box .time {
    font-size: 3.7vw;
    font-weight: bok;
  }
  #top_fv_sec .cont .list ul li.support_wrap .support_label {
    font-size: 3.7vw;
  }
  #top_about_sec {
    margin-bottom: 40vw;
    padding: 22vw 0 0;
  }
  #top_about_sec::after {
    bottom: -20vw;
    height: 30vw;
  }
  #top_about_sec .deco.deco1 {
    left: -15vw;
    width: 55vw;
    height: 55vw;
  }
  #top_about_sec .deco.deco2 {
    top: 130vw;
    left: auto;
    right: 13vw;
    width: 45vw;
    height: 45vw;
  }
  #top_about_sec .deco.deco3 {
    display: none;
  }
  #top_about_sec .deco.deco4 {
    bottom: 0;
    right: -20vw;
    width: 45vw;
    height: 45vw;
  }
  #top_about_sec .top_about_main_cont {
    margin-bottom: 13vw;
  }
  #top_about_sec .top_about_main_cont .cont .top_ttl_box {
    margin-bottom: 6vw;
  }
  #top_about_sec .top_about_main_cont .cont .top_ttl_box .en {
    font-size: 4.25vw;
    margin-bottom: 3vw;
  }
  #top_about_sec .top_about_main_cont .cont .top_ttl_box .ttl {
    font-size: 5.35vw;
  }
  #top_about_sec .top_about_main_cont .cont .lead_text {
    font-size: 6.4vw;
    letter-spacing: 0.34em;
    margin-bottom: 6vw;
  }
  #top_about_sec .top_about_main_cont .cont .text {
    font-size: 3.7vw;
    letter-spacing: 0.05em;
  }
  #top_about_sec .top_about_main_cont .cont .text + .text {
    margin-top: 4vw;
  }
  #top_about_sec .top_about_flow_cont .scroll-hint-icon-wrap {
    z-index: 1;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap {
    width: 100vw;
    margin: 0;
    padding-left: 5vw;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .top_ttl_box {
    margin-bottom: 4vw;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .top_ttl_box .ttl {
    font-size: 5.9vw;
    line-height: 1.5;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .top_ttl_box .ttl .small {
    display: block;
    font-size: 4.8vw;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .list {
    width: 100%;
    overflow-x: scroll !important;
    overflow-y: hidden !important;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .list ul {
    padding-right: 5vw;
    width: 282vw;
    min-width: 282vw;
    gap: 0 5vw;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .list ul::before {
    top: 20vw;
    right: 5vw;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .list ul li .deco {
    top: 45vw;
    font-size: 3.7vw;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .list ul li .en_label {
    font-size: 3.8vw;
    margin-bottom: 2.5vw;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .list ul li .img {
    height: 28vw;
    margin-bottom: 5.5vw;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .ttl_box {
    height: 12.5vw;
    padding-bottom: 5.5vw;
    margin-bottom: 12px;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .ttl_box .ttl {
    font-size: 3.8vw;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .text {
    font-size: 3.5vw;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .cur_list .cur {
    font-size: 3.5vw;
  }
  #top_about_sec .top_about_flow_cont .sec_wrap .list ul li .text_box .cur_list .cur + .cur {
    margin-top: 1vw;
  }
  .common_top_ttl_box .common_ttl_box {
    margin-bottom: 3vw;
  }
  .common_top_ttl_box .text {
    font-size: 3.7vw;
  }
  .common_ttl_box .en {
    font-size: 4.25vw;
    margin-bottom: 2vw;
  }
  .common_ttl_box .ttl {
    font-size: 5.35vw;
  }
  .common_voice_box {
    width: 90vw;
  }
  .common_voice_box a:hover .img_box .img img {
    transform: scale(1);
  }
  .common_voice_box a:hover .voice_cont .com_wrap .com_box .num_box {
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
  }
  .common_voice_box a:hover .btn {
    background-color: #BC5D77;
  }
  .common_voice_box a .img_box {
    height: 41vw;
  }
  .common_voice_box a .img_box .name_box {
    padding: 2vw 5vw 0 5vw;
  }
  .common_voice_box a .img_box .name_box .old {
    font-size: 3.3vw;
    margin-bottom: 1.5vw;
  }
  .common_voice_box a .img_box .name_box .name {
    font-size: 3.7vw;
  }
  .common_voice_box a .voice_cont {
    padding: 7vw 5vw 7vw;
  }
  .common_voice_box a .voice_cont .designs_text {
    top: 2vw;
    right: 17vw;
    font-size: 3.6vw;
  }
  .common_voice_box a .voice_cont .lead_text {
    font-size: 4.1vw;
    margin-bottom: 4vw;
  }
  .common_voice_box a .voice_cont .com_wrap {
    margin-bottom: 6vw;
  }
  .common_voice_box a .voice_cont .com_wrap .com_box {
    width: 30vw;
  }
  .common_voice_box a .voice_cont .com_wrap .com_box .label {
    line-height: 6vw;
    font-size: 3.7vw;
  }
  .common_voice_box a .voice_cont .com_wrap .com_box .num_box {
    padding: 2vw 0 3vw;
  }
  .common_voice_box a .voice_cont .com_wrap .com_box .num_box .num {
    font-size: 8.2vw;
  }
  .common_voice_box a .voice_cont .com_wrap .com_box .num_box .num .small {
    font-size: 4vw;
  }
  .common_voice_box a .voice_cont .com_wrap .arrow {
    width: 7vw;
  }
  .common_voice_box a .voice_cont .text_box .ttl {
    font-size: 4.1vw;
    margin-bottom: 2vw;
  }
  .common_voice_box a .voice_cont .text_box .text {
    font-size: 3.6vw;
  }
  .common_voice_box a .btn {
    height: 10vw;
    gap: 0 3vw;
  }
  .common_voice_box a .btn .label {
    font-size: 3.7vw;
  }
  .common_voice_box a .btn .arrow {
    width: 3vw;
  }
  #top_voice_sec {
    margin-bottom: 18vw;
  }
  #top_voice_sec .common_top_ttl_box {
    margin-bottom: 7vw;
  }
  #top_voice_sec .slider_wrap .slider_guide_box {
    position: relative;
    top: auto;
    transform: translateY(0);
    left: auto;
    right: auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 0 3.5vw;
  }
  #top_voice_sec .slider_wrap .slider_guide_box .arrow {
    width: 12vw;
    height: 12vw;
  }
  #top_voice_sec .slider_wrap .slider_guide_box .arrow:hover {
    background-color: #fff;
  }
  #top_voice_sec .slider_wrap .slider_guide_box .arrow:hover svg path {
    fill: #B4B4B4;
  }
  #top_voice_sec .slider_wrap .slider_guide_box .arrow svg {
    width: 4vw;
  }
  #top_voice_sec .slider_wrap .slider_guide_box .dots_list {
    flex-grow: 1;
    display: block;
  }
  #top_voice_sec .slider_wrap .slider_guide_box .dots_list ul {
    position: inherit;
    bottom: 0;
    display: flex;
  }
  #top_voice_sec .slider_wrap .slider_guide_box .dots_list ul li {
    flex: 1 0 auto;
    display: inline-block;
    width: auto;
    height: 4px;
    margin: 0;
    background-color: #F4F4F4;
    border-radius: 100vmax;
  }
  #top_voice_sec .slider_wrap .slider_guide_box .dots_list ul li.slick-active {
    background-color: #D06880;
  }
  #top_voice_sec .slider_wrap .slider_guide_box .dots_list ul li button {
    width: 100%;
    height: 100%;
    padding: 0;
    border-radius: 100vmax;
  }
  #top_voice_sec .slider_wrap .slider_guide_box .dots_list ul li button::before {
    content: none;
  }
  #top_voice_sec .slider_wrap .top_voice_slider {
    margin-bottom: 6vw;
  }
  #top_voice_sec .slider_wrap .top_voice_slider .common_voice_box {
    width: calc(90vw - 12px);
    margin: 0 6px;
  }
  #top_voice_sec .slider_wrap .top_voice_slider .common_voice_box + .common_voice_box {
    margin-top: 6vw;
  }
  #top_voice_sec .slider_wrap .top_voice_slider .common_voice_box:nth-child(3) {
    transition-delay: 0s;
  }
  #top_voice_sec .slider_wrap .top_voice_slider .common_voice_box:nth-child(4) {
    transition-delay: 0s;
  }
  .common_btn {
    width: 100%;
  }
  .common_btn a {
    gap: 0 3.5vw;
    padding: 3.5vw 5vw 3.5vw 9vw;
  }
  .common_btn a:hover {
    background-color: #BC5D77;
    border: 1px solid transparent;
  }
  .common_btn a:hover .label {
    color: #fff;
  }
  .common_btn a:hover .arrow_box {
    background-color: #fff;
  }
  .common_btn a:hover .arrow_box .arrow svg path {
    fill: #BC5D77;
  }
  .common_btn a .label {
    font-size: 4.2vw;
  }
  .common_btn a .arrow_box {
    width: 7.6vw;
    height: 7.6vw;
  }
  .common_btn a .arrow_box .arrow {
    width: 2.5vw;
    height: 2.5vw;
  }
  #top_reason_sec {
    padding: 18vw 0 20vw;
    margin-bottom: 20vw;
  }
  #top_reason_sec .deco.deco1 {
    width: 90vw;
    top: 5vw;
    right: -20vw;
  }
  #top_reason_sec .deco.deco2 {
    width: 80vw;
    bottom: 5vw;
    left: -25vw;
  }
  #top_reason_sec .cont .common_top_ttl_box {
    margin-bottom: 7vw;
  }
  #top_reason_sec .cont .list {
    margin-bottom: 12vw;
  }
  #top_reason_sec .cont .list ul {
    display: block;
  }
  #top_reason_sec .cont .list ul li + li {
    margin-top: 8vw;
  }
  #top_reason_sec .cont .list ul li:nth-child(2) {
    animation-delay: 0s;
  }
  #top_reason_sec .cont .list ul li:nth-child(3) {
    animation-delay: 0s;
  }
  #top_reason_sec .cont .list ul li .img {
    height: 41vw;
    margin-bottom: 5vw;
  }
  #top_reason_sec .cont .list ul li .text_box .ttl_box {
    padding-left: 3vw;
    height: 13.4vw;
    margin-bottom: 3vw;
  }
  #top_reason_sec .cont .list ul li .text_box .ttl_box .ttl {
    font-size: 4.8vw;
  }
  #top_reason_sec .cont .list ul li .text_box .text {
    font-size: 3.5vw;
  }
  #top_com_sec {
    margin-bottom: 20vw;
  }
  #top_com_sec::before {
    top: 12vw;
    left: 2.5vw;
    right: 2.5vw;
    bottom: -50vw;
  }
  #top_com_sec .cont .common_top_ttl_box {
    margin-bottom: 7vw;
  }
  #top_com_sec .cont .table_cont {
    width: 95vw;
    margin-right: -5vw;
    overflow-x: scroll;
  }
  #top_com_sec .cont .table_cont .table_wrap {
    width: 269.3vw;
    min-width: 269.3vw;
    padding-right: 5vw;
  }
  #top_com_sec .cont .table_cont .table_wrap::before {
    top: 35.7vw;
    right: 5vw;
  }
  #top_com_sec .cont .table_cont .table_wrap .icon_heart {
    width: 4vw;
    margin-left: 59.7vw;
    margin-bottom: 1vw;
  }
  #top_com_sec .cont .table_cont .table_wrap table thead th {
    font-size: 5.6vw;
    width: 45vw;
  }
  #top_com_sec .cont .table_cont .table_wrap table thead th .inner {
    height: 20vw;
  }
  #top_com_sec .cont .table_cont .table_wrap table thead th .small {
    margin-top: 2vw;
    font-size: 3.7vw;
  }
  #top_com_sec .cont .table_cont .table_wrap table thead th:nth-of-type(2) .inner.tall {
    height: 30.7vw;
  }
  #top_com_sec .cont .table_cont .table_wrap table tbody tr th {
    font-size: 4.1vw;
  }
  #top_com_sec .cont .table_cont .table_wrap table tbody tr:nth-of-type(1) td {
    height: 35.8vw;
    font-size: 3.7vw;
  }
  #top_com_sec .cont .table_cont .table_wrap table tbody tr td {
    height: 29vw;
    font-size: 4.2vw;
  }
  #top_com_sec .cont .table_cont .table_wrap table tbody tr td .small {
    font-size: 3.7vw;
  }
  #top_com_sec .cont .table_cont .table_wrap table tbody tr td.love_circle, #top_com_sec .cont .table_cont .table_wrap table tbody tr td.circle, #top_com_sec .cont .table_cont .table_wrap table tbody tr td.x {
    background-size: 15vw;
  }
  #top_com_sec .cont .table_cont .table_wrap table tbody tr td.tri {
    background-size: 16vw;
  }
  #top_flow_sec {
    margin-bottom: 20vw;
  }
  #top_flow_sec .common_top_ttl_box {
    margin-bottom: 8vw;
  }
  #top_flow_sec .flow_list::before {
    content: "";
    position: absolute;
    top: 10vw;
    bottom: 40vw;
    left: calc(10.25vw - 0.5px);
    right: auto;
    height: auto;
    width: 1px;
  }
  #top_flow_sec .flow_list ul {
    display: block;
  }
  #top_flow_sec .flow_list ul li {
    display: flex;
    flex-direction: inherit;
    gap: 0 4vw;
  }
  #top_flow_sec .flow_list ul li + li {
    margin-top: 7vw;
  }
  #top_flow_sec .flow_list ul li:first-child .icon_wrap {
    margin-top: 6vw;
  }
  #top_flow_sec .flow_list ul li:first-child .icon_wrap .icon {
    width: 9.2vw;
  }
  #top_flow_sec .flow_list ul li:first-child .text_box {
    padding-top: 0;
  }
  #top_flow_sec .flow_list ul li:nth-child(2) {
    transition-delay: 0s;
  }
  #top_flow_sec .flow_list ul li:nth-child(2) .icon_wrap::before {
    content: none;
  }
  #top_flow_sec .flow_list ul li:nth-child(2) .icon_wrap .icon {
    width: 9.8vw;
  }
  #top_flow_sec .flow_list ul li:last-child {
    transition-delay: 0s;
  }
  #top_flow_sec .flow_list ul li:last-child .icon_wrap::before {
    content: none;
  }
  #top_flow_sec .flow_list ul li:last-child .icon_wrap .icon {
    width: 9vw;
  }
  #top_flow_sec .flow_list ul li .icon_wrap {
    flex-shrink: 0;
    width: 20.5vw;
    height: 20.5vw;
    margin: 12vw 0 0;
  }
  #top_flow_sec .flow_list ul li .icon_wrap::before, #top_flow_sec .flow_list ul li .icon_wrap:after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 2vw;
    height: 2vw;
  }
  #top_flow_sec .flow_list ul li .icon_wrap::before {
    top: -1vw;
    left: 0;
  }
  #top_flow_sec .flow_list ul li .icon_wrap::after {
    bottom: -1vw;
    right: 0;
  }
  #top_flow_sec .flow_list ul li .icon_wrap .step_box {
    top: -6vw;
    width: 10.25vw;
    height: 10.25vw;
    padding-top: 1vw;
  }
  #top_flow_sec .flow_list ul li .icon_wrap .step_box .num {
    font-size: 3.6vw;
  }
  #top_flow_sec .flow_list ul li .icon_wrap .step_box .num .label {
    font-size: 3.2vw;
  }
  #top_flow_sec .flow_list ul li .text_box {
    padding-top: 6vw;
    flex-grow: 1;
  }
  #top_flow_sec .flow_list ul li .text_box::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 1px;
    width: auto;
    background: repeating-linear-gradient(to right, #C6C6C6 0 3px, transparent 3px 6px);
  }
  #top_flow_sec .flow_list ul li .text_box .ttl_box {
    height: auto;
    margin-bottom: 2.5vw;
  }
  #top_flow_sec .flow_list ul li .text_box .ttl_box .ttl {
    text-align: left;
    font-size: 4vw;
  }
  #top_flow_sec .flow_list ul li .text_box .text {
    font-size: 3.2vw;
    letter-spacing: 0.06em;
  }
  #top_faq_sec {
    padding: 18vw 0 20vw;
  }
  #top_faq_sec .deco {
    top: 5%;
    left: -3vw;
    width: 45vw;
  }
  #top_faq_sec .cont .common_top_ttl_box {
    margin-bottom: 6vw;
  }
  #top_faq_sec .cont .faq_list ul li {
    padding: 5vw 5vw 5vw;
  }
  #top_faq_sec .cont .faq_list ul li + li {
    margin-top: 3vw;
  }
  #top_faq_sec .cont .faq_list ul li .q_box .en {
    font-size: 4vw;
    margin-right: 4vw;
  }
  #top_faq_sec .cont .faq_list ul li .q_box .ttl {
    font-size: 4.1vw;
  }
  #top_faq_sec .cont .faq_list ul li .q_box .icon_box {
    margin-left: 3vw;
    width: 7.7vw;
    height: 7.7vw;
  }
  #top_faq_sec .cont .faq_list ul li .q_box .icon_box .border {
    width: 3.9vw;
    height: 1px;
  }
  #top_faq_sec .cont .faq_list ul li .a_box {
    margin-top: 4vw;
    padding-top: 4vw;
  }
  #top_faq_sec .cont .faq_list ul li .a_box .inner {
    padding-bottom: 2vw;
  }
  #top_faq_sec .cont .faq_list ul li .a_box .inner .en {
    font-size: 4vw;
    margin-right: 4.5vw;
  }
  #top_faq_sec .cont .faq_list ul li .a_box .inner .text_box .text {
    font-size: 3.2vw;
  }
  #footer_cta_sec {
    padding: 18vw 0;
    background-image: url(image/cta_back_img_sp.jpg);
  }
  #footer_cta_sec .text_box .ttl_box {
    margin-bottom: 4vw;
  }
  #footer_cta_sec .text_box .ttl_box .en {
    font-size: 4.6vw;
    margin-bottom: 2vw;
  }
  #footer_cta_sec .text_box .ttl_box .ttl {
    font-size: 8vw;
  }
  #footer_cta_sec .text_box .text {
    font-size: 3.7vw;
  }
  #footer_cta_sec .text_box .line_btn {
    width: 100%;
    margin: 8vw auto 0;
  }
  #footer_cta_sec .text_box .line_btn a {
    padding: 3.5vw 5vw 3.5vw 7.5vw;
  }
  #footer_cta_sec .text_box .line_btn a:hover {
    background-color: #A83A69;
    border: 1px solid transparent;
  }
  #footer_cta_sec .text_box .line_btn a:hover .label {
    color: #fff;
  }
  #footer_cta_sec .text_box .line_btn a:hover .arrow_box {
    background-color: #fff;
  }
  #footer_cta_sec .text_box .line_btn a:hover .arrow_box .arrow svg path {
    fill: #BC5D77;
  }
  #footer_cta_sec .text_box .line_btn a .icon {
    width: 7.6vw;
    margin-right: 6vw;
  }
  #footer_cta_sec .text_box .line_btn a .label {
    font-size: 4.2vw;
  }
  #footer_cta_sec .text_box .line_btn a .arrow_box {
    width: 7.6vw;
    height: 7.6vw;
  }
  #footer_cta_sec .text_box .line_btn a .arrow_box .arrow {
    width: 2.5vw;
    height: 2.5vw;
  }
  #main_footer {
    padding: 20vw 0 22vw;
  }
  #main_footer .deco {
    width: 50vw;
  }
  #main_footer .deco.deco1 {
    top: 77vw;
    right: -15vw;
  }
  #main_footer .deco.deco2 {
    bottom: -111vw;
    left: -10vw;
  }
  #main_footer .cont .link_cont {
    display: none;
  }
  #main_footer .cont .data_cont {
    display: block;
  }
  #main_footer .cont .data_cont .logo {
    width: 50vw;
    margin: 0 auto 11vw;
  }
  #main_footer .cont .data_cont .sun_data_block {
    margin-left: 0;
    text-align: center;
  }
  #main_footer .cont .data_cont .sun_data_block .list {
    margin-bottom: 15vw;
  }
  #main_footer .cont .data_cont .sun_data_block .list ul {
    display: block;
  }
  #main_footer .cont .data_cont .sun_data_block .list ul li + li {
    margin-top: 3vw;
  }
  #main_footer .cont .data_cont .sun_data_block .list ul li a {
    font-size: 3.4vw;
  }
  #main_footer .cont .data_cont .sun_data_block .copy {
    text-align: center;
    font-size: 3.1vw;
  }
  /* 共通設定 */
  .common_page_main {
    padding-top: 70px;
  }
  .common_page_main .deco {
    width: 70vw;
    top: -5vw;
    right: -18vw;
  }
  .common_page_main .text_box {
    padding-top: 25vw;
  }
  .common_page_main .text_box .en {
    font-size: 4vw;
    margin-bottom: 2.5vw;
  }
  .common_page_main .text_box .ttl {
    font-size: 6.5vw;
    letter-spacing: 0.1em;
    margin-bottom: 7vw;
  }
  .common_page_main .text_box .breadcrumb {
    text-align: left;
    font-size: 2.8vw;
  }
  .common_page_main .img {
    height: 60vw;
  }
  .common_page_wrap {
    padding: 17vw 0 17vw;
  }
  .common_single_wrap {
    padding: 0 0 17vw;
  }
  .reserve_text {
    font-size: 6vw;
  }
  .breadcrumb {
    font-size: 2.4vw;
  }
  .breadcrumb.single {
    text-align: left;
    margin-top: 19vw;
  }
  /* SP固定ページ 個人情報保護方針 */
  .privacy_cont_sec .main_text {
    font-size: 3.3vw;
    margin-block: 0 10vw;
  }
  .privacy_cont_sec dl + dl {
    margin-block: 8vw 0;
  }
  .privacy_cont_sec dl dt {
    font-size: 4.1vw;
    padding-block: 0 0.5em;
    margin-block: 0 0.7em;
  }
  .privacy_cont_sec dl dd {
    font-size: 3.3vw;
  }
  /* SP固定ページ 404ページ */
  #page_404 .num {
    font-size: 20vw;
    line-height: 1.5;
  }
  #page_404 .text {
    font-size: 3.5vw;
  }
  .wp-pagenavi {
    margin-top: 12vw;
  }
  .wp-pagenavi a,
  .wp-pagenavi span {
    padding: 1.5vw 2.8vw !important;
    margin: 0 2px;
    font-size: 3.6vw;
  }
  .common_form_page {
    padding: 20vw 0 7vw;
  }
  .common_form_page .container {
    display: block;
  }
  .common_form_page .container .text_block {
    position: inherit;
    top: 0;
    margin-bottom: 10vw;
  }
  .common_form_page .container .text_block .top_text_box {
    margin-bottom: 0;
  }
  .common_form_page .container .text_block .top_text_box .ttl {
    font-size: 7.2vw;
    margin-bottom: 5vw;
  }
  .common_form_page .container .text_block .top_text_box .text {
    font-size: 3.6vw;
  }
  .common_form_page .container .text_block .top_text_box .text a {
    margin: 0 0.1vw;
  }
  .common_form_page .container .text_block .top_text_box .text + .text {
    margin-top: 1.5vw;
  }
  .common_form_page .container .text_block .form_guide_box {
    margin-top: 5vw;
    margin-bottom: 10vw;
  }
  .common_form_page .container .text_block .form_guide_box .ttl {
    font-size: 3.8vw;
    padding-bottom: 2vw;
  }
  .common_form_page .container .text_block .thum_box {
    gap: 0 5vw;
  }
  .common_form_page .container .text_block .thum_box .text_box .cont_list {
    margin-top: 3vw;
  }
  .common_form_page .container .text_block .thum_box .text_box .cont_list ul li + li {
    margin-top: 2vw;
  }
  .common_form_page .container .text_block .thum_box .text_box .cont_list ul li {
    font-size: 3.5vw;
  }
  .common_form_page .container .text_block .thum_box .text_box .cont_list ul li::before {
    margin-right: 2vw;
    width: 1.5vw;
    height: 1.5vw;
  }
  .common_form_page .container .text_block .thum_box .thum {
    width: 30%;
    border-radius: 3vw;
    padding: 2vw;
  }
  .common_form_page .container .form_cont {
    width: 100%;
    padding: 7vw 3.5vw 6vw;
    margin-left: 0;
  }
  .common_form_page .container .form_cont .top_text_box {
    margin-bottom: 6vw;
  }
  .common_form_page .container .form_cont .top_text_box .lead {
    font-size: 3.6vw;
  }
  .common_form_page .container .form_cont .form_wrap .form_box {
    margin-bottom: 7vw;
  }
  .common_form_page .container .form_cont .form_wrap .form_box .list ul li + li {
    margin-top: 5.5vw;
  }
  .common_form_page .container .form_cont .form_wrap .form_box .list ul li .label {
    font-size: 3.5vw;
    margin-bottom: 3vw;
  }
  .common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box input[type=text] {
    padding: 2.5vw 3.5vw;
  }
  .common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box input[type=text]::-moz-placeholder {
    font-size: 3.6vw;
  }
  .common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box input[type=text]::placeholder {
    font-size: 3.6vw;
  }
  .common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box textarea {
    padding: 3vw 3.5vw;
    font-size: 3.6vw;
    height: 50vw;
  }
  .common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box textarea::-moz-placeholder {
    font-size: 3.6vw;
  }
  .common_form_page .container .form_cont .form_wrap .form_box .list ul li .data_box textarea::placeholder {
    font-size: 3.6vw;
  }
  .common_form_page .container .form_cont .form_wrap .btn button {
    line-height: 16vw;
    font-size: 4.2vw;
  }
  .common_form_page .container .form_cont .form_wrap .btn button:hover {
    transform: translateY(0);
    box-shadow: 0 6px #333333;
  }
  .common_form_page .container .form_cont .form_wrap button[name=submitBack] {
    margin-top: 3vw;
  }
  .common_form_page .container .form_cont .form_wrap .thanks_text_box .ttl {
    font-size: 4.5vw;
    margin-bottom: 5vw;
  }
  .common_form_page .container .form_cont .form_wrap .thanks_text_box .text {
    font-size: 3.6vw;
  }
  .common_form_page .container .form_cont .form_wrap .thanks_text_box .text + .text {
    margin-top: 2vw;
  }
  /* layout helpers */
  .data_box.check_wrap {
    display: block;
  }
  .mw_wp_form .horizontal-item {
    display: block;
  }
  .mw_wp_form .horizontal-item + .horizontal-item {
    margin-top: 2vw;
  }
  .radio_btns {
    display: block;
  }
  #sidebar {
    width: 100%;
    padding: 0 15px;
    margin-top: 5vw;
  }
  #sidebar .block + .block {
    margin-top: 10vw;
  }
  #sidebar .common_link_box {
    margin-bottom: 0;
  }
  #sidebar .block .top_ttl {
    font-size: 3.6vw;
    padding-bottom: 2vw;
    margin-bottom: 6vw;
  }
  #sidebar .block .top_ttl::before {
    width: 30%;
  }
  #sidebar .block .ranking_list ul li + li {
    margin-top: 5vw;
  }
  #sidebar .block .ranking_list ul li a {
    gap: 0 3vw;
  }
  #sidebar .block .ranking_list ul li a .ranking_box {
    width: 6vw;
  }
  #sidebar .block .ranking_list ul li a .ranking_box .num {
    font-size: 3.5vw;
    line-height: 6vw;
  }
  #sidebar .block .ranking_list ul li a .img {
    width: 34%;
  }
  #sidebar .block .ranking_list ul li a .text_box .ttl {
    font-size: 3.1vw;
  }
  #sidebar .block .ranking_list ul li a:hover .img img {
    transform: scale(1);
  }
  #sidebar .block .voice_list ul li + li {
    margin-top: 4vw;
  }
  #sidebar .block .voice_list ul li a {
    gap: 0 3vw;
  }
  #sidebar .block .voice_list ul li a .img {
    width: 34%;
  }
  #sidebar .block .voice_list ul li a .text_box .date {
    font-size: 3vw;
    margin-bottom: 1vw;
  }
  #sidebar .block .voice_list ul li a .text_box .ttl {
    font-size: 3.1vw;
  }
  #sidebar .block .voice_list ul li a:hover .img img {
    transform: scale(1);
  }
  /* 準備中 */
  .sorry_sec .text_box .text {
    text-align: left;
    font-size: 4vw;
  }
  .sorry_sec .text_box .text + .text {
    margin-top: 3vw;
  }
  .sorry_sec .text_box .common_btn {
    margin: 7vw 0 0;
  }
  .single_page_wrap {
    padding-top: calc(70px + 10vw);
    padding-bottom: 19vw;
    margin-bottom: 0;
  }
  .single_page_wrap #sidebar {
    padding: 0;
    margin-top: 14vw;
  }
  #page_commercial .commercial_outline_sec .cont .table_wrap {
    margin-bottom: 20px;
  }
  #page_commercial .commercial_outline_sec .cont .table_wrap table {
    display: block;
  }
  #page_commercial .commercial_outline_sec .cont .table_wrap table tbody {
    display: block;
    width: 100%;
  }
  #page_commercial .commercial_outline_sec .cont .table_wrap table tr {
    display: block;
    width: 100%;
    border-top: none;
    border-right: none;
  }
  #page_commercial .commercial_outline_sec .cont .table_wrap table tr + tr {
    margin-top: 3vw;
  }
  #page_commercial .commercial_outline_sec .cont .table_wrap table tr:last-child {
    border-bottom: none;
  }
  #page_commercial .commercial_outline_sec .cont .table_wrap table tr th {
    display: block;
    font-size: 4vw;
    width: 100%;
    padding: 3vw 5vw;
  }
  #page_commercial .commercial_outline_sec .cont .table_wrap table tr td {
    display: block;
    font-size: 3.6vw;
    padding: 5vw 5vw;
  }
  #page_commercial .commercial_outline_sec .cont .map_wrap {
    height: 55vw;
  }
  .common_voice_list .list {
    display: block;
  }
  .common_voice_list .list .common_voice_box + .common_voice_box {
    margin-top: 11vw;
  }
  #page_service #top_about_sec {
    margin-bottom: 40vw;
    padding-top: 22vw;
  }
  #page_service .service_reason_sec {
    margin-bottom: 18vw;
  }
  #page_service .service_reason_sec .deco.deco1 {
    width: 90vw;
    top: 5vw;
    right: -20vw;
  }
  #page_service .service_reason_sec .deco.deco2 {
    width: 80vw;
    bottom: 5vw;
    left: -25vw;
  }
  #page_service .service_reason_sec .cont .common_top_ttl_box {
    margin-bottom: 10vw;
  }
  #page_service .service_reason_sec .cont .list ul li {
    display: block;
  }
  #page_service .service_reason_sec .cont .list ul li + li {
    margin-top: 10vw;
  }
  #page_service .service_reason_sec .cont .list ul li .img {
    width: 100%;
    height: 41vw;
    margin-bottom: 5vw;
  }
  #page_service .service_reason_sec .cont .list ul li .text_block .ttl_box {
    padding-left: 3vw;
    height: 13.4vw;
    margin-bottom: 3vw;
  }
  #page_service .service_reason_sec .cont .list ul li .text_block .ttl_box .ttl {
    font-size: 4.8vw;
  }
  #page_service .service_reason_sec .cont .list ul li .text_block .text {
    font-size: 3.5vw;
  }
  #page_service .service_support_sec {
    margin-bottom: 31vw;
  }
  #page_service .service_support_sec .common_top_ttl_box {
    margin-bottom: 7vw;
  }
  #page_service .service_support_sec .list ul {
    display: block;
  }
  #page_service .service_support_sec .list ul li {
    display: block;
    padding: 7vw 5vw 7vw;
  }
  #page_service .service_support_sec .list ul li + li {
    margin-top: 2.5vw;
  }
  #page_service .service_support_sec .list ul li .top_cont {
    display: flex;
    align-items: center;
    gap: 0 3.5vw;
    margin-bottom: 3vw;
  }
  #page_service .service_support_sec .list ul li .top_cont .icon {
    flex-shrink: 0;
    width: 16vw;
    margin: 0;
  }
  #page_service .service_support_sec .list ul li .top_cont .ttl_box {
    flex-grow: 1;
    display: block;
    height: auto;
    text-align: left;
  }
  #page_service .service_support_sec .list ul li .top_cont .ttl_box .ttl {
    font-size: 4.2vw;
    line-height: 1.5;
  }
  #page_service .service_support_sec .list ul li .text_box {
    text-align: left;
  }
  #page_service .service_support_sec .list ul li .text_box .text {
    font-size: 3.5vw;
    line-height: 1.6;
  }
  #page_service .service_course_sec {
    margin-bottom: 31vw;
  }
  #page_service .service_course_sec::before, #page_service .service_course_sec::after {
    top: -13vw;
    bottom: -13vw;
    width: 100%;
  }
  #page_service .service_course_sec .cont {
    display: flex;
    flex-direction: column-reverse;
    align-items: inherit;
    gap: 8vw 0;
  }
  #page_service .service_course_sec .cont .text_block .common_ttl_box {
    margin-bottom: 5vw;
  }
  #page_service .service_course_sec .cont .text_block .text {
    font-size: 3.6vw;
  }
  #page_service .service_course_sec .cont .text_block .text + .text {
    margin-top: 2vw;
  }
  #page_service .service_course_sec .cont .text_block .common_btn {
    margin-top: 8vw;
  }
  #page_service .service_course_sec .cont .img {
    width: 100%;
    height: 55vw;
  }
  #page_service #top_voice_sec {
    margin-bottom: 22vw;
  }
  #page_course {
    padding: 17vw 0 17vw;
  }
  #page_course::before {
    filter: blur(10px);
  }
  #page_course .course_table_sec .top_text_box {
    margin-bottom: 9vw;
    text-align: left;
  }
  #page_course .course_table_sec .top_text_box .text {
    font-size: 3.6vw;
    letter-spacing: 0.04em;
  }
  #page_course .course_table_sec .table_cont {
    position: relative;
    width: 95vw;
    margin-right: -5vw;
    overflow-x: scroll;
  }
  #page_course .course_table_sec .table_cont .table_wrap {
    width: 181vw;
    height: 58.5dvh;
    min-width: 181vw;
    padding-right: 5vw;
  }
  #page_course .course_table_sec .table_cont .table_wrap::before {
    top: 20vw;
    right: 5vw;
  }
  #page_course .course_table_sec .table_cont .table_wrap table {
    border-collapse: separate;
  }
  #page_course .course_table_sec .table_cont .table_wrap table thead th {
    position: sticky;
    top: 0;
    z-index: 10;
    font-size: 4.6vw;
    width: 47vw;
  }
  #page_course .course_table_sec .table_cont .table_wrap table thead th .inner {
    height: 18vw;
  }
  #page_course .course_table_sec .table_cont .table_wrap table tbody tr th {
    position: sticky;
    left: 0;
    z-index: 1;
    font-size: 3.8vw;
  }
  #page_course .course_table_sec .table_cont .table_wrap table tbody tr th .small {
    font-size: 3.4vw;
  }
  #page_course .course_table_sec .table_cont .table_wrap table tbody tr:nth-of-type(1) td {
    padding: 3.5vw;
    font-size: 3.4vw;
  }
  #page_course .course_table_sec .table_cont .table_wrap table tbody tr td {
    height: 29vw;
  }
  #page_course .course_table_sec .table_cont .table_wrap table tbody tr td .icon.circle {
    width: 7vw;
  }
  #page_course .course_table_sec .table_cont .table_wrap table tbody tr td .icon.x {
    width: 7vw;
  }
  #page_course .course_table_sec .table_cont .table_wrap table tbody tr td .icon_label {
    font-size: 3.7vw;
    margin-top: 1vw;
  }
}/*# sourceMappingURL=style.css.map */