@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.mainVisual {
	padding: 0 3rem;
	position: relative;
	z-index: 4;
	background: url(../img/index/main_bg.jpg) no-repeat center top / cover;
}
.mainVisual .photoBox {
	margin: 0 auto;
	max-width: 143.6rem;
	position: relative;
}
.mainVisual .photoBox .btn {
	position: absolute;
	bottom: 11.4rem;
	left: 1.7rem;
	width: 59.6rem;
}
.mainVisual .photoBox .btn a {
	display: block;
}
.mainVisual .photoBox .btn a:hover {
	opacity: 0.7;
}
#main .worry {
	padding: 9.5rem 0 9.6rem;
	position: relative;
	z-index: 3;
}
#main .worry::after {
	width: 53rem;
	height: 54.5rem;
	position: absolute;
	z-index: 1;
	top: -20rem;
	right: 0;
	content: "";
	background: url(../img/index/worry_bg01.png) no-repeat left top / 100%;
	pointer-events: none;
}
#main .worry::before {
	width: 30.3rem;
	height: 36.4rem;
	position: absolute;
	z-index: 1;
	bottom: -17.3rem;
	left: 0;
	content: "";
	background: url(../img/index/worry_bg02.png) no-repeat left top / 100%;
	pointer-events: none;
}
#main .worry .content {
	position: relative;
	z-index: 2;
}
#main .worry h2 {
	margin-bottom: 2.8rem;
	text-align: center;
}
#main .worry .imgBox {
	align-items: center;
}
#main .worry .imgBox .photo {
	margin: 0 3.7rem 0 0;
}
#main .worry .imgBox .worryList {
	margin-top: 0.5rem;
}
#main .worry .imgBox .worryList li {
	margin-bottom: 2.2rem;
	padding-left: 3.5rem;
	font-weight: 700;
	font-size: 2.2rem;
	color: #0B0B0B;
	font-feature-settings: "palt";
	background: url(../img/common/icon01.png) no-repeat left top 1rem / 2.3rem;
}
#main .worry .imgBox .worryList li:last-child {
	margin-bottom: 0;
}
#main .worry .imgBox .worryList .line {
	color: #0A6FB4;
	background: -webkit-linear-gradient(#FEEF89,#FEEF89) repeat-x left bottom  / 100% 1rem;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
}
#main .solve {
	padding: 9.5rem 0 10.2rem;
	position: relative;
	z-index: 2;
	background: url(../img/common/bg01.png) no-repeat left top /cover;
}
#main .solve::after {
	width: 10.8rem;
	height: 3rem;
	position: absolute;
	top: -0.1rem;
	left: 50%;
	transform: translateX(-50%);
	content: "";
	background: url(../img/common/icon02.png) no-repeat left top / 100%;
	pointer-events: none;
}
#main .solve::before {
	width: 51.9rem;
	height: 63.7rem;
	position: absolute;
	z-index: 1;
	bottom: -16rem;
	right: 0;
	content: "";
	background: url(../img/index/solve_bg01.png) no-repeat left top / 100%;
	pointer-events: none;
}
#main .solve .content {
	position: relative;
	z-index: 2;
}
#main .solve h2 {
	margin-bottom: 6.2rem;
	text-align: center;
}
#main .solve .text {
	margin-bottom: 6.1rem;
	font-weight: 500;
	color: #fff;
	text-align: center;
	font-size: 1.9rem;
	font-feature-settings: "palt";
	line-height: 2.75;
	letter-spacing: 0.06em;
	text-shadow: 0.2rem 0.2rem 0.5rem rgba(0, 0, 0, 0.3),-0.2rem -0.2rem 0.5rem rgba(0, 0, 0, 0.3);
}
#main .solve .text .yellow {
	font-size: 2.2rem;
	color: #FCEE8E;
}
#main .reason {
	padding: 8.2rem 0 10rem;
	background-color: #E1EBF8;
}
#main .reason h2 {
	margin-bottom: 20.6rem;
	text-align: center;
}
#main .reason .imgBox {
	margin: 0 0 14rem auto;
	width: calc(50% + 59.6rem);
	position: relative;
}
#main .reason .imgBox .photoBox {
	position: absolute;
	z-index: 1;
	top: -10.6rem;
	left: 0;
	max-width: 30.99vw;
	min-width: 40rem;
}
#main .reason .imgBox .photoBox::after {
	position: absolute;
	z-index: -1;
	top: -3rem;
	left: -3rem;
	width: 20rem;
	height: 20rem;
	content: "";
	background-color: #CFE2F5;
}
#main .reason .imgBox .photoBox img {
	width: 100%;
}
#main .reason .imgBox .textBox {
	padding: 2rem 1.5rem 7.4rem 28.5rem;
	margin-left: auto;
	width: 77.5%;
	position: relative;
	background-color: #fff;
	box-shadow: -4.2rem 0 4rem -3rem rgba(0,0,0,0.1),
	4.2rem 0 4rem -2rem rgba(0,0,0,0.1),
	0 -0.5rem 1rem -0.7rem rgba(0,0,0,0.08),
	0 2.5rem 2rem rgba(0,0,0,0.08);
}
#main .reason .imgBox .textBox::after {
	width: 63.6rem;
	height: 22.7rem;
	position: absolute;
	z-index: 1;
	bottom: 0;
	right: 0;
	content: "";
	background-color: #F9F8F8;
	clip-path: polygon(100% 0, 0% 100%, 100% 100%);
}
#main .reason .imgBox .textBox h3 {
	margin: -7rem 0 4.9rem;
	text-align: right;
}
#main .reason .imgBox .textBox .sub {
	width: 59rem;
}
#main .reason .imgBox .textBox .ttl {
	margin-bottom: 2rem;
	font-weight: 700;
	color: #0A6FB4;
	font-size: 3rem;
	letter-spacing: 0.1em;
	font-style: italic;
}
#main .reason .imgBox .textBox .txt {
	position: relative;
	z-index: 2;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.1em;
}
#main .reason .imgBox .textBox .img {
	max-width: 14.948vw;
	position: absolute;
	z-index: 2;
	bottom: -2.448vw;
	right: 2.24vw;
}
#main .reason .imgBox:nth-of-type(2n) {
	margin: 0 0 23.3rem;
	width: calc(50% + 70rem);
}
#main .reason .imgBox:nth-of-type(2n) .photoBox {
	top: -6rem;
	top: -3.125vw;
	left: auto;
	right: 0;
}
#main .reason .imgBox:nth-of-type(2n) .photoBox::after {
	left: auto;
	right: -3rem;
}
#main .reason .imgBox:nth-of-type(2n) .textBox {
	padding: 2rem 23.5rem 7.4rem 1rem;
	margin: 0;
	width: 73%;
}
#main .reason .imgBox:nth-of-type(2n) .textBox::after {
	right: auto;
	left: 0;
	clip-path: polygon(0 0, 0% 100%, 100% 100%);
}
#main .reason .imgBox:nth-of-type(2n) h3 {
	margin: -7.5rem 0 6rem;
	text-align: left;
}
#main .reason .imgBox:nth-of-type(2n) .sub {
	margin-left: auto;
	width: 61rem;
}
#main .reason .imgBox:nth-of-type(2n) .img {
	right: auto;
	left: 4.219vw;
	bottom: -0.937vw;
}
#main .reason .imgBox01 .photoBox {
	top: -14.5rem;
}
#main .reason .imgBox01 .textBox .img {
	bottom: -3.3rem;
	right: 8.5rem;
}
#main .reason .imgBox:last-of-type {
	margin-bottom: 0;
}
@media all and (max-width: 1920px) {
	#main .reason .imgBox .textBox {
		padding-left: 14.844vw;

	}
	#main .reason .imgBox:nth-of-type(2n) .textBox {
		padding-right: 12.24vw;
	}
}
@media all and (min-width: 897px) and (max-width: 1490px)  {
	#main .reason .imgBox {
		width: calc(50% + 59rem) !important;
	}
	#main .reason .imgBox:nth-of-type(2n) .img {
		left: 0;
	}
	#main .reason .imgBox:nth-of-type(2n) .textBox {
		padding-right: 11rem;
	}
}
#main .support {
	padding: 9.6rem 0 10.6rem;
	position: relative;
	background: url(../img/common/bg01.png) no-repeat left bottom / 100% 69.5rem;
}
#main .support::after {
	width: 22.6rem;
	height: 48.3rem;
	position: absolute;
	z-index: 1;
	top: 50%;
	transform: translateY(-38%);
	right: 0;
	content: "";
	background: url(../img/index/support_bg01.png) no-repeat left top / 100%;
}
#main .support .content {
	max-width: 104rem;
	position: relative;
	z-index: 2;
}
#main .support h2 {
	margin-bottom: 10rem;
	text-align: center;
}
#main .supportBox {
	margin-bottom: 7rem;
	padding: 2.5rem 2rem;
	position: relative;
	background-color: #E1EBF8;
	border-radius: 0.5rem;
}
#main .supportBox::after {
	width: 10.8rem;
	height: 3rem;
	position: absolute;
	bottom: -2.9rem;
	left: 50%;
	transform: translateX(-50%);
	content: "";
	background: url(../img/common/icon03.png) no-repeat left top / 100%;
}
#main .supportBox h3 {
	margin-bottom: 5.3rem;
	text-align: center;
	color: #0A6FB4;
	font-size: 3rem;
	letter-spacing: 0.04em;
	font-style: italic;
}
#main .supportList {
	margin-top: -2rem;
}
#main .supportList li {
	padding: 0 1.2rem 3.1rem;
	margin: 2rem 2% 0 0;
	width: 32%;
	background-color: #fff;
	border-radius: 0.5rem;
}
#main .supportList li:nth-child(3n) {
	margin-right: 0;
}
#main .supportList .ttl {
	margin: -2.5rem 0 2.9rem;
	text-align: center;
	color: #0A6FB4;
	font-weight: 700;
}
#main .supportList .ttl .num {
	padding: 1rem 0.5rem;
	margin: 0 auto 0.5rem;
	width: 5rem;
	height: 5rem;
	display: block;
	border-radius: 50%;
	color: #fff;
	text-align: center;
	font-size: 2.1rem;
	font-weight: 900;
	font-family: "Roboto", sans-serif;
	background-color: #0A6FB4;
}
#main .supportList .txt {
	font-size: 1.5rem;
	font-weight: 500;
	color: #0A0A0A;
	line-height: 1.6;
}
#main .support .title {
	margin-bottom: 3.3rem;
	text-align: center;
	color: #FCE969;
	font-size: 4rem;
	font-weight: 700;
	font-style: italic;
	letter-spacing: 0.02em;
}
#main .support .text {
	margin-bottom: 5.5rem;
	text-align: center;
	color: #fff;
	font-size: 2rem;
	font-weight: 500;
	font-feature-settings: "palt";
	line-height: 2.25;
}
#main .price {
	padding: 10.6rem 0 10rem;
	background-color: #E1EBF8;
	border-bottom: 0.2rem solid #fff;
}
#main .price .headLine01 {
	color: #0A0A0A;
}
#main .price .headLine01 .en {
	color: #fff;
	background-color: #0A6FB4;
}
#main .price .priceBox {
	margin-bottom: 6.5rem;
	position: relative;
	z-index: 1;
}
#main .price .priceBox::before {
	position: absolute;
    z-index: -1;
    top: -3rem;
    left: -3rem;
    width: 20rem;
    height: 20rem;
    content: "";
    background-color: #CBDFF1;
}
#main .price .priceBox::after {
	position: absolute;
    z-index: -1;
    bottom: -3rem;
    right: -3rem;
    width: 20rem;
    height: 20rem;
    content: "";
    background-color: #CBDFF1;
}
#main .price .priceBox .sub {
	background-color: #fff;
	border: 0.3rem solid #0A6FB4;
	box-shadow: 0 0 1rem rgba(0, 0, 0, 0.3);
}
#main .price .priceBox .ttl01 {
	padding: 0.2rem 4rem 0.8rem;
	margin: 0 auto 6.2rem;
	width: fit-content;
	color: #fff;
	font-weight: 500;
	font-size: 2.6rem;
	letter-spacing: 0.03em;
	background-color: #0A6FB4;
	border-radius: 0 0 0.5rem 0.5rem;
}
#main .price .priceBox .img {
	margin: 0 auto 6rem;
	width: 51.1rem;
}
#main .price .priceBox .ttl02 {
	padding: 1.2rem 1rem;
	position: relative;
	color: #fff;
	text-align: center;
	font-size: 2.8rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	background-color: #0A6FB4;
}
#main .price .priceBox .ttl02::after {
	width: 7rem;
	height: 2.3rem;
	position: absolute;
	bottom: -2.2rem;
	left: 50%;
	transform: translateX(-50%);
	content: "";
	background: url(../img/common/icon04.png) no-repeat left top / 100%;
}
#main .price .priceList {
	padding: 6.8rem 10.5rem 7rem;
}
#main .price .priceList > li {
	margin-bottom: 3rem;
	padding: 0 0 2.9rem 1rem;
	display: flex;
	justify-content: space-between;
	border-bottom: 1px solid #DDDDDD;
}
#main .price .priceList > li:last-child {
	margin-bottom: 0;
	padding-bottom: 0;
	border: 0;
}
#main .price .priceList .lBox .ttl {
	font-weight: 700;
	font-size: 2.2rem;
}
#main .price .priceList .txtList li {
	margin-bottom: 0.7rem;
	font-size: 1.6rem;
	font-weight: 700;
}
#main .price .priceList .txtList li:last-child {
	margin-bottom: 0;
}
#main .price .priceList .money {
	font-size: 2.2rem;
	font-weight: 700;
}
#main .price .priceList .money .jp {
	font-size: 1.4rem;
}
#main .price .priceList .num {
	font-size: 2.5rem;
	letter-spacing: 0.02em;
}
#main .company {
	margin-bottom: -0.1rem;
	padding: 7.5rem 0 8.6rem;
	background: url(../img/index/company_bg.png) no-repeat left top / cover;
}
#main .company .headLine01 {
	margin-bottom: 6rem;
}
#main .company .headLine01 .en {
	padding: 0.7rem 1.7rem 0.5rem;
}
#main .company .tableBox {
	position: relative;
	z-index: 1;
}
#main .company .tableBox::after {
	width: 34rem;
	height: 37.1rem;
	position: absolute;
	z-index: -1;
	top: -4.8rem;
	left: -28.3rem;
	content: "";
	background: url(../img/index/company_bg01.png) no-repeat left top / 100%;
}
#main .company table {
	width: 100%;
	border-collapse: collapse;
}
#main .company table th,
#main .company table td {
	padding: 1.1rem 2.7rem;
	text-align: left;
	font-weight: 400;
	font-size: 1.6rem;
	color: #fff;
	vertical-align: middle;
	word-break: break-all;
}
#main .company table tr:nth-child(2n-1) th,
#main .company table tr:nth-child(2n-1) td {
	color: #0A0A0A;
	background-color: #fff;
}
#main .company table th {
	width: 12%;
}
#main .company table td {
	padding: 1.1rem 1rem 1.1rem 0;
}
#main .contact {
	padding: 8.5rem 0 10rem;
	background: #E1EBF8 url(../img/index/contact_bg.png) no-repeat left top / 100% 55.6rem;
}
#main .contact .headLine01 {
	margin-bottom: 3rem;
}
#main .contact .headLine01 .en {
	padding: 0.7rem 1.7rem 0.5rem;
}
#main .contact .text {
	margin-bottom: 6.5rem;
	color: #fff;
	text-align: center;
	font-size: 2.1rem;
	line-height: 2.09;
	letter-spacing: 0.02em;
}
#main .contact .mailForm {
	padding: 6.1rem 5.5rem 6.2rem;
	background-color: #fff;
	box-shadow: 0 0 4rem rgba(0, 0, 0, 0.15);
}
#main .contact table {
	margin-bottom: 3rem;
	width: 100%;
	border-collapse: collapse;
}
#main .contact table th,
#main .contact table td {
	padding: 0.5rem 0;
	text-align: left;
	color: #0A0A0A;
	font-weight: 500;
	border: 0;
	vertical-align: top;
	word-break: break-all;
}
#main .contact table th {
	padding: 1.5rem 0;
	width: 23.6%;
}
#main .contact table .must {
	margin-left: 2.2rem;
	padding: 0 1.1rem 0.2rem;
	display: inline-block;
	font-weight: 400;
	color: #fff;
	text-align: center;
	font-size: 1.3rem;
	background-color: #FA7523;
}
#main .contact .mailForm table input[type="text"],
#main .contact .mailForm table input[type="email"], 
#main .contact .mailForm table input[type="tel"],
#main .contact .mailForm table select, 
#main .contact .mailForm table textarea {
	padding: 1rem 2.2rem;
	width: 100%;
	height: 5rem;
	color: rgba(10,10,10,0.5);
	font-weight: 400;
	font-size: 1.8rem;
	border-radius: 0;
	border: 0;
	box-sizing: border-box;
	box-shadow: none;
	background-color: #F6F7F7;
	appearance: none;
	-moz-appearance: none;
	-webkit-appearance: none;
}
#main .contact .mailForm input::placeholder,
#main .contact .mailForm select::placeholder,
#main .contact .mailForm textarea::placeholder {
	color: rgba(10,10,10,0.5);
}
#main .contact .mailForm table select {
	background: #F6F7F7 url(../img/common/icon05.png) no-repeat right 2rem center / 1.5rem;
}
#main .contact .mailForm table textarea {
	min-height: 23.6rem;
	resize: vertical;
}
#main .contact .mailForm .submit {
	text-align: center;
}
#main .contact .mailForm .submit li {
	margin: 0 1.5rem;
}
#main .contact .mailForm .submit input {
    width: 30.5rem;
	height: 8.7rem;
	border: 0;
	box-shadow: none;
	box-sizing: border-box;
	cursor: pointer;
	appearance: none;
    -moz-appearance: none;
    -webkit-appearance: none;
	background: url(../img/common/comBtn03.png) no-repeat left top / 100%;
	transition: .3s;
}
#main .contact .mailForm .submit .li01 input[type="button"] {
	background-image: url(../img/common/comBtn04.png);
}
@media all and (min-width: 897px) {
	#main .contact .mailForm .submit input:hover {
		opacity: 0.7;
	}
}
@media all and (min-width: 897px) and (max-width: 1450px)  {
	.mainVisual .photoBox .btn {
		width: 50rem;
		bottom: 7.5rem;
	}
}
@media all and (max-width: 896px) {
	.mainVisual {
		padding: 0 1rem;
		background: url(../img/index/main_bg.jpg) no-repeat center top / cover;
	}
	.mainVisual .photoBox .btn {
		bottom: 5.333vw;
		left: 1rem;
		width: 40%;
	}
	#main .worry {
		padding: 5rem 0;
	}
	#main .worry::after {
		width: 20rem;
		height: 21rem;
		top: -6rem;
	}
	#main .worry::before {
		width: 15rem;
		height: 19rem;
		bottom: -10rem;
	}
	#main .worry h2 {
		margin: 0 auto 3rem;
		width: 26rem;
	}
	#main .worry .imgBox {
		margin: 0 auto;
		display: block;
		width: 33.5rem;
	}
	#main .worry .imgBox .photo {
		margin: 0 auto 2rem;
		width: 10rem;
	}
	#main .worry .imgBox .worryList {
		margin-top: 0;
	}
	#main .worry .imgBox .worryList li {
		margin-bottom: 1.5rem;
		padding-left: 2.5rem;
		font-size: 1.5rem;
		background-size: 1.5rem;
		background-position: left top 0.7rem;
	}
	#main .solve {
		padding: 5rem 0;
	}
	#main .solve::after {
		width: 7rem;
	}
	#main .solve::before {
		width: 25rem;
		height: 31rem;
		bottom: -8rem;
	}
	#main .solve h2 {
		margin: 0 auto 3rem;
		width: 33.5rem;
	}
	#main .solve .text {
		margin-bottom: 4rem;
		font-size: 1.4rem;
		line-height: 1.8;
		letter-spacing: 0;
	}
	#main .solve .text .yellow {
		font-size: 1.6rem;
	}
	#main .reason {
		padding: 5rem 0;
	}
	#main .reason h2 {
		margin: 0 auto 7rem;
		width: 30rem;
	}
	#main .reason .imgBox {
		margin: 0 0 7rem !important;
		width: auto !important;
	}
	#main .reason .imgBox:last-of-type {
		margin-bottom: 0 !important;
	}
	#main .reason .imgBox .photoBox {
		margin-left: auto;
		position: relative;
		max-width: 100%;
		min-width: 100%;
		top: 0 !important;
	}
	#main .reason .imgBox .photoBox::after {
		display: none;
	}
	#main .reason .imgBox .textBox {
		padding: 3rem 2rem 10rem !important;
		margin: 0;
		width: auto !important;
	}
	#main .reason .imgBox .textBox::after {
		width: 20rem;
		height: 10rem;
	}
	#main .reason .imgBox .textBox h3 {
		margin: -5rem 0 2rem !important;
		width: 22rem;
		text-align: left;
	}
	#main .reason .imgBox .textBox .sub {
		margin: 0 !important;
		width: auto !important;
	}
	#main .reason .imgBox .textBox .ttl {
		margin-bottom: 1.5rem;
		font-size: 2rem;
	}
	#main .reason .imgBox .textBox .txt {
		text-align: justify;
		letter-spacing: 0;
	}
	#main .reason .imgBox .textBox .img {
		max-width: 10rem;
		left: auto !important;
		bottom: 0 !important;
		right: 1rem !important;
	}
	#main .reason .imgBox:nth-of-type(2n) .img {
		right: auto !important;
		left: 0 !important;
	}
	#main .support {
		padding: 5rem 0;
		background-size: 100% 53rem;
	}
	#main .support::after {
		width: 10rem;
		height: 24rem;
		top: 54%;
		transform: translateY(0);
	}
	#main .support h2 {
		margin: 0 auto 3rem;
		width: 30rem;
	}
	#main .supportBox {
		margin-bottom: 5rem;
		padding: 2.5rem 2rem;
	}
	#main .supportBox::after {
		width: 8rem;
	}
	#main .supportBox h3 {
		margin-bottom: 3rem;
		font-size: 2rem;
	}
	#main .supportList {
		margin-top: 0;
		display: block;
	}
	#main .supportList li {
		padding: 1rem 2rem;
		margin: 0 0 2rem !important;
		width: auto;
	}
	#main .supportList li:last-child {
		margin-bottom: 0;
	}
	#main .supportList .ttl {
		margin: -2.5rem 0 1rem;
	}
	#main .supportList .txt {
		text-align: justify;
		font-size: 1.4rem;
	}
	#main .support .title {
		margin-bottom: 2rem;
		font-size: 2.5rem;
	}
	#main .support .text {
		margin-bottom: 4rem;
		font-size: 1.5rem;
		line-height: 1.8;
	}
	#main .price {
		padding: 5rem 0;
	}
	#main .price .priceBox {
		margin-bottom: 3rem;
	}
	#main .price .priceBox::before {
		top: -2rem;
		left: -2rem;
		width: 10rem;
		height: 10rem;
	}
	#main .price .priceBox::after {
		bottom: -2rem;
		right: -2rem;
		width: 10rem;
		height: 10rem;
	}
	#main .price .priceBox .sub {
		border-width: 0.2rem;
	}
	#main .price .priceBox .ttl01 {
		padding: 0.2rem 2rem 0.5rem;
		margin: 0 auto 3rem;
		font-size: 1.6rem;
	}
	#main .price .priceBox .img {
		margin-bottom: 3rem;
		width: 23rem;
	}
	#main .price .priceBox .ttl02 {
		padding: 0.4rem 1rem;
		font-size: 1.6rem;
	}
	#main .price .priceBox .ttl02::after {
		width: 4rem;
	}
	#main .price .priceList {
		padding: 3rem 2rem;
	}
	#main .price .priceList > li {
		margin-bottom: 1.5rem;
		padding: 0 0 1.5rem 0;
	}
	#main .price .priceList .lBox .ttl {
		font-size: 1.4rem;
	}
	#main .price .priceList .txtList li {
		margin-bottom: 0;
		font-size: 1.2rem;
		letter-spacing: 0;
	}
	#main .price .priceList .money {
		font-size: 1.3rem;
	}
	#main .price .priceList .money .jp {
		font-size: 1rem;
	}
	#main .price .priceList .num {
		font-size: 1.5rem;
		letter-spacing: 0;
	}
	#main .company {
		margin-bottom: 0;
		padding: 5rem 0;
	}
	#main .company .headLine01 {
		margin-bottom: 3rem;
	}
	#main .company .tableBox::after {
		width: 20rem;
		height: 25rem;
		top: -4.8rem;
		left: -10rem;
	}
	#main .company table th,
	#main .company table td {
		padding: 0.5rem 1rem !important;
		font-size: 1.4rem;
	}
	#main .company table th {
		width: 8rem;
	}
	#main .contact {
		padding: 5rem 0;
		background-size: auto 35rem;
	}
	#main .contact .text {
		margin-bottom: 3rem;
		font-size: 1.5rem;
		line-height: 1.8;
	}
	#main .contact .mailForm {
		padding: 2rem;
	}
	#main .contact table th,
	#main .contact table td {
		padding: 0;
		display: block;
		width: 100% !important;
	}
	#main .contact table th {
		padding: 1rem 0;
	}
	#main .contact table .must {
		margin-left: 1rem;
		padding: 0 0.7rem;
		font-size: 1.1rem;
	}
	#main .contact .mailForm table input[type="text"],
	#main .contact .mailForm table input[type="email"], 
	#main .contact .mailForm table input[type="tel"],
	#main .contact .mailForm table select, 
	#main .contact .mailForm table textarea {
		padding: 0.5rem 1.5rem;
		height: 4rem;
		font-size: 1.4rem;
	}
	#main .contact .mailForm table select {
		background-size: 1.1rem auto;
	}
	#main .contact .mailForm table textarea {
		min-height: 15rem;
	}
	#main .contact .mailForm .submit {
		display: block;
	}
	#main .contact .mailForm .submit li {
		margin: 0 0 2rem;
	}
	#main .contact .mailForm .submit li:last-child {
		margin-bottom: 0;
	}
	#main .contact .mailForm .submit input {
		width: 23rem;
		height: 6.9rem;
	}
}
#main .errorMsg {
	color: #f00;
	margin-bottom: 2rem;
}
/*------------------------------------------------------------
	thanks
------------------------------------------------------------*/
#main .sendTxt {
	text-align: center;
	font-size: 2rem;
	line-height: 1.8;
	color: #f00;
}
@media all and (max-width: 896px) {
	#main .sendTxt {
		font-size: 1.5rem;
	}
}