@charset "utf-8";
/*------------------------------------------------------------
	contact
------------------------------------------------------------*/
.headLine01 {
	margin-bottom: 40px;
}
.contactBox {
	margin-bottom: 47px;
	padding: 56px 0 30px;
	position: relative;
}
.contactBox .content02 {
	margin-bottom: 0;
}
.contactBox p {
	margin-bottom: 34px;
	font-size: 1.8rem;
	line-height: 2;
	letter-spacing: 0.05em;
}
.contactBox .red {
	color: #ff0000;
}
.contactBox .info {
	margin-bottom: 22px;
}
.contactBox .info a {
	display: inline-block;
	color: #6d6d6d;
}
.contactBox .num {
	display: block;
	font-size: 4rem;
	font-weight: bold;
	line-height: 1;
	font-family: 'Roboto Condensed', sans-serif;
	color: #5c5c5c;
}
.contactBox .time {
	margin: 4px 0 0 33px;
	display: block;
	font-size: 1.2rem;
	letter-spacing: 0.05em;
}
.contactBox .num img {
	margin: 3px 8px 0 0;
}
.contactBox .writeBox {
	position: relative;
}
.contactBox .telBox p {
	margin-bottom: 0;
	line-height: 1.777;
	letter-spacing: 0;
}
.contactBox .telBox .imgBox {
	margin-bottom: 23px;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
}
.contactBox .writeBox .photoBox {
	position: absolute;
	top: -85px;
	right: 39px;
	z-index: 150;
}
.writeBox {
	padding: 40px 60px 85px 63px;
}
.contactBox .writeBox {
	padding: 42px 250px 30px 58px;
}
.alone {
	margin: 33px 0;
	font-size: 1.8rem;
	letter-spacing: 0.05em;
}
.contact.content02 {
	margin-bottom: 92px;
}
table {
	width: 100%;
	border-collapse: collapse;
}
.mailForm th {
	padding: 33px 10px 17px 47px;
	width: 35%;
	text-align: left;
	vertical-align: top;
	color: #585858;
	font-size: 1.8rem;
	font-weight: normal;
	letter-spacing: 0.05em;
	line-height: 1.56;
	background: url("../image/contact/text01.png") no-repeat left top 33px;
	border-bottom: 1px solid #eee;
}
.mailForm th.special {
	background: none;
}
.mailForm th.must {
	background: url("../image/contact/text01.png") no-repeat left top 33px;
}
.mailForm td {
	padding: 18px 0 17px;
	text-align: left;
	vertical-align: top;
	color: #585858;
	font-size: 1.8rem;
	letter-spacing: 0.05em;
	border-bottom: 1px solid #eee;
}
.mailForm td .textBox {
	margin: 10px 0 13px;
	padding: 25px 20px 25px 27px;
	width: 535px;
	font-size: 1.6rem;
	letter-spacing: 0.05em;
	line-height: 1.75;
	border: 1px solid #d1d1d1;
	border-radius: 5px;
	box-sizing: border-box;
}
.mailForm td .textBox .innerBox {
	height: 334px;
	width: 100%;
	position: relative;
}
.mailForm td .textBox .innerBox .subBox {
	height: 100%;
	width: 100%;
	overflow-y: auto;
	box-sizing: border-box;
}
.mailForm td .subBox p {
	margin-right: 25px;
}
.mailForm td .textBox .ttl {
	color: #ff6d64;
	font-weight: bold;
}
.mailForm td .textBox a {
	color: #585858;
}
.mailForm input[type="text"], .mailForm input[type="email"], .mailForm input[type="tel"] {
	appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
	width: 344px;
	height: 52px;
	padding: 0 20px;
	border: 1px solid #d1d1d1;
	border-radius: 5px;
	box-sizing: border-box;
	color: #585858;
	font-size: 1.8rem;
	letter-spacing: 0.05em;
}
.mailForm input[type="text"].wid, .mailForm input[type="email"].wid, .mailForm input[type="tel"].wid, .mailForm textarea.wid {
	width: 100%;
}
.mailForm input::-webkit-input-placeholder, .mailForm textarea::-webkit-input-placeholder {
	color: #b9b9b9;
	opacity: 1;
}
.mailForm input:-moz-placeholder, .mailForm textarea:-moz-placeholder {
	color: #b9b9b9;
	opacity: 1;
}
.mailForm input::-moz-placeholder, .mailForm textarea::-moz-placeholder {
	color: #b9b9b9;
	opacity: 1;
}
.mailForm input:-ms-input-placeholder, .mailForm textarea:-ms-input-placeholder {
	color: #b9b9b9;
	opacity: 1;
}
.mailForm textarea {
	appearance:none;
    -moz-appearance:none;
    -webkit-appearance:none;
	height: 382px;
	padding: 13px 20px;
	color: #585858;
	font-size: 1.8rem;
	letter-spacing: 0.05em;
	border: 1px solid #d1d1d1;
	border-radius: 5px;
	box-sizing: border-box;
	resize: vertical;
}
.mailForm select {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	width: 344px;
	height: 52px;
	padding: 0 40px 0 20px;
	color: #585858;
	font-size: 1.8rem;
	letter-spacing: 0.05em;
	border: 1px solid #d1d1d1;
	border-radius: 5px;
	box-sizing: border-box;
	background: url("../image/contact/icon01.png") no-repeat right 20px center;
}
select::-ms-expand {
	display: none;
}
.mailForm input[type="radio"], .mailForm input[type="checkbox"] {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	padding: 0;
	display: none;
}
.mailForm input[type="radio"] + span, .mailForm input[type="radio"]:checked + span, .mailForm input[type="checkbox"] + span, .mailForm input[type="checkbox"]:checked + span {
	margin-right: 15px;
	padding: 2px 0 0 28px;
	color: #585858;
	font-size: 1.6rem;
	letter-spacing: 0.05em;
	font-weight: normal;
}
.mailForm input[type="checkbox"] + span, .mailForm input[type="checkbox"]:checked + span {
	padding-left: 35px;
	font-size: 1.8rem;
}
.mailForm input[type="radio"] + span {
	background: url("../image/contact/icon02.png") no-repeat left center;
}
.mailForm input[type="radio"]:checked + span {
	background: url("../image/contact/icon03.png") no-repeat left center;
}
.mailForm input[type="checkbox"] + span {
	background: url("../image/contact/icon05.png") no-repeat left center;
}
.mailForm input[type="checkbox"]:checked + span {
	background: url("../image/contact/icon06.png") no-repeat left center;
}
.mailForm .choice input[type="text"] {
	margin-right: 10px;
	padding-right: 55px;
	background: url("../image/contact/icon04.png") no-repeat right 20px center;
}
.mailForm .tips {
	margin-top: 10px;
	color: #585858;
	font-size: 1.4rem;
}
.mailForm .top {
	margin: 15px 0 25px;
}
.mailForm .date p {
	margin: 25px 0 10px;
	font-size: 1.6rem;
}
.mailForm .date span {
	margin-right: 20px;
	font-size: 1.8rem;
	display: inline-block;
	font-weight: bold;
}
.mailForm input[type="submit"] {
	padding: 0;
	-webkit-appearance: none;
}
.mailForm .submit {
	text-align: center;
}
.mailForm .submit li {
	margin: 0 5px;
	display: inline-block;
}
.mailForm .submit li input {
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
	margin-top: 33px;
	width: 337px;
	height: 57px;
	text-align: center;
	color: #fff;
	font-size: 1.8rem;
	letter-spacing: 0.2em;
	border: 0;
	box-shadow: 0;
	border-radius: 25.5px;
	background: linear-gradient(90deg, rgb(105, 108, 247) 0%, rgb(59, 166, 237) 100%);
	cursor: pointer;
}
.mailForm .waring, .mailForm .errorTxt {
	margin: 13px 0 8px;
	padding-left: 20px;
	color: #ff0000;
	font-weight: 700;
	font-size: 2rem;
	display: block;
	background: url("../image/common/icon06.png") no-repeat left top 8px;
	letter-spacing: 0.05em;
}
.contactBox .snsline02 {
	margin-top: 15px;
	text-align: center;
}
.contactBox .snsline02 a {
}
.contactBox .snsline02 a img {
	width: 150px;
	height: auto;
}

@media all and (min-width: 897px) {
	.mailForm .submit li input:hover {
		opacity: 0.8;
	}
}
/*------------------------------------------------------------
	.comfirmBox
------------------------------------------------------------*/
.comfirmBox p {
	font-size: 1.8rem;
	letter-spacing: 0.05em;
}
.comfirmBox .text01 {
	margin: 0 -10px 42px 0;
}
.comfirmBox .text02 {
	line-height: 2;
}
.comfirmBox .text02:not(:last-child) {
	margin-bottom: 25px;
}
.comfirmBox .date li:not(:last-child) {
	margin-bottom: 13px;
}
.comfirmBox .date span {
	margin-right: 30px;
}
.comfirmBox .date .text04 {
	font-weight: 400;
}
.comfirmBox th, .comfirmBox td {
	padding: 29px 10px 29px 25px;
}
.comfirmBox th {
	padding-left: 45px;
	width: 30%;
	background-position: left top 30px;
}
.comfirmBox .writeBox {
	padding: 38px 63px 90px;
}
.comfirmBox .submit .reset input {
	background: linear-gradient(90deg, rgb(175, 175, 175) 0%, rgb(148, 148, 148) 100%);
}
/*------------------------------------------------------------
	.thanks
------------------------------------------------------------*/
.thanksBox.content02 {
	margin-bottom: 98px;
}
.thanksBox .headLine01 {
	margin-bottom: 38px;
}
.thanksBox .headLine02 {
	margin-bottom: 23px;
}
.thanksBox .writeBox {
	padding: 50px 10px 48px;
	text-align: center;
}
.thanksBox h4 {
	margin-bottom: 30px;
	font-weight: 500;
	font-size: 3rem;
	letter-spacing: 0.05em;
}
.thanksBox p {
	font-size: 1.8rem;
	line-height: 1.777;
	letter-spacing: 0.05em;
}
.thanksBox p:not(:last-child) {
	margin-bottom: 35px;
}
@media all and (max-width: 896px) {
	.content02 {
		margin: 0 25px;
		max-width: inherit;
	}
	.headLine01 {
		margin-bottom: 20px;
	}
	.contactBox {
		padding: 28px 0 25px;
	}
	.contactBox p {
		margin-bottom: 20px;
		font-size: 1.4rem;
		line-height: 1.714;
	}
	.borderBox {
		padding: 4px;
		border-radius: 10px;
	}
	.writeBox {
		padding: 0 20px 40px;
		border-radius: 5px;
	}
	.contactBox .writeBox {
		padding: 24px 16px 20px 22px;
	}
	.contactBox .num {
		font-size: 3.2rem;
	}
	.contactBox .num img {
		margin-right: 5px;
		width: 6.8%;
	}
	.contactBox .time {
		margin: 6px 0 0 0;
		font-size: 1.3rem;
	}
	.contactBox .telBox p {
		padding-right: 120px;
		font-size: 1.3rem;
		line-height: 1.538;
	}
	.contactBox .writeBox .photoBox {
		top: inherit;
		right: 15px;
		bottom: 0;
	}
	.contactBox .photoBox {
		width: 107px;
	}
	.mailForm th {
		padding: 20px 5px 0 35px;
		width: 100%;
		display: block;
		font-size: 1.4rem;
		border: 0;
		background-position: left top 22px;
		background-size: 26px auto;
		box-sizing: border-box;
	}
	.mailForm th.must {
		background-position: left top 22px;
		background-size: 26px auto;
	}
	.mailForm td {
		padding: 13px 0 15px;
		display: block;
		font-size: 1.4rem;
	}
	.mailForm select {
		width: 100%;
		height: 40px;
		font-size: 1.4rem;
		background-size: 16px auto;
	}
	.mailForm input[type="text"], .mailForm input[type="email"], .mailForm input[type="tel"] {
		width: 100%;
		height: 40px;
		font-size: 1.4rem;
	}
	.mailForm td .textBox {
		width: 100%;
		font-size: 1.3rem;
	}
	.mailForm textarea {
		font-size: 1.4rem;
		height: 200px;
	}
	.mailForm .tips {
		font-size: 1.3rem;
	}
	.mailForm .date li:not(:last-child) {
		margin-bottom: 11px;
	}
	.mailForm .date p {
		margin-bottom: 9px;
		font-size: 1.3rem;
	}
	.mailForm .date p span {
		display: block;
		font-size: 1.4rem;
	}
	.mailForm .choice input[type="text"] {
		margin-bottom: 10px;
		background-position: right 10px center;
		background-size: 22px auto;
	}
	.mailForm input[type="radio"] + span {
		background: url("../image/contact/icon02.png") no-repeat left center;
		background-size: 16px auto;
	}
	.mailForm input[type="radio"]:checked + span {
		background: url("../image/contact/icon03.png") no-repeat left center;
		background-size: 16px auto;
	}
	.mailForm input[type="radio"] + span, .mailForm input[type="radio"]:checked + span, .mailForm input[type="checkbox"] + span, .mailForm input[type="checkbox"]:checked + span {
		padding-left: 23px;
		font-size: 1.4rem;
		background-size: 16px auto;
	}
	.mailForm .top {
		margin-right: -10px;
		font-size: 1.4rem;
	}
	.mailForm .submit li {
		margin: 0 4px;
		width: 100%;
	}
	.mailForm .submit li input {
		max-width: 400px;
		width: 100%;
		font-size: 1.6rem;
	}
	.mailForm td .subBox p {
		margin-right: 5px;
	}
	.alone {
		font-size: 1.4rem;
	}
	.mailForm .waring {
		font-size: 1.5rem;
		background-size: 15px auto;
	}
	.comfirmBox .text01 {
		margin-bottom: 17px;
		font-size: 1.4rem;
		line-height: 1.741;
	}
	.comfirmBox .text02 {
		font-size: 1.4rem;
	}
	.content02 {
		margin-bottom: 0;
	}
	.thanksBox .headLine01 {
		margin-bottom: 22px;
	}
	.thanksBox .headLine02 {
		margin-bottom: 16px;
	}
	.thanksBox .writeBox {
		padding: 40px 25px 35px;
		text-align: left;
	}
	.thanksBox h4 {
		margin-bottom: 15px;
		font-size: 1.6rem;
		text-align: center;
		font-weight: 700;
	}
	.thanksBox p {
		font-size: 1.4rem;
	}
	.thanksBox p:not(:last-child) {
		margin-bottom: 22px;
	}
	.comfirmBox .writeBox {
		padding: 5px 20px 40px;
	}
	.comfirmBox .mailForm .submit li {
		width: 45%;
	}
	.mailForm .waring, .mailForm .errorTxt {
		font-size: 1.4rem;
	}
	.mailForm .waring, .mailForm .errorTxt {
		background-position: left top 4px;
	}
	.contactBox .snsline02 {
		padding-right: 0;
		text-align: center;
	}
	.contactBox .snsline02 a img {
		width: 120px;
		height: auto;
	}
}
.jspVerticalBar {
	width: 14px;
	background-color: #fff;
}
.jspTrack {
	background-color: #ececec;
	border-radius: 10px;
	width: 6px;
	margin-left: 3px;
}
.jspDrag {
	background-color: #b2b2b2;
	border-radius: 10px;
}
.jspVerticalBar .jspArrow {
	position: relative;
	top: -6px;
	height: 12px;
	width: 12px;
	border-radius: 50%;
	background-color: #d5d5d5;
}
.jspVerticalBar .jspArrowDown {
	top: auto;
	bottom: -6px;
}
.jspCap {
	display: block;
	height: 6px;
}