@charset "UTF-8";
/*----------------------------------------------------------------------------------------------------------
 contact.html 20230825
----------------------------------------------------------------------------------------------------------*/

body.contact #contact-title {
	margin: 90px auto 70px;
}
body.contact #contact-title h3 {
	text-align: center;
	font-size: 36px;
	font-size: 3.6rem;
	letter-spacing: 0.2em;
	color: #808080;
	line-height: 1.666666667;
	font-family: source-han-serif-japanese, serif;
}

body.contact #contactbox .inner {
	max-width: 942px;
}
body.contact .formbox table {
	width: 100%;
	margin: 0;
	font-size: 16px;
	font-size: 1.6rem;
}
body.contact .formbox table th  {
	width: 28%;
	padding: 30px 0 30px 50px;
	font-size: 16px;
	font-size: 1.6rem;
	color: ##4d4d4d;
	line-height: 1.5em;
	text-align: left;
	border-bottom: solid 1px #4d4d4d;
	vertical-align: top;
}
body.contact .formbox table td {
	width: 70%;
	padding: 30px 50px;
	font-size: 16px;
	font-size: 1.6rem;
	color: #4d4d4d;
	line-height: 1.5em;
	text-align: left;
	border-bottom: solid 1px #4d4d4d;
	vertical-align: middle;
}

body.contact .formbox table select {
	padding: 6px 5px;
	border: solid 1px #fff;
	background: #fff;
}
body.contact .formbox table label {
	display: inline-block;
	width: 48%;
	padding: 5px 0;
}
body.contact .formbox table label input {
	width: auto;
	padding: 6px 30px 6px 5px;
	border: solid 1px #fff;
}
body.contact .formbox table label span {
	padding-right: 4px;
}

body.contact .formbox table span.hss {
	margin: 0 0 0 4px;
	padding: 0;
	font-size: 10px;
	color: ##4d4d4d;
	vertical-align: super;
}


body.contact .formbtmtxt {
	width: 90%;
	margin: 0;
	padding: 20px 0 20px 48px;
}

body.contact .formppbox {
	margin: 60px 0 50px;
}
body.contact .formppbox h3 {
	font-size: 16px;
	font-size: 1.6rem;
	color: #4d4d4d;
	text-align: center;
}
body.contact .formppbox .ppintxt {
	width: 100%;
	margin: 40px 0 30px;
	padding: 40px 50px;
	line-height: 1.8em;
	border: solid 1px #4d4d4d;
}
body.contact .formppbox .ppcapttxt {
	line-height: 1.6em;
	text-decoration: underline;
	text-align: center;
}

body.contact .formbtnbox {
	width: 50%;
	margin: 40px auto;
	line-height: 1.5em;
	text-align: center;
}
body.contact .formbtnbox div {
	margin: 10px 0;
}
body.contact .bsubmit2 {
	display: block;
	width: 100%;
	border: 1px solid #00B496;
	color: #00B496;
	text-align: center;
	padding: 27px 0;
	position: relative;
	cursor: pointer;
	overflow: hidden;
	background: transparent;
	transition: color 0.3s cubic-bezier(0.38, 0.005, 0.215, 1) 0.2s;
}
body.contact .bsubmit2:before {
	content: "";
	position: absolute;
	width: 200%;
	height: 200%;
	background: #00B496;
	top: -100%;
	left: -116%;
	z-index: 0;
	-webkit-transform: rotate(-60deg);
	-moz-transform: rotate(-60deg);
	-ms-transform: rotate(-60deg);
	-o-transform: rotate(-60deg);
	transform: rotate(-60deg);
	transition: all 0.6s cubic-bezier(0.38, 0.005, 0.215, 1);
}
body.contact .bsubmit2 span {
	font-size: 1.2em;
}
body.contact .bsubmit2:hover {
	opacity: 1;
	color: #fff !important;
}
body.contact .bsubmit2:hover:before {
	-webkit-transform: rotate(0deg);
	-moz-transform: rotate(0deg);
	-ms-transform: rotate(0deg);
	-o-transform: rotate(0deg);
	transform: rotate(0deg);
	width: 300%;
	height: 200%;
	left: -100%;
	transition: all 0.6s cubic-bezier(0.38, 0.005, 0.215, 1);
}
body.contact .bsubmit2:hover span {
	position: relative;
	z-index: 1;
	background: transparent;
}


.backbtnbox {
	width: 50%;
	margin: 0 auto;
	padding: 30px 0;
}
.backbtnbox .submbtn {
	display: block;
	width: 100%;
	color: #fff;
	padding: 16px 0;
	background: #3d3d3d;
		-moz-border-radius: 4px;
		-webkit-border-radius: 4px;
	border-radius: 4px;
	border: 1px solid #3d3d3d;
	cursor: pointer;
}
.submbtn {
	display: block;
	width: 200px;
	color: #111;
	padding: 16px 0;
	background: #eee;
		-moz-border-radius: 4px;
		-webkit-border-radius: 4px;
	border-radius: 4px;
	border: 1px solid #ddd;
	cursor: pointer;
}
.submbtn:hover {
	color: #fff;
	background: #999;
}

.contactmsg {
	padding: 0 0 20px;
	font-size: 13px;
	font-size: 1.3rem;
	text-align: center;
}

.errbox {
	position: relative;
	width: 80%;
	margin: 50px 10%;
	padding: 50px 80px;
	outline: 3px solid #ccc;
	outline-offset: -1.5rem;
	border-box: box-sizing;
}
.errbox::before {
	position: absolute;
	top: 0rem;
	left: 50%;
	transform: translateX(-50%);
	padding: 0.5rem 1rem;
	background: #fff;
	color: #ff0000;
	font-size: 22px;
	font-size: 2.2rem;
	letter-spacing: 0.2em;
	content: attr(data-title);
}
.errbox div {
	color: #333;
	line-height: 1.6;
}


.thanksbox {
	position: relative;
	width: 80%;
	margin: 50px 10%;
	padding: 50px 80px;
	outline: 3px solid #ccc;
	outline-offset: -1.5rem;
	border-box: box-sizing;
}
.thanksbox::before {
	position: absolute;
	top: 0rem;
	left: 50%;
	transform: translateX(-50%);
	padding: 0.5rem 1rem;
	background: #fff;
	color: #333;
	font-size: 22px;
	font-size: 2.2rem;
	letter-spacing: 0.2em;
	content: attr(data-title);
}
.thanksbox div {
	color: #333;
	line-height: 1.6;
	text-align: center;
}


.backlink {
	padding: 10px 0;
	text-align: center;
}
body.contact input[type="text"],
body.contact input[type="email"],
body.contact input[type="number"] {
	padding: 0;
	border: none;
	border-radius: 0;
	outline: none;
	background: none;
	border: solid 1px #ccc;
	border: none !important;
}
body.contact table textarea {
	width: 90%;
	margin: 0 auto;
	padding: 8px 5px !important;
	background: #fff;
	border: solid 1px #ccc;
	border: none !important;
	border-radius: 2px;
}
.imeon {
	ime-mode: active;
}
.imeoff {
	ime-mode: disabled;
}
.ipt01 {
	width: 94% !important;
	padding: 8px 5px !important;
}
.ipt02 {
	width: 60% !important;
	padding: 8px 5px !important;
}
.ipt03 {
	width: 40% !important;
	padding: 8px 5px !important;
}
.ipt04 {
	width: 10% !important;
	padding: 8px 5px !important;
}
.ipt05 {
	width: 400px !important;
	padding: 8px 5px !important;
}


/**
 * !!! ブレークポイント !!!
 */

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

}

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

}
@media only screen and (max-width: 950px) {

body.contact #contact-title h3 {
	text-align: center;
	font-size: 30px;
	font-size: 3.0rem;
	letter-spacing: 0.1em;
	line-height: 1.20;
}


}
@media only screen and (max-width: 768px) {


body.contact .formbox table th  {
	display: block;
	width: 100%;
	padding: 20px 0 8px 10px;
	color: ##4d4d4d;
	line-height: 1.5em;
	border-bottom: dotted 1px #999;
}
body.contact .formbox table td {
	display: block;
	width: 100%;
	padding: 8px 20px 20px;
	font-size: 1.0em;
	color: ##4d4d4d;
	line-height: 1.5em;
}
body.contact .formppbox .ppintxt {
	padding: 20px 30px;
	line-height: 1.6em;
}

body.contact .formbtnbox {
	width: 100%;
	margin: 40px auto;
	line-height: 1.5em;
	text-align: center;
}

}
