@charset "utf-8";
@import url(https://fonts.googleapis.com/css?family=Open+Sans);

body{
}

/* html5 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main{
    display: block;
}
audio,
canvas,
video{
	display: inline-block;
}



/* ページ本体 */
#PageBody{
	/* for mobac show
	padding: 20px 15px 0;
	*/
	padding: 0px 15px 0;
	margin: 0 auto;
	max-width: 750px;
	font-family: "Open Sans", "Helvetica Neue", Helvetica, "Arial", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	-webkit-text-size-adjust: 100%;
}





/* フォントサイズとウェイト */
#PageBody h1,
#PageBody h2,
#PageBody h3,
#PageBody h4,
#PageBody h5,
#PageBody h6,
#PageBody .h1,
#PageBody .h2,
#PageBody .h3,
#PageBody .h4,
#PageBody .h5,
#PageBody .h6{
	font-family: "Open Sans", "Helvetica Neue", Helvetica, "Arial", YuGothic, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-weight: 300;
	line-height: 1.2;
	color: inherit;
}
#PageBody h1,
#PageBody .h1,
#PageBody h2,
#PageBody .h2,
#PageBody h3,
#PageBody .h3{
	margin-top: 22px;
	margin-bottom: 11px;
}
#PageBody h4,
#PageBody .h4,
#PageBody h5,
#PageBody .h5,
#PageBody h6,
#PageBody .h6{
	margin-top: 11px;
	margin-bottom: 11px;
}
#PageBody h1,
#PageBody .h1{
	font-size: 32px;
}
#PageBody h2,
#PageBody .h2{
	font-size: 28px;
}
#PageBody h3,
#PageBody .h3{
	font-size: 24px;
}
#PageBody h4,
#PageBody .h4{
	font-size: 19px;
}
#PageBody p{
	text-align: justify;
	margin: 0 0 11px;
}
#PageBody p[align="center"]{
	text-align: center;
}
#PageBody b,
#PageBody font,
#PageBody button,
#PageBody input,
#PageBody textarea{
	font-family: inherit !important;
}
#PageBody b,
#PageBody button,
#PageBody input[type="button"],
#PageBody input[type="submit"],
#PageBody input[type="reset"]{
	font-weight: 600;
}




/* フォーム */
#PageBody input[type="text"],
#PageBody input[type="password"],
#PageBody textarea,
#PageBody select{
	max-width: 100%;
	height: 34px;
	padding: 6px 12px;
	font-size: 14px;
	line-height: 1.428571429;
	color: #555555;
	vertical-align: middle;
	background-color: #ffffff;
	border: 1px solid #cccccc;
	border-radius: 4px;
	box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
	-webkit-transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
	transition: border-color ease-in-out 0.15s, box-shadow ease-in-out 0.15s;
	
	margin: 2px;
}
@media only screen and (max-width:800px){
}

#PageBody input[type="text"]:focus,
#PageBody input[type="password"]:focus,
#PageBody textarea:focus,
#PageBody select:focus{
	border-color: #66afe9;
	outline: 0;
	-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6);
	box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075), 0 0 8px rgba(102, 175, 233, 0.6);
}



#PageBody select{
	padding: 5px 4px;
}
#PageBody button,
#PageBody input[type="button"],
#PageBody input[type="submit"],
#PageBody input[type="reset"]{
	display: inline-block;
	padding: 6px 12px;
	margin-bottom: 0;
	font-size: 14px;
	font-weight: normal;
	line-height: 1.428571429;
	text-align: center;
	white-space: nowrap;
	vertical-align: middle;
	cursor: pointer;
	border: 1px solid transparent;
	border-radius: 4px;
	
	/* width: auto !important; */
	width: auto;
	min-width: 9em;
	
	/*
	color: #ffffff;
	background-color: #f0ad4e;
	border-color: #eea236;
	*/
	color: #000000;
	background-color: #e6e6e6;
	border-color: #000000;
}
#PageBody form table table button,
#PageBody form table table input[type="button"]{
	/* width: auto !important; */
	width: auto;
}
#PageBody button:hover,
#PageBody input[type="button"]:hover,
#PageBody input[type="submit"]:hover,
#PageBody input[type="reset"]:hover{
	/*
	color: #ffffff;
	background-color: #ed9c28;
	border-color: #d58512;
	*/
	color: #000000;
	background-color: #cccccc;
	border-color: #000000;
}
#PageBody button:active,
#PageBody input[type="button"]:active,
#PageBody input[type="submit"]:active,
#PageBody input[type="reset"]:active{
	background-image: none;
	outline: 0;
	box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
}


/* 基本情報の登録内容の変更ボタンみたいな右側に小さく表示されるボタン */
#PageBody input[type="submit"].whiteAndSmallButton{
	background-color: #fff;
	/*
	border-color: rgba(0,0,0,0.2);
	*/
	border-color: #000000;
	color: #000;
	font-size: 14px !important;
	padding: 4px 8px !important;
	margin: 5px !important;
	/* width: auto !important; */
	width: auto;
}
#PageBody input[type="submit"].whiteAndSmallButton:hover{
	color: #000;
	background-color: #efefef;
	/*
	border-color: rgba(0,0,0,0.2);
	*/
	border-color: #000000;
}



/* テーブル */
#PageBody table{
	width: auto !important;
    max-width: 100%;
    margin: 0;
	border-spacing: 1px;
	border-collapse: separate;
	box-sizing: border-box;
}
#PageBody th,
#PageBody td{
    /*padding: 1px;*/
    vertical-align: middle;
}

#PageBody table[width="700"],
#PageBody table[width="710"],
#PageBody table[width="720"],
#PageBody table[width="100%"]{
	width: 100% !important;
}
/*#PageBody table[cellpadding="5"] th,
#PageBody table[cellpadding="5"] td{
    padding: 5px !important;
}*/
/*#PageBody th.txt,
#PageBody td.txt,
#PageBody th.txtw,
#PageBody td.txtw{
    border: none !important;
}
#PageBody th.txtw,
#PageBody td.txtw{
    font-size: 18px !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
#PageBody tr[align="center"] th,
#PageBody tr[align="center"] td{
    text-align: center;
}*/







/* モバイル */
@media only screen and (max-width:800px){
	/* 特定のテーブルはモバイルでは縦並びにする */
	#PageBody table.verticalLayoutOnMobile,
	#PageBody table.verticalLayoutOnMobile tbody,
	#PageBody table.verticalLayoutOnMobile tr,
	#PageBody table.verticalLayoutOnMobile th,
	#PageBody table.verticalLayoutOnMobile td{
		width: auto;
		max-width: 100%;
		box-sizing: border-box;
		display: block;
	}
	#PageBody table.verticalLayoutOnMobile tr{
		margin: 1px;
	}
	#PageBody table.verticalLayoutOnMobile th,
	#PageBody table.verticalLayoutOnMobile td{
		margin: 1px 0;
	}
	
	/* 特定のテーブルはモバイルでは縦並びにする */
	#PageBody table.verticalTableOnMobile,
	#PageBody table.verticalTableOnMobile > tbody,
	#PageBody table.verticalTableOnMobile > tbody > tr,
	#PageBody table.verticalTableOnMobile > tbody > tr > th,
	#PageBody table.verticalTableOnMobile > tbody > tr > td{
		width: auto;
		max-width: 100%;
		box-sizing: border-box;
		display: block;
	}
	#PageBody table.verticalTableOnMobile > tbody > tr{
		margin: 1px;
	}
	#PageBody table.verticalTableOnMobile > tbody > tr > th,
	#PageBody table.verticalTableOnMobile > tbody > tr > td{
		margin: 1px 0;
	}
	
	/* 特定のテーブルセルはスクロール領域にする */
	#PageBody td.scrollableOnMobile{
		display: block !important;
		max-width: calc(100vw - 34px) !important;
		overflow: auto !important;
		-webkit-overflow-scrolling: touch;
	}
	
	/* フォーム入力欄は原則として幅100%にする */
	#PageBody input[type="text"],
	#PageBody input[type="password"],
	#PageBody textarea,
	#PageBody select{
		width: 100%;
		display: block;
		margin: 2px 0;
		font-size: 16px;
	}
	
	/* モバイルだと送信ボタンは原則縦並び */
	#PageBody input[type="submit"],
	#PageBody input[type="reset"],
	#PageBody input[type="button"]{
		display: block;
		margin-bottom: 20px !important;
		width: 100% !important;
		height: auto !important;
		padding: 10px 0 !important;
		font-size: 16px !important;
		text-align: center;
	}
	/*#PageBody input[type="submit"]:last-child,
	#PageBody input[type="button"]:last-child{
		margin-bottom: 0 !important;
	}*/
	
	/* 郵便番号など特定のフォーム部品は大きさを変える */
	#PageBody input[name="zip1"],
	#PageBody input[name="zip2"],
	#PageBody input[name="fax1"],
	#PageBody input[name="fax2"],
	#PageBody input[name="fax3"],
	#PageBody input[name="phone1"],
	#PageBody input[name="phone2"],
	#PageBody input[name="phone3"] {
        display: inline-block;
        text-align: center;
        margin: 0 5px !important;
    }
	#PageBody input[name="zip1"]{
        width: 4em;
    }
	#PageBody input[name="zip2"],
	#PageBody input[name="fax1"],
	#PageBody input[name="fax2"],
	#PageBody input[name="fax3"],
	#PageBody input[name="phone1"],
	#PageBody input[name="phone2"],
	#PageBody input[name="phone3"] {
        width: 5em;
    }
	#PageBody input[name="zip2"] + input{
        padding: 5px 10px;
        margin: 5px 5px 0 !important;
    }
	
	/* モバイルだと縦並びになるボタンを囲むグループ（余計なスペースや改行を消してレイアウト調整する時用） */
	#PageBody .ButtonsVerticalOnMobile{
		padding: 0;
		font-size: 0; /* 余計なスペースなどはフォントサイズを0にすることによって削除する */
	}
	#PageBody .ButtonsVerticalOnMobile br{
		display: none;
	}
	#PageBody table.ButtonsVerticalOnMobile,
	#PageBody table.ButtonsVerticalOnMobile tbody,
	#PageBody table.ButtonsVerticalOnMobile tr,
	#PageBody table.ButtonsVerticalOnMobile td{
		display: block;
		margin: 0;
		padding: 0;
		width: auto;
	}
	
	/* 表示順を調整するリセット・送信ボタン */
	#PageBody .sp_btn_sort{
		display: flex !important;
		flex-direction: column;
		padding: 20px 0 0;
	}
	#PageBody .sp_btn_sort br{
		display: none;
	}
	#PageBody .sp_btn_sort td.sp_first,
	#PageBody .sp_btn_sort td.sp_second,
	#PageBody .sp_btn_sort td.sp_third,
	#PageBody .sp_btn_sort td.sp_fourth,
	#PageBody .sp_btn_sort td.sp_fifth{
		display: block;
		width: 100% !important;
		padding: 0;
	}
	#PageBody .sp_btn_sort input.sp_first,
	#PageBody .sp_btn_sort input.sp_second,
	#PageBody .sp_btn_sort input.sp_third,
	#PageBody .sp_btn_sort input.sp_fourth,
	#PageBody .sp_btn_sort input.sp_fifth,
	#PageBody .sp_btn_sort a.sp_first,
	#PageBody .sp_btn_sort a.sp_second,
	#PageBody .sp_btn_sort a.sp_third,
	#PageBody .sp_btn_sort a.sp_fourth,
	#PageBody .sp_btn_sort a.sp_fifth,
	#PageBody .sp_btn_sort .sp_first input,
	#PageBody .sp_btn_sort .sp_second input,
	#PageBody .sp_btn_sort .sp_third input,
	#PageBody .sp_btn_sort .sp_fourth input,
	#PageBody .sp_btn_sort .sp_fifth input{
		display: block;
		margin-bottom: 20px !important;
		width: 100% !important;
		padding: 10px 0 !important;
		font-size: 16px !important;
		text-align: center;
	}
	#PageBody .sp_btn_sort .sp_first.sp_mb10,
	#PageBody .sp_btn_sort .sp_second.sp_mb10,
	#PageBody .sp_btn_sort .sp_third.sp_mb10,
	#PageBody .sp_btn_sort .sp_fourth.sp_mb10,
	#PageBody .sp_btn_sort .sp_fifth.sp_mb10{
		margin-bottom: 10px !important;
	}
	#PageBody .sp_btn_sort .sp_first{
		order: 1;
	}
	#PageBody .sp_btn_sort .sp_second{
		order: 2;
	}
	#PageBody .sp_btn_sort .sp_third{
		order: 3;
	}
	#PageBody .sp_btn_sort .sp_fourth{
		order: 4;
	}
	#PageBody .sp_btn_sort .sp_fifth{
		order: 5;
	}
	
	
	/* モバイルだとボタンっぽくなるリンク */
	#PageBody .sp_ext_link,
	#PageBody .sp_ext_link2,
	#PageBody .sp_ext_link3{
		font-weight: normal;
		line-height: 1.428571429;
		white-space: nowrap;
		vertical-align: middle;
		cursor: pointer;
		border: 1px solid transparent;
		border-radius: 4px;
		
		width: auto !important;
		height: auto !important;
		
		display: block;
		margin-bottom: 20px !important;
		width: 100% !important;
		padding: 10px 0 !important;
		font-size: 16px !important;
		text-align: center;
		
		/*
		color: #ffffff;
		background-color: #ccc;
		border-color: rgba(0,0,0,0.1);
		*/
		font-weight: normal;
		color: #000000;
		background-color: #e6e6e6;
		border-color: #000000;
	}
	#PageBody .sp_ext_link:hover,
	#PageBody .sp_ext_link2:hover,
	#PageBody .sp_ext_link3:hover{
		/*
		color: #ffffff;
		background-color: #bbb;
		border-color: rgba(0,0,0,0.1);
		*/
		font-weight: normal;
		color: #000000;
		background-color: #cccccc;
		border-color: #000000;
		text-decoration: none;
	}
	#PageBody .sp_ext_link:active,
	#PageBody .sp_ext_link2:active,
	#PageBody .sp_ext_link3:active{
		background-image: none;
		outline: 0;
		box-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
		text-decoration: none;
	}
	#PageBody .sp_ext_link:last-child,
	#PageBody .sp_ext_link2:last-child,
	#PageBody .sp_ext_link3:last-child{
		margin-bottom: 0 !important;
	}
	
	
	
	/* モバイルではテーブルは原則100% */
	#PageBody table{
		width: 100% !important;
	}
	
	
	
	/* ログイン画面のボタンのレイアウト調整 */
	#PageBody table[width="420"] input[type="submit"]:last-child,
	#PageBody table[width="500"] input[type="submit"]:last-child{
		margin-bottom: 0 !important;
	}
	
	
	
	/* モバイルだと表示・非表示が切り替わるやつ */
	#PageBody .sp_ext_hide{
		display: none;
	}
	#PageBody .sp_ext_visible{
		display: block;
	}
	
	
	
	
	/*
	
	
	
	
	
	
	
	
	
	.sp_ext_hr{
		display: block;
		width: 100%;
		margin: 5px 0;
		border-bottom: 2px solid #333;
	}


	.sp_ext_sheet{
		font-size: 20px;
	}
	.sp_ext_sheet img{
		vertical-align: bottom;
	}
	.sp_ext_sheet center:nth-child(1){
		font-weight: 400;
		font-size: 20px;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		box-sizing: border-box;
		white-space: nowrap;
		overflow: hidden;
		word-spacing: 0;
		padding: 0;
		margin: 0;
		display: block;
		height: 56px;
		line-height: 56px;
		background: #fff;
		color: #FFFFFF;
		background:#009688;
		width: 100%;
		white-space: nowrap;
		overflow: visible;
	}
	.sp_ext_sheet hr{
		border: none;
		margin: 0;
		padding: 0;
		border-bottom: 1px solid #ddd;
	}
	.sp_ext_sheet form{
		padding: 0 10px;
	}
	.sp_ext_sheet form input{
		margin: 0;
	}
	.sp_ext_sheet_content{
		width:90%;
		margin: 0 auto;
		font-size: 20px;
	}
	*/
	
	#PageBody form table table button,
	#PageBody form table table input[type="button"]{
		width: auto !important;
	}
	#PageBody input[type="submit"].whiteAndSmallButton{
		width: auto !important;
	}
}



@media print{
	/* 印刷時は表示しないやつ */
	.noprint{
		display: none !important;
	}
}



@media only screen and (max-width:800px){
	@-ms-viewport{
		width: device-width;
	}
}