@charset "UTF-8";

/* ---------------------------------------
  contact
-----------------------------------------*/


/* pagettl
--------------------------------*/

@media screen and (max-width: 768px) {
	#pagettl .ico img {
		width: 16vw;
	}
}


/* contents
--------------------------------*/

#contact {
	padding: 50px 0 120px;
}

#contact .lead {
	width: 780px;
	margin: 0 auto;
}

#contact .lead .txt {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 2.125;
	letter-spacing: 0;
}

#contact .lead .btn {
	margin-top: 30px;
}

.form_wrap {
	margin-top: 100px;
	background-color: #cfe6ec;
	position: relative;
	padding: 0 204px 70px;
}

.form_wrap .formttl {
	font-size: 3.6rem;
	position: relative;
	top: -1em;
}

.form_wrap>.txt {
	font-size: 1.6rem;
	line-height: 2.125;
	letter-spacing: 0.05em;
}


/*form*/

.form {
	margin: 0 auto;
	margin-top: 30px;
	background-repeat: repeat-x;
	background-image: linear-gradient(to right, #4c4948, #4c4948 1px, transparent 1px, transparent 3px);
	background-size: 3px 1px;
	background-position: left top;
}

.form .box {
	padding: 30px 0;
	position: relative;
	background-repeat: repeat-x;
	background-image: linear-gradient(to right, #4c4948, #4c4948 1px, transparent 1px, transparent 3px);
	background-size: 3px 1px;
	background-position: left top;
}

.form .box dl {
	display: flex;
	justify-content: space-between;
		align-items: center;
}

.form .box dl+dl {
	margin-top: 20px;
}

.form .box dl dt,
.form .box dl dd,
.form .box dl dd p {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.5;
}

.form .box dl dd p {
	line-height: 1;
}

.form .box dl dt {
	width: 244px;
}

.form .box dl dt .must {
	display: inline-block;
	color: #fff;
	background: #cdb07c;
	font-weight: 400;
	font-size: 1.2rem;
	letter-spacing: 0.1em;
	padding: 0 .275em;
	height: 17px;
	line-height: 17px;
	margin-left: 1em;
	background-color: #e60012;
}

.form .box dl dd {
	width: 548px;
}

.form .box dl.phone dd {
	display: flex;
}

.form .box dl dd.flex {
	justify-content: space-between;
}

.form .box dl dd.flex p{
	max-width: 49%;
}

.form .box dl dd span.txt {
	display: inline-block;
	min-width: 3em;
}

.form input[type="text"],
.form input[type="email"],
.form input[type="tel"],
.form select,
.form textarea {
	background: #fff;
	height: 48px;
	border: 1px solid #bfbfbf;
	padding: .5em 1em;
	width: 100%;
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.875;
}

.form input.short {
	width: 214px;
}

.form input.short2 {
	width: 129px;
}

::placeholder {
	color: #d2d2d3;
}

:-ms-input-placeholder {
	color: #d2d2d3;
}

::-ms-input-placeholder {
	color: #d2d2d3;
}


/*textarea*/

.form .message textarea {
	height: 330px;
	resize: vertical;
	overflow: auto;
}


/*check*/

.form .checkwrap {
	margin: -8px 0;
}

.form .checkwrap li {
	line-height: 1;
}

.form .checkwrap li+li {
	margin-top: 5px;
}

.form .checkwrap label {
	position: relative;
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 1.875;
}

.form input[type=checkbox] {
	position: absolute;
	top: 0;
	left: 0;
	width: 1px;
	visibility: hidden;
}

.form input[type=checkbox]+span {
	display: inline-block;
	position: relative;
	padding-left: 34px;
	cursor: pointer;
	line-height: 1.875;
}

.form input[type=checkbox]+span::before {
	content: "";
	position: absolute;
	top: 6px;
	left: 0;
	border: 2px solid #4c4948;
	border-radius: 50%;
	width: 20px;
	height: 20px;
	background-color: #fff;
}

.form input[type=checkbox]:checked+span::after {
	content: "";
	position: absolute;
	top: 11.4px;
	left: 5.4px;
	width: 10px;
	height: 10px;
	background-color: #0468b6;
	border-radius: 50%;
}


/*address*/

.form .box .address dd span.ttl {
	display: block;
	min-width: inherit;
	margin: 0 0 .8em;
}
.form .box .address p.post{
/*	display: flex;*/
}
.form .box .address p+p {
	margin-top: 25px;
}

.form .box .address .post_btn {
	display: inline-block;
	margin-left: 40px;
}

.form .box .address .post_btn input[type='button'] {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	position: relative;
	color: #4c4948;
	font-weight: 500;
	font-size: 1.6rem;
	letter-spacing: 0.1em;
	width: 177px;
	height: 48px;
	border-radius: 24px;
	background-color: #ffc93c;
	transition: .3s ease;
	cursor: pointer;
}

.form .box .phone span.txt,
.form .box .address span.txt {
	min-width: inherit;
	display: inline-block !important;
	font-weight: bold;
	margin: .7em .5em 0;
}


/*privacy*/

.form .privacy {
	border: none;
	padding: 30px 0 0;
	background-repeat: repeat-x;
	background-image: linear-gradient(to right, #4c4948, #4c4948 1px, transparent 1px, transparent 3px);
	background-size: 3px 1px;
	background-position: left top;
}

.form .privacy .txt {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: 2.125;
	letter-spacing: 0.05em;
}

.form .privacy .txt a {
	color: #0468b6;
	text-decoration: underline;
}

.form .privacy .checkwrap {
	margin: 30px 0 0;
}


/*submitbtn*/

.form .submitbtn {
	position: relative;
	margin: 35px auto 0;
}

.form .submitbtn input {
	display: block;
	margin: 0 auto;
	width: 200px;
	height: 50px;
	background-color: #ffc93c;
	color: #4c4948;
	font-weight: 500;
	font-size: 1.8rem;
	height: 50px;
	line-height: 1.5;
	letter-spacing: 0.06em;
	border-radius: 25px;
	cursor: pointer;
	transition: .3s ease;
}


/*contact_btn*/

#contact .contact_btn {
	margin-top: 60px;
	max-width: 935px;
}

#contact .contact_btn .midashi {
	width: 196px;
}

#contact .contact_btn .number {
	display: flex;
	align-items: center;
	padding: 0;
	margin-left: 30px;
}

#contact .contact_btn .number .tel {
	font-size: 4.6rem;
	margin-right: .5em;
}

#contact .contact_btn .tel_num {
	background-color: inherit;
	background: url('../img/contact/tel_link_pc.png') no-repeat center top;
	border-radius: 0;
	height: 151px;
	font-size: 0;
}

@media screen and (min-width: 769px) {
	.form .box .address .post_btn input[type='button']:hover,
	.form .submitbtn input:hover {
		background-color: #ffb13c;
	}
}

@media screen and (max-width: 768px) {
	#contact {
		padding: 10vw 0 24vw;
	}

	#contact .contact_btn .tel_num {
		background: none;
		padding: 0;
	}
	#contact .contact_btn .tel_num a {
		background: url('../img/contact/tel_link_sp.png') no-repeat center top;
		display: block;
		width: 100%;
		height: 38vw;
		background-size: contain;
	}
	#contact .lead {
		width: 100%;
	}
	#contact .lead .txt {
		font-size: 3.2vw;
		line-height: 2;
	}
	#contact .lead .btn {
		margin-top: 6vw;
	}
	.form_wrap {
		width: 100vw;
		margin-left: -8vw;
		margin-right: -8vw;
		margin-top: 18vw;
		padding: 0 8vw 10vw;
	}
	.form_wrap .formttl {
		font-size: 7.2vw;
	}
	.form_wrap>.txt {
		font-size: 3.2vw;
		line-height: 2;
	}
	/*form*/
	.form {
		margin-top: 6vw;
		background-image: linear-gradient(to right, #4c4948, #4c4948 1px, transparent 1px, transparent .7vw);
		background-size: .7vw 1px;
	}
	.form .box {
		padding: 6vw 0;
		position: relative;
		background-image: linear-gradient(to right, #4c4948, #4c4948 1px, transparent 1px, transparent .7vw);
		background-size: .7vw 1px;
	}
	.form .box dl {
		display: block;
	}
	.form .box dl+dl {
		margin-top: 5vw;
	}
	.form .box dl dt,
	.form .box dl dd,
	.form .box dl dd p {
		font-size: 3.2vw;
	}
	.form .box dl dt {
		width: 100%;
		margin-bottom: 1em;
	}
	.form .box dl dt .must {
		font-size: 2.8vw;
		height: 4vw;
		line-height: 4vw;
		align-self:
	}
	.form .box dl dd {
		width: 100%;
	}
	.form .box dl dd span.txt {
		min-width: 2.5em;
	}
	.form input[type="text"],
	.form input[type="email"],
	.form input[type="tel"],
	.form select,
	.form textarea {
		height: 9.3vw;
		font-size: 3.2vw;
	}
	.form input.short {
		width: 33vw;
	}
	.form input.short2 {
		width: 23vw;
	}
	/*textarea*/
	.form .message textarea {
		height: 44vw;
	}
	/*check*/
	.form .checkwrap {
		margin: 0;
	}
	.form .checkwrap li+li {
		margin-top: 1vw;
	}
	.form .checkwrap label {
		font-size: 3.2vw;
	}
	.form input[type=checkbox]+span {
		padding-left: 6vw;
	}
	.form input[type=checkbox]+span::before {
		top: 1vw;
		border: 1px solid #4c4948;
		width: 4.6vw;
		height: 4.6vw;
		background-color: #fff;
	}
	.form input[type=checkbox]:checked+span::after {
		top: 2.15vw;
		left: 1.15vw;
		width: 2.3vw;
		height: 2.3vw;
	}
	/*address*/
	.form .box .address p+p {
		margin-top: 4vw;
	}
	.form .box .address .post_btn {
		margin-left: 2vw;
		margin-right: 0;
	}
	.form .box .address .post_btn input[type='button'] {
		font-size: 3.2vw;
		width: 28vw;
		height: 9.33vw;
		border-radius: 4.65vw;
	}
	/*privacy*/
	.form .privacy {
		padding: 6vw 0 0;
		background-repeat: repeat-x;
		background-image: linear-gradient(to right, #4c4948, #4c4948 1px, transparent 1px, transparent .7vw);
		background-size: .7vw 1px;
	}
	.form .privacy .txt {
		font-size: 3.2vw;
		line-height: 2;
	}
	.form .privacy .checkwrap {
		margin: 5vw 0 0;
	}
	/*submitbtn*/
	.form .submitbtn {
		position: relative;
		margin: 35px auto 0;
	}
	.form .submitbtn input {
		width: 50vw;
		height: 12vw;
		font-size: 4.6vw;
		border-radius: 6vw;
	}
	/*contact_btn*/
	#contact .contact_btn {
		margin-top: 8vw;
	}
	#contact .contact_btn .midashi {
		width: 100%;
	}
	#contact .contact_btn .number {
		display: block;
		padding: 3vw 0 0;
		margin-left: 0;
	}
	#contact .contact_btn .number .tel {
		font-size: 7.8vw;
		margin-right: 0;
	}
}


/*エラー用*/

.form .box .wpcf7-not-valid-tip {
	display: block;
	margin-top: 0.25em;
	font-size: .85em;
}

.form .box .wpcf7-list-item {
	display: block;
}

.form .box .subject-check .wpcf7-list-item  {
	margin-left: 0;
}

.form .box .wpcf7-list-item + .wpcf7-list-item{
	margin-top: 4px;
}
@media screen and (max-width: 768px){
	.form .box .wpcf7-list-item + .wpcf7-list-item{
		margin-top: 1vw;
	}
}

/* calender UI */

.date-picker-wrap {
	display: flex;
}

/*datepicker*/

.ui-datepicker {
	width: 240px !important;
}

.ui-datepicker * {
	font-size: 1.4rem !important;
}

.ui-datepicker-calendar .day-sunday>a,
.ui-datepicker-calendar .day-holiday>a {
	background: #ffc0c0;
}

.ui-datepicker-calendar .day-saturday>a {
	background: #c0d0ff;
}

#datepicker1 {
	width: 210px;
	margin-right: 46px;
}

.form .box dl dd .date-picker-wrap + p {
	line-height: 1.6;
	padding-top: .5em;
}

select[name="time"] {
	width: 210px;
	padding-right: 2em;
	background-image: url(../img/common/select.png);
	background-repeat: no-repeat;
	background-position: right 0.75em center;
}

@media screen and (max-width: 768px) {
	.form .box dl dd .date-picker-wrap {
		flex-direction: column;
	}

	#datepicker1,
	select[name="time"] {
		margin-right: 0;
		width: calc(100% - 5.3em);
	}

	select[name="time"] {
		margin-top: 4vw;
	}
}