@charset "UTF-8";

#contents{
	width: 960px;
	margin: 0 auto;
}

#main{
	margin: 20px 0;
}

#side{
}

footer{
	background-color: #226584;
	color: #ffffff;
	padding: 20px 0;
	text-align: center;
}

/* テーブルの横幅、thとtdの基本指定 */
table{
	width:100%;
}

.form{
	margin: 20px 0 0 0;
}
.form table th{
	width:35%;
	font-size: 108%;
	padding: 25px 10px 0;
	vertical-align:top;
}
	.form table th b{
		font-weight: normal;
		display: block;
	}

.form table td{
	width:82%;
	font-size: 108%;
	border-bottom: 1px solid #E5E5E5;
	padding: 17px 10px 17px;
	vertical-align:middle;
}

/* 各フィールドの横幅パターン */

.form table td .small{
	width:33%;
}
.form table td .medium{
	width:60%;
}
.form table td .large{
	width:95%;
}


/* パーツの余白調整 */
.form table td span {
    margin-right: 5px;
}
.form table td label {
    margin-right: 30px;
    vertical-align: text-top;
}

.form table td .label02 {
	margin-right: 20px;
    padding-top: 10px;
    vertical-align: text-top;
}



/* 必須項目 */
.form table th b {
	position:relative;
	padding-right:20%;
}
.form table th .required span{
	position:absolute;
	top:middle;
	right:0 ;
	top:0 ;
	/top:-5px ;
	background-color:#CC1800;
	color:#FFF;
	font-size:85%;
	padding:3px 7px;
}

.form table th b span{
	position:absolute;
	top:middle;
	right:0 ;
	top:0 ;
	/top:-5px ;
	background-color:#BCBCBC;
	color:#FFF;
	font-size:85%;
	padding:3px 7px;
}


/* 入力項目 */
.form input[type="text"],
.form input[type="email"], 
.form input[type="tel"],
.form textarea{
	background-color: #FFFFFF;
	border: 1px solid #CCCCCC;
	border-radius: 3px 3px 3px 3px;
	box-shadow: 2px 2px 2px 0 rgba(200, 200, 200, 0.2) inset;
	font-size: 100%;
	min-height: 14px;
	padding: 9px 11px;
}
.form .drop {
	padding: 4px;
	font-size:100%;
	border: 1px solid #CCCCCC;
	border-radius: 3px 3px 3px 3px;
	box-shadow: 2px 2px 2px 0 rgba(200, 200, 200, 0.2) inset;
}
.form input[type="text"]:focus, 
.form input[type="email"]:focus,
.form input[type="tel"]:focus,
textarea:focus {
   background-color: #EFEFEF;
}

/* ボタン類 */
.form_btn{
	text-align: center;
	margin: 40px 0;
}
.form_btn li{
	display: inline-block;
	/display: inline;
	/zoom: 1;
	margin: 0 10px 0 0;
}

.btn_confirm {
background: linear-gradient(#fdfdfd, #e7e7e7);
border: 1px solid #C1C1C1;
    border-radius: 4px 4px 4px 4px;
box-shadow: 0 0 3px 0 #FFFFFF inset;
    display: inline-block;
    font-size: 149%;
	width:430px;
    height: 62px;
    text-align: center;
	behavior: url(/form_template/css/PIE.htc);
	cursor: pointer;
margin-bottom: 50px;
}
.btn_submit {
background: linear-gradient(#fdfdfd, #e7e7e7);
    border: 1px solid #C1C1C1;
    border-radius: 4px 4px 4px 4px;
    box-shadow: 0 0 3px 0 #FFFFFF inset;
    display: inline-block;
    font-size: 149%;
    width: 280px;
    height: 62px;
    text-align: center;
    behavior: url(/form_template/css/PIE.htc);
    cursor: pointer;
	   margin-bottom: 20px;
}

.btn_back {
background: linear-gradient(#d7d7d7, #d7d7d7);
    border: 1px solid #C1C1C1;
    border-radius: 4px 4px 4px 4px;
    box-shadow: 0 0 3px 0 #FFFFFF inset;
    display: inline-block;
    font-size: 149%;
    width: 280px;
    height: 62px;
    text-align: center;
    behavior: url(/form_template/css/PIE.htc);
    cursor: pointer;
	   margin-bottom: 20px;
}
.postal_btn {
    border: 1px solid #C1C1C1;
    border-radius: 4px 4px 4px 4px;
    box-shadow: 0 0 3px 0 #FFFFFF inset;
    display: inline-block;
	padding:7px 2px 7px 7px;
	font-size:85%;
	background: #fdfdfd;
	background: -webkit-gradient(linear, 0 0, 0 bottom, from(#fdfdfd), to(#e7e7e7));
	background: -webkit-linear-gradient(#fdfdfd, #e7e7e7);
	background: -moz-linear-gradient(#fdfdfd, #e7e7e7);
	background: -ms-linear-gradient(#fdfdfd, #e7e7e7);
	background: -o-linear-gradient(#fdfdfd, #e7e7e7);
	background: linear-gradient(#fdfdfd, #e7e7e7);
	-pie-background: linear-gradient(#fdfdfd, #e7e7e7);
	width:15em;
	behavior: url(/form_template/css/PIE.htc);
	cursor: pointer;
}
	.postal_btn span{
		background: url("../img/icon_postal.png") no-repeat scroll 0 center;
		padding-left:15px;
	}


/* エラーリスト */
ul.error{
	background-color: #fae7e8;
	border: 1px solid #e72407;
	padding: 20px 20px;
}
ul.error li{
	color: #CC1800;
}
ul.error li a {
	color: #CC1800;
    text-decoration: underline;
}
ul.error li a:visited {
    color: #CC1800;
    text-decoration: underline;
}
ul.error li a:hover {
    color: #CC1800;
    min-height: 1em;
    text-decoration: none;
}

/* 各フィールドのエラーメッセージ */
span.error{
	color: #CC1800;
	display:block;
	margin-top:7px;
	font-size:86%;
}
tr.error{
	background-color:#fae7e8;
}

/* 見出し */
.form h2 {
	padding: 5px 0 30px 30px;
}


/* 個人情報保護方針 */
.form form div.privacy_policy {
	background-color: #F9F9F9;
	border: 1px solid #E5E5E5;
	height: 160px;
	line-height: 1.8em;
	overflow-y: scroll;
	padding: 20px 80px;
	width: 740px;
}
.form form div.privacy_policy h2{
	margin-top:15px !important;
	padding: 0 0 5px 0;
	font-size:124%;
	font-weight:bold;

	background:none !important;
    border:none;
    color: #121212;
	margin-top:30px;
}
.form form div.privacy_policy h3{
	padding-top:15px;
	padding-bottom: 5px;
	font-size:108%;
	font-weight:bold;
}


/* 説明文 */
.info{
	margin: 10px 0;
}


/* ステップ表示 */
.progress{
	margin: 20px 0;
}
.progress img{
	margin: 20px 0;
	width: 100%;
}
/* 入力補助 */
.form table td .note{
	color: #999999;
	display:inline-block;
	margin-bottom:5px;
}

.tab{
	list-style-type: none;
}
.tab li{
	display: inline-block;
	background-color: #D2D3D2;
	border-radius: 5px;
}
.tab li a{
	display: block;
	padding: 10px;
	color: #fff;
	font-size: 2rem;
}
.tab li.active{
	background-color: #08588F;
}

form .file-wrap {
	padding: 10px 5px;
	border-bottom: 1px solid #ddd;
}
form .file-wrap:last-child {
	padding-bottom: 0;
	border-bottom: 0;
}
form .file-wrap .file-name {
	margin: 0 5px 5px 5px;
}
form .file-wrap .file-info button {
	border: 1px solid #C1C1C1;
    border-radius: 4px 4px 4px 4px;
    box-shadow: 0 0 3px 0 #FFFFFF inset;
    display: inline-block;
	padding:4px 8px 4px 8px;
	font-size:80%;
	background: #fdfdfd;
	background: -webkit-gradient(linear, 0 0, 0 bottom, from(#fdfdfd), to(#e7e7e7));
	background: -webkit-linear-gradient(#fdfdfd, #e7e7e7);
	background: -moz-linear-gradient(#fdfdfd, #e7e7e7);
	background: -ms-linear-gradient(#fdfdfd, #e7e7e7);
	background: -o-linear-gradient(#fdfdfd, #e7e7e7);
	background: linear-gradient(#fdfdfd, #e7e7e7);
	-pie-background: linear-gradient(#fdfdfd, #e7e7e7);
	behavior: url(/form_template/css/PIE.htc);
	cursor: pointer;
}

/* 上部固定ナビ対策 
  padding-topの値に、ナビの高さを入力する  
*/
/*
@-webkit-keyframes modify{
	0% { padding-top: 75px; margin-top: -75px; }
	100% { padding-top: 0; margin-top: 0; }
}
@keyframes  modify{
	0% { padding-top: 75px; margin-top: -75px; }
	100% { padding-top: 0; margin-top: 0; }
}
input:target {
	-webkit-animation: modify 0.1s;
	animation: modify 0.1s;
}
*/


/* 追記 */

#wrapperBg {
background:url(img/bg_under.jpg) no-repeat center top;
}

#contents.wide {
background:url(img/bg_category.jpg) no-repeat center top;
}

body#contact #side {
margin-top:0;
}

#categoryTtl {
height:200px;
}

body#contact #contents {
margin:0 auto 0px !important;
}

body#contact .mainBox {
background:url(img/bg_mainBox.gif) #FFF no-repeat top left;
padding-top:20px;
padding-bottom:20px;
margin-bottom:20px;
}

#telBox .fl {
width:430px;
position:relative;
}

#telBox .fl h2 {
margin-bottom:15px;
}

#telBox .fl p#telProduct {
position:absolute;
top:57px;
left:164px;
}

#telBox .fr {
width:230px;
}

#telBox .fr h2 {
margin-bottom:15px;
}

#telBox .fr #telCompany,
#telBox .fr #telBuy {
margin-left:20px;
}

#telBox .fr #telBuy {
margin-top:44px;
}


#formInBox {
padding:20px;
border-top:1px solid #008444;
background:#FFFFFF;
position:relative;
}

#formInBox h2 {
margin-bottom:15px;
}

#formInBox #formInBtn {
position:absolute;
top:143px;
left:38px;
z-index:2;
}


/* ////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// お問い合わせフォーム */

#desc p {
margin-bottom:10px;
position:relative;
}

#desc p span {
padding-left:35px;
}

#desc img {
position:absolute;
top:3px;
left:0;
}

#formBox {
width:660px;
margin:0px;
/*padding:20px 20px;*/
background:#FFFFFF;
}

#formBox table {
width:660px;
}

#formBox table th {
background:url(img/line_form.gif) repeat-x left bottom;
padding:14px 20px 12px;
font-size:93%;
font-weight:bold;
vertical-align:top;
width:210px;
color:#333333;
}

#formBox table td {
background:url(img/line_form.gif) repeat-x left bottom;
padding:12px 20px;
font-size:93%;
width:310px;
}

#formBox table th.mdl {
width:50px;
}

#formBox table td.mdl {
width:130px;
}

#formBox table td.req {
width:40px;
padding:15px 0 0;
padding-right:19px;
vertical-align:top;
}

#formBox table td span {
display:block;
margin-top:3px;
}

#formBox table td img {
float:right;
}

input.sizeS,
textarea.sizeS {
width:50px;
}

input.sizeM,
textarea.sizeM {
width:350px;
}

input.sizeS,
textarea.sizeS,
input.sizeM,
textarea.sizeM,
select {
font-size:100%;
border:1px solid #e5e5e5;
border-top:1px solid #cccccc;
border-left:1px solid #cccccc;
padding:5px;
background:#f5f5f5;
}

#errorBox {
width:618px;
margin:25px 0px 25px;
background:#fae7e8;
padding:20px;
border:1px solid #ea959a;
}

#errorBox ul {
margin:16px 23px 0;
}

#errorBox ul li {
list-style:disc;
margin-top:4px;
font-weight:bold;
}

#errorBox ul li a {
color:#d0111b;
}

.btn {
margin-top:20px;
width:660px;
}

.btn p#confirmBtn {
margin-left:125px;
}

.btn p#confirmBtn input {
background-image: url(/contact/form/img/btn_confirm.gif);
background-repeat: no-repeat;
width: 410px;
height: 41px;
border: 0;
cursor: pointer;
}

.btn p.fl {
padding-left:50px;
}

.btn p.fr {
padding-right:50px;
}

table#confirm th {
width:200px;
}

table#confirm td {
width:460px;
}

#completeBox h2 {
font-weight:bold;
color:#000000;
font-size:123.1%;
line-height:1.4;
}

#completeBox ul {
margin:30px;
}

#completeBox ul li {
list-style:outside disc;
}

.sp_br{
display: none;
}

.form table td.q2_list {
	border-bottom: 0;
}

@media screen and (max-width: 767px) {

#headerIn,#contents,#main,#pkz ul,#pagetop img {
    width: 100%;
}

#headerIn #hnavi,#headerIn #navi,#side,#contactsBox,#footer{
		display: none;
}

	#header{
padding-left: 3%;
padding-bottom: 2%;
}

	#contact-main{
    margin-left: 1%;
    margin-right: 1%;
}

	#underTtl{
		width: 65%;
	}
	#underTtl .engTxt{
		margin-left: 5px;
	}
#pkz{
	   padding-top: 1%;
}
#pkz ul li#home{
    margin-left: 3%;
}
	
	#formTable th{
		width: 85%;
	}

.form table td .medium {
    width: 90%;
}

.form table td div {
	margin-left: 1.4em;
	text-indent: -1.4em;
}

.btn_confirm {
width: 100%;
	}

	.form_btn li{
		width: 100%;
	}
	
.sp_br{
display: block;
}
	
#underTtl .fl {
line-height: 1.3;
}
.mainBox {
padding: 35px 5px 0;
}
.form table td {
	width: 100%;
}

.form table td .large{
	width:100%;
}
.form table td.q2_list {
	width: 88%;
	border-bottom: 0;
}

.form table th b {
	padding-right:0;
}

.form table th .required span{
	right:-50px ;
}
	
}