@charset "UTF-8";

#contact main {
	background: #F9F9F7;
	color: #21130B;
}

/* ========================================
@media screen and (min-width: 768px),print {
======================================== */
@media screen and (min-width: 768px),print {
.p-fv {
	padding-block: 696px 0;
}

.p-fv .l-inner.l-fv {
	text-align: center;
}

.p-fv .p-fv__txt {
	background: #FDD4A8;
	font-size: 28px;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 1;
	margin-bottom: 78px;
	margin-inline: auto;
	position: relative;
	width: -moz-fit-content;
	width: fit-content;
}

.p-fv .p-fv__txt:before {
	background: url(../images/contact/contact_txt_icon.svg) no-repeat center center/contain;
	content: "";
	height: 33px;
	left: -40px;
	position: absolute;
	top: -32px;
	width: 50px;
}

.p-fv .p-fv__txt02 {
	font-size: 30px;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 1.6666666667;
	margin-bottom: 20px;
	margin-inline: auto;
	padding-inline: 69px;
	position: relative;
	width: -moz-fit-content;
	width: fit-content;
}

.p-fv .p-fv__txt02:before {
	background: url(../images/contact/contact_line.svg) no-repeat center center/contain;
	bottom: 0;
	content: "";
	height: 89px;
	left: 0;
	position: absolute;
	width: 39px;
}

.p-fv .p-fv__txt02::after {
	background: url(../images/contact/contact_line.svg) no-repeat center center/contain;
	bottom: 0;
	content: "";
	height: 89px;
	position: absolute;
	right: 0;
	transform: scale(-1, 1);
	width: 39px;
}

.p-fv .p-fv__txt02 span {
	color: #D8780C;
	font-size: 30px;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 1.6666666667;
}

.p-fv .p-fv__txt03 {
	font-size: 18px;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 2.7777777778;
	margin-bottom: 40px;
}

.p-fv .p-fv__txt04 {
	position: relative;
	margin-bottom: -123px;
}

.p-fv .p-fv__txt04 a {
  display: grid;
  grid-template-columns: repeat(1,minmax(0, 1fr));
	gap: 1px 0;
  background: url(../images/contact/contact_box.png) no-repeat top center/auto;
	margin-inline: auto;
	max-width: 600px;
	padding-block: 37px 35px;
	width: 95%;
}

.p-fv .p-fv__txt04 span.top {
	background: #ffffff;
	font-size: 22px;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 1.2727272727;
	margin-inline: auto;
	width: -moz-fit-content;
	width: fit-content;
  padding-inline: 4px;
}

.p-fv .p-fv__txt04 span.bottom {
	color: #ffffff;
	font-size: 16px;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 2;
}

#contact .form-Box {
	background: #F9F9F7;
	padding-block: 0 160px;
}

}

/* ========================================
@media screen and (min-width:768px) and ( max-width:1300px) {
======================================== */
@media screen and (min-width:768px) and ( max-width:1300px) {
.p-fv {
	padding-block: 37.538vw 0;
}
}

/* ========================================
@media screen and (min-width:768px) and ( max-width:1200px) {
======================================== */
@media screen and (min-width:768px) and ( max-width:1200px) {
#contact .l-main__title .l-main__contents-left .en img {
  width: 35.75vw;
  height: auto;
}

#contact .l-main__title .l-main__contents-right img {
  width: 50.5vw;
  height: auto;
}

.p-fv .p-fv__human img {
  width: 96vw;
  height: auto;
  position: relative;
  z-index: 1;
}

.p-fv .p-fv__txt04 {
	margin-bottom: -10.25vw;
}
}


/* ========================================
@media screen and (max-width: 767px) {
======================================== */
@media screen and (max-width: 767px) {
#contact main {
	background: #F9F9F7;
	color: #21130B;
}

.p-fv {
	padding-block: 112.527vw 0;
}

.p-fv .l-inner.l-fv {
	text-align: center;
}

.p-fv .p-fv__txt {
	background: #FDD4A8;
	font-size: 3.865vw;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 1.625;
	margin-bottom: 9.662vw;
	margin-inline: auto;
	position: relative;
	width: -moz-fit-content;
	width: fit-content;
	padding-inline: 1vw;
}

.p-fv .p-fv__txt:before {
	background: url(../images/contact/contact_txt_icon.svg) no-repeat center center/contain;
	content: "";
	height: 5.348vw;
	left: 3.338vw;
	position: absolute;
	top: -6.729vw;
	width: 8.005vw;
}

.p-fv .p-fv__txt02 {
	font-size: 5.314vw;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 1.5454545455;
	margin-bottom: 6.831vw;
	margin-inline: auto;
	padding-inline: 12.077vw;
	position: relative;
	width: -moz-fit-content;
	width: fit-content;
}

.p-fv .p-fv__txt02:before {
	background: url(../images/contact/contact_line.svg) no-repeat center center/contain;
	bottom: 0;
	content: "";
	height: 21.498vw;
	left: 0;
	position: absolute;
	width: 9.42vw;
}

.p-fv .p-fv__txt02::after {
	background: url(../images/contact/contact_line.svg) no-repeat center center/contain;
	bottom: 0;
	content: "";
	height: 21.498vw;
	position: absolute;
	right: 0;
	transform: scale(-1, 1);
	width: 9.42vw;
}

.p-fv .p-fv__txt02 span {
	color: #D8780C;
	display: block;
	font-size: 5.314vw;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 1.5454545455;
}

.p-fv .p-fv__txt03 {
	font-size: 3.865vw;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 1.875;
	margin-bottom: 7.246vw;
}

.p-fv .p-fv__txt04 {

}

.p-fv .p-fv__txt04 a {
  background: url(../images/contact/contact_box_sp.png) no-repeat top center/contain;
	display: grid;
	grid-template-columns: repeat(1, minmax(0, 1fr));
	margin-bottom: 10.386vw;
	margin-inline: auto;
	padding-block: 7.005vw 5.314vw;
	width: min(95%, 89.3vw);
}

.p-fv .p-fv__txt04 span.top {
	background: #ffffff;
	font-size: 3.865vw;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 1.75;
	margin-inline: auto;
	width: -moz-fit-content;
	width: fit-content;
  padding-inline: 1vw;
}

.p-fv .p-fv__txt04 span.bottom {
	color: #ffffff;
	font-size: 3.382vw;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 2.2;
}

.p-fv .p-fv__human {
	margin-inline: auto;
	width: min(95%, 52.6570048309vw);
}

#contact .form-Box {
	background: #F9F9F7;
	margin-bottom: -37vw;
	padding-block: 0 0vw;
}

#contact .form-Box .form-box-inner {
	top: -3vw;
}

#contact  .l-main__title .l-main__contents-left .en img {
  width: 66vw;
}

#contact .l-main__title .l-main__contents {
  padding-block: 20.908vw 17.217vw;
  gap: 8vw 0;
}

#contact .l-main__title .l-main__contents-left {
  padding-inline: 4vw;
}

#contact .l-main__title .l-main__contents-left .en {
  margin-bottom: 1vw;
}

#contact .sp-page-top {
	padding-block: 61vw 7.246vw;
}

#contact .form-Box th span {
  font-size: 3.382vw;
  font-weight: 400;
  line-height: 6.28vw; /* 185.714% */
  letter-spacing: 0.203vw;
}

}