@charset "utf-8";
*, *:before, *:after {
	/*-webkit-appearance: auto!important;*/
}
input[type="submit"] {
    -webkit-appearance: none!important;
}
/* =============================================================================
	お問い合わせ
   ========================================================================== */
.contact .keyimages {background:#caf3ff;}
.contact .keyimages h2 {height: 250px;position: relative;text-align: center;	
}
.contact .keyimages h2 span.box {
	display: inline-block;
    margin: 107px 0;
}


#contact01 {
	padding-top: 60px;
	padding-bottom: 60px;
	background: #f7f7f7;
	margin: 0 auto;
	text-align: center;
	position: relative;
}
#contact01:after {
    border: 50px solid transparent;
        border-top-color: #f7f7f7;
        border-bottom-width: 0;
        bottom: -50px;
        content: "";
        display: block;
        left: 50%;
        position: absolute;
	margin-left: -50px;
        width: 0;
}
#contact01 ul {
	margin: 0 auto;
	max-width: 592px;
	text-align: left;
	padding-bottom: 50px;
	position: relative;
}

#contact01 ul li {
	position: relative;
	font-size: 20px;
	font-weight: bold;
	line-height: 2.4em;
	letter-spacing: 0.02em;
}
#contact01 ul li:before {
	position: absolute;
    top: 0;
	bottom: 0;
	left: -40px;
	margin: auto;
	content: "";
	vertical-align: middle;
	width: 21px;
	height: 20px;
	background: url(../img/contact/icon-check.png) no-repeat 0 100%;
	background-size: cover;
	z-index: 1;	
}
#contact01 ul li span {
	background: linear-gradient(transparent 60%, #f4ff3d 0%);
	line-height: 1em;
}
#contact01 .contact01-txt {
	font-size: 29px;
	font-weight: bold;
	padding-top: 50px;
	display: inline-block;
	border-bottom: solid 6px #ff7f2a;
}
@media screen and (min-width: 768px) {
	#contact01 ul:before {
		position: absolute;
    top: 81px;
	bottom: 0;
	left: -281px;
	margin: auto;
	content: "";
	vertical-align: middle;
	width: 209px;
	height: 325px;
	background: url(../img/contact/img-contact01-1.png) no-repeat 0 100%;
	background-size: cover;
	z-index: 1;	
}
	#contact01 ul:after {
		position: absolute;
    top: 81px;
	bottom: 0;
	right: -281px;
	margin: auto;
	content: "";
	vertical-align: middle;
	width: 244px;
	height: 367px;
	background: url(../img/contact/img-contact01-2.png) no-repeat 0 100%;
	background-size: cover;
	z-index: 1;	
}
}


@media screen and (max-width: 767px) {
	.contact .keyimages h2 {height: 150px;}
    .contact .keyimages h2 span.box {padding: 62px 0;margin: 0}
	.contact h2 img {
	height: 25px;
	}
	
	#contact01 {
		padding: 30px 0;
	}
	#contact01 ul {
		width: 100%;	
		padding-left: 40px;
		padding-bottom: 30px;
	}
	#contact01 ul li {
		font-size: 16px;
		line-height: 1.6em;
		padding-bottom: 10px;
	}
	#contact01 ul li:before {
		top: 0;
		margin: 0;
	}
	#contact01 .contact01-txt {
		font-size: 24px;
	}
	#contact01:after {
    border: 30px solid transparent;
    border-top-color: #f7f7f7;
    border-bottom-width: 0;
    bottom: -30px;
    content: "";
    display: block;
    left: 50%;
    position: absolute;
    margin-left: -30px;
    width: 0;
}
	
}


/*電話でのお問い合わせ*/
#contact02 {
	padding: 80px 0;
	text-align: center;
}
#contact02 .contact02-tel {
	color: #555558;
	font-size: 22px;
	font-weight: bold;
	padding: 50px 0;
	border: 3px dotted #009cc9;
	max-width: 600px;
	margin: 0 auto;
	margin-bottom: 30px;
}
#contact02 .contact02-tel .img {
	padding: 16px 0;
}
#contact02 .contact02-tel span {
	color: #0070ba;
	font-size: 18px;
}
#contact02 .contact02-tel small {
	font-size: 16px;
	color: #555558;
}
#contact02 h3 {
	font-size: 22px;
	color: #ff7f2a;
	font-weight: bold;
	padding-bottom: 10px;
}
#contact02 p {
	font-size: 15px;
}

@media screen and (min-width: 768px) {

}

@media screen and (max-width: 767px) {
	#contact02 {
		padding-top: 50px;
		padding-bottom: 30px;
	}
	#contact02 .contact02-tel {
		padding: 30px 0;
		font-size: 20px;
	}
	#contact02 .contact02-tel .img {
		padding: 14px;
	}
	#contact02 .contact02-tel span {
		font-size: 16px;
	}
	#contact02 .contact02-tel small {
		font-size: 14px;
	}
	#contact02 h3 {
		font-size: 20px;
	}
	#contact02 p {
		text-align: left;
	}
	
}

/*お問い合わせフォーム*/
#contact03 {
	padding-bottom: 80px;
}
#contact03 p {
	text-align: center;
	padding-bottom: 30px;
}
#contact03 p a {
	text-decoration: underline;
	color: #0080cc;
}
#contact03 .submit {
	text-align: center;
	position: relative;
	margin-bottom: 15px;
	display: inline-block;
    width: 234px;
    height: 41px;
	margin: 10px; margin-top: 40px;
}
#contact03 .submit:after {
	position: absolute;
    top: 3px;
    bottom: 0;
    right: 20px;
    margin: auto;
    content: "";
    vertical-align: middle;
    width: 8px;
    height: 8px;
    border-top: 3px solid #fff;
    border-right: 3px solid #fff;
    -webkit-transform: rotate(
45deg);
    transform: rotate(
45deg);
    z-index: 1;
}
#contact03 .submit input {position: relative; color: #fff;cursor: pointer; border: none;font-size: 18px; display: inline-block;text-align: center; padding: 10px 50px;background-color: #00a0c9;-webkit-appearance: none;border-radius: 5px;}
#contact03 .submit input:hover {background-color: #2b975b;transition:all .5s ease;}
#contact03 label.error {color: #fe0030;}

#contact03 .form {
	font-size: 15px;
}
#contact03 .form dd input {
	font-size: 15px;
}
#contact03 .form dd textarea {
	font-size: 15px;
}
#contact03 dt {
	position: relative;
}

#contact03 dt small {
	font-weight: normal;
	color: #555558;
	font-size: 15px;
}

#contact03 form .center {
	text-align: center;
	padding: 20px 0;
}


@media screen and (min-width: 768px) {
	#contact03 .form {
		max-width: 850px;
		margin: 0 auto;
	}
	#contact03 form dt span {
    position: absolute;
    top: 50%;
    right: 77px;
    transform: translate3d(0, -50%, 0);
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    text-align: center;
    width: 46px;
    background-color: #f2011d;
    color: #fff;
    display: inline-block;
    padding: 0 5px;
}
	#contact03 form dt .nini {
    position: absolute;
    top: 50%;
    right: -112px;
    transform: translate3d(0, -50%, 0);
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    text-align: center;
    width: 46px;
    background-color: #c4ccba;
    color: #1f2b20;
    display: inline-block;
    padding: 0 5px;
}
	#contact03 form .address .left dt span {
		right: -113px;
	}
	#contact03 form {
		padding-top: 50px;
		text-align: left;
	}
    #contact03 dl {width: 100%;letter-spacing: -0.4em;}
    #contact03 dt {padding: 20px 0;width: 34%;display: inline-block;letter-spacing: normal;vertical-align: top;font-weight: bold;}
    #contact03 dt span {color: #fff;padding-left:10px;font-weight: normal;}
    #contact03 dd {width: 66%;display: inline-block;letter-spacing: normal;vertical-align: top;}
	#contact03 dd input,#contact03 dd textarea {width: 100%;padding: 16px;border: none;background-color: #f7f7f7;}
		#contact03 dl .postalCode input {
		width: 45%;
	}
	#contact03 .address .left {
		float: left;
	padding: 20px 0;
    width: 34%;
    display: inline-block;
    letter-spacing: normal;
    vertical-align: top;
    font-weight: bold;
		position: relative;
	}
	#contact03 .address .left span {
		    position: absolute;
    top: 50%;
    right: 77px;
    transform: translate3d(0, -50%, 0);
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    text-align: center;
    width: 46px;
    background-color: #f2011d;
    color: #fff;
    display: inline-block;
    padding: 0 5px;
	}
	#contact03 .address .right {float: right;width: 66%;}
	#contact03 .address .right input {
		width: 100%;
    	padding: 16px;
    	border: none;
    	background-color: #f7f7f7;
		margin-bottom: 15px;
	}
	#contact03 .address .right input:first-child {
		width: 45%;
	}
	#contact03 .address .right dd {
		width: 100%;
		padding-bottom: 20px;
	}
	#contact03 .address .clear {clear: both;}
	#contact03 input[type="radio"],#contact03 input[type="checkbox"] {
    	width: auto;
		padding: 0;
}
}
@media screen and (max-width: 767px) {
	#contact03 {
		padding: 30px 0;
	}
	 #contact03 dl {width: 100%;}
    #contact03 dt {padding: 20px 0 10px;font-weight: bold; text-align: left;}
    
	#contact03 form dt span {
		right: 0 ;
	}
	#contact03 form dt span {
    text-align: center;
    width: 46px;
    background-color: #d01406;
    color: #fff;
    display: inline-block;
    padding: 0 5px;
	margin-left: 10px;
}
	
	#contact03 form dt .nini {
    text-align: center;
    width: 46px;
    background-color: #c4ccba;
    color: #1f2b20;
    display: inline-block;
    padding: 0 5px;
		margin-left: 10px;
}
	#contact03 input[type="radio"],#contact03 input[type="checkbox"] {
    	width: auto;
		padding: 0;
}
	#contact03 input[type="radio"] {
		width: auto;
	}
    #contact03 dd {padding: 0 0 10px;}

    #contact03 dd input[type=text],#contact03 dd input[type=email],#contact03 dd input[type=tel],#contact03 dd textarea {width: 100%;padding: 10px;border: none;background: #f7f7f7;}
	#contact03 .postalCode input {width: 100%;}
	#contact03 .address .left {
		padding: 20px 0 10px;
    	font-weight: bold;
    	text-align: left;
	}
	#contact03 .address .right input {
		width: 100%;
    	padding: 16px;
    	border: none;
    	background-color: #f7f7f7;
		margin-bottom: 15px;
	}
	#contact03 .address .right input:first-child {
		width: 90%;
	}
}



/* =============================================================================

   ========================================================================== */

@media screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}
/* =============================================================================

   ========================================================================== */
@media screen and (min-width: 1024px) {
}
@media screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}