@charset "utf-8";

/*     defolt_css     */
body {
  font-family: 'Noto Sans JP', "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 14px;
  line-height: 1.7;
  padding: 0;
  color: #535353;
}

/*  reset css   */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

a.gnav:hover {
    opacity: 1;
}

/*========= 背景動画設定のCSS ===============*/

/*header設定*/
#header {
    position: relative;
    height: auto;
}

.mv_wrap {
    position: relative;
}

.mv_txt {
    position: absolute;
    width: 50%;
    top: 55%;
    transform: translate(0, -50%);
}

.mv_txt h1 {
    font-size: 3.5vw;
    margin-bottom: 1vw;
    color: #fcfcfc;
    letter-spacing: 2px;
    font-family: 'Zen Old Mincho', serif;
    font-weight: 500;
}

.mv_txt p {
    color: #fcfcfc;
    font-weight: 900;
    letter-spacing: 2px;
    font-size: 2.6vw;
    font-style: oblique;
    margin-bottom: 0.8vw;
}

#video-area{
    z-index: -1;/*最背面に設定*/
    top: 0;
    right:0;
    left:0;
    bottom:0;
    overflow: hidden;
}



/*========= レイアウトのためのCSS ===============*/

#container {
    padding: 0;
    text-align: center;
    /*background: url(../img/back.png);*/
}

.wht_bg {
    background: #fff;
}

.header_logo {
    margin: 0 0 0 48px;
}

.sec1_btn_wrap {
    padding: 25px 55px 0 0;
}

.pc_nav li a:hover > .gf {
    color: #3aabd6;
    opacity: 1;
}

.pc_nav li a .gf:hover {
    color: #3aabd6;
    opacity: 1;
}

.pc_nav li.current-menu-ancestor > a .gf,
.pc_nav li.current-menu-item > a .gf,
.pc_nav li.current-menu-parent > a .gf,
.pc_nav li.current-post-ancestor > a .gf,
.pc_nav li.current_page_ancestor > a .gf,
.pc_nav li.current_page_parent > a .gf,
.pc_nav li > a:hover:after {
color: #3AABD6;
}

a:hover {
    opacity: .7;
}

.sec16 .flex_in a:hover {
  opacity: 1;
}

a.bor:hover {
    text-decoration: underline;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

/*  reset css   */
body {
  margin: 0 !important;
}

body {
    font-family: 'Noto Sans JP', "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-size: 16px;
    line-height: 1.7;
    padding: 0;
    color: #000;
    word-break: break-word;
}
* {
  margin: 0;
  padding: 0;
}

a {
  text-decoration: none;
  transition: all .3s;
  display: block;
  color: #000;
}

p, li {
    line-height: 2;
    font-size: 1.176vw;
    color: #fcfcfc;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Noto Sans JP', "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  letter-spacing: 1px;
}

/*画像の最大幅を画面のサイズの最大幅に設定*/
img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
}

footer {
  position: relative;
}

ul {
  list-style: none;
  padding: 0;
  padding-inline-start: 0px;
  width: 100%;
}

button {
  display: inline-block;
  position: relative;
  background: none;
  border: none;
  color: #fff;
  font-size: 18px;
  cursor: pointer;
  margin: 20px 30px;
  background: rgba(0, 0, 0, 0.09);
}

input, select, textarea {
  font-family: ryo-gothic-plusn, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #212121;
  border: solid 1px #E0E0E0;
  background: #FAFAFA;
}

.pc_nav {
    margin-right: 50px;
}

ul#menu-main-menu {
    padding: 0;
    padding-inline-start: 0px;
    float: right;
    display: inline-block;
    width: auto;
    margin-top: 60px;
    border-top: solid 1px #fff;
}

a.btn_a {
    max-width: 325px;
    padding: 10px 0;
    color: #707070;
    border: solid 3px;
}

a.btn_b {
    max-width: 325px;
    padding: 10px 0;
    color: #232839;
    border: solid 3px;
    margin-left: auto;
}

span.wpcf7-spinner {
    display: block;
}

th, td {
    padding: 20px 0;
    vertical-align: top;
    text-align: left;
    position: relative;
}

/* iOSでのデフォルトスタイルをリセット */
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}

input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}

input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}

.center {
  text-align: center;
}

/* FAQ */

.faq_wrap {
    margin-top: 20px;
    text-align: left;
}

.cp_qa .cp_actab {
    position: relative;
    overflow: hidden;
    width: 100%;
    margin: 0 0 30px 0;
}
.cp_qa .cp_actab {
  position: relative;
  overflow: hidden;
  width: 100%;
  margin: 0 0 20px 0;
}
.cp_qa .cp_actab:before {
  content: "";
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #9e9e9e, #9e9e9e 1px, transparent 1px, transparent 2px);
  background-size: 3px 1px;
  background-repeat: repeat-x;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
}
.cp_qa .cp_actab input {
	position: absolute;
	opacity: 0;
}
/* 質問 */
.cp_qa .cp_actab label {
  color: var(--System-Gray-900, #212121);
  font-family: "Noto Sans JP";
  font-size: 18px;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.5px;
  position: relative;
  display: block;
  margin: 0 0 0 0;
  padding: 1em 3em 1em 3.5em;
  cursor: pointer;
}
.cp_qa .cp_actab label::before {
    width: 36px;
    height: 36px;
    content: '';
    background: url(../img/common/qa3.svg);
    background-size: 100%;
    position: absolute;
    left: 20px;
    top: 50%;
    -webkit-transform: translate(0, -50%);
    transform: translate(0,-50%);
}
/* --質問の＋アイコン */
.cp_qa .cp_actab label::after {
    font-size: 1.7em;
    font-weight: bold;
    line-height: 2em;
    position: absolute;
    top: 50%;
    right: 20px;
    content: '';
    background: url(../img/common/qa1.svg);
    background-size: contain;
    background-repeat: no-repeat;
    display: inline-block;
    width: 16px;
    height: 16px;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
}
/* 答え */
.cp_qa .cp_actab .cp_actab-content {
	position: relative;
	overflow: hidden;
	max-height: 0;
	padding: 0 0 0 2.5em;
	-webkit-transition: max-height 0.2s;
  transition: max-height 0.2s;
}
.cp_qa .cp_actab .cp_actab-content::before {
  width: 17px;
  height: 27px;
  content: '';
  background: url(../img/common/qa4.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  position: absolute;
  left: 28px;
  top: 36px;
  -webkit-transform: translate(0, -50%);
  transform: translate(0,-50%);
}

.cp_qa .cp_actab .cp_actab-content p {
  margin: 1em 1em 1em 1.6em;
  color: var(--System-Gray-500, #616161);
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 30px;
  letter-spacing: 1px;
}

p.qa_anc {
    color: #343434;
}
/* 質問を開いた時の仕様 */
/* --答えの高さ */
.cp_qa .cp_actab input:checked ~ .cp_actab-content {
	max-height: none;
}
/* 質問をクリックした時の+の動き */
.cp_qa .cp_actab input[type=checkbox]:checked + label::after {
  background: url(../img/common/qa2.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
	-webkit-transform-origin: 50% 50%;
	transform-origin: 50% 50%;
}

a.link_blue {
    color: #00A7FF;
}

/* FAQ */

input.wpcf7-form-control.has-spinner.wpcf7-submit {
    width: auto;
    padding: 10px 40px;
    margin: auto;
    text-align: center;
    background: #9e9e9e;
    color: #fff;
}

span.wpcf7-list-item {
  padding-right: 15px;
  margin: 0 0 0 0;
}

table.form_tbl.rec td input[type="text"], 
table.form_tbl.rec td input[type="tel"], 
table.form_tbl.rec td input[type="email"] {
  width: 94%;
  padding: 8px 15px;
  font-size: 16px;
}

table.form_tbl.rec td input[type="file"] {
  cursor: pointer;
  background: none;
  border: none;
}

table.form_tbl td.birth {
  display: flex;
  flex-direction: row;

  select {
    width: 65px;
    padding: 5px 5.5px 5px 5px;
    margin-right: 0;
  }
  
  div {
    margin-right: 8px;
  }
}

td.birth p {
  display: flex;
  width: auto;
}

td.birth p label {
  width: 100%;
}

table.form_tbl.rec td textarea {
  width: 94%;
  font-size: 16px;
  padding: 15px;
}

.hidden_box {
  width: 50vw;
  height: 25vw;
  overflow: scroll;
  border: solid 1px;
  margin: 0 auto 25px;
  padding: 40px 70px 40px 40px;
  overflow-x: hidden;
  overflow-y: auto;
  -ms-overflow-style: none;
  scrollbar-width: none;
  background: #FAFAFA;
  border: solid 1px #e0e0e0;
}

.hidden_box h4 {
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 30px;
  letter-spacing: 1px;
  color: #757575;
}

.hidden_box p {
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 30px;
  letter-spacing: 1px;
  color: #757575;
}

.hidden_box a {
  font-family: "Noto Sans JP";
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 30px;
  letter-spacing: 1px;
  color: #757575;
}

div#wpcf7-f210-o1 {
  color: #000;
}

.hidden_box::-webkit-scrollbar {
  width: 5px;
}

.hidden_box::-webkit-scrollbar-thumb {
  background: #404040;
  border-radius: 3px;
}

.hidden_box::-webkit-scrollbar-track {
  background: #fff;
  height: 98%;
  margin: 1%;
}

.submit_btn {
    text-align: center;
    width: 300px;
    margin: 0 auto;
}

span.haveto {
    color: #fff;
    background: #E00A17;
    font-size: 12px;
    border-radius: 2px;
    margin-left: 5px;
    padding: 4px 12px 4px;
}

span.wpcf7-not-valid-tip {
  position: relative;
  color: red;
  left: 0;
  padding: 1% 0 0;
}

div.screen-reader-response {
  display: none;
}

.wpcf7-response-output {
  text-align: center;
  color: red;
  margin-top: 35px;
}

#wrapper {
  overflow: hidden;
}

.top1 img, .top2 img, .top3 img {
  overflow: hidden;
  object-fit: cover;
  height: 100%;
}

.wpcf7-form-control-wrap {
    position: relative;
}

.center span.wpcf7-form-control-wrap {
    display: flex;
    justify-content: center;
}

.days {
    width: 45%;
}

.hour {
    width: 45%;
}

select {
  align-items: center;
  display: -webkit-inline-flex;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  padding: 12px 5.5px 12px 15px;
  width: 100px;
  margin: 0 10px 0 0;
  font-size: 16px;
}

span.space_span {
  margin-right: 2%;
}

td.name_flex p {
  display: flex;
}

table.form_tbl.rec td.name_flex input[type="text"] {
  margin: 0 10% 0 0;
  width: 73%;
}

input {
    width: 100%;
    max-width: 780px;
    padding: 4px 0;
}

td input {
    padding: 4px 0 4px 5px;
}

.hour select {
    max-width: 344.47px;
}

.days input {
    max-width: 334.47px;
    padding-left: 10px;
}

.w100_form {
    margin: 5% auto;
    width: 100%;
}

table.form_tbl {
  width: 48.529411764705884vw;
  margin: auto;
  border-top: solid 1px #9e9e9e;
}

table.form_tbl td {
  padding: 30px 0 30px;
  text-align: left;
  width: 70%;
}

table.form_tbl th {
  padding: 30px 0 30px;
  width: 30%;
}

table.form_tbl th:after,
table.form_tbl td:after {
  content: "";
  position: absolute;
  display: none;
  width: 100%;
  height: 0;
  bottom: 0;
  left: 0;
  background: none;
}

h3.formttl.center,
table.form_tbl th {
    text-align: left;
    font-weight: 500;
}

h3.personal_info {
  margin: 60px auto 8px;
  text-align: center;
  font-size: 20px;
  font-style: normal;
  font-weight: 500;
  line-height: 32px;
  letter-spacing: 0.5px;
}

/*::::::: ERROR MESSAGE :::::::*/


td p span.wpcf7-form-control-wrap span.wpcf7-not-valid-tip {
    width: auto;
    display: block;
    bottom: 0;
}

.year span.wpcf7-form-control-wrap {
  width: 70px;
}

.month span.wpcf7-form-control-wrap {
  width: 70px;
}

.days span.wpcf7-form-control-wrap {
  width: 70px;
}

.year p span.wpcf7-form-control-wrap span.wpcf7-not-valid-tip {
  white-space: nowrap;
}

.month p span.wpcf7-form-control-wrap span.wpcf7-not-valid-tip {
  display: none;
}

.days p span.wpcf7-form-control-wrap span.wpcf7-not-valid-tip {
  display: none;
}

/*::::::: ERROR MESSAGE :::::::*/

.reserved {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-bottom: 30px;
}

p.rec_form_p {
  width: 590px;
  margin: 0 auto 25px;
}

.wpcf7-radio {
    width: 100%;
    display: flex;
}

.wpcf7-radio label {
    display: flex;
    align-items: center;
}

input[type="radio"] {
    display: inline-block;
    width: 25px;
}

textarea {
    width: 98%;
    height: 150px;
    padding: 1%;
}

p.personal_info {
    font-weight: 500;
    text-align: center;
    margin: 25px 0 5px;
}

p.contact_info {
    max-width: 680px;
    margin: 0 auto 30px;
}

.acceptance-780 {
    justify-content: center;
}

.wpcf7-acceptance label {
  display: flex;
  align-items: center;
  justify-content: space-around;
  text-align: left;
}

input[type="checkbox"] {
  width: 22px;
  height: 22px;
  margin-right: 5px;
}

.wpcf7-acceptance {
    margin-bottom: 40px;
}

.submit_btn input {
    background: none;
}

/*  ラジオボタン  */

input[type="radio"] {
  opacity: 0;
  visibility: hidden;
  position: absolute;
}

.wpcf7-list-item.first {
  margin-left: 0;
}

span.wpcf7-list-item-label {
  position: relative;
  display: flex;
  align-items: center;
  cursor: pointer;
}

span.wpcf7-list-item-label::before {
  display: block;
  content: "";
  border-radius: 50%;
  border: 1px solid #212121;
  width: 22px;
  height: 22px;
  margin-right: 10px;
}

span.wpcf7-list-item-label::after {
  display: block;
  position: absolute;
  content: "";
  border-radius: 50%;
  width: 13px;
  height: 13px;
  background-color: #212121;
  left: 5.5px;
  top: 50%;
  transform: translateY(-50%);
  display: none;
}

input[type="radio"]:checked + span.wpcf7-list-item-label::after {
  display: block;
}

.center span.wpcf7-form-control-wrap span.wpcf7-list-item-label::before {
  display: none;
}

/*  ラジオボタン  */

.con_p_wrap {
    text-align: center;
}

span.sns {
    margin-bottom: 1.4vw;
}

footer {
  background: url(../img/common/footer_bg.jpg);
  background-size: cover;
}

footer .flex {
  flex-wrap: nowrap;
}

ul.flex_menu {
  margin: 0 20px;
  width: auto;
}

ul.flex_menu li a {
  color: #fff;
  margin: 1.029vw 0;
  font-size: 1.176vw;
  text-align: left;
}

.footer_logo {
  width: 15.735vw;
}

footer .d-pc-flex {
  width: 88.235vw;
  margin: auto;
  padding: 1.471vw;
  justify-content: space-between;
}

p.copy {
  font-family: Inter;
  font-size: 14px;
  color: #fff;
}

.cprt {
  width: 95%;
  padding: 30px 0 20px;
  margin: auto;
  display: flex;
  justify-content: space-between;
  border-top: solid 1px #757575;
}

.footer_menu_policy {
  display: flex;
}

.footer_menu_policy a {
  color: #bbb;
  font-family: "Noto Sans JP";
  font-size: 1.029vw;
  font-style: normal;
  font-weight: 400;
  line-height: 1.912vw;
  margin-left: 1.471vw;
  letter-spacing: 0.074vw;
}

.flex {
  display: flex;
  align-items: flex-start;
}

.sec15, .sec16, .sec17 {
  padding: 20px 0;
}

.sec15 {
  background: url(../img/top/webp/sec15_bg.webp);
  background-size: cover;
}

.sec17 {
  background: url(../img/common/webp/cta_bg.webp);
  background-size: cover;
  position: relative;
  overflow: hidden;
}

.sec17:before {
  content: "";
  position: absolute;
  top: -5.074vw;
  left: 6vw;
  width: 16.838vw;
  height: 28.971vw;
  background: url(../img/common/webp/cta_l_logo.webp);
  background-size: cover;
  opacity: .1;
}

.sec17:after {
  content: "";
  position: absolute;
  top: 6vw;
  right: 1vw;
  width: 23.75vw;
  height: 6.838vw;
  background: url(../img/common/webp/cta_r_logo.webp);
  background-size: cover;
  opacity: .1;
}

.w860 {
  width:63.235vw;
  margin: auto;
}

.sec15 .d-pc-flex {
  justify-content: space-evenly;
}

.sec16 {
  padding: 0;
}

.sec16 .flex_in {
  width: 50%;
}


/*---------------  ここから NEW CSS  ---------------*/
/*---------------  ここから NEW CSS  ---------------*/

@media screen and (max-width: 767px) {

  footer {
    background: var(--bg-blk-bg, linear-gradient(246deg, #212121 27.88%, #3D3D3D 62.04%, #8B8A8A 99.25%));
  }

  p {
    font-size: 4.145vw;
  }

  li {
    line-height: 2;
    font-size: 4.145vw;
    color: #fcfcfc;
  }

  #breadcrumb ul li {
    color: #fff;
    padding-left: 4.145vw;
    position: relative;
  }

  #breadcrumb ul li:before {
    content: ">";
    position: absolute;
    left: 5px;
    font-size: 4.145vw;
  }

  footer .flex {
    flex-direction: column;
    text-align: left;
  }

  ul.flex_menu {
    margin: 0 0;
    width: auto;
  }

  ul.flex_menu li a {
    color: #fff;
    margin: 14px 0 0;
    font-size: 16px;
  }

  footer .d-pc-flex {
    margin: 0 25px;
  }

  .cprt {
    width: 86%;
    padding: 46px 7% 120px;
    flex-direction: column;
  }

  .cp_qa .cp_actab label {
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    letter-spacing: 0.5px;
    position: relative;
    display: block;
    margin: 0 0 0 0;
    padding: 1em 2em 1em 2.8em;
    cursor: pointer;
    text-indent: 0;
  }

  .cp_qa .cp_actab .cp_actab-content p {
    margin: 1em 1em 1em 0.3em;
  }

  .cp_qa .cp_actab label::before {
    width: 30px;
    height: 30px;
    left: 5px;
    top: 50%;
  }

  .cp_qa .cp_actab .cp_actab-content::before {
    width: 17px;
    height: 27px;
    content: '';
    background: url(../img/common/qa4.svg);
    background-size: 100%;
    background-repeat: no-repeat;
    position: absolute;
    left: 10px;
    top: 36px;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
  }

  .cp_qa .cp_actab label::after {
    font-size: 1.7em;
    font-weight: bold;
    line-height: 2em;
    position: absolute;
    top: 50%;
    right: 5px;
  }

  .sec8.d-pc-flex {
    .facility_txt p {
        font-family: "Noto Sans JP";
        font-size: 14px;
        font-style: normal;
        font-weight: 400;
        line-height: 26px; /* 185.714% */
        letter-spacing: 1px;
        margin: 20px 0 30px;
    }
    .main_slide_wrap {
        margin-bottom: 20px;
    }
    .cp_qa .cp_actab label {
        font-size: 16px;
        font-style: normal;
        font-weight: 700;
        line-height: 22px;
        letter-spacing: 0.5px;
    }
  }
  .cp_qa .cp_actab .cp_actab-content {
    position: relative;
    overflow: hidden;
    max-height: 0;
    padding: 0 0 0 9.5vw;
    -webkit-transition: max-height 0.2s;
    transition: max-height 0.2s;
  }
  .cprt {
    padding: 46px 0 120px;
    margin: auto;
    display: flex;
    justify-content: space-between;
    border-top: solid 1px #757575;
  }

  .footer_menu_policy {
    flex-direction: column;
  }

  .footer_menu_policy a {
    color: #bbb;
    font-family: "Noto Sans JP";
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    height: 20px;
    margin: 0 0 10px;
  }

  .wpcf7-list-item {
    margin: 0 0 0 0;
  }

  span.wpcf7-list-item-label {
    position: relative;
    display: flex;
    align-items: center;
    cursor: pointer;
  }

  .wpcf7-acceptance span.wpcf7-list-item-label {
    width: 83%;
  }

  .entry_box .center_ttl p {
    width: 90%;
    text-align: left;
  }

  .sec17:before {
    display: none;
  }
  
  .sec17:after {
    display: none;
  }
}