@charset "UTF-8";
/* CSS Document */
/* CSS Document */
@import url("https://fonts.googleapis.com/css2?family=Kaisei+Tokumin&family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap");
.txt8 {
  font-size: 8px;
  font-size: 0.8rem;
}

.txt9 {
  font-size: 9px;
  font-size: 0.9rem;
}

.txt10 {
  font-size: 10px;
  font-size: 1rem;
}

.txt11 {
  font-size: 11px;
  font-size: 1.1rem;
}

.txt12 {
  font-size: 12px;
  font-size: 1.2rem;
}

.txt13 {
  font-size: 13px;
  font-size: 1.3rem;
}

.txt14 {
  font-size: 14px;
  font-size: 1.4rem;
}

.txt15 {
  font-size: 15px;
  font-size: 1.5rem;
}

.txt16 {
  font-size: 16px;
  font-size: 1.6rem;
}

.txt17 {
  font-size: 17px;
  font-size: 1.7rem;
}

.txt18 {
  font-size: 18px;
  font-size: 1.8rem;
}

.txt19 {
  font-size: 19px;
  font-size: 1.9rem;
}

.txt20 {
  font-size: 20px;
  font-size: 2rem;
}

.txt21 {
  font-size: 21px;
  font-size: 2.1rem;
}

.txt22 {
  font-size: 22px;
  font-size: 2.2rem;
}

.txt23 {
  font-size: 23px;
  font-size: 2.3rem;
}

.txt24 {
  font-size: 24px;
  font-size: 2.4rem;
}

.txt25 {
  font-size: 25px;
  font-size: 2.5rem;
}

.txt26 {
  font-size: 26px;
  font-size: 2.6rem;
}

.txt27 {
  font-size: 27px;
  font-size: 2.7rem;
}

.txt28 {
  font-size: 28px;
  font-size: 2.8rem;
}

.txt29 {
  font-size: 29px;
  font-size: 2.9rem;
}

.txt30 {
  font-size: 30px;
  font-size: 3rem;
}

.txt31 {
  font-size: 31px;
  font-size: 3.1rem;
}

.txt32 {
  font-size: 32px;
  font-size: 3.2rem;
}

.txt33 {
  font-size: 33px;
  font-size: 3.3rem;
}

.txt34 {
  font-size: 34px;
  font-size: 3.4rem;
}

.txt35 {
  font-size: 35px;
  font-size: 3.5rem;
}

.txt36 {
  font-size: 36px;
  font-size: 3.6rem;
}

.txt37 {
  font-size: 37px;
  font-size: 3.7rem;
}

.txt38 {
  font-size: 38px;
  font-size: 3.8rem;
}

.txt39 {
  font-size: 39px;
  font-size: 3.9rem;
}

.txt40 {
  font-size: 40px;
  font-size: 4rem;
}

.txt41 {
  font-size: 41px;
  font-size: 4.1rem;
}

.txt42 {
  font-size: 42px;
  font-size: 4.2rem;
}

.txt43 {
  font-size: 43px;
  font-size: 4.3rem;
}

.txt44 {
  font-size: 44px;
  font-size: 4.4rem;
}

.txt45 {
  font-size: 45px;
  font-size: 4.5rem;
}

.txt46 {
  font-size: 46px;
  font-size: 4.6rem;
}

.txt47 {
  font-size: 47px;
  font-size: 4.7rem;
}

.txt48 {
  font-size: 48px;
  font-size: 4.8rem;
}

.txt49 {
  font-size: 49px;
  font-size: 4.9rem;
}

.txt50 {
  font-size: 50px;
  font-size: 5rem;
}

.txt51 {
  font-size: 51px;
  font-size: 5.1rem;
}

.txt52 {
  font-size: 52px;
  font-size: 5.2rem;
}

.txt53 {
  font-size: 53px;
  font-size: 5.3rem;
}

.txt54 {
  font-size: 54px;
  font-size: 5.4rem;
}

.txt55 {
  font-size: 55px;
  font-size: 5.5rem;
}

.txt56 {
  font-size: 56px;
  font-size: 5.6rem;
}

.txt57 {
  font-size: 57px;
  font-size: 5.7rem;
}

.txt58 {
  font-size: 58px;
  font-size: 5.8rem;
}

.txt59 {
  font-size: 59px;
  font-size: 5.9rem;
}

.txt60 {
  font-size: 60px;
  font-size: 6rem;
}

.txt61 {
  font-size: 61px;
  font-size: 6.1rem;
}

.txt62 {
  font-size: 62px;
  font-size: 6.2rem;
}

.txt63 {
  font-size: 63px;
  font-size: 6.3rem;
}

.txt64 {
  font-size: 64px;
  font-size: 6.4rem;
}

.txt65 {
  font-size: 65px;
  font-size: 6.5rem;
}

.txt66 {
  font-size: 66px;
  font-size: 6.6rem;
}

.txt67 {
  font-size: 67px;
  font-size: 6.7rem;
}

.txt68 {
  font-size: 68px;
  font-size: 6.8rem;
}

.txt69 {
  font-size: 69px;
  font-size: 6.9rem;
}

.txt70 {
  font-size: 70px;
  font-size: 7rem;
}

.txt71 {
  font-size: 71px;
  font-size: 7.1rem;
}

.txt72 {
  font-size: 72px;
  font-size: 7.2rem;
}

.txt73 {
  font-size: 73px;
  font-size: 7.3rem;
}

.txt74 {
  font-size: 74px;
  font-size: 7.4rem;
}

.txt75 {
  font-size: 75px;
  font-size: 7.5rem;
}

.txt76 {
  font-size: 76px;
  font-size: 7.6rem;
}

.txt77 {
  font-size: 77px;
  font-size: 7.7rem;
}

.txt78 {
  font-size: 78px;
  font-size: 7.8rem;
}

.txt79 {
  font-size: 79px;
  font-size: 7.9rem;
}

.txt80 {
  font-size: 80px;
  font-size: 8rem;
}

.txt81 {
  font-size: 81px;
  font-size: 8.1rem;
}

.txt82 {
  font-size: 82px;
  font-size: 8.2rem;
}

.txt83 {
  font-size: 83px;
  font-size: 8.3rem;
}

.txt84 {
  font-size: 84px;
  font-size: 8.4rem;
}

.txt85 {
  font-size: 85px;
  font-size: 8.5rem;
}

.txt86 {
  font-size: 86px;
  font-size: 8.6rem;
}

.txt87 {
  font-size: 87px;
  font-size: 8.7rem;
}

.txt88 {
  font-size: 88px;
  font-size: 8.8rem;
}

.txt89 {
  font-size: 89px;
  font-size: 8.9rem;
}

.pd0 {
  padding: 0px !important;
}

.pd5 {
  padding: 5px !important;
}

.pd10 {
  padding: 10px !important;
}

.pd15 {
  padding: 15px !important;
}

.pd20 {
  padding: 20px !important;
}

.pd25 {
  padding: 25px !important;
}

.pd30 {
  padding: 30px !important;
}

.pd35 {
  padding: 35px !important;
}

.pd40 {
  padding: 40px !important;
}

.pd45 {
  padding: 45px !important;
}

.pd50 {
  padding: 50px !important;
}

.pd55 {
  padding: 55px !important;
}

.pd60 {
  padding: 60px !important;
}

.pd-t0 {
  padding-top: 0px;
}

.pd-r0 {
  padding-right: 0px !important;
}

.pd-b0 {
  padding-bottom: 0px;
}

.pd-l0 {
  padding-left: 0px;
}

.pd-t5 {
  padding-top: 5px;
}

.pd-r5 {
  padding-right: 5px !important;
}

.pd-b5 {
  padding-bottom: 5px;
}

.pd-l5 {
  padding-left: 5px;
}

.pd-t10 {
  padding-top: 10px;
}

.pd-r10 {
  padding-right: 10px !important;
}

.pd-b10 {
  padding-bottom: 10px;
}

.pd-l10 {
  padding-left: 10px;
}

.pd-t15 {
  padding-top: 15px;
}

.pd-r15 {
  padding-right: 15px !important;
}

.pd-b15 {
  padding-bottom: 15px;
}

.pd-l15 {
  padding-left: 15px;
}

.pd-t20 {
  padding-top: 20px;
}

.pd-r20 {
  padding-right: 20px !important;
}

.pd-b20 {
  padding-bottom: 20px;
}

.pd-l20 {
  padding-left: 20px;
}

.pd-t25 {
  padding-top: 25px;
}

.pd-r25 {
  padding-right: 25px !important;
}

.pd-b25 {
  padding-bottom: 25px;
}

.pd-l25 {
  padding-left: 25px;
}

.pd-t30 {
  padding-top: 30px;
}

.pd-r30 {
  padding-right: 30px !important;
}

.pd-b30 {
  padding-bottom: 30px;
}

.pd-l30 {
  padding-left: 30px;
}

.pd-t35 {
  padding-top: 35px;
}

.pd-r35 {
  padding-right: 35px !important;
}

.pd-b35 {
  padding-bottom: 35px;
}

.pd-l35 {
  padding-left: 35px;
}

.pd-t40 {
  padding-top: 40px;
}

.pd-r40 {
  padding-right: 40px !important;
}

.pd-b40 {
  padding-bottom: 40px;
}

.pd-l40 {
  padding-left: 40px;
}

.pd-t45 {
  padding-top: 45px;
}

.pd-r45 {
  padding-right: 45px !important;
}

.pd-b45 {
  padding-bottom: 45px;
}

.pd-l45 {
  padding-left: 45px;
}

.pd-t50 {
  padding-top: 50px;
}

.pd-r50 {
  padding-right: 50px !important;
}

.pd-b50 {
  padding-bottom: 50px;
}

.pd-l50 {
  padding-left: 50px;
}

.pd-t55 {
  padding-top: 55px;
}

.pd-r55 {
  padding-right: 55px !important;
}

.pd-b55 {
  padding-bottom: 55px;
}

.pd-l55 {
  padding-left: 55px;
}

.pd-t60 {
  padding-top: 60px;
}

.pd-r60 {
  padding-right: 60px !important;
}

.pd-b60 {
  padding-bottom: 60px;
}

.pd-l60 {
  padding-left: 60px;
}

/* CSS Document */
.sp_br {
  display: none;
}
@media (max-width: 430px) {
  .sp_br {
    display: inline;
  }
}

.pc_br {
  display: inline;
}
@media (max-width: 430px) {
  .pc_br {
    display: none;
  }
}

.pc_none {
  display: none;
}
@media (max-width: 430px) {
  .pc_none {
    display: block;
  }
}
@media (max-width: 978px) {
  .pc_none {
    display: block;
  }
}

.sp_none {
  display: block;
}
@media (max-width: 430px) {
  .sp_none {
    display: none;
  }
}
@media (max-width: 978px) {
  .sp_none {
    display: none;
  }
}

.hide-pc {
  display: none !important;
}
@media (max-width: 430px) {
  .hide-pc {
    display: block;
  }
}

@media (max-width: 430px) {
  .hide-sp {
    display: none !important;
  }
}

:root {
  --color-main: #092040;
  --color-main-light: #1B3B65;
  --color-main-light02: #F9EDE5;
  --color-accent: #D9C047;
  --color-accent-light: #FAF9F2;
  --color-white: #fff;
  --color-black: #000000;
}

:focus {
  outline: none;
}

i::before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
  font-style: normal;
}

.has-text-align-right {
  text-align: right !important;
}

input[type=submit] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  border-radius: 0;
}

.aligncenter {
  display: block;
  margin: 0 auto;
}

.alignright {
  float: right;
}

.alignleft {
  float: left;
}

.alignright,
.alignleft {
  margin: 8px;
}

img[class*=wp-image-],
img[class*=attachment-] {
  height: auto;
  max-width: 100%;
}

/*　共通部分　*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
figure {
  margin: 0px;
  padding: 0px;
  border: 0;
  outline: 0;
  background: transparent;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 600;
  font-size: 1em;
  line-height: normal;
}

/*　HTML5　*/
article,
aside,
details,
footer,
header,
hgroup,
menu,
nav,
section,
summary {
  display: block;
}

html,
body {
  margin: 0px 0;
  padding: 0px;
  line-height: 2;
  font-size: 62.5%;
  overflow-x: hidden;
  box-sizing: border-box;
  -ms-overflow-style: scrollbar;
}

body {
  font-family: "Noto Sans JP", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, "Meiryo", "sans-serif";
  text-align: justify;
  word-break: break-all;
  font-size: 18px;
  font-size: 1.8rem;
  background: var(--color-main);
  color: var(--color-white);
  position: relative;
  z-index: -3;
}

img {
  max-width: 100%;
  width: auto;
  height: auto;
  border: 0px;
  margin: 0px;
  padding: 0px;
  vertical-align: bottom;
}

a {
  text-decoration: none;
  color: var(--color-white);
}
a:visited {
  color: var(--color-white);
}

ul,
ol {
  list-style: none;
  margin: 0;
  padding: 0;
}

li {
  margin: 0;
  padding: 0;
}

.container {
  max-width: 100%;
  margin: 0 auto;
  padding-left: 30px;
  padding-right: 30px;
}
@media (max-width: 1920px) {
  .container {
    width: 1400px;
    max-width: 100% !important;
  }
}
@media (max-width: 1470px) {
  .container {
    width: 1200px;
  }
}
@media (max-width: 978px) {
  .container {
    width: auto;
    padding: 0 15px;
  }
}

.d-flex {
  display: flex;
  flex-wrap: wrap;
}

.mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.bt_link {
  display: block;
  position: relative;
  width: 300px;
  max-width: 90%;
  margin: 0 auto;
  margin-top: 4.1666666667vw;
}
.bt_link a {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-white);
  background-color: var(--color-main);
  padding: 1.0416666667vw 0vw 1.0416666667vw 0vw;
  font-size: 18px;
  font-size: 1.8rem;
  border-radius: 9999px;
  text-align: center;
  letter-spacing: 0.04em;
}
.bt_link a:hover {
  opacity: 0.8;
}
.bt_link::after {
  content: "";
  display: block;
  width: 26px;
  height: 26px;
  background: url("../images/icon_btn_arrow.svg") no-repeat;
  background-position: center;
  background-size: 100%;
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
}

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

a[href*="tel:"] {
  pointer-events: none;
  cursor: default;
  text-decoration: none;
}

@media (max-width: 430px) {
  a[href*="tel:"] {
    pointer-events: inherit;
  }
}
body.is-fixed {
  overflow: hidden;
  position: fixed;
  width: 100%;
}

.form .smf-block label[aria-required=true]::after {
  content: " ※必須";
  color: red;
  font-size: 0.9em;
  margin-left: 0.3em;
}
.form header {
  height: 100px;
}
.form .reaf_2 {
  z-index: 1;
}
.form main h2 {
  background-image: url("../images/under_bg.svg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  position: relative;
  width: 100%;
  height: 200px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 36px;
  font-size: 3.6rem;
  font-family: "Kaisei Tokumin", serif;
}
@media (max-width: 430px) {
  .form main h2 {
    top: 0px;
  }
}
.form main .form_content {
  width: 90%;
  margin: 0 auto;
}
@media (max-width: 430px) {
  .form main .form_content {
    padding-top: 5.2083333333vw;
  }
}
.form main .form_content hr {
  width: 100%;
  margin-top: 1rem;
}
.form_wrapper {
  width: 80%;
  margin: 0 auto;
  text-align: center;
  padding: 2.6041666667vw 0vw 5.2083333333vw 0vw;
}
@media (max-width: 430px) {
  .form_wrapper {
    width: 100%;
  }
}
.form_wrapper .tel {
  color: var(--color-accent);
  display: flex;
  align-items: center;
  gap: 20px;
  justify-content: center;
  font-size: 1.7708333333vw;
}
.form_wrapper .tel a {
  color: var(--color-accent);
}
@media (max-width: 430px) {
  .form_wrapper .tel {
    font-size: 18px;
    font-size: 1.8rem;
    margin-bottom: 30px;
  }
}
.form_wrapper .tel span {
  font-family: "Kaisei Tokumin", serif;
  font-size: 3.6458333333vw;
}
@media (max-width: 430px) {
  .form_wrapper .tel span {
    font-size: 30px;
    font-size: 3rem;
  }
}
.form_wrapper_bnr {
  display: flex;
  justify-content: center;
}
.form_bnr {
  display: flex;
  justify-content: center;
  gap: 50px;
  flex-wrap: wrap;
}
@media (max-width: 978px) {
  .form_bnr {
    gap: 20px;
    margin-bottom: 45px;
  }
  .form_bnr a {
    width: 100%;
  }
}
.form hr {
  height: 2px;
}
.form .breadcrumbs {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 100px;
}
.form .breadcrumbs ul {
  display: flex;
}
.form .breadcrumbs ul li {
  position: relative;
  padding-right: 1em;
  margin-right: 0.5em;
}
.form .breadcrumbs ul li::after {
  content: ">";
  position: absolute;
  right: 0;
  color: #999;
}
.form .breadcrumbs ul li:last-child::after {
  content: "";
}

header {
  padding: 1.5625vw 3.3333333333vw 0vw 3.3333333333vw;
}
header .header_container .pc_nav {
  display: flex;
  justify-content: center;
}
@media (max-width: 430px) {
  header .header_container .pc_nav {
    display: none;
  }
}
header .header_container .pc_nav ul {
  display: flex;
  width: 100%;
  justify-content: center;
  gap: 40px;
}
header .header_container .pc_nav ul li {
  text-align: center;
}
@media (max-width: 430px) {
  header .header_container .pc_nav {
    display: none;
  }
}
header .header_container .sp_nav {
  position: fixed;
  top: 0;
  right: 0;
  width: 100%;
  max-width: 320px;
  height: 100vh;
  background: #fff;
  z-index: 100;
  transform: translateX(100%);
  opacity: 0;
  transition: transform 0.4s ease, opacity 0.4s ease;
  padding: 60px 20px;
}
header .header_container .sp_nav.is-open {
  transform: translateX(0);
  opacity: 1;
}
header .header_container .sp_nav ul {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
header .header_container .sp_nav ul li {
  text-align: left;
  font-size: 16px;
}
header .header_container .hamburger {
  cursor: pointer;
  position: absolute;
  z-index: 100;
  width: 50px;
  height: 50px;
  background-color: #fff;
  border-radius: 50%;
  right: 20px;
  top: 20px;
}
header .header_container .hamburger span {
  display: block;
  height: 3px;
  width: 50%;
  background: #333;
  position: absolute;
  left: 12px;
  transition: 0.3s;
}
header .header_container .hamburger span:nth-child(1) {
  top: 18px;
}
header .header_container .hamburger span:nth-child(2) {
  top: 27px;
}
header .header_container .hamburger.active span:nth-child(1) {
  transform: rotate(45deg);
  top: 25px;
}
header .header_container .hamburger.active span:nth-child(2) {
  transform: rotate(-45deg);
  top: 25px;
}
header .header_container .globalMenuSp {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  background: var(--color-main);
  transform: translateX(100%);
  transition: transform 0.4s ease;
  z-index: 99;
  overflow-y: auto;
  height: calc(var(--vh, 1vh) * 100);
}
header .header_container .globalMenuSp.active {
  transform: translateX(0);
}
header .header_container .globalMenuSp .logo {
  position: absolute;
  z-index: 0;
  width: 12.15vw;
  height: 9.52vw;
  max-height: 137.088px;
  text-align: center;
}
@media (max-width: 430px) {
  header .header_container .globalMenuSp .logo {
    flex: 0 0 28%;
    width: 29.15vw;
    top: 20px;
    left: 20px;
  }
}
header .header_container .globalMenuSp nav {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 4.1666666667vw;
}
header .header_container .globalMenuSp nav ul {
  position: relative;
  margin-top: 16rem;
}
header .header_container .globalMenuSp nav ul li {
  text-align: center;
  font-size: 22px;
  font-size: 2.2rem;
}
header .header_container .globalMenuSp .sns_icon {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4rem;
  margin-bottom: 2.0833333333vw;
}
header .header_container .globalMenuSp .tel {
  display: flex;
  justify-content: center;
  gap: 2rem;
  align-items: center;
  font-family: "Kaisei Tokumin", serif;
  color: var(--color-accent);
}
header .header_container .globalMenuSp .tel span {
  font-size: 36px;
  font-size: 3.6rem;
}
header .header_container .globalMenuSp_bnr {
  display: flex;
  flex-direction: column;
  align-items: center;
}
header .header_container .globalMenuSp .main_view_btn_nav_sp .main_view_btn_sp_area_nav {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
}
header .header_container .globalMenuSp .main_view_btn_nav_sp .main_view_btn_sp_area_nav a {
  display: block;
  line-height: 0;
  width: 50%;
}
header .header_container .globalMenuSp .main_view_btn_nav_sp .main_view_btn_sp_area_nav a img {
  width: 100%;
  height: auto;
  display: block;
}
header h1 {
  position: absolute;
  z-index: 0;
  width: 12.15vw;
  height: 9.52vw;
  max-height: 137.088px;
  text-align: center;
}
@media (max-width: 430px) {
  header h1 {
    flex: 0 0 28%;
    width: 29.15vw;
    top: 20px;
    left: 20px;
  }
}
header nav {
  color: var(--color-white);
}

.reaf_2 {
  position: absolute;
  right: 0;
  top: 0;
  z-index: -1;
  width: 18.5vw;
}
@media (max-width: 430px) {
  .reaf_2 {
    width: 42.5vw;
  }
}

.treat {
  position: relative;
  width: 100%;
  z-index: -1;
}
.treat .reaf_1 {
  position: absolute;
  left: 0;
  top: 160px;
  width: 18.5vw;
}
@media (max-width: 430px) {
  .treat .reaf_1 {
    width: 28.5vw;
    top: 500px;
  }
}
.treat .castle_1 {
  position: absolute;
  left: 140px;
  top: 30px;
  z-index: -1;
  width: 18.5vw;
}
@media (max-width: 430px) {
  .treat .castle_1 {
    left: -40px;
    width: 38.5vw;
    top: 370px;
  }
}
.treat .castle_2 {
  position: absolute;
  right: 30px;
  top: 380px;
  z-index: -1;
  width: 18.5vw;
}
@media (max-width: 430px) {
  .treat .castle_2 {
    right: -70px;
    top: 190px;
    width: 58.5vw;
  }
}

.main_view {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}
@media (max-width: 430px) {
  .main_view {
    padding-top: 10.4166666667vw;
    max-width: 100%;
  }
}
.main_view img {
  width: 100%;
  height: auto;
}
.main_view picture {
  display: block;
  width: 100%;
  max-width: 570px;
  margin: 0 auto;
}
.main_view picture img {
  display: block;
  width: 100%;
  height: auto;
}
@media (max-width: 430px) {
  .main_view picture img {
    width: 80%;
    margin: 0 auto;
  }
}
.main_view_figure_sp_area {
  display: flex;
  justify-content: center;
}
@media (max-width: 1920px) {
  .main_view_figure_sp_area {
    display: none;
  }
}
@media (max-width: 430px) {
  .main_view_figure_sp_area {
    display: flex;
  }
}
.main_view_figure_sp_area .figure_1,
.main_view_figure_sp_area .figure_2 {
  flex: 1;
  max-width: 40%;
  position: relative;
  margin: 5.2083333333vw 0vw 5.2083333333vw 0vw;
}
.main_view_btn_sp_area {
  display: flex;
  justify-content: center;
  position: relative;
  width: 100%;
}
@media (max-width: 1920px) {
  .main_view_btn_sp_area {
    display: none;
  }
}
@media (max-width: 430px) {
  .main_view_btn_sp_area {
    display: flex;
    position: fixed;
    bottom: 0;
    z-index: 3;
  }
}
.main_view_sub_text {
  text-align: center;
}
@media (max-width: 1920px) {
  .main_view_sub_text {
    display: none;
  }
}
@media (max-width: 430px) {
  .main_view_sub_text {
    display: block;
    margin: 5.2083333333vw 0vw 5.2083333333vw 0vw;
  }
}
.main_view .main_view_txt {
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
.main_view .main_view_txt_left, .main_view .main_view_txt_right {
  flex: 1;
  max-width: 20%;
}
.main_view .main_view_txt_left {
  transform: translateX(13vw);
}
.main_view .main_view_txt_right {
  transform: translateX(-13vw);
}
.main_view .main_view_txt_center {
  flex: 2;
  max-width: 54%;
}
@media (max-width: 430px) {
  .main_view .main_view_txt_center {
    max-width: 90%;
    padding-top: 15%;
  }
}
.main_view .main_view_txt_1 {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.main_view .main_view_txt_1_figure_1, .main_view .main_view_txt_1_figure_2 {
  flex: 1;
  max-width: 11%;
}
.main_view .main_view_txt_1_figure_1 {
  transform: translateX(0);
  transform: translateY(0);
}
.main_view .main_view_txt_1_figure_2 {
  transform: translateX(0);
  transform: translateY(0);
}
.main_view .main_view_txt_1_center {
  flex: 2;
  max-width: 75%;
  text-align: center;
}
@media (max-width: 430px) {
  .main_view .main_view_txt_1_center {
    max-width: 80%;
  }
}
.main_view .main_view_txt_1_center h2 {
  font-family: "Kaisei Tokumin", serif;
  font-size: 28px;
  font-size: 2.8rem;
  margin: 0vw 0vw 1.5625vw 0vw;
  color: var(--color-accent);
}
.main_view .main_view_txt_1_center h2 span {
  font-size: 46px;
  font-size: 4.6rem;
}
@media (max-width: 430px) {
  .main_view .main_view_txt_1_center h2 {
    font-size: 18px;
    font-size: 1.8rem;
  }
  .main_view .main_view_txt_1_center h2 span {
    font-size: 24px;
    font-size: 2.4rem;
  }
}
.main_view .main_view_btn {
  background-repeat: no-repeat;
  position: relative;
}
.main_view .main_view_btn .figure_1 {
  position: absolute;
  left: -18%;
  top: 26rem;
  max-width: 13rem;
}
@media (max-width: 430px) {
  .main_view .main_view_btn .figure_1 {
    position: absolute;
    left: 18%;
    top: 370px;
    max-width: 11rem;
  }
}
.main_view .main_view_btn .figure_2 {
  position: absolute;
  right: -18%;
  top: 26rem;
  max-width: 13rem;
}
@media (max-width: 430px) {
  .main_view .main_view_btn .figure_2 {
    position: absolute;
    right: 18%;
    top: 370px;
    max-width: 11rem;
  }
}
.main_view .main_view_btn p {
  text-align: center;
  font-size: 18px;
  font-size: 1.8rem;
}
@media (max-width: 430px) {
  .main_view .main_view_btn p {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
.main_view .main_view_btn p span {
  display: block;
}
.main_view .main_view_btn p span img {
  width: -moz-fit-content;
  width: fit-content;
}
.main_view .main_view_btn p .en {
  font-size: 2rem;
  line-height: 1.4;
}
@media (max-width: 430px) {
  .main_view .main_view_btn p .en {
    font-size: 12px;
    font-size: 1.2rem;
  }
}
.main_view .figure_3 {
  text-align: center;
  width: auto;
  margin-bottom: 45px;
}
.main_view .bg_txt {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin-top: 1.0416666667vw;
}
@media (max-width: 430px) {
  .main_view .bg_txt {
    width: 90%;
    margin: 0 auto;
    padding-top: 7.8125vw;
    display: flex;
    gap: 70px;
  }
}
.main_view .bg_txt h2 {
  font-size: 2.8rem;
  color: var(--color-accent);
  font-family: "Kaisei Tokumin", serif;
}
@media (max-width: 430px) {
  .main_view .bg_txt h2 {
    font-size: 2.1rem;
    margin-bottom: 46.875vw;
  }
}
.main_view .bg_txt h2 span {
  font-size: 4.6rem;
}

.contact_btn {
  margin-top: 1.5625vw;
  display: flex;
  justify-content: center;
}
.contact_btn a {
  display: inline-flex;
  width: 277px;
  padding: 1.375rem 0;
  background-color: var(--color-white);
  border-radius: 9999px;
  text-align: center;
  color: var(--color-black);
  flex-direction: row;
  justify-content: center;
  gap: 8px;
  margin-bottom: 5px;
}
.contact_btn a .icon,
.contact_btn a .arrow {
  line-height: normal;
}

.more_btn {
  margin-top: 1.5625vw;
  display: flex;
  justify-content: center;
}
.more_btn a {
  display: inline-flex;
  width: 277px;
  padding: 1.375rem 0;
  border-radius: 9999px;
  text-align: center;
  color: var(--color-white);
  flex-direction: row;
  justify-content: center;
  border: #fff 2px solid;
  position: relative;
  gap: 8px;
}
.more_btn a .icon,
.more_btn a .arrow {
  line-height: normal;
  position: absolute;
  right: 10%;
}

.aboutus {
  display: flex;
  width: auto;
  justify-content: center;
  margin: 0 auto;
  flex-direction: column;
  align-items: center;
  margin-top: 10.4166666667vw;
  padding: 0vw 4.1666666667vw 0vw 0vw;
}
@media (max-width: 430px) {
  .aboutus {
    display: flex;
    width: auto;
  }
}
@media (max-width: 978px) {
  .aboutus {
    width: auto;
  }
}
.aboutus_wrapper {
  position: relative;
}
.aboutus_content {
  display: flex;
  flex-direction: row;
  margin-bottom: 5.2083333333vw;
  align-items: center;
}
@media (max-width: 430px) {
  .aboutus_content {
    width: auto;
    flex-direction: column;
  }
}
.aboutus_img img {
  position: relative;
  left: -70px;
}
@media (max-width: 430px) {
  .aboutus_img img {
    left: -20px;
    width: 80%;
  }
}
.aboutus_info {
  width: 700px;
  margin-top: 4.6875vw;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
@media (max-width: 430px) {
  .aboutus_info {
    width: 90%;
    margin: 0 auto;
  }
}
.aboutus_info .reaf_3 {
  position: absolute;
  z-index: -1;
  width: 25.5vw;
  right: -20%;
  bottom: 2%;
}
@media (max-width: 430px) {
  .aboutus_info .reaf_3 {
    width: 45.5vw;
    right: -5%;
    bottom: -6%;
  }
}
.aboutus_info h4 {
  font-family: "Kaisei Tokumin", serif;
  font-size: 28px;
  font-size: 2.8rem;
}
.aboutus_info_area {
  display: flex;
  flex-direction: row;
  gap: 50px;
}
@media (max-width: 430px) {
  .aboutus_info_area {
    flex-direction: column;
    gap: 20px;
  }
}
.aboutus_info_area img {
  width: 15.625vw;
}
@media (max-width: 430px) {
  .aboutus_info_area img {
    width: 100%;
  }
}

h3 {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 5.2083333333vw;
}
h3 .en {
  font-family: "Noto Serif JP", serif;
  color: var(--color-accent);
}
h3 .jp {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.6rem;
  font-weight: bold;
  display: block;
  margin-top: 1em;
}
h3.heading--bg {
  background-image: url(../images/heading--bg.png);
  width: 430px;
  background-position: 0 40px;
  background-repeat: no-repeat;
  height: 100px;
}

hr {
  border: none;
  height: 10px;
  background: linear-gradient(to right, #d9c047, #f38101);
  margin: 2rem 0;
  width: 1520px;
}
@media (max-width: 430px) {
  hr {
    z-index: -2;
    margin-top: 10.4166666667vw;
    width: 90%;
    height: 5px;
  }
}

.services {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.services_wrapper {
  display: flex;
  flex-direction: row;
  gap: 6rem;
  padding: 4.1666666667vw 4.1666666667vw 4.1666666667vw 4.1666666667vw;
}
@media (max-width: 430px) {
  .services_wrapper {
    padding: 50px 20px;
    flex-direction: column;
  }
}
@media (max-width: 978px) {
  .services_wrapper {
    gap: 0;
  }
}
@media (max-width: 978px) {
  .services_content {
    padding: 0vw 1.0416666667vw 0vw 1.0416666667vw;
  }
}
.services_content h4 {
  font-size: 36px;
  font-size: 3.6rem;
  font-family: "Kaisei Tokumin", serif;
  color: var(--color-accent);
  padding-top: 2.0833333333vw;
}
.services_content h4 + p {
  padding-bottom: 1.5625vw;
}
.services_content .services_info {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
@media (max-width: 430px) {
  .services_content .services_info {
    margin-top: 2.6041666667vw;
  }
}
.services_content .services_info dl {
  font-size: 22px;
  font-size: 2.2rem;
  font-family: "Kaisei Tokumin", serif;
  display: flex;
  gap: 20px;
}
@media (max-width: 430px) {
  .services_content .services_info dl {
    flex-direction: column;
  }
}
.services_content .services_info dl dt {
  width: 15.625vw;
  border: white 1px solid;
  border-left: 4px solid white;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 430px) {
  .services_content .services_info dl dt {
    width: 100%;
  }
}
.services_content .services_info dl dd {
  font-size: 25px;
  font-size: 2.5rem;
}
@media (max-width: 430px) {
  .services_content .services_info dl dd {
    width: 100%;
    text-align: center;
  }
}
.services_content .services_info dl dd.price span {
  font-size: 18px;
  font-size: 1.8rem;
}

.scenes {
  margin-top: 4.1666666667vw;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.scenes_content {
  position: relative;
  display: flex;
  gap: 0;
  align-items: center;
}
@media (max-width: 430px) {
  .scenes_content {
    position: relative;
    display: flex;
    gap: 0;
    align-items: center;
    flex-direction: column;
  }
}
.scenes_content .treat_left,
.scenes_content .treat_right {
  flex: 1;
}
.scenes_content .treat_left .scenes_bg_left_deep,
.scenes_content .treat_right .scenes_bg_left_deep {
  position: absolute;
  z-index: -1;
  top: -50%;
  width: 30rem;
}
@media (max-width: 430px) {
  .scenes_content .treat_left .scenes_bg_left_deep,
  .scenes_content .treat_right .scenes_bg_left_deep {
    position: absolute;
    z-index: -1;
    top: -130px;
    width: 55%;
    right: 0;
  }
}
.scenes_content .scenes_list {
  flex: 3;
  text-align: left;
  margin: 0 auto;
}
.scenes_content .scenes_list ul {
  width: 520px;
  margin: 0 auto;
}
@media (max-width: 978px) {
  .scenes_content .scenes_list ul {
    width: 90%;
  }
}
@media (max-width: 430px) {
  .scenes_content .scenes_list ul {
    width: 334px;
    line-height: normal;
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin: 30px 0;
  }
}
.scenes_content .scenes_list ul li {
  position: relative;
  padding-left: 32px;
  font-family: "Kaisei Tokumin", serif;
  font-size: 28px;
  font-size: 2.8rem;
}
.scenes_content .scenes_list ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background-image: url(../images/scenes_list_icon.png);
  background-size: contain;
  background-repeat: no-repeat;
}
.scenes_wrapper {
  margin: 4.1666666667vw 0vw 4.1666666667vw 0vw;
  width: 100%;
  position: relative;
  /*
  .treat_left,.treat_right {
      .scenes_bg_left {
          position: absolute;
          left: -360px;
          top: 10%;
      }
      .scenes_bg_left_deep {
          position: absolute;
          left: 0;
          top: -140px;
          width: 20%;
      }
      .scenes_bg_right {
          position: absolute;
          right: -360px;
          top: 10%;
      }
      .picture {
          .scenes_bg_center {
              position: absolute;
              bottom: -190px;
              width: 100%;
              z-index: -2;
          }
      }
  }
  @include mq-sp  {
  .treat_left,.treat_right {
      position: relative;
          .scenes_bg_left {
              position: relative;
              left: 0;
              top: 0;
          }
          .scenes_bg_left_deep {
              position: absolute;
              top: -120px;
              width: 60%;
              z-index: -1;
              left: 190px;
          }
          .scenes_bg_right {
              position: relative;
              right: 0;
              top: 0;
          }
          .picture {
              .scenes_bg_center {
                  position: relative;
                  bottom: 0;
                  width: 200%;
                  z-index: -2;
              }
          }
      }
  }
      */
  /*
  ul.scenes_list {
      display: flex;
      flex-direction: column;
      gap: 20px;
      @include vw(padding-top, 80);
      width: 526px;
      margin: 0 auto;

      @include mq-sp {
          width: 90%;
          gap: 0px;
          @include vw(padding-bottom, 100);
      }

      li {
      position: relative;
      padding-left: 32px;
      @include font-jp;
      @include fz(28);

      &::before {
          content: '';
          position: absolute;
          left: 0;
          top: 50%;
          transform: translateY(-50%);
          width: 24px;
          height: 24px;
          background-image: url(../images/scenes_list_icon.png);
          background-size: contain;
          background-repeat: no-repeat;
          }
      }
  }
      */
}
@media (max-width: 430px) {
  .scenes_wrapper {
    padding-top: 7.8125vw;
  }
}
.scenes_wrapper .reaf_4 {
  position: absolute;
  bottom: -23vw;
  z-index: -2;
  left: 0;
}
@media (max-width: 430px) {
  .scenes_wrapper .reaf_4 {
    width: 100%;
  }
}

.work {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.work_wrapper {
  display: flex;
  flex-direction: column;
  gap: 6rem;
  padding-top: 4.1666666667vw;
  margin: 0vw 0vw 5.2083333333vw 0vw;
  transform: scale(1);
}
@media (max-width: 1470px) {
  .work_wrapper {
    transform: scale(0.9);
  }
}
@media (max-width: 430px) {
  .work_wrapper {
    padding: 2.6041666667vw 0vw 1.0416666667vw 0vw;
    flex-direction: column;
  }
}
.work_wrapper dd {
  display: none;
}
.work_wrapper .more_btn {
  display: none;
}
.work_content {
  display: flex;
  flex-direction: row;
  gap: 30px;
}
@media (max-width: 430px) {
  .work_content {
    flex-direction: column;
    align-items: center;
  }
}

.howit {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}
.howit .reaf_4 {
  position: absolute;
  z-index: -1;
  width: 20%;
  right: 0;
  top: 21%;
}
@media (max-width: 430px) {
  .howit .reaf_4 {
    width: 50%;
    right: 0;
    bottom: -7%;
    top: auto;
    z-index: 2;
  }
}
.howit_wrapper {
  transform: scale(1);
  display: flex;
  flex-direction: row;
  gap: 2rem;
  margin: 5.2083333333vw 0vw 5.2083333333vw 0vw;
  padding: 4.1666666667vw 7.2916666667vw 0vw 7.2916666667vw;
}
@media (max-width: 1920px) {
  .howit_wrapper {
    transform: scale(0.9);
  }
}
@media (max-width: 1470px) {
  .howit_wrapper {
    transform: scale(0.8);
  }
}
@media (max-width: 978px) {
  .howit_wrapper {
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
  }
}
@media (max-width: 430px) {
  .howit_wrapper {
    padding: 2.6041666667vw 0vw 1.0416666667vw 0vw;
    flex-direction: column;
    gap: 6rem;
  }
}
.howit_content {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 30px;
  align-items: center;
  background: white;
  justify-content: center;
  width: 270px;
  height: 270px;
  outline: 2px solid var(--color-main);
  outline-offset: -8px;
}
@media (max-width: 430px) {
  .howit_content {
    flex-direction: column;
    align-items: center;
    z-index: 2;
  }
}
.howit_content .houit_no {
  position: absolute;
  top: -40px;
}
.howit_content dl {
  font-family: "Kaisei Tokumin", serif;
  font-size: 20px;
  font-size: 2rem;
  line-height: normal;
  text-align: center;
  color: var(--color-main);
}

.faq {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  background-color: var(--color-main-light);
  padding-bottom: 15.625vw;
}
.faq::before {
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  z-index: -1;
  pointer-events: none;
  content: "";
  position: absolute;
  top: -20%;
  left: 0;
  width: 100%;
  aspect-ratio: 1920/400;
  background-image: url("../images/faq_bg_top.svg");
}
@media screen and (max-width: 1160px) {
  .faq::before {
    top: -15%;
    aspect-ratio: 1450/500;
    background-size: cover;
  }
}
@media (max-width: 430px) {
  .faq::before {
    top: -200px;
    z-index: -1;
    width: 310%;
  }
}
@media (max-width: 430px) {
  .faq {
    padding-top: 15.625vw;
  }
}
.faq_wrapper {
  display: flex;
  gap: 2rem;
  margin: 5.2083333333vw 0vw 5.2083333333vw 0vw;
  width: 80%;
  flex-direction: column;
  align-items: center;
}
@media (max-width: 430px) {
  .faq_wrapper {
    padding: 2.6041666667vw 0vw 1.0416666667vw 0vw;
    flex-direction: column;
    gap: 6rem;
  }
}
.faq_content {
  width: 100%;
}
.faq_content .accordion {
  display: flex;
  gap: 20px;
  flex-direction: column;
}
.faq_content .accordion-question {
  display: block;
  width: 100%;
  font-size: 22px;
  font-size: 2.2rem;
  font-family: "Kaisei Tokumin", serif;
  cursor: pointer;
  background: var(--color-white);
  display: flex;
  align-items: center;
  border: none;
  height: 90px;
  position: relative;
}
@media (max-width: 430px) {
  .faq_content .accordion-question {
    height: 100px;
    font-size: 20px;
    font-size: 2rem;
  }
  .faq_content .accordion-question .faq_q {
    width: 60%;
    text-align: left;
  }
}
.faq_content .accordion-question .faq_icon {
  padding: 0vw 2.0833333333vw 0vw 1.0416666667vw;
}
@media (max-width: 430px) {
  .faq_content .accordion-question .faq_icon {
    padding: 0vw 4.1666666667vw 0vw 2.0833333333vw;
  }
}
.faq_content .accordion-question .faq_icon_arrow {
  position: absolute;
  right: 40px;
}
@media (max-width: 430px) {
  .faq_content .accordion-question .faq_icon_arrow {
    right: 20px;
  }
}
.faq_content .accordion-question .active {
  transform: scaleY(-1);
}
.faq_content .accordion-answer {
  display: none;
  background: var(--color-accent-light);
  font-size: 22px;
  font-size: 2.2rem;
  font-family: "Kaisei Tokumin", serif;
  border: none;
  position: relative;
}
.faq_content .accordion-answer p {
  display: flex;
  align-items: center;
  flex-direction: row;
  padding: 20px 0 20px;
  color: #F38101;
  width: 100%;
}
.faq_content .accordion-answer p .faq_icon {
  padding-left: 2%;
  width: 5%;
}
@media (max-width: 430px) {
  .faq_content .accordion-answer p .faq_icon {
    width: 11%;
    padding-right: 2%;
  }
}
.faq_content .accordion-answer p .faq_a {
  width: 90%;
}
@media (max-width: 430px) {
  .faq_content .accordion-answer p .faq_a {
    width: 80%;
    line-height: normal;
  }
}

.contact {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  background-color: var(--color-accent);
  z-index: 1;
  padding-top: 1.5625vw;
}
@media (max-width: 430px) {
  .contact {
    padding-top: 41.6666666667vw;
  }
}
.contact::before {
  content: "";
  position: absolute;
  top: -15%;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("../images/contact_bg_top.svg");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: contain;
  z-index: -1;
  pointer-events: none;
}
@media (max-width: 430px) {
  .contact::before {
    top: -60px;
    z-index: -1;
    width: 310%;
  }
}
.contact::after {
  content: "";
  position: absolute;
  bottom: -99%;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("../images/contact_bg_top.svg");
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: contain;
  transform: scaleY(-1);
  z-index: -1;
  pointer-events: none;
}
.contact .treat_1 {
  position: relative;
  min-width: 52.0833333333vw;
}
@media (max-width: 430px) {
  .contact .treat_1 {
    width: 100%;
  }
}
.contact .treat_1 .contact_1 {
  position: absolute;
  top: -45rem;
  min-width: 52.0833333333vw;
}
@media (max-width: 430px) {
  .contact .treat_1 .contact_1 {
    top: -28rem;
  }
}
.contact h3 {
  color: var(--color-black);
}
.contact h3 span {
  color: var(--color-black);
}
.contact_content_bnr {
  display: flex;
  gap: 20px;
  margin-top: 2.6041666667vw;
}
.contact_content_bnr p {
  text-align: center;
  margin-top: -10px;
  color: var(--color-black);
}
@media (max-width: 430px) {
  .contact_content_bnr {
    flex-direction: column;
    align-items: center;
  }
}
.contact_content_bnr img {
  height: 96px;
}
.contact_content_bnr + p {
  text-align: center;
  color: var(--color-black);
  margin-top: 2.6041666667vw;
}
@media (max-width: 430px) {
  .contact_content_bnr + p {
    font-size: 20px;
    font-size: 2rem;
  }
}
.contact_content__area {
  text-align: center;
}
.contact_content__area a {
  display: inline-block;
  margin-top: 15px;
}
.contact .reaf_5 {
  position: absolute;
  left: 0;
  top: -120px;
  width: 23%;
}
@media (max-width: 430px) {
  .contact .reaf_5 {
    position: absolute;
    left: 0;
    top: -120px;
    width: 45%;
  }
}
.contact .reaf_6 {
  position: absolute;
  right: 0;
  width: 15%;
  bottom: -40%;
}
@media (max-width: 430px) {
  .contact .reaf_6 {
    position: absolute;
    right: 0;
    width: 45%;
    bottom: -38%;
  }
}
.contact_form__txt {
  width: 100%;
  text-align: center;
  margin-top: 30px;
}
.contact_form__txt_big {
  font-size: 120%;
  text-align: center;
  margin-top: 20px;
}

.access {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 20.8333333333vw 0vw 5.2083333333vw 0vw;
  z-index: 1;
}
@media (max-width: 430px) {
  .access {
    padding-top: 26.0416666667vw;
  }
  .access h3.heading--bg {
    background-image: none;
  }
}
.access_wrapper {
  display: flex;
  flex-direction: row;
  gap: 6rem;
  width: 90%;
  padding-top: 4.1666666667vw;
  margin: 0vw 0vw 5.2083333333vw 0vw;
}
@media (max-width: 430px) {
  .access_wrapper {
    padding: 23.4375vw 0vw 1.0416666667vw 0vw;
    flex-direction: column;
  }
}
.access_content {
  display: flex;
  flex-direction: column;
  width: 100%;
}
@media (max-width: 430px) {
  .access_content {
    flex-direction: column;
    align-items: baseline;
  }
}
.access_content h4 {
  font-family: "Kaisei Tokumin", serif;
  font-size: 28px;
  font-size: 2.8rem;
  border-bottom: 1px var(--color-accent) solid;
  padding: 0vw 0vw 1.0416666667vw 0vw;
  margin: 0vw 0vw 1.0416666667vw 0vw;
}
.access_content h4 + p span {
  display: block;
}
@media (max-width: 430px) {
  .access_content h4 {
    width: 100%;
    padding: 0vw 0vw 4.1666666667vw 0vw;
    margin-bottom: 4.1666666667vw;
  }
}
.access_content .tel {
  color: var(--color-accent);
  display: flex;
  align-items: center;
  gap: 20px;
}
.access_content .tel span {
  font-family: "Kaisei Tokumin", serif;
  font-size: 36px;
  font-size: 3.6rem;
}
@media (max-width: 978px) {
  .access_content .tel {
    display: flex;
    gap: 0;
    flex-direction: column;
    align-items: flex-start;
  }
}
.access .map {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  height: 50%;
}
@media (max-width: 430px) {
  .access .map {
    height: 100vw;
  }
}
.access .map iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

footer {
  padding-bottom: 15.625vw;
}
footer .footer_container {
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 5rem;
}
@media (max-width: 430px) {
  footer .footer_container {
    flex-direction: column;
    padding-bottom: 52.0833333333vw;
  }
}
footer .footer_container .footer_info {
  font-family: "Kaisei Tokumin", serif;
  gap: 30px;
  display: flex;
  flex-direction: column;
  align-content: center;
  justify-content: center;
  align-items: center;
}
footer .footer_container .footer_info .footer_text {
  font-size: 22px;
  font-size: 2.2rem;
  text-align: center;
  line-height: normal;
}
footer .footer_container .footer_info .sns_icon {
  display: flex;
  gap: 30px;
}
footer .footer_bg {
  width: 100%;
  z-index: -1;
  position: absolute;
  bottom: 0;
}
footer .footer_bg img {
  width: inherit;
}
footer .copyright {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
}

.hamburger,
.globalMenuSp {
  display: none;
}
@media (max-width: 430px) {
  .hamburger,
  .globalMenuSp {
    display: block;
  }
}

.page_top {
  background-image: url("../images/pagetop.png");
  width: 161px;
  height: 195px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: normal;
  padding-left: 19px;
  background-repeat: no-repeat;
  position: absolute;
  right: 5%;
  bottom: 0;
}
@media (max-width: 430px) {
  .page_top {
    top: -80px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
  }
}
@media (max-width: 978px) {
  .page_top {
    right: 0%;
    bottom: -120px;
  }
}

.scroll {
  position: absolute;
  right: 2%;
  bottom: 22%;
}
@media (max-width: 430px) {
  .scroll {
    display: none;
  }
}

.main_view_txt_right img {
  display: none;
}

.snow-monkey-form {
  margin-top: 45px;
}
.snow-monkey-form .smf-item {
  display: flex;
  margin-bottom: 45px;
  align-items: center;
}
.snow-monkey-form .smf-item .smf-item__col--label {
  flex: 0 0 265px;
  max-width: 100%;
  padding: 0 15px;
  display: flex;
  font-size: 18px;
  font-size: 1.8rem;
  align-items: center;
  justify-content: space-between;
}
.snow-monkey-form .smf-item .smf-item__col--controls {
  flex: 0 0 calc(100% - 265px);
  max-width: 100%;
  padding: 0 15px 0 70px;
}
.snow-monkey-form button[data-action=back] {
  background-color: #ccc;
  border: none;
  color: #333;
  font-weight: bold;
  padding: 15px;
  text-align: center;
  cursor: pointer;
  font-size: 16px;
  font-size: 1.6rem;
}
.snow-monkey-form input:not([type=radio]),
.snow-monkey-form textarea {
  border: none !important;
  width: 100% !important;
  padding: 30px !important;
  background: #f4f4f4 !important;
  border-radius: 0 !important;
  font-size: 18px;
  font-size: 1.8rem;
}
.snow-monkey-form input:not([type=radio])::-moz-placeholder, .snow-monkey-form textarea::-moz-placeholder {
  color: #cbcbcc;
}
.snow-monkey-form input:not([type=radio])::placeholder,
.snow-monkey-form textarea::placeholder {
  color: #cbcbcc;
}
.snow-monkey-form input:not([type=radio]):-moz-read-only, .snow-monkey-form textarea:-moz-read-only {
  border: none;
  font-weight: bold;
}
.snow-monkey-form input:not([type=radio]):read-only,
.snow-monkey-form textarea:read-only {
  border: none;
  font-weight: bold;
}
.snow-monkey-form textarea {
  height: 200px;
}
.snow-monkey-form .smf-label {
  margin-bottom: 4px;
  display: inline-block;
  position: relative;
}
.snow-monkey-form .smf-item__description {
  background-color: var(--color-accent);
  color: var(--color-main);
  font-size: 14px;
  padding: 1px 6px;
  border-radius: 3px;
  display: inline-block;
  margin-top: 0 !important;
  margin-left: 15px;
}
.snow-monkey-form .smf-form-control {
  background-color: #f5f7f7;
  border: none;
  border-radius: 8px;
  padding: 12px;
  width: 100%;
}
.snow-monkey-form .smf-action {
  padding: 40px 0 250px;
  text-align: center;
}
.snow-monkey-form .smf-action .smf-button-control {
  margin: 0 auto;
}
.snow-monkey-form button[type=submit] {
  background: #EE7100;
  color: var(--color-white);
  padding: 15px 45px;
  border: none;
  border-radius: 999px;
  font-weight: bold;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  justify-content: center;
  font-size: 22px;
  font-size: 2.2rem;
  letter-spacing: 0.1em;
  font-family: "Zen Kaku Gothic New", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", sans-serif;
  min-width: 300px;
}
.snow-monkey-form button[type=submit]::before {
  content: "";
  background: url("../images/icon_submit.svg") no-repeat;
  background-size: 100%;
  display: block;
  width: 28px;
  height: 20px;
}
.snow-monkey-form button[data-action=back] {
  background-color: #CCC;
  border: none;
  color: #333;
  font-weight: bold;
  padding: 15px;
  text-align: center;
  font-size: 16px;
  font-size: 1.6rem;
  cursor: pointer;
}
.snow-monkey-form .smf-button-control__control[data-action=back] {
  background: transparent !important;
  color: #333 !important;
  text-decoration: underline !important;
}
.snow-monkey-form .smf-button-control__control[data-action=back]::before {
  content: none;
}
.snow-monkey-form .smf-select-control {
  position: relative;
  display: block;
  width: 100%;
  font-size: 18px;
  font-size: 1.8rem;
}
.snow-monkey-form .smf-select-control__control {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  width: 100%;
  padding: 15px !important;
  border: none !important;
  border-radius: 10px !important;
  background-color: #f5f5f5 !important;
  color: #000;
  box-sizing: border-box;
  font-size: 18px;
  font-size: 1.8rem;
}
.snow-monkey-form .smf-select-control__toggle {
  background-color: transparent !important;
  left: auto !important;
  right: 16px !important;
  top: 50% !important;
  bottom: auto !important;
  width: 25px !important;
  height: 25px !important;
  transform: translateY(-50%) !important;
  background-image: url("data:image/svg+xml,%3Csvg fill='%23001641' height='12' viewBox='0 0 24 24' width='12' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;
  pointer-events: none !important;
  z-index: 1 !important;
}
.snow-monkey-form .smf-select-control__toggle::before {
  display: none !important;
}
.snow-monkey-form input[type=radio] {
  position: absolute !important;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  margin-top: 1px !important;
}
.snow-monkey-form .smf-radio-button-control__label {
  padding-left: 25px;
}

/* 電話番号3分割（ラッパー内） */
.tel-wrapper > .wp-block-group__inner-container {
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
}
.tel-wrapper > .wp-block-group__inner-container .tel-part {
  min-width: 10px;
  width: 170px !important;
}

form[data-screen=confirm] .smf-action {
  display: flex;
  flex-wrap: wrap;
  margin-top: 90px;
}
form[data-screen=confirm] .smf-action .smf-button-control {
  order: 1;
  flex: 0 0 40%;
  max-width: 100%;
  margin: 0 auto !important;
}
form[data-screen=confirm] .smf-action .smf-button-control:nth-of-type(2) {
  flex: 0 0 61%;
  max-width: 100%;
  margin: 0 auto 15px !important;
  order: 0;
}

.smf-complete-content h3 {
  font-size: 22px;
  font-size: 2.2rem;
}

@media print, screen and (max-width: 768px) {
  .snow-monkey-form {
    margin-top: 45px;
  }
  .snow-monkey-form input:not([type=radio]),
  .snow-monkey-form textarea {
    padding: 15px !important;
  }
  .snow-monkey-form .smf-item {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 45px;
    align-items: center;
  }
  .snow-monkey-form .smf-item .smf-item__col--label {
    flex: 0 0 100%;
    max-width: 100%;
    padding: 0 15px;
    display: flex;
    font-size: 18px;
    font-size: 1.8rem;
    align-items: center;
    justify-content: flex-start;
    font-weight: 500;
  }
  /* 電話番号3分割（ラッパー内） */
}
@media print and (max-width: 430px), screen and (max-width: 768px) and (max-width: 430px) {
  .snow-monkey-form .smf-item .smf-item__col--label {
    margin-bottom: 10px;
  }
}
@media print, screen and (max-width: 768px) {
  .snow-monkey-form .smf-item .smf-item__col--controls {
    flex: 0 0 100%;
    max-width: 100%;
    padding: 0 15px 0 15px;
  }
}
@media print and (max-width: 430px), screen and (max-width: 768px) and (max-width: 430px) {
  .snow-monkey-form .smf-item .smf-item__col--controls {
    max-width: 100%;
  }
}
@media print, screen and (max-width: 768px) {
  .tel-wrapper > .wp-block-group__inner-container {
    display: flex;
    gap: 12px;
    flex-wrap: nowrap;
  }
  .tel-wrapper > .wp-block-group__inner-container .tel-part {
    flex: 0 0 33.333%;
    min-width: 10px;
    width: 100% !important;
  }
  .smf-action {
    padding: 45px 0 150px !important;
    text-align: center;
  }
  .smf-action .smf-button-control {
    margin: 0 auto;
  }
}
[data-name=tel1],
[data-name=tel2] {
  position: relative;
}
[data-name=tel1]::after,
[data-name=tel2]::after {
  content: "-";
  position: absolute;
  right: -15px;
  top: 50%;
  transform: translateY(-50%);
}

.contact_form {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}

.form_tel .smf-item__controls {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 3rem;
}
@media (max-width: 430px) {
  .form_tel .smf-item__controls {
    gap: 1rem;
  }
}/*# sourceMappingURL=common.css.map */