/*
index.css
*/

/* reset ***********************************************/
h1, h2, h3, h4, h5, h6, p{
	font-weight: normal;
	margin: 0;
}

ul, ol, dl, li, dt, dd{
	list-style: none;
	margin: 0;
	padding: 0;
}

button,
input[type="submit"],
input[type="button"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	padding: 0;
	border: none;
	outline: none;
	background: transparent;
	box-shadow: none;
}

/* main_title **********************************************
.main_title{
	width: 100%;
	border-top: 1px solid #fbfbfb;
	border-bottom: 1px solid #fbfbfb;
	margin-bottom: 21px;
}

.main_title h2{
	width: 960px;
	margin: 0 auto;
	font-size: 43px;
	font-weight: normal;
	color: #2a69b0;
	line-height: 231px;
	background-image: url("../img/ttl_bg.jpg");
	background-repeat: no-repeat;
	background-position: right center;
}

 main *********************************************
.main_body{
	width: 960px;
	height: auto;
	display: block;
	overflow: hidden;
	margin: 0 auto;
}

.main_body .contact_form{
	width: 712px;
	float: left;
}

.main_body h3{
	font-size: 24px;
	color: #2a69b0;
}

.main_body .contact_form>p{
	font-size: 14px;
	color: #2a69b0;
	margin: 23px 0;
	line-height: 150%;
}
*/

#main_left02{
	width:505px;
	margin:0px 24px 20px 3px;float:left;
	text-align:left;
}

#main_left02 p.policy_txt:nth-of-type(1){
	margin:30px 0 20px;
}

#main_left02 p.policy_txt:nth-of-type(2){
	margin-bottom: 10px;
}

#main_left02 p.lead_text{
	margin:10px 0px 20px 5px;
}

#main_left02 p#policy_notice {
	margin: 20px 0 12px;
	color: #cc4444;
	font-size: 12px;
	font-weight: bold;
	text-align: center;
	line-height: 1;
	visibility: hidden;
}

.policy{
	width: 505px;
	height: 108px;
	border: 1px solid #8f8f8f;
}

.policy .text{
	width: 490px;
	height: 87px;
	margin: 10px 5px 10px 15px;
	font-size: 12px;
	color: #808080;
	line-height: 200%;
	overflow-y: scroll;
}

.agree_btn {
	width: 100%;
	margin-bottom: 48px;
	text-align: center;
}

#agreement_btn {
	width: 136px;
	height: 56px;
	font-size: 19px;
	color: #fff;
	background: url(../img/contact_btn_g.gif) no-repeat;
	text-align: center;
}
#agreement_btn.ready{
	background: url(../img/contact_btn_o.gif) no-repeat;
	opacity: 1;
}
#agreement_btn.ready:hover{
	color: #fff;
	opacity: 0.7;
	cursor: pointer;
}
#agreement_btn:focus{
	outline: none;
}

#input_form {
	display: none;
}

.input_form_inner {
	width: 100%;
	margin-bottom: 55px;
	padding: 33px;
	color: #747474;
	background-color: #f2f1ec;
	text-align: center;
	box-sizing: border-box;
	border-radius: 20px;
}

.input_form_inner h1 {
	margin-bottom: 30px;
	font-size: 19px;
	line-height: 1;
}

.input_form_inner p {
	font-size: 13px;
	line-height: 1;
}

.input_form_inner li {
	width: 100%;
	height: 65px;
	margin-bottom: 5px;
	line-height: 65px;
}

.input_form_inner li:nth-of-type(1) {
	margin-top: 16px;
}

.input_form_inner li:nth-of-type(4) {
	margin-bottom: 0;
}

p.indicate {
	font-size: 13px;
	color: #6767fd;
	line-height: 23px;
	margin-bottom: 38px;
	text-align: center;
}

p.indicate a.txt_link:hover {
	opacity: 0.7;
}

#ma {
	display: none;
	text-align: center;
}

#ma .addImg {
	width: 100%;
	height: 93px;
	margin: 15px auto 63px;
	padding: 26px 0;
	box-sizing: border-box;
	background: url(../img/contact_add_bg.gif) no-repeat;
}

#ma .sub_ttl {
	width: 420px;
	margin: 0 auto 32px;
	padding-bottom: 20px;
	font-size: 13px;
	border-bottom: 1px solid #656565;
}

#ma .q_cont01 {
	color: #fb7e0b;
	font-size: 13px;
	line-height: 1;
}

#ma .q_cont01>li,
.q_cont01.inquiry_description_details {
	margin-bottom: 14px;
	padding-left: 100px;
	text-align: left;
}

#ma .q_cont01>li:nth-of-type(2) {
	margin-top: -5px;
}

#ma .q_cont01 li span {
	display: inline-block;
	padding-right: 3px;
	font-size: 17px;
}

#ma .q_cont02>li {
	margin-bottom: 14px;
	padding-left: 110px;
	text-align: left;
}



/* 20210115 お問い合わせフォーム改修 スタイル追加 */
/* module */
.err_msg {
	color: red;
	display: none;
	margin-top: 10px;
}
.has_err + .err_msg {
	display: block;
	font-size: .875rem;
}

.flex_container {
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
}

.strict_line_break {
	word-break: keep-all;
	-webkit-line-break: strict;
	line-break: strict;
	word-wrap: break-word;
	overflow-wrap: break-word;
}



/* input_form */
.input_items_container,
.input_form_inner .form_description,
.input_item {
	font-size: .875rem;
}

.input_items_container {
	margin-bottom: 30px;
	text-align: left;
}

.input_form_inner .form_description {
	color: #fb7e0b;
	line-height: 1.6;
	margin-bottom: 15px;
}

.input_item_container {
	margin-bottom: 20px;
}

.input_description {
	margin-bottom: 10px;
}

.required_icon {
	background-color: #fb7e0b;
	border-radius: 5px;
	box-sizing: border-box;
	color: #FFF;
	-ms-flex: 36px 0 0;
	flex: 36px 0 0;
	font-size: .75rem;
	height: 21.2px;
	line-height: 1.3;
	margin-bottom: auto;
	margin-right: 10px;
	padding: 3px;
	text-align: center;
}

.input_item {
	border: none;
	box-sizing: border-box;
	line-height: 1;
	padding: 15px;
	width: 100%;
}
.input_item::placeholder {
  color: #CCC;
}
/* 旧Edge対応 */
.input_item::-ms-input-placeholder {
  color: #CCC;
}
/* IE対応 */
.input_item:-ms-input-placeholder {
  color: #CCC;
}


.form_description_container {
	text-align: left;
}

.input_form_inner .inquiry_description {
	margin-left: 1em;
	text-indent: -1em;
}

.input_form_inner .inquiry_description_details {
	line-height: 1.75;
	margin-left: 1.3em;
	text-indent: -1.3em;
}

.btn_container .mail_link {
	background: url(../img/contact_bg02.gif) no-repeat center /contain;
	color: #d9d9d9;
	cursor: default;
	display: block;
	font-size: 16px;
	opacity: .5;
}

.btn_container.active .mail_link {
	color: #fb7e0b;
	cursor: pointer;
	font-weight: bold;
	opacity: 1;
}

.btn_container.active .mail_link:hover {
	background: url(../img/contact_bg02_o.gif) no-repeat center /contain;
}


#ma .q_cont01.inquiry_description_details {
	line-height: 1.75;
}



/*
input[type="image"]{
	display: block;
	margin: 0 auto 55px;
}

input[type="image"]:hover{
	opacity: 0.8;
}

.form_btn{
	width: 100%;
	height: auto;
	overflow: hidden;
	text-align: center;
	margin-bottom: 55px;
	*padding-bottom: 55px
}

.form_btn.left{
	float: left;
	width: 50%;
	margin-top: 50px;
}

.form_btn.right{
	float: right;
	width: 50%;
	margin-top: 50px;
}

.form_btn a,
.form_btn input[type="submit"],
.form_btn input[type="button"]{
	padding: 17px 68px;
	width:247px;
	height:59px;
	background-image: url("../img/btn_confirm.jpg");
	border:none;
}

.form_btn a{
	margin: 20px 0 20px;
}

.form_btn a:hover,
.form_btn [type="submit"]:hover,
.form_btn [type="button"]:hover{
	color: #fff;
	cursor: pointer;
	opacity: 0.6;
	filter: alpha(opacity=60);
	-moz-opacity: 0.6;
}
*/

/* フォーム入力関係 ※2018.11 ページ改修に伴いフォーム削除 */
/*
#main_left02.confirm p.lead_text,
#main_left02.thanks p.lead_text{
	border-bottom: 1px dotted #000;
	line-height: 200%;
	padding-bottom: 5px;
}

#main_left02 table{
	width:505px;
}

#main_left02 table,tr,td{
	border:none;
	border-collapse:collapse;
}

#main_left02 table tr{
	width: 250px;
}

#main_left02 table tr.dark{
	background-color: #f6f4f2;
}

#main_left02 table tr:nth-of-type(2n+1){
	background-color: #fff;
}

#main_left02 table tr:nth-of-type(2n){
	background-color: #f6f4f2;
}

#main_left02 table tr td.prerequisite span{
	font-size: 12px;
}

#main_left02 table tr td{
	font-size: 12px;
	padding: 5px 10px;
	vertical-align: middle;
	line-height: 160%;
	border: 0px;
}

#main_left02 table tr td .notice{
	font-size: 10px;
}

#main_left02 table tr td:nth-of-type(1){
	line-height: 140%;
}

#main_left02 table tr td:nth-of-type(2){
}

#main_left02 table input[type="checkbox"]{
	margin-right: 10px;
}

#main_left02 table tr:nth-of-type(2) td p{
	width: 100%;
	float: left;
	float: none\9;
}

#main_left02 table tr:nth-of-type(1) td p{
	width: 100%\9;
	float: left\9;
}

#main_left02 table input[type="text"]{
	width: 290px;
	height: 27px;
	line-height: 30px;
}

#main_left02 table input[type="text"].tel{
	width: 40px;
}

#main_left02 table textarea{
	line-height:15px;
	padding:5px;
	width: 280px;
	height: 82px;
	resize: none;
}
.textarea_space{
	margin:5px;
	padding:10px 0 0 15px;
}

.must{
	font-size: 10px;
	color:#ff6c00;
}

.confirm .form_btn input{
	width:145px;
	height:60px;
	margin-top: 30px;
	background-image: url("../img/btn_fix.jpg");
}

.confirm .form_btn input#send_btn{
	margin-left: 30px;
	background-image: url("../img/btn_send.jpg");
}
*/
