@charset "utf-8";

form#mail_form * {
	margin: 0;
	padding: 0;
}

form#mail_form {
	width: 960px;
	margin: 20px auto 10px auto;
	padding: 10px 0;
	background: #ffffff;
	border: 1px solid #cccccc;
	border-radius: 7px;
	box-shadow: 0 0 7px rgba( 0, 0, 0, 0.2 );
	font-size: 95%;
	line-height: 1.8;
}

form#mail_form dl {
	width: 90%;
	margin: 0 auto;
	overflow: hidden;
}

form#mail_form dl dt {
	clear: both;
	width: 30%;
	float: left;
	border-top: 1px solid #cccccc;
	padding: 16px 0 5px 0;
/*	text-align: left; */
	overflow: hidden;
	line-height: 1.3;
	font-weight: bold;
	font-size: 115%;
	letter-spacing: 0.1em;
}

form#mail_form dl dd {
	width: 65%;
	float: right;
	border-top: 1px solid #cccccc;
	padding: 2px 0 7px 5%;
}

form#mail_form dl dt:first-child,
form#mail_form dl dt:first-child + dd {
	border: none;
}

form#mail_form dl dt span {
	display: block;
	font-size: 85%;
	color: #ffffff; /* #3377ff; */
}


/* -- for JavaScript ここから -------------------------------------------------------------------------------- */

form#mail_form dl dt span.required,
form#mail_form dl dt span.optional {
	display: inline-block; 
/*	float: right; */
	color: #ffffff;
	padding: 2px 4px 1px 4px;
/*	border-radius: 3px; */
	font-size: 70%;
	font-weight: normal;
	margin-left:16px;
	vertical-align: top;
/*	top: -0.2em; */
}

form#mail_form dl dt span.required {
	background: #d9534f;
	border: 1px solid #d43f3a;
border-radius: 8px;
}


form#mail_form dl dt span.optional {
	background: #337ab7;
	border: 1px solid #2e6da4;
}

form#mail_form dl dd .vertical-middle {
/*	line-height: 200%; */
	padding-top: 10px;
}


form#mail_form dl dd span.error_blank,
form#mail_form dl dd span.error_format,
form#mail_form dl dd span.error_match {
	display: block;
	color: #ff0000;
	margin-top: 3px;
}


span.loading {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	border-top: 5px solid rgba( 255, 255, 255, 0.2 );
	border-right: 5px solid rgba( 255, 255, 255, 0.2 );
	border-bottom: 5px solid rgba( 255, 255, 255, 0.2 );
	border-left: 5px solid #ffffff;
	-webkit-transform: translateZ( 0 );
	-ms-transform: translateZ( 0 );
	transform: translateZ( 0 );
	-webkit-animation: load-circle 1.0s linear infinite;
	animation: load-circle 1.0s linear infinite;
	position: absolute;
	top: 50%;
	left: 50%;
	margin-top: -30px;
	margin-left: -30px;
}

@-webkit-keyframes load-circle {
	0% {
		-webkit-transform: rotate( 0deg );
		transform: rotate( 0deg );
	}
	100% {
		-webkit-transform: rotate( 360deg );
		transform: rotate( 360deg );
	}
}

@keyframes load-circle {
	0% {
		-webkit-transform: rotate( 0deg );
		transform: rotate( 0deg );
	}
	100% {
		-webkit-transform: rotate( 360deg );
		transform: rotate( 360deg );
	}
}


/* -- for JavaScript ここまで -------------------------------------------------------------------------------- */


form#mail_form input[type="text"],
form#mail_form input[type="password"],
form#mail_form input[type="email"],
form#mail_form input[type="tel"] {
	max-width: 90%;
	padding: 7px 2%;
	border: 1px solid #cccccc;
	border-radius: 3px;
	background: #E8E8E8; /* fafafa; */
	-webkit-appearance: none;
	font-size: 100%;
	font-family: inherit;
	margin-top: 7px;
height:1.2em;
}

form#mail_form input[type="text"]:focus,
form#mail_form input[type="password"]:focus,
form#mail_form input[type="email"]:focus,
form#mail_form input[type="tel"]:focus,
form#mail_form textarea:focus {
	box-shadow: 0px 0px 5px #55ccff;
	border: 1px solid #55ccff;
	background: #ffffff;
}

form#mail_form ul li input[type="radio"],
form#mail_form ul li input[type="checkbox"] {
	margin-right: 10px;
	margin-top: 10px;
}

form#mail_form ul li:first-child input[type="radio"],
form#mail_form ul li:first-child input[type="checkbox"] {
	margin-top: 0px;
}

form#mail_form select {
	font-size: 100%;
	font-family: inherit;
	margin-top: 10px;
/*	background: #E8E8E8;  */
}

form#mail_form textarea {
	display: block;
	width: 90%;
	max-width: 90%;
	height: 200px;
	padding: 7px 2%;
	resize: vertical;
	border: 1px solid #cccccc;
	border-radius: 3px;
	background: #fafafa;
	-webkit-appearance: none;
	font-size: 100%;
	font-family: inherit;
}


form#mail_form ul {
	list-style-type: none;
}

form#mail_form ul li label:hover {
	cursor: pointer;
}


form#mail_form input#affiliation {
	width: 60%;
}

form#mail_form input#familyname,
form#mail_form input#givenname,
form#mail_form input#kana_family,
form#mail_form input#kana_given,
form#mail_form input#zip,
form#mail_form input#tel,
form#mail_form input#province {
	width: 30%;
}

form#mail_form input#city,
form#mail_form input#email,
form#mail_form input#email_check {
	width: 80%;
}

form#mail_form input#zip + a {
	display: inline-block;
	padding: 5px 15px;
	border: 1px solid #46b8da;
	border-radius: 3px;
	background: #5bc0de;
	font-size: 100%;
	color: #ffffff;
	text-decoration: none;
}

form#mail_form input#zip + a:hover {
	cursor: pointer;
	background: #31b0d5;
	border: 1px solid #269abc;
}

form#mail_form p#form_submit {
	width: 90%;
	margin: 0 auto;
	padding: 15px 0;
	border-top: 1px solid #cccccc;
}

form#mail_form input[type="button"] {
	padding: 7px 20px;
	border-radius: 6px;
	background: #02732A; /* 337ab7 */ 
	border: 1px solid #02732A;
	font-size: 100%;
	color: #fff;
	font-family: inherit;
	-webkit-appearance: none;
}

form#mail_form input[type="button"]:hover {
	cursor: pointer;
	border: 1px solid #02726D; /* 204d74 */
	background: #02726D; /* 286090 */
}

form#mail_form input#form_submit_button {
	margin-left: 35%;
}

.topTitle {
	font-size:1.5rem;
 	text-align:center;
	font-weight:bold;
}
.cp_hr01 {
	border-width: 1px 0 0 0;
	border-style:dotted;
	background-color:#F4F4F4;
	width:90%;
}
/* form#mail_form .office .company { */
form#mail_form .office {
        position: absolute;
	text-align:left;
	padding-top:4px;
	padding-bottom:4px;
        line-height:130%;
        left: 63%;
	width: 36%;
/*	transform: translateX(-50%); */
	display: inline-block;
	font-color:#333;
}
form#mail_form .infoBox {
	line-height:1.3;
	margin-top: 25px; 
}

form#mail_form .infoBox dt {
	font-size:1.2rem;
	color:#02732A;  /* #ff6600; */
}

form#mail_form .helpBox {
	padding: 10px 0;
	border: 1px solid #cccccc;
	border-radius: 7px;
/*	box-shadow: 0 0 7px rgba( 0, 0, 0, 0.2 ); */
	line-height:1.3;
	background: #FAFAD2;
}
form#mail_form .helpBox dt {
	text-align:center;
	font-size:1.0rem;
	color:#2F5CFC;
}

form#mail_form dd .accordion2 {
	padding-top: 10px; 
}
form#mail_form dd .accordion1 {
	padding-top: 10px; 
}

form#mail_form .title1 {
	padding-top: 5px;
	padding-bottom: 3px;
	padding-left: 29px;
	text-align: center;
	font-weight: bold;
	font-size:100%;
	color: #FF0000;
}
form#mail_form .title2 {
	font-weight: bold;
}
form#mail_form .title2help {
	font-weight: bold;
	line-height:1.2;
	text-indent: -2em;
	padding-left: 2em;
}
form#mail_form .notice_header1 {
	padding-top: 3px;
	padding-bottom: 3px;
	font-size:100%;
	padding-left: 1em;
	text-indent: -1em;

}
form#mail_form .notice_header2 {
	line-height: 1.3;
	padding: 2px
}
form#mail_form .notice_header2 li {
/*	padding-left: 15px; */
	text-indent: -1em;
	padding-left: 1em;
}
.personalInfo {
	text-align:center;
}

/* -- responsive ----------------------------------------------------------------------------------------------------------------- */

/* 1000pixel start */
@media screen and ( max-width: 1000px ) {

form#mail_form {
	width: 95%;
	font-size: 100%;
}

form#mail_form dl {
	overflow: visible;
}

form#mail_form dl dt {
	width: auto;
	float: none;
	text-align: left;
	padding: 15px 0 5px;
	font-weight: bold;
}

form#mail_form dl dd {
	width: auto;
	float: none;
	border-top: none;
	padding: 0px 0 20px 0px;
}

form#mail_form dl dt span {
	font-weight: normal;
}

/* -- for JavaScript ここから -------------------------------------------------------------------------------- */

form#mail_form dl dt span.required,
form#mail_form dl dt span.optional {
	margin-right: 1em;
	margin-bottom: 2em;
}


/* -- for JavaScript ここまで -------------------------------------------------------------------------------- */

form#mail_form input[type="text"],
form#mail_form input[type="email"],
form#mail_form input[type="tel"] {
	margin-top: 0px;
}

form#mail_form input#zip + a {
	padding: 6px 15px 5px;
}

form#mail_form input#form_submit_button {
	margin-left: 0;
}

form#mail_form select {
	font-size: 16px;
	margin-top: 0;
}

form#mail_form input#tel {
	width: 50%;
}

form#mail_form .settlement_error {
	text-align:center;
	width:360px; 
	margin-left:auto;margin-right:auto;
	margin-top:5px;
	margin-bottom:20px;
	padding: 12px 0px 10px 0px;
}

form#mail_form .office {
        position: absolute;
	font-color:#ff0000;
	text-align:left;
	padding-top:4px;
	padding-bottom:4px;
        line-height:130%;
        left: 10%;
	width: 80%;
/*	transform: translateX(-50%); */
	display: inline-block;
	font-size: 11px;
}
form#mail_form .personalInfo {
	text-align:left;
        line-height:130%;
	padding-left:12px;
	padding-right:9px;
}
}
/* 1000pixel end */


/* fujita */
form#mail_form dl dt .orange { color:#ff6600; }

form#mail_form dl dd .notice {
	font-size:13px;
	padding-top:2px;
	line-height: 1.4;
}
form#mail_form dl dd .line_middle {
	margin-top:14px;
	line-height: 1.4;
}

/*
#header {
	text-align: center;
	margin: 0px auto;
	padding-top: 20px;
	font-size:32px;
	color: #ffffff; 
	width: 100%;
	background: #4288C6; 
}
*/
#footer {
	clear: both;
	text-align: center;
	font-size: small;
	color: #0e3c53;
	padding: 7px 0px;
/*	margin: 30 0px 0; */
	margin: 0px auto;
}

.red    { color:#ff0000; }
.error {
	font-size:small;
	color:#fff;
	width:91%;
	padding-left: 4px;
	background: #ff2929;
	border-radius: 4px;
}

body {
	color: #454545; 
	background: #ECE69C; /* f0f0f0; */
	font-family:'Meiryo','メイリオ','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro',Verdana,'ＭＳ Ｐゴシック',sans-serif;line-height:1.5;color:#333;-webkit-text-size-adjust:none;
}

/* 確認ページ ***************************** */
form#mail_form .confirmMessage {
 	text-align:center;
	width: 90%;
	margin: 0 auto;
	font-weight:bold;
	font-size:1.0rem;
        color: #ff0000;
        line-height:170%;
}
@media screen and ( max-width: 1000px ) {
form#mail_form .confirmMessage {
 	text-align:left;
	width: 90%;
	margin: 0 auto;
	font-weight:bold;
	font-size:1.0rem;
        color: #ff0000;
        line-height:170%;
}
}

/* 完了ページ ***************************** */
form#mail_form .completeBox1 {
	text-align:left;
	width: 90%;
	margin: 0 auto;
	margin-top:5px;
	margin-bottom:20px;
        line-height:130%;
    font-weight:bold;
	font-size:120%;
}
form#mail_form .completeBox2 {
	text-align:left;
	width: 90%;
	margin: 0 auto;
	margin-top:5px;
	margin-bottom:20px;
/*	padding: 0px 0px 6px 52px; */
        line-height:130%;
	font-size:110%;
}
form#mail_form .completeBox3 {
	text-align:left;
	width: 90%;
	margin: 0 auto;
	margin-top:5px;
	margin-bottom:10px;
/*	padding: 8px 0px 1px 52px; */
	font-size:85%;
}
form#mail_form .office {
    position: relative;
	margin-top:0px;
	padding-top:0px;
	padding-bottom:5px;
	margin-bottom:10px;
	font-size: 0.9em;
}


/* エラーページ ***************************** */
form#mail_form .errorTitle {
	text-align:center;
	font-size:18px;
        color: #ff0000;
}
form#mail_form .errorDetail {
	text-align:left;
	font-size:16px;
        color: #333;
}


