@charset "UTF-8";



/*----------------------------------------------------
	RESET
----------------------------------------------------*/

/* 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;
}

/* form style */

dl dd input , 
dl dd textarea , 
dl dd select , 
dl dd label {
  padding: 3px 0;
  border: none;
  font-size: 14px;
}

dl dd input , 
dl dd textarea , 
dl dd select {
  border: 1px #d1cdcd solid;
}


input[type="checkbox"] {
    position: relative;
    z-index: 2;
}
input[type="checkbox"]:checked + label {
   /* background: #ff0000;*/
    border: none;
}

input[type="text"]:focus,
textarea:focus {
  outline: none;
}

input::-webkit-input-placeholder {
  font-family:"游ゴシック", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "游ゴシック", YuGothic, sans-serif;
}
input:-moz-placeholder {
  font-family:"游ゴシック", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "游ゴシック", YuGothic, sans-serif;
}
input::-moz-placeholder {
  font-family:"游ゴシック", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "游ゴシック", YuGothic, sans-serif;
}
input:-ms-input-placeholder {
  font-family:"游ゴシック", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "游ゴシック", YuGothic, sans-serif;
}






/*----------------
form
------------------*/
div.input_wrapp {
  width: auto;
}

input.long_text {
  width: calc(100% - 12px);
  height: 26px;
  padding: 5px;
  margin-bottom: 5px;
  font-size: 16px;
}

textarea.areaM {
  width: calc(100% - 12px);
  height: 120px;
  padding: 5px;
  margin-bottom: 5px;
  font-size: 16px;
}



/* error style */

dl dd.error {
  font-size: 13px;
}

dl dd input{
  position:relative;
  z-index:2;
}

dl dd label {
  padding:5px 5px 5px 25px;
  margin : 0 5px 0 -25px;
  margin-left:-25px;
  position:relative;
  z-index:1;
}

dl dd.error input , 
dl dd.error textarea , 
dl dd.error select , 
div.error option , 
dl dd.error label {
  background: #F1D1D5;
}


* html dl dd.error label {
  background:none;
}
*+html dl dd.error label{
  background:none;
}
dl dd p.error, 
div.agree_block p.error {
  width: auto;
  margin: 0 0 5px 0;
  font-size: 15px;
  color: #CB4E5A;
  font-weight:bold;
}
/* end error style */








/*----------------------------------------------------
	WRAPP
----------------------------------------------------*/
div#WRAPP {
  width: 100%;
  margin: 0 auto;
  padding: 0;
  text-align: left;
}

div#RESERV {
  width: auto;
  padding: 60px 0 80px 0;
}


div#RESERV div#PAGE_TITLE {
  width: auto;
  padding: 0 0 35px 0;
}

div#RESERV div#PAGE_TITLE div.inner {
  width: auto;
}

div#RESERV div#PAGE_TITLE div.inner h2 {
  width: auto;
}

div#RESERV div#PAGE_TITLE div.inner h2 img {
  width: 100%;
}


div#RESERV div.read_container {
  width: 90%;
  margin: 0 auto;
  padding: 0 0 35px 0;
}

div#RESERV div.read_container div.inner {
  width: auto;
}

div#RESERV div.read_container div.inner p {
  width: auto;
  font-size: 15px;
  line-height: 1.8em;
  letter-spacing: 0.05em;
}


div#RESERV div.step_box {
  width: auto;
  padding: 0 0 25px 0;
}

div#RESERV div.step_box p {
  width: 90%;
  margin: 0 auto;
}

div#RESERV div.step_box p img {
  width: 100%;
}





div#RESERV div.form_container {
  width: auto;
  margin: 0 auto;
}


div#RESERV div.form_container ul.form_list {
  width: auto;
}

div#RESERV div.form_container ul.form_list li {
  width: auto;
  padding: 0 0 25px 0;
}

div#RESERV div.form_container ul.form_list li dl {
  width: auto;
}

div#RESERV div.form_container ul.form_list li dl dt {
  width: auto;
  padding: 15px 0;
  background-color: #FFEECF;
}

div#RESERV div.form_container ul.form_list li dl dd {
  width: 90%;
  margin: 0 auto;
  padding: 20px 0 10px 0;
}



div#RESERV div.form_container ul.form_list li dl dt span {
  width: 90%;
  display: block;
  margin: 0 auto;
  font-size: 16px;
  line-height: 1.8em;
  font-weight: bold;
  letter-spacing: 0.05em;
}

div#RESERV div.form_container ul.form_list li dl dt span i.icon {
  width: auto;
  display: inline-block;
  padding: 5px 8px;
  line-height: 1.0em;
  text-align: center;
  border-radius: 10px;
}

div#RESERV div.form_container ul.form_list li dl dt span i.icon.require {
  color: #fff;
  font-size: 14px;
  background-color: #E05A5A;
  border: 1px #E05A5A solid;
}

div#RESERV div.form_container ul.form_list li dl dt span i.icon.any {
  font-size: 14px;
  background-color: #fff;
  border: 1px #524439 solid;
}




/* input style */

div#RESERV div.form_container ul.form_list li dl dd#type span.type_radio {
  width: auto;
  display: block;
  padding: 0 0 8px 0;
}

div#RESERV div.form_container ul.form_list li dl dd#type span.type_radio:last-child {
  padding: 0;
}

div#RESERV div.form_container ul.form_list li dl dd#type span.type_radio label em {
  width: auto;
  display: inline-block;
  margin: 0 0 0 10px;
  font-size: 16px;
}



div#RESERV div.form_container ul.form_list li dl dd div.half_box {
  display: -webkit-box;
  display: -webkit-flexbox;
  display: -moz-flexbox;
  display: -ms-flexbox;
  display: -moz-flex;
  display: flex;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}

div#RESERV div.form_container ul.form_list li dl dd div.half_box p {
  width: 48%;
}


div#RESERV div.form_container ul.form_list li dl dd div.box_radio {
  display: -webkit-box;
  display: -webkit-flexbox;
  display: -moz-flexbox;
  display: -ms-flexbox;
  display: -moz-flex;
  display: flex;
  justify-content: flex-start;
  -webkit-box-align: center;
  -ms-flex-align: center;
  -webkit-align-items: center;
  align-items: center;
}

div#RESERV div.form_container ul.form_list li dl dd div.box_radio p {
  width: auto;
  margin: 0 25px 0 0;
}

div#RESERV div.form_container ul.form_list li dl dd div.box_radio p:last-child {
  margin: 0;
}

div#RESERV div.form_container ul.form_list li dl dd div.box_radio p label em {
  width: auto;
  display: inline-block;
  margin: 0 0 0 10px;
  font-size: 16px;
}

div#RESERV div.form_container ul.form_list li dl dd p.exe_text {
  width: auto;
  padding: 10px 0 0 0;
  font-size: 14px;
  letter-spacing: 0.05em;
  line-height: 1.8em;
}







/*============================
privacy_block
============================*/

div#RESERV div.privacy_block {
  width: auto;
}

div#RESERV div.privacy_block div.bl_inner {
  width: 90%;
  margin: 0 auto;
  padding: 25px 0 0 0;
}

div#RESERV div.privacy_block div.bl_inner div#PRIVACY {
  width: calc(100% - 34px);
  height: 200px;
  margin: 0 auto;
  padding: 20px 15px;
  overflow-y: scroll;
  border: #ccc 2px solid;
}

div#RESERV div.privacy_block div.bl_inner div#PRIVACY p {
  width: auto;
  padding: 0 0 15px 0;
  font-size: 14px;
  line-height: 1.8em;
  letter-spacing: 0.05em;
}

div#RESERV div.privacy_block div.bl_inner div#PRIVACY p em {
  width: auto;
  display: block;
  padding: 0 0 5px 0;
  font-size: 15px;
  font-weight: bold;
  line-height: 1.8em;
  letter-spacing: 0.05em;
  border-bottom: 1px #ccc solid;
}

div#RESERV div.privacy_block div.bl_inner div#PRIVACY p.center {
  font-weight: bold;
  text-align: center;
}

div#RESERV div.privacy_block div.bl_inner div#PRIVACY p.center em {
  width: auto;
  display: block;
  font-size: 18px;
  font-weight: bold;
  text-align: center;
  border: none;
}


div#RESERV div.privacy_block div.bl_inner div#PRIVACY p:last-child {
  padding: 0;
}



div#RESERV div.agree_block {
  width: auto;
  padding: 25px 0 0 0;
  text-align: center;
}

div#RESERV div.agree_block p.agree {
  width: auto;
  display: inline-block;
}

div#RESERV div.agree_block p.agree em {
  width: auto;
  display: inline-block;
  margin: 0 0 0 10px;
  font-size: 16px;
}





/* confirm style */
div#RESERV div.form_container ul.form_list.confirm li dl dd {
  font-size: 16px;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1.8em;
}







/* error style */
div#RESERV div.error_container {
  width: 90%;
  margin: 0 auto;
}

div#RESERV div.error_container p.error_text_exe {
  width: auto;
  padding: 0 0 50px 0;
  font-size: 15px;
  font-weight: bold;
  color: #CB4E5A;
  line-height: 1.8em;
  letter-spacing: 0.05em;
}


div#RESERV div.error_container p.error_back_form {
  width: 80%;
  margin: 0 auto;
}

div#RESERV div.error_container p.error_back_form a {
  width: 100%;
  height: 72px;
  display: block;
  color: #fff;
  font-size: 18px;
  line-height: 72px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  border-radius: 100vh;
  box-shadow: 0 0 4px gray;
  background-color: #A7A7A7;
  transition: 0.3s;
}

div#RESERV div.error_container p.error_back_form a:hover {
  width: 100%;
  height: 72px;
  display: block;
  color: #fff;
  font-size: 18px;
  line-height: 72px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  border-radius: 100vh;
  box-shadow: 0 0 4px gray;
  background-color: #4E4E4E;
  transition: 0.3s;
}







/* done style */

div#RESERV div.comp_container {
  width: 90%;
  margin: 0 auto;
}

div#RESERV div.comp_container div.comp_inner {
  width: auto;
}

div#RESERV div.comp_container div.comp_inner h3 {
  width: auto;
  padding: 35px 0 50px 0;
}

div#RESERV div.comp_container div.comp_inner h3 span {
  width: auto;
  display: block;
  font-size: 24px;
  font-weight: bold;
  line-height: 1.6em;
  letter-spacing: 0.03em;
  text-align: center;
}

div#RESERV div.comp_container div.comp_inner p {
  width: auto;
  font-size: 13px;
  letter-spacing: 0.05em;
  line-height: 1.8em;
  text-align: center;
}

div#RESERV div.comp_container div.comp_inner p.lastcall {
  width: auto;
  padding: 15px 0 50px 0;
  font-size: 13px;
  letter-spacing: 0.05em;
  line-height: 1.8em;
  text-align: center;
}

div#RESERV div.comp_container div.comp_inner p.lastcall em {
  width: auto;
  display: block;
  font-size: 20px;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1.8em;
  text-align: center;
}

div#RESERV div.comp_container div.comp_inner p.lastcall em a {
  color: #000;
}


div#RESERV div.comp_container div.comp_inner div.read {
  width: auto;
  padding: 0 0 50px 0;
}

div#RESERV div.comp_container div.comp_inner div.read p {
  width: auto;
  font-size: 14px;
  letter-spacing: 0.03em;
  line-height: 1.8em;
  text-align: center;
}

div#RESERV div.comp_container div.comp_inner p.backTop {
  width: 80%;
  margin: 0 auto;
}


div#RESERV div.comp_container div.comp_inner p.backTop a {
  width: 100%;
  height: 72px;
  display: block;
  color: #fff;
  font-size: 18px;
  line-height: 72px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  border-radius: 100vh;
  box-shadow: 0 0 4px gray;
  background-color: #A7A7A7;
  transition: 0.3s;
}

div#RESERV div.comp_container div.comp_inner p.backTop a:hover {
  width: 100%;
  height: 72px;
  display: block;
  color: #fff;
  font-size: 18px;
  line-height: 72px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  border-radius: 100vh;
  box-shadow: 0 0 4px gray;
  background-color: #4E4E4E;
  transition: 0.3s;
}










/*============================
bt 
============================*/

#RESERV div.bt_area {
  width: auto;
  padding: 35px 0 0 0;
}

#RESERV div.bt_area ul {
  width: auto;
}

#RESERV div.bt_area ul li {
  width: 80%;
  margin: 0 auto;
}

#RESERV div.bt_area.confirm ul li.send {
  margin: 0 auto 35px auto;
}


#RESERV div.bt_area ul li.send .submit {
  width: 100%;
  height: 72px;
  color: #fff;
  font-size: 18px;
  line-height: 72px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  border-radius: 100vh;
  box-shadow: 0 0 4px gray;
  background-color: #F44B38;
  transition: 0.3s;
}

#RESERV div.bt_area ul li.send .submit:hover {
  width: 100%;
  height: 72px;
  color: #fff;
  font-size: 18px;
  line-height: 72px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  border-radius: 100vh;
  box-shadow: 0 0 4px gray;
  background-color: #F47324;
  transition: 0.3s;
}




#RESERV div.bt_area.confirm ul li.back a {
  width: 100%;
  height: 72px;
  display: block;
  color: #fff;
  font-size: 18px;
  line-height: 72px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  border-radius: 100vh;
  box-shadow: 0 0 4px gray;
  background-color: #A7A7A7;
  transition: 0.3s;
}

#RESERV div.bt_area.confirm ul li.back a:hover {
  width: 100%;
  height: 72px;
  display: block;
  color: #fff;
  font-size: 18px;
  line-height: 72px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  border-radius: 100vh;
  box-shadow: 0 0 4px gray;
  background-color: #4E4E4E;
  transition: 0.3s;
}










footer p.copy {
  padding: 15px 0;
}