@charset "UTF-8";

[data-page="contact"] .footbaner{
  display: none;
}

/* FORM RESET ====================================== */
button, [type="button"], [type="reset"], [type="submit"]{cursor:pointer;}
button, input, optgroup, select, textarea{
  font:inherit;
  font-size: inherit;
  box-sizing: border-box;
}
button,select,input,textarea{
  color:inherit;
  border-style:none;
  background-color:transparent;
  padding: 0;
  margin: 0;
  text-transform:none;
}
button, html [type="button"], [type="reset"], [type="submit"]{
  border:none;
  border-radius:0;
  -webkit-appearance:button;
}
optgroup{
  font-weight:bold;
}
button{
  overflow:visible;
}
textarea{
  overflow:auto;resize:vertical;
}
input:not(:placeholder-shown){
  background-color: rgba(255, 255, 255, .8);
}
textarea:not(:placeholder-shown){
  background-color: rgba(255, 255, 255, .8);
}
input:-webkit-autofill {
  transition: background-color 10000s ease-in-out 0s;
}


/* FORM ====================================== */

/* .contact_form{
  padding: 2em 0 0;
  transform: translateY(1em);
  transition: transform .5s , opacity .5s;
  height: 0;
} */
/* .select_form{
  position: absolute;
  top: 0;
  visibility: hidden;
  opacity: 0;
}
#tab_contact:checked ~ #contact_form, 
#tab_reserve:checked ~ #reserve_form{
  position: relative;
  visibility: visible;
  opacity: 1;
  transform: translateY(0);
  height: inherit;
} */

.select_tab_input{
  display: none;
}
.select_tab_wrap{
  display: flex;
  justify-content: space-between;
  padding: .5em 0;
}
.select_tab .txt{
  display: inline-block;
  width: fit-content;
}
.select_tab .txt::before{
  content: "";
  display: inline-block;
  width: .7em;
  height: .7em;
  margin-right: .3em;
  margin-bottom: .05em;
  background-color: var(--c-grey-l);
  border-radius: 50%;
}
.select_tab{
  width: 49%;
  font-size: 1.2em;
  font-weight: 500;
  padding: 1.3em 0;
  text-align: center;
  color: var(--c-grey-d2);
  border: 1px solid var(--c-grey-l);
}
#tab_reserve:checked ~ .select_tab_wrap .select_tab[for="tab_reserve"],
#tab_contact:checked ~ .select_tab_wrap .select_tab[for="tab_contact"]{
  color: #fff;
  border-color: var(--c-black);
  background-color: var(--c-black);
}
#tab_reserve:checked ~ .select_tab_wrap .select_tab[for="tab_reserve"] .txt::before,
#tab_contact:checked ~ .select_tab_wrap .select_tab[for="tab_contact"] .txt::before{
  background-color: var(--c-gold);
}


.form_wide {
  padding: 2em 2em 8em;
}
.dark.contact_page .footer{
  border-top: 1px solid #504b44;
}

.forms_main_desc {
  font-size: 1.25rem;
  padding: .5em 0 3em;
  line-height: 1.7;
}
.form-list{
  padding: 2em 0;
}
.form_line_box{
  padding: 1em 0;
}
.form-ttl,
input[type="radio"],
input[type="radio"] + label{
  font-size: 1.3em;
  font-weight: 500;
  padding: .8em 0;
}
input[type="radio"] + label{
  font-weight: 400;
  padding: .4em;
  margin-right: .5em;
}
input[type="radio"]:checked{
  font-weight: 500;
}
.req_lavel{
  display: inline-block;
  font-size: .7em;
  font-weight: 500;
  background-color: var(--c-gold);
  color: var(--c-white);
  letter-spacing: .05em;
  line-height: 1;
  padding: 0.15em 0.3em .2em;
  /* transform: scale(.95); */
  margin-left: .8em;
}

.form-body .input,
.form-body .select,
.form-body .textarea{
  width: 100%;
  font-size: 1.3em;
  padding: .9em .6em 1em;
  /* background-color: #fff; */
  border-bottom: 1px solid var(--c-grey-d2);
}

.recruit-box .form_line_box {
  padding: .5em 0;
}
.recruit-box .form-body .input,
.recruit-box .form-body .select,
.recruit-box .form-body .textarea{
  border: 1px solid var(--c-grey-d2);
}
.form-body .select{
  appearance: none;
  white-space: initial;
  border: 1px solid var(--c-grey-d2);
}
.select_box {
  position: relative;
}
.select_box::after {
  position: absolute;
  right: 1em;
  top: -.1em;
  bottom: 0;
  margin: auto;
  content: "";
  display: block;
  width: .5em;
  height: .5em;
  border-left: 2px solid;
  border-bottom: 2px solid;
  border-color: var(--c-grey-d);
  transform: rotateZ(-45deg);
  pointer-events: none;
}
.select-required:invalid {
  color: var(--c-grey-d);
  background-color: transparent;
}
.select-required {
  background-color: #fff;
}
.form-body input::placeholder,
.form-body textarea::placeholder{
  font-size: 1.2rem;
  color: #aaa;
}
.form-body input:focus,
.form-body textarea:focus,
.form-body input:not(:placeholder-shown),
.form-body textarea:not(:placeholder-shown){
  outline: none;
  background-color: rgba(255, 255, 255, .8);
}

.alert_mess,
.alert_mess_email{
  display: none;
  font-size: 1.2em;
  font-weight: 500;
  padding: .6em 0 0;
  color: var(--c-red);
}
.no_input + .alert_mess,
.false_email ~ .alert_mess_email{
  display: block;
}
input.no_input,
input.false_email,
textarea.no_input {
  /* background-color: #fff7fd ; */
  border-bottom: 1px solid var(--c-red) !important;
}

/* BUTTON */
.web_reserve_btn {
  width: 100%;
  display: block;
  font-size: 1.45rem;
  font-weight: 500;
  letter-spacing: .03em;
  padding: 1.3em 0;
  margin: 1.5em 0;
  text-align: center;
  border-radius: 0.1em;
  transition: opacity .5s;
}
.web_reserve_btn.withbg {
  background-color: var(--c-black);
  color: var(--c-white);
}
.web_reserve_btn:hover{
  opacity: .7;
}
.web_reserve_btn[disabled]{
  cursor:not-allowed;
  opacity: .3;
}

/* complete.html =========================*/
.desc_block{
  padding: 2em 0;
}
/* .comp_caution_block{
  padding: 1em 1.5em;
  border: 1px solid var(--c-grey-l);
} */

.comp_ttl{
  display: block;
  font-size: 1.7em;
  font-weight: 600;
}
.comp_desc {
  font-size: 1.2rem;
  padding: 1.8em 0;
  line-height: 1.8;
}

.caution-ttl{
  padding: .5em 0;
  /* text-align: center; */
}
.caution-desc{
  padding: 1em 0;
  line-height: 1.7;
}
@media (min-width: 769px) {
  .form_wide {
    padding: 2em 3em 12em;
    max-width: 54rem;
    margin: auto;
  }
  /* .caution-ttl{
    text-align: center;
  } */

}/* 769 end */


/* complete.html =========================*/
.desc_block{
  padding: 2em 0;
}
/* .comp_caution_block{
  padding: 1em 1.5em;
  border: 1px solid var(--c-grey-l);
} */

.comp_ttl{
  display: block;
  font-size: 1.7em;
  font-weight: 600;
}
.comp_desc {
  font-size: 1.2rem;
  padding: 1.8em 0;
  line-height: 1.8;
}

.caution-ttl{
  padding: .5em 0;
  /* text-align: center; */
}
.caution-desc{
  padding: 1em 0;
  line-height: 1.7;
}
@media (min-width: 769px) {
  .form_wide {
    padding: 2em 3em 12em;
    max-width: 54rem;
    margin: auto;
  }
  /* .caution-ttl{
    text-align: center;
  } */

}/* 769 end */


/* LOAD ANIMATION====================== */
.loader.loaded {
  display: flex;
  transition: opacity .25s linear;
  opacity: .8;
}

.loader {
  opacity: 0;
  position: fixed;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  z-index: 10001;
  margin: auto;
  box-sizing: border-box;
  display: none;
  flex: 0 1 auto;
  flex-direction: column;
  flex-grow: 1;
  flex-shrink: 0;
  flex-basis: 25%;
  max-width: 25%;
  height: 150px;
  align-items: center;
  justify-content: center; 
}

/**
  * Lines
  */
@-webkit-keyframes line-scale {
  0% {
    -webkit-transform: scaley(1);
            transform: scaley(1); }
  50% {
    -webkit-transform: scaley(0.4);
            transform: scaley(0.4); }
  100% {
    -webkit-transform: scaley(1);
            transform: scaley(1); } }
@keyframes line-scale {
  0% {
    -webkit-transform: scaley(1);
            transform: scaley(1); }
  50% {
    -webkit-transform: scaley(0.4);
            transform: scaley(0.4); }
  100% {
    -webkit-transform: scaley(1);
            transform: scaley(1); } }

.line-scale > div:nth-child(1) {
  -webkit-animation: line-scale 1s -0.4s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
          animation: line-scale 1s -0.4s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08); }

.line-scale > div:nth-child(2) {
  -webkit-animation: line-scale 1s -0.3s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
          animation: line-scale 1s -0.3s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08); }

.line-scale > div:nth-child(3) {
  -webkit-animation: line-scale 1s -0.2s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
          animation: line-scale 1s -0.2s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08); }

.line-scale > div:nth-child(4) {
  -webkit-animation: line-scale 1s -0.1s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
          animation: line-scale 1s -0.1s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08); }

.line-scale > div:nth-child(5) {
  -webkit-animation: line-scale 1s 0s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08);
          animation: line-scale 1s 0s infinite cubic-bezier(0.2, 0.68, 0.18, 1.08); }

.line-scale > div {
  background-color: #999;
  width: 4px;
  height: 35px;
  border-radius: 2px;
  margin: 2px;
  -webkit-animation-fill-mode: both;
          animation-fill-mode: both;
  display: inline-block;
}