@charset "utf-8";
/* CSS Document */

.sp_width100{
	width: 50%;
}

/*モーダルを開くボタン*/
.modal-open{
  display: inline-block;
  text-align: center;
  padding: 18px 0;
  width: 140px;
  font-weight: normal;
  color: #fff;
  background: #000;
  margin: 0;
  cursor: pointer;
}
/*モーダル本体の指定 + モーダル外側の背景の指定*/
.modal-container{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0,0,0,50%);
  /*padding: 40px 20px;*/
  padding: 0 0;
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
  box-sizing: border-box;
	overflow-y: scroll;
}
/*モーダル本体の擬似要素の指定*/
.modal-container:before{
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
}
/*モーダル本体に「active」クラス付与した時のスタイル*/
.modal-container.active{
  opacity: 1;
  visibility: visible;
  z-index: 3;
}
/*モーダル枠の指定*/
.modal-body{
  position: relative;
  display: inline-block;
  vertical-align: middle;
  max-width: 900px;
  width: 90%;
  height: 92%;

  border-radius: 5px;
  overflow-y: scroll;
}
/*モーダルを閉じるボタンの指定*/
.modal-close{
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: 10px;
  right: 10px;
  width: 80px;
  height: 60px;
  font-size: 50px;
  line-height: 1.0;
  color: #000000;
  cursor: pointer;
}
/*モーダルを閉じるボタンの指定*/
.modal-close2{
	border: solid 1px #CCCCCC;
	padding: 15px 0;
	margin: 50px auto;
	text-align: center;
	width: 220px;
	font-size: 20px;
	line-height: 1.0;
	color: #000000;
	cursor: pointer;
}
/*モーダル内のコンテンツの指定*/
.modal-content{
  background: #fff;
  text-align: left;
  padding: 30px;
}



/* --------------------------
 loader
----------------------------*/
#loading{
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	/*
	background-color: rgba(0,0,0,0.5);
	background-color: #FFFFFF;
	*/
	z-index: 9999;
}
#loading_img{
	position: absolute;
	top: 30%;
	left: 50%;
}

/* --------------------------
 common
----------------------------*/
html{
	overflow-x: hidden;
}
body{
	/*font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;*/
	font-family: "游ゴシック", "Yu Gothic Medium", "游明朝", "Hiragino Sans", "ヒラギノ角ゴシック", "MS PGothic", sans-serif;
	background-color: #EFEFEF;
	color: #404040;
}
.mincho {
	font-family: Georgia,"游明朝","Yu Mincho",YuMincho,"Hiragino Mincho ProN","HGS明朝E","メイリオ",Meiryo,"Sawarabi Mincho",serif;
}
.gothic {
	font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
}

/* IE10,IE11対応 */
/*
@media all and (-ms-high-contrast: none){
	body{
		font-family: "メイリオ", Meiryo, sans-serif;
	}
}
*/
_:lang(x)::-ms-backdrop, body, .gothic, input{
	font-family: "メイリオ", Meiryo, sans-serif;
}

*/
/* --------------------------
 reset
----------------------------*/
body,p,ul,form{
	margin: 0;
	padding: 0;
}

ul,ol,li{
	list-style: none;
}

button{
	background-color: transparent;
	border: none;
	cursor: pointer;
	outline: none;
	padding: 0;
	appearance: none;
}

/* --------------------------
 Tag for html5
----------------------------*/
article,
aside,
footer,
header,
nav,
section {
	display: block;
}

/* --------------------------
 main wrapper
----------------------------*/
#wrapper{
}

/* --------------------------
 image
----------------------------*/
img{
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

/* --------------------------
 clearfix
----------------------------*/
.cf:after{
	content: "";
	clear: both;
	display: block;
}

/* --------------------------
 float
----------------------------*/
.flr {
	float: right;
}
.fll {
	float:left;
}

/* --------------------------
 main
----------------------------*/
#main #content #mainarea{
	max-width: 980px;
	margin: 0 auto;
/*
	font-size: 16px;
	line-height: 1.4;
*/
	font-style: normal;
	word-wrap: break-word;

	background-color: #ffffff;
}

#mainarea{
	border:solid 0px #ffffff; /* */
}






.kiyaku_text{
    margin: 20px auto;
    padding: 10px;
    border: solid 1px #ccc;
    width: 100%;
    background: #fff;

    line-height: 1.0;
    font-size: 13px;
}

p.message{
	color: #666666;
	font-size: 15px;
	font-weight: bold;
	line-height: 1.4;
	margin: 0 15px 20px;
}
h2.title {
    margin-bottom: 10px;
    padding: 8px;
    border-top: solid 1px #ebeced;
    color: #fff;
    background: url("../images/bg_tit_sub_01.jpg") repeat-x left bottom;
    background-color: #889AE4;
    font-size: 22px;
    font-weight: bold;
}

.form_entry ul{
	border-bottom: solid 1px #CCCCCC;
}
.form_entry li{
	background-color: #ffffff;
	border-top: solid 1px #CCCCCC;
	font-size: 0;
}
.form_entry li .left{
	width: 32%;
	background-color: #ffffff;
	vertical-align: middle;
	display: inline-block;
	font-size: 15px;
	margin: 15px 0;
	padding: 0 15px;
}
.form_entry li .right{
	width: 68%;
	background-color: #ffffff;
	vertical-align: middle;
	display: inline-block;
	font-size: 15px;
	margin: 15px 0;
}

.form_entry li .left span, .form_entry li .right span{
	display: inline-block;
	vertical-align: middle;
}

span.indispensable {
  display: inline-block;
  line-height: 1.0;
  padding: 4px 4px;
  font-size: 10px;
  color: #fff;
  border-radius: 2px;
  -moz-border-radius: 2px;
  -webkit-border-radius: 2px;
  -khtml-border-radius: 2px;
  background-color: #ff5f82;
  vertical-align: middle;
}

h3{
	/*background-color: #FFE777;*/
	background-color: #EEEEEE;

	font-size: 18px;
	font-weight: bold;
	margin: 30px 0px 0px;
	padding: 15px 15px;
}

/* --------------------------
 form
----------------------------*/
.form_entry h2{
}

.form_entry p{
	/*margin: 0 20px;*/
}

.form_entry .main_message{
	border-top: dotted 4px #B7B0A9;
	border-bottom: dotted 4px #B7B0A9;
	padding: 50px 20px 50px 20px; /* レイアウト調整 */
	text-align: center;
}

.form_entry .main_message p{
	margin: 0 0;
}

.form_entry .main_message .close{
	margin:30px 0 30px;
}


.form_entry .main_list{
	border-top: dotted 4px #B7B0A9;
	border-bottom: dotted 4px #B7B0A9;
	padding: 10px 20px 10px 40px; /* レイアウト調整 */
}

.form_entry .main_list li{
	list-style-type: decimal;
	margin: 10px 0 20px;

	color: #ff2aa2;
	font-weight: bold;
}

.form_entry .main_list li span{
	color: #404040;
	/*font-weight: normal;*/
}

.form_entry .main_list li p{
	color: #404040;
	font-weight: normal;
}

.form_entry .main_list li .photo_area input[type=button]{
	margin: 15px 0 10px;
}
.form_entry li .photo_area input[type=button]{
	margin: 0px 0 10px;
	padding: 3px 15px;
	border-radius: 3px;
}



.form_entry .main_list li .photo_area .photo_preview{
	max-width: 200px;
}
.fld51_preview{
	max-width: 200px;
}
.fld52_preview{
	max-width: 200px;
}
.fld53_preview{
	max-width: 200px;
}
.fld54_preview{
	max-width: 200px;
}
.fld55_preview{
	max-width: 200px;
}

.form_entry .main_list li .photo_area img{
	margin: 15px 0 0px;
}

.form_entry input[type=text]{
	display: block;
	width: 100%;
	border: solid 1px #ccc;
	padding: 5px 5px;
	/*margin-left: -15px; レイアウト調整 */
}

.form_entry textarea{
	display: block;
	width: 96%;
	border: solid 1px #ccc;
	margin-top: 5px;
	padding: 5px 5px;
	vertical-align: middle;
	 /*margin-left: -15px レイアウト調整 */
}

/* --------------------------
 button
----------------------------*/
.btn_area{
	text-align: center;
	margin: 30px 5px 30px
}
.btn_area .btn_left{
	display: inline-block;
}
.btn_area .btn_right{
	display: inline-block;
}

input[type=image]{
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

.btn_image{
	background: none;
	width: auto;
	border: 0;
	margin: 0;
	padding: 0;
	font-size: 0;
	line-height: 0;
	overflow: visible;
	cursor: pointer;
}

button{
	margin: 0 2px; /*レイアウト調整*/
}

button:hover,
button:focus{
	opacity: 0.8;
}

.btn_blue{
	display: inline-block;
	position: relative;
	text-decoration: none;
	color: #ffffff;
	width: 120px;
	height: 36px;
	line-height: 36px;
	border-radius: 5px;
	text-align: center;
	vertical-align: middle;
	overflow: hidden;
	font-size: 18px;
	font-weight: bold;
	background-image: -webkit-linear-gradient(#99CCFF 0%, #0080C0 100%);
	background-image: linear-gradient(#99CCFF 0%, #0080C0 100%);
	box-shadow: 0 1px 1px rgba(0, 0, 0, 0.28);
}

.btn_green{
	display: inline-block;
	position: relative;
	text-decoration: none;
	color: #ffffff;
	width: 120px;
	height: 36px;
	line-height: 36px;
	border-radius: 5px;
	text-align: center;
	vertical-align: middle;
	overflow: hidden;
	font-size: 18px;
	font-weight: bold;
	background-image: -webkit-linear-gradient(#C0D20A 0%, #91AA10 100%);
	background-image: linear-gradient(#C0D20A 0%, #91AA10 100%);
	box-shadow: 0 1px 1px rgba(0, 0, 0, 0.28);
}

.btn_red{
	display: inline-block;
	position: relative;
	text-decoration: none;
	color: #ffffff;
	width: 120px;
	height: 36px;
	line-height: 36px;
	border-radius: 5px;
	text-align: center;
	vertical-align: middle;
	overflow: hidden;
	font-size: 18px;
	font-weight: bold;
	background-image: -webkit-linear-gradient(#EE2121 0%, #EE2121 100%);
	background-image: linear-gradient(#EE2121 0%, #EE2121 100%);
	box-shadow: 0 1px 1px rgba(0, 0, 0, 0.28);
}

.btn_orange{
	display: inline-block;
	position: relative;
	text-decoration: none;
	color: #ffffff;
	width: 120px;
	height: 36px;
	line-height: 36px;
	border-radius: 5px;
	text-align: center;
	vertical-align: middle;
	overflow: hidden;
	font-size: 18px;
	font-weight: bold;
	background-image: -webkit-linear-gradient(#FF8C00 0%, #FF2A00 100%);
	background-image: linear-gradient(#FF8C00 0%, #FF2A00 100%);
	box-shadow: 0 1px 1px rgba(0, 0, 0, 0.28);
}

.btn_gray{
	display: inline-block;
	position: relative;
	text-decoration: none;
	color: #ffffff;
	width: 120px;
	height: 36px;
	line-height: 36px;
	border-radius: 5px;
	text-align: center;
	vertical-align: middle;
	overflow: hidden;
	font-size: 18px;
	font-weight: bold;
	background-image: -webkit-linear-gradient(#B1B1B1 0%, #656565 100%);
	background-image: linear-gradient(#B1B1B1 0%, #656565 100%);
	box-shadow: 0 1px 1px rgba(0, 0, 0, 0.28);
}

/* --------------------------
 ヘッダー
----------------------------*/
header{
}

/* --------------------------
 フッター
----------------------------*/
footer{
	margin:50px 15px 0px;
	text-align: center;
	border-top: solid 1px #CCCCCC;
}

footer #copyright{
	color: #666666;
	font-size: 12px;
	line-height: 1.4;
	padding: 10px 0 30px;
	letter-spacing: 0.1em;
}

//* datepicker 背景/文字の色 *//
.class-holiday > .ui-state-default {
  background: #FFFFCC !important;
  color: red !important;
}
.class-sunday > .ui-state-default {
  background: #FFCCCC !important;
  color: red !important;
}
.class-saturday > .ui-state-default {
  background: #CCCCFF !important;
  color: blue !important;
}
header{
}
header div{
}
header h1{
}

h1{
	color: #000;
	font-size: 22px;
	font-weight: bold;
	line-height: 1.0;
	margin-left: 10px;
}

.left p{
	line-height:1.2;
}

/* --------------------------
 Attention
----------------------------*/
ul.attention{
	border: none;
	margin-top: 15px;
}
.attention{
	list-style: none;
	margin-left: 1.0em;
}
.attention li{
	text-indent: -1.0em;
	border: none;
	font-size: inherit;
	line-height: 1.4;
}
.attention li:before{
	content: "※";
}

.marker_yellow{
	/*background: linear-gradient(transparent 60%,#ff0 50%);*/
	border-bottom: 1px dashed #000000;
}

.main_frame{
	margin: 30px 30px;
}


.modal-content .idx{
	font-weight: bold;
	font-size: 1.2rem;
	margin-top: 5px;
}
.modal-content .frm{
	margin-top: 50px;
}
.modal-content .ttl{
	background-color: #EFEFEF; 
	width: 100%; 
	padding: 15px 0;
}
.modal-content .ttl span{
	display: block;
	margin: 0 15px;
	line-height: 1.4;
}
.modal-content .cnt{
	margin: 15px 15px 0;
	line-height: 1.4;
}
.modal-content .btn{
	text-align: right;
	margin-top: 15px;
}

table.numjushinki2{
	width: 100%;
	margin-top: 15px;
}
.numjushinki2 td{
	padding: 15px 5px 15px 5px;
	border: solid 1px #CCCCCC;
}

.flow02{
	margin: 0 auto 50px;
	width: 90%;
}
.flow02:after {
	height: 0;
	visibility: hidden;
	content: ".";
	display: block;
	clear: both;
}
.flow02 .box{
	padding-top: 0px; /* テキストの位置調整 */
	width: 5%; /* ウィンドウの幅が広くなった時のために％で指定 */
	height: 10px;
	background: #CCCCCC; /* １番目のボックスの色指定 */
	float: left;
	position: relative;

	font-size: 11px;
	font-weight: normal;
	line-height: 2.0;
	color: #666666;
	text-align: center;
}

.flow02 .box02{ background: #EFEFEF; } /* 2*/
.flow02 .box03{ background: #EFEFEF; } /* 3*/
.flow02 .box04{ background: #EFEFEF; } /* 4*/
.flow02 .box05{ background: #EFEFEF; } /* 5*/
.flow02 .box06{ background: #EFEFEF; } /* 6*/
.flow02 .box07{ background: #EFEFEF; } /* 6*/
.flow02 .box08{ background: #EFEFEF; } /* 6*/
.flow02 .box09{ background: #EFEFEF; } /* 6*/
.flow02 .box10{ background: #EFEFEF; } /* 6*/
.flow02 .box11{ background: #EFEFEF; } /* 6*/
.flow02 .box12{ background: #EFEFEF; } /* 6*/
.flow02 .box13{ background: #EFEFEF; } /* 6*/
.flow02 .box14{ background: #EFEFEF; } /* 6*/
.flow02 .box15{ background: #EFEFEF; } /* 6*/
.flow02 .box16{ background: #EFEFEF; } /* 6*/
.flow02 .box17{ background: #EFEFEF; } /* 6*/
.flow02 .box18{ background: #EFEFEF; } /* 6*/
.flow02 .box19{ background: #EFEFEF; } /* 6*/
.flow02 .box20{ background: #EFEFEF; } /* 6*/
 
/* ボックス左側三角形 */
.flow02 .box:before{
	border-left: 14px solid #FFFFFF; /* 1 */
	border-top: 5px solid transparent;
	border-bottom: 5px solid transparent;
	content: "";
	position: absolute;
	left: 0; /* ボックスの左に合わせて三角形を作る */
	top: 0;
}
.flow02 .box02:before{ border-left-color: #CCCCCC; } /* 2 */
.flow02 .box03:before{ border-left-color: #EFEFEF; } /* 3 */
.flow02 .box04:before{ border-left-color: #EFEFEF; } /* 4 */
.flow02 .box05:before{ border-left-color: #EFEFEF; } /* 5 */
.flow02 .box06:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box07:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box08:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box09:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box10:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box11:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box12:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box13:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box14:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box15:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box16:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box17:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box18:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box19:before{ border-left-color: #EFEFEF; } /* 6 */
.flow02 .box20:before{ border-left-color: #EFEFEF; } /* 6 */
 
/* 最後ボックスだけ右側三角形 */
.flow02 .box12:after {
	border-left: 14px solid #EFEFEF; /* 最後の三角形は最後のボックスと同じ色を指定 */
	border-top: 5px solid transparent;
	border-bottom: 5px solid transparent;
	content: "";
	position: absolute;
	right: -14px; /* 三角形の幅の分だけ右にずらす */
	top: 0;
}
.flow02 .box span{
    padding-left: 15px; /* テキストの位置調整 */
}

@media screen and (max-width: 1024px){
	.faq .accordion_one .accordion_header{
		font-size: 18px;
	}
}
@media screen and (max-width: 767px){
	.faq .accordion_one .accordion_header{
		font-size: 16px;
		text-align: left;
		padding: 5px 60px 5px 15px;
	}
	.main_frame{
		padding: 0 0;
	}
}
