@charset "UTF-8";

body {
	background-image: none;
}

.form_title {
	font-size: 24px;
	text-align: center;
	padding-left: 0px;
}
@media screen and (min-width : 670px){
	.form_title_br {
		display: none;
	}
}
@media screen and (max-width : 820px){
	.form_title {
		font-size: 18px;
	}
}
@media screen and (max-width : 468px){
	.form_title {
		font-size: 16px;
	}
}

/*お問い合わせフォーム*/
.form {
	width: 100%;
	border-collapse:collapse;
	float: left;
	margin-top: 16px;
	border: 1px solid #999999;
	margin-bottom: 3%;
}
.form th {
	width: 25%;
	vertical-align: middle;
	padding-top: 16px;
	padding-bottom: 16px;
	padding-left: 14px;
	padding-right: 14px;
	font-weight: normal;
	text-align: left;
	background-color: #ECECEC;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border: 1px solid #999999;
	line-height: 1.4em;
}
.form th.group {
	background-color: #CECECE;
}
.form tr td {
	width: 75%;
	vertical-align: middle;
	padding-top: 16px;
	padding-right: 14px;
	padding-bottom: 16px;
	padding-left: 14px;
	text-align: left;
	border: 1px solid #999999;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	line-height: 1.4em;
}
@media screen and (max-width : 700px){
	.form {
		border-top-width: 1px;
		border-top-style: solid;
		border-top-color: #999999;
		border-right-style: none;
		border-bottom-style: none;
		border-left-style: none;
	}
	.form th {
		border-top: none;
		border-bottom: none;
		width: 100%;
        display: block;
		padding-top: 8px;
		padding-bottom: 6px;
		line-height: normal;
    }
	.form th.bousai_th {
		border-bottom-width: 1px;
		border-bottom-style: solid;
		border-bottom-color: #999999;
	}
	.form tr td {
		width: 100%;
        display: block;
		padding-top: 8px;
		padding-bottom: 12px;
		line-height: normal;
    }
}

.form tr td p{
	padding-top: 0px;
	padding-bottom: 0px;
}
.form tr td a {
	color: #4F6671;
	text-decoration: underline;
}
.form tr td a:visited {
	color: #4F6671;
	text-decoration: underline;
}
.form tr td a:active {
	color: #4F6671;
	text-decoration: underline;
}
.form tr td a:hover {
	color: #35b8bd;
	text-decoration: underline;
}

.bousai {
	float: left;
	width: 100%;
}
.bousai_sanko {
	float: left;
	width: 260px;
	height: 30px;
	line-height: 1.6em;
}
@media screen and (max-width : 839px){
	.bousai_sanko {
		width: 100%;
	}
}
.bousai_day {
	line-height: 1.6em;
	float: left;
}
@media screen and (min-width : 580px){
	.bousai_br {
		display: none;
	}
}
@media screen and (min-width : 810px){
	.bousai_price_br {
		display: none;
	}
}
@media screen and (min-width : 380px){
	.bousai_course_br {
		display: none;
	}
}
@media screen and (min-width : 900px){
	.bousai_kyukyu_br {
		display: none;
	}
}
@media screen and (min-width : 360px){
	.bousai_preview_br {
		display: none;
	}
}

.bousai_hr {
	width: 100%;
}

.cap {
	font-size: 13px;
	float: left;
	width: 100%;
	margin-top: 16px;
}
.cap_s {
	line-height: 1.2em;
}

.privacy_ck {
	padding-top: 8px;
}

select {
	height: 30px;
	border: 1px solid #999999;
	background-color: #fbf8f5;
	margin-bottom: 2px;
}
input, textarea {
	width: 100%;
	height: 30px;
	ime-mode: disabled;
	border: 1px solid #999999;
	background-color: #fbf8f5;
	margin-bottom: 2px;
	border-radius: 3px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	padding-left: 8px;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
textarea {
	height: 70px;
	padding-top: 5px;
	padding-bottom: 5px;
}
.ime_active {
	ime-mode: active;
}
.ime_auto {
	ime-mode: auto;
}

.h_120p {
	height: 120px;
}
.h_400p {
	height: 400px;
}
.h_200p {
	height: 200px;
}

.w_48 {
	width: 48%;
}

.w_60 {
	width: 60%;
}
@media screen and (max-width : 600px){
	.w_60 {
		width: 80%;
	}
}
@media screen and (max-width : 560px){
	.w_60 {
		width: 100%;
	}
}
.w_80 {
	width: 80%;
}
@media screen and (max-width : 560px){
	.w_80 {
		width: 100%;
	}
}
.w_100 {
	width: 100%;
}
.w_50p {
	width: 50px;
}
.w_70p {
	width: 70px;
}
.w_100p {
	width: 100px;
}
.w_120p {
	width: 120px;
}
.w_180p {
	width: 180px;
}

/*費用合計表示*/
.total {
	width: 100px;
	font-size: 15px;
	background-color: #FFFFFF;
	border-top-style: none;
	border-right-style: none;
	border-bottom-style: none;
	border-left-style: none;
	padding-top: 12px;
	padding-right: 0px;
	padding-bottom: 0px;
	padding-left: 0px;
	font-family: 'Noto Sans Japanese', 'ＭＳ Ｐゴシック', 'Osaka', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', sans-serif;
}

/*入力必須*/
.input_hisu {
	font-size: 12px;
	float: left;
	width: 100%;
}

/*エラーメッセージ*/
.error_cap {
	color: #CC0000;
	padding-bottom: 4px;
}
.error_t {
	color: #CC0000;
}
.error {
	background-color: #FFD0D0 !important;
}
.error_privacy {
	color: #CC0000;
	background-color: #FFFF99;
	padding-top: 4px;
	padding-bottom: 4px;
}
.error_mese {
	text-align: center;
	float: left;
	width: 100%;
	margin-top: 14px;
	margin-bottom: 20px;
	color:#ffffff;
	background-color: #dc143c;
	font-size: 16px;
	font-weight: bold;
	padding-top: 6px;
	padding-bottom: 5px;
}

/*送信終了時メッセージ*/
.end_mese {
	line-height: 1.6em;
	float: left;
	width: 100%;
	padding-bottom: 20%;
	margin-top: 40px;
}

/*フォームボタン*/
.btn_box {
	float: left;
	width: 100%;
	margin-top: 10px;
}
.btn_box_l {
	float: left;
	width: 49%;
	margin-top: 10px;
}
.btn_box_r {
	float: right;
	width: 49%;
	margin-top: 10px;
}
.btn_box_three {
	width: 32%;
    margin: 0 0.6%;
}
button.btn_form {
	font-size: 15px;
	padding-top: 10px;
	padding-bottom: 10px;
	color: #ffffff;
	width: 100%;
	border-style: none;
	border-radius: 3px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	background-color: #999999;
}
@media screen and (max-width : 599px){
	button.btn_form {
		font-size: 14px;
	}
}
button.btn_form:hover {
	color: #ffffff;
	background-color: #CC0000;
}

/*チェックボックス*/
[type="checkbox"]:checked,
[type="checkbox"]:not(:checked) {
	position: absolute;
	left: -9999px;
}
[type="checkbox"]:checked + label,
[type="checkbox"]:not(:checked) + label {
	position: relative;
	padding-left: 28px;
	cursor: pointer;
	line-height: 18px;
	display: inline-block;
	color: #000000;
}
[type="checkbox"]:checked + label:before,
[type="checkbox"]:not(:checked) + label:before {
	content: '';
	position: absolute;
	left: 0;
	top: 0;
	width: 18px;
	height: 18px;
	border: 1px solid #000000;
	background: #fff;
}
[type="checkbox"]:checked + label:after,
[type="checkbox"]:not(:checked) + label:after {
	content: '';
	width: 8px;
	height: 8px;
	background: #cc0000;
	position: absolute;
	top: 6px;
	left: 6px;
	-webkit-transition: all 0.2s ease;
	transition: all 0.2s ease;
}
[type="checkbox"]:not(:checked) + label:after {
	opacity: 0;
	-webkit-transform: scale(0);
	transform: scale(0);
}
[type="checkbox"]:checked + label:after {
	opacity: 1;
	-webkit-transform: scale(1);
	transform: scale(1);
}

/*ラジオボタン*/
label.radio_text {
	cursor: pointer;
	position: relative;
	margin-right: 20px;
	overflow: hidden;
	padding-left: 20px;
	padding-bottom: 5px;
	padding-top: 1px;
	display: inline-block;
}
label.radio_text:before {
	position: absolute;
	width: 15px;
	height: 15px;
	border: 1px solid #000;
	border-radius: 50%;
	left: 0px;
	top: 4px;
	content: '';
	z-index: 3;
}
label.radio_text:after {
	content: '';
	position: absolute;
	width: 9px;
	height: 9px;
	border-radius: 100%;
	left: 4px;
	top: 8px;
	background-color: #cc0000;
	z-index: 1;
}
label.radio_text input[type="radio"] {
	-moz-appearance: none;
	-webkit-appearance: none;
	position: absolute;
	z-index: 2;
	width: 20px;
	height: 20px;
	left: -23px;
	top: 1px;
	margin: 0px;
	box-shadow: 20px -1px #FFF;
}
label.radio_text input[type="radio"]:checked {
	box-shadow: none;
}
label.radio_text input[type="radio"]:focus {
	opacity: 0.2;
	box-shadow: 20px -1px #FFF;
}