@charset "utf-8";
/*
Theme Name:mrp04-child
Template:mrp04
Version: 0.01
 */

/*--------------------------------------
 * 共通設定
 * -----------------------------------*/
.flex-jsb{
	display:-webkit-box;
	display:-ms-flexbox;
	display:flex;
	-webkit-box-pack:justify;
	-ms-flex-pack:justify;
	justify-content:space-between;
}

body {
	font-family: 'Noto Sans JP',"游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN", Roboto, "Droid Sans", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", Helvetica, Arial, sans-serif;

}

.w-110{
	max-width:1100px;
	width:100%;
	margin: 60px auto 30px auto;
}

.m-60{
	margin:60px 0;
}

.m-auto{
	width:auto;
}

.post li.col-3 {
	-ms-flex-preferred-size: 32%;
	flex-basis: 32%;
	background: #fff;
	text-align: center;
	-webkit-box-shadow: 0 0 4px 0px #3e3a39;
	box-shadow: 0 0 4px 0px #3e3a39;
	padding: 20px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.post img {
	padding: 0;
	border:none;
}

.post h3 span {
	background: inherit;
	padding-left: 0;
}

.txt-center{
	text-align:center!important;
}

#content{
	padding:0;
}

.post{
	margin:0;
}

a.linkbtn01 {
	display: inline-block;
	min-width: 180px;
	position: relative;
	font-size: 15px;
	text-align: left;
	background-color: #ffffff;
	border: 1px solid #333;
	border-radius: 3px;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	padding-top: 5px;
	padding-bottom: 7px;
	padding-left: 22px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	color: #333;
}

a.linkbtn01:before{
	content: "";
	width: 33px;
	position: absolute;
	top: 50%;
	margin-top: -1px;
	right: 15px;
	border-top: 1px solid #333;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
	-webkit-transition: all 0.3s ease;
}

a.linkbtn01:after{
	content: "";
	height: 5px;
	position: absolute;
	top: 50%;
	right: 16px;
	margin-top: -5px;
	border-left: 1px solid #333;
	-webkit-transform: skewX(45deg);
	-ms-transform: skewX(45deg);
	transform: skewX(45deg);
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	z-index: 1;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
	-webkit-transition: all 0.3s ease;
}

a.linkbtn01:hover{
	color:#333;
}

a.linkbtn01:hover:before {
	width:43px;
	right:-2px;
}
a.linkbtn01:hover:after {
	right:0;
}
.home #content{
	padding:0;
}

#breadcrumb ul li a, #breadcrumb ul li {
	color: #333;
	font-size: 1rem;
}

#breadcrumb {
	background: none;
	padding: 5px;
}

#copyright {
	color: #ffffff;
	background: #f30000;
}

.mb-20{
	margin-bottom:20px;
}

.tel-sub-txt {
	display: inline-flex;
	justify-content: flex-end;
	align-items: center;
}

p.sub-txt01,
p.sub-txt02 {
	font-size: 0.9rem!important;
	position: relative;
	top: 10px;
	margin-right: 5px;
}

p.sub-txt01{
	margin-right: 25px;
}

#footer {
	background: rgb(255 233 233);
}




/*--------------------------------------
 * PCヘッダー調整
 * -----------------------------------*/

@media print, screen and (min-width: 1024px) {
	header#header {
		width: 100%;
		position: fixed;
		padding:0;
		box-sizing: border-box;
		top: 0px;
		z-index: 99;
		height: auto;
	}

	nav#mainNav{
		width:100%;
		position:fixed;
		top: 106px;
		z-index:99;
	}

	#header .inner {
		width: 100%;
		background:#fff;
	}

	div#mainImg {
		padding: 0!important;
	}

	#header-layout{
		width: 1100px;
    	padding: 5px 0;
    	padding-bottom: 10px;
	}
	.panel ul li {
		margin: 0;
	}
	.panel.nav-effect {
		background: #f30000;
	}

	#header .logo img {
		max-height: 85px;
	}

	nav#mainNav ul li a span,
	nav#mainNav ul li a b {
		line-height: 1.5;
	}
	nav#mainNav ul li a{
		padding: 0px 35px 0px;
	}

	nav#mainNav ul li a:before {
		content:"";
		width: 24px;
		height:24px;
		display: block;
		margin: 5px auto 0;
		background-position: center !important;
	}

	nav#mainNav ul li#menu-item-5 a:before {
		background:url(/struct/wp-content/uploads/top-icon.png)no-repeat;
		background-size:contain;
	}

	nav#mainNav ul li#menu-item-2113 a:before {
		background:url(/struct/wp-content/uploads/corse-icon.png)no-repeat;
		left: 43%;
		background-size:contain;
	}

	nav#mainNav ul li#menu-item-69 a:before{
		background:url(/struct/wp-content/uploads/service-icon-w.png)no-repeat;
		background-size: contain;
	}

	nav#mainNav ul li#menu-item-70 a:before{
		background:url(/struct/wp-content/uploads/option-icon.png)no-repeat;
		background-size: contain;
	}

	nav#mainNav ul li#menu-item-71 a:before{
		background:url(/struct/wp-content/uploads/company-icon.png)no-repeat;
		left:36%;
		background-size: contain;
	}

	nav#mainNav ul li a:hover:before{
		-webkit-transform: translateY(-3px);
		-ms-transform: translateY(-3px);
		transform: translateY(-3px);
	}
	nav#mainNav ul li {
		position: relative;
	}
	nav#mainNav ul li:after {
		content: "/";
		position: absolute;
		color:#fff;
		top: 50%;
		right: 0;
		transform: translateY(-50%);
	}
	nav#mainNav ul li:last-child:after{
		content:none;
	}
	#header .contact .float {
		float: none;
		display: flex;
		justify-content: flex-end;
		align-items: center;
	}
	#header .contact .tel {
		color: #f30000;
		display: flex;
		flex-direction: column;
		font-size: 200%;
		letter-spacing: 0.1rem;
		font-family:'Noto Sans JP';
		font-weight:700;
	}
	.tel p.tel-txt {
		font-size: 1.1rem!important;
		font-weight: 900;
		color: #333;
		font-family: 'Noto Sans JP';
		letter-spacing: 0.15rem;
	}
	#header .contact .tel img {
		padding: 0 10px 4px 0;
		vertical-align:middle;
		height: 100%;
		box-sizing:border-box;
	}
	#header .contact .mail {
		display: inline-block;
		margin-left: 30px;
	}
	nav#mainNav ul li.current-menu-item a b, nav#mainNav ul li a:hover b, nav#mainNav ul li a:active b, nav#mainNav ul li.current-menu-parent a b {
		color: #fdfdfd;
	}
	nav#mainNav ul li a {
		color:#fff;
		font-size: 19px;
	}
	.reserve-link {
		position: fixed;
		/*
		top: 500px;
		 */
top: 440px;
right: -20px;
display: block;
z-index: 999;
}

.estimate-link{
	position:fixed;
	right:-20px;
	/*
	top: 355px;
	 */
top:295px;
z-index:999;
}

.reserve-link a img,
.estimate-link a img{
	width:80%;
}

}

/*-------------------------
 * 下層h1
 * ----------------------*/
header#h1Header {
	overflow: visible;
	height: 150px;
	width: 1100px;
	margin: 220px auto 0 auto;
	background: none;
}

header#h1Header:before{
	content:"";
	width:100vw;
	position:absolute;
	height:100%;
	left:50%;
	transform:translateX(-50%);
	background-color: #ffffff;
}

header#h1Header h1.title {
	position: relative;
	text-align: left;
	font-size: 2.2rem;
	text-shadow: 0 0 5px #fff;
	background: none;
	color: #f30000;
}

#breadcrumb ul li:first-child{
	margin-left:0;
}

/*-----------------------
 * 新着情報
 * --------------------*/
span.jp {
	text-align: center;
	display: block;
	font-size: 1.8rem;
	padding-bottom:10px;
	font-weight: 700;
	letter-spacing: 0.1rem;
}

span.jp:first-letter{
	color:#f30000;
}

div#front_top_content {
	margin: 60px auto;
	width: 1100px;
}

.fronttop-link {
	margin: 60px 0;
	display: flex;
	justify-content: center;
}

h1.title.first.top-loop {
	font-weight: 400;
	letter-spacing: 0.1rem;
}

.postlist .post_text {
	width: 100%;
	margin: 20px auto;
}

.post .time, .postlist .time, .post2b .time, .post4b .time {
	color: #ffffff;
	background-color: #0102fc;
	padding: 5px 15px;
	margin: 0 20px;
}

.postlist .date {
	font-size: 1.2rem;
	letter-spacing: 0.1rem;
}

/*-----------------------
 * トップページ
 * --------------------*/
.corse-menu {
	padding: 3.5em 0 0 0;
	background-color: #fff;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4' viewBox='0 0 4 4'%3E%3Cpath fill='%23b2e0f1' fill-opacity='0.76' d='M1 3h1v1H1V3zm2-2h1v1H3V1z'%3E%3C/path%3E%3C/svg%3E");
	position: relative;
}

.ttl-icon {
	width: 90px;
	height: 90px;
	margin: 0 auto 20px auto;
	background: url(/struct/wp-content/uploads/character.png)no-repeat;
	position: relative;
	background-size: contain;
}

h2.ttl01 {
	text-align: center;
	font-size: 2rem;
	font-weight: 900;
	letter-spacing: 0.3rem;
	color: #f30000;
	background: none;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 0 10px 0;
	padding: 0;
}



h2.ttl01:before,
h2.ttl01:after{
	content:"";
	width:3px;
	height:40px;
	background-color: #f30000;
	visibility:visible;
	position: relative;
	top: 0;
	left: 0;
}

h2.ttl01:before{
	margin-right: 30px;
	transform: rotate(-35deg);
}

h2.ttl01:after{
	margin-left: 30px;
	transform: rotate(35deg);
}


.top-estimate {
	padding: 90px;
	position: relative;
	background-color: #ffe9e9;
	/* background-image: url("data:image/svg+xml,%3Csvg width='20' height='20' viewBox='0 0 20 20' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%2396d1fd' fill-opacity='0.4' fill-rule='evenodd'%3E%3Ccircle cx='3' cy='3' r='3'/%3E%3Ccircle cx='13' cy='13' r='3'/%3E%3C/g%3E%3C/svg%3E"); */
}

dl.estimate dt {
	text-align: center;
	font-size: 2rem;
	padding: 0 0 60px 0;
	color: #333;
	position:relative;
}

dl.estimate dt:after{
	content:"";
	width: 90px;
	height:2px;
	background:#333;
	position:absolute;
	bottom:20px;
	left: 50%;
	transform: translateX(-50%);
}

dl.estimate ol {
	display: flex;
	justify-content: space-around;
	align-items: center;
	width: 53%;
	margin: 0;
	/* box-sizing: border-box; */
}

ul.contact-area {margin: 0;width: 45%;display: flex;flex-direction: column;justify-content: center;align-items: flex-start;}

dl.estimate dd {
	display: flex;
	justify-content: space-between;
	width: auto;
	margin-top: 30px;
}

.step-head-img {
	width: 40%;
	padding: 20px;
	box-sizing: border-box;
}

.bg-img {
	width: 260px;
	height: 360px;
	background: url(/struct/wp-content/uploads/guide-img01.png)no-repeat;
	background-size: contain;
	position: absolute;
	bottom: 0;
	right: 0;
}

li.e-list {
	/* border: 2px solid; */
	/* width: 400px; */
	/* padding: 20px; */
	text-align: left;
}



.post ol li {
	list-style: none;
	line-height: 2;
	position: relative;
	color: #333;
	font-size:1.2rem;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 50%;
}

.post ol li:after{
	content: '';
	position: absolute;
	top: 50%;
	right: 0;
	transform: rotate(45deg) translateY(-50%);
	width: 10px;
	height: 10px;
	border-width: 2px 2px 0 0;
	border-style: solid;
	border-color: #333;
}

.post ol li:last-child:after{
	border:none;
}

a.e-link,
a.e-link-mail {
	background-color: #f30000;
	border: 1px solid transparent;
	color: #fff;
	width: 300px;
	border: 2px solid #333;
	padding: 30px;
	position:relative;
	transition:0.3s;
	display:flex;
	justify-content:center;
	align-items:center;
	font-size:1.3rem;
}

a.e-link-mail{
	background:#fff;
	color:#333;
	border:2px solid #333;
}

i.fa.fa-envelope-o.es-mail {
	margin-right: 10px;
	font-size: 1.6rem;
}

a.e-link:after{
	content: '';
	position: absolute;
	top: 50%;
	right: 10px;
	transform: translateY(-50%);
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 9px 0 9px 15px;
	border-color: transparent transparent transparent #fff;
}

.plan-Box {
	max-width: 1200px;
	width: 90%;
	padding: 0;
	margin: 60px auto;
}

h2.plan-ttl {
	margin-bottom: 30px;
	font-size:2rem;
	line-height: 1.5;
}

.plan-item {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	justify-content: space-between;
	/* margin-right: -15px; */
	/* margin-left: -15px; */
	width: 1100px;
	margin: 0 auto;
}

.plan-col3 {
	background: #f30000;
	/* border-radius: 20px; */
	-webkit-box-shadow: 0 0 15px rgb(0 0 0 / 10%);
	box-shadow: 0 0 15px rgb(0 0 0 / 10%);
	text-align: center;
	padding: 0;
	font-weight: bold;
	color: #fff;
}

.plan-row {
	-webkit-box-flex: 0;
	-ms-flex: 0 0 33.333333%;
	flex: 0 0 32%;
	max-width: 32%;
}

p.price {
	font-size: 2.3rem;
	letter-spacing: 0.2rem;
	color: #fff;
	padding: 10px 0;
}

span.tax {
	font-size: 1rem;
}

h3.col2__tit {
	background: none;
	font-size: 1.5rem;
	color: #fff;
	font-family: 'Noto Sans JP';
	/* font-weight: 700; */
	letter-spacing: 0.2rem;
	padding: 20px 0;
}

.plan-linkarea {
	color: #fff;
	padding: 30px 0;
	font-weight: 100;
}

.col2-img img {
	/* border-radius: 10px; */
}

.col2-img {
	/* width: 70%; */
	/* margin: 0 auto; */
}

p.sub-ttl {
	text-align: center;
	line-height: 2.5;
}

.moving-flow{
	margin-top:60px;
}

.point dl dd.price-02 {
	font-size: 2rem;
	letter-spacing: 0.2rem;
	text-align: center;
	color: #f30000;
	font-weight: 700;
}

p.point-txt {
	text-align: center;
	font-weight: 700;
	font-size: 1.2rem;
	padding: 20px 0;
	margin-bottom:20px;
	position: relative;
	border: 3px solid #696969;
	border-radius: 10px;
	background: #f9f9f9;
}

p.point-txt:before{
	position: absolute;
	bottom: -14px;
	left: 1em;
	width: 0;
	height: 0;
	content: '';
	border-width: 14px 12px 0 12px;
	border-style: solid;
	border-color: #696969 transparent transparent transparent;
}

p.point-txt:after{
	position: absolute;
	bottom: -10px;
	left: 1em;
	width: 0;
	height: 0;
	content: '';
	border-width: 14px 12px 0 12px;
	border-style: solid;
	border-color: #f9f9f9 transparent transparent transparent;
}





span.b-txt.corse {
	padding: 0;
	font-size: 3.6rem;
	color: #0002f2;
	bottom: 5px;
	position: relative;
}

ul.corse-flex {
	margin: 0;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

ul.corse-flex li {
	width: 48%;
	padding: 30px;
	box-sizing: border-box;
	border: 2px solid;
	margin-bottom: 60px;
}

ul.corse-flex li:nth-child(1){
	border-color: #333333;
	background:#e9ffe5;
}

ul.corse-flex li:nth-child(2){
	border-color: #333333;
	background:#fff7ee;
}

ul.corse-flex li:nth-child(3){
	border-color: #333333;
	background:#eef9ff;
}

ul.corse-flex li:nth-child(4){
	border-color: #333333;
	background:#fef;
}

.corse-Box {
	padding: 30px 90px;
	width: 1100px;
	margin: 0 auto;
}

.head-img img {
	max-height: 130px;
}

.head-img {
	display: flex;
	justify-content: center;
	padding-bottom: 20px;
	position:relative;
	/* background: #f4ffee; */
}

.head-img:after{
	content:"";
	position:absolute;
	width:90px;
	height:2px;
	background:#444;
	bottom:20px;
}

/*----------------------------
 * トップページリンクボタン
 * -------------------------*/
a.c-linkbtn,
a.i-linkbtn,
a.b-linkbtn {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	width: 300px;
	height: 60px;
	color: #333;
	font-size: 18px;
	font-weight: 400;
	text-decoration: none;
	transition: 0.3s;
	background-color: rgba(255,255,255,0.8);
}

a.c-linkbtn.btn01{
	border:1px solid #f30000;
}

a.c-linkbtn.btn02{
	border:1px solid #f30000;
}

a.c-linkbtn.btn03,
a.i-linkbtn,
a.b-linkbtn{
	border: 1px solid #f30000;
}

a.c-linkbtn.btn04{
	border:1px solid #f30000;
}


a.c-linkbtn:after,
a.i-linkbtn:after,
a.b-linkbtn:after{
	content: '';
	position: absolute;
	bottom: 10px;
	right: 10px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 0 12px 12px;
}

a.c-linkbtn.btn01:after{
	border-color: transparent transparent #f30000 transparent;
}

a.c-linkbtn.btn02:after{
	border-color: transparent transparent #f30000 transparent;
}

a.c-linkbtn.btn03:after,
a.i-linkbtn:after,
a.b-linkbtn:after{
	border-color: transparent transparent #f30000 transparent;
}

a.c-linkbtn.btn04:after{
	border-color: transparent transparent #f30000 transparent;
}

a.c-linkbtn:hover{
	border: 1px solid rgba(255,255,255,0.8);
}

a.c-linkbtn.btn01:hover{
	background:#52dea8
}

a.c-linkbtn.btn02:hover{
	background:#fab55a;
}

a.c-linkbtn.btn03:hover,
a.i-linkbtn:hover,
a.b-linkbtn:hover{
	background:#f30000;
}

a.c-linkbtn.btn04:hover{
	background:#fa7482;
}

a.c-linkbtn:hover,
a.i-linkbtn:hover,
a.b-linkbtn:hover{
	color:#fff;
}

a.c-linkbtn:hover:after,
a.i-linkbtn:hover:after,
a.b-linkbtn:hover:after{
	border-color: transparent transparent #f2f2f2 transparent;
	color:#fff;
}

.corse-link {
	display: flex;
	justify-content: center;
}

/*-----リンクボタンここまで---------*/

.benefits {
	padding: 3.5em 3em;
}

h2.benefits-ttl {
	padding-top: 10px;
}

.benefits-box {
	/* width: 1100px; */
	/* margin: 0 auto; */
	position: relative;
}

.benefits-column {
	margin-top: 60px;
}

ul.b-list {
	display: flex;
	justify-content: space-between;
	/* padding: 60px 0; */
}

ul.b-list li {
	width: 31%;
	position: relative;
	padding: 60px 0 0 0;
}

.b-image img {
	width: 100%;
	max-height: 224px;
}

.service-num {display: flex;flex-direction: column;position: absolute;top: 0;line-height: 1;background: #fff;padding: 20px;border: 1px solid #f30000;}

span.small {
	letter-spacing: 0.2rem;
	font-weight: 700;
	color: #0004f3;
	font-size: 1.1rem;
}

span.l-num {
	font-size: 4.5rem;
	font-weight: 900;
	color: #f30000;
	letter-spacing: 0.3rem;
}

h3.b-sub-ttl {
	font-size: 1.4rem;
	padding: 30px 0;
	margin:0 0 20px 0;
	position: relative;
	padding-bottom: 10px;
	color: #f30000;
	font-weight:700;
	min-height: 50px;
}

h3.b-sub-ttl:after,
h4.ttl:after{
	content: '';
	position: absolute;
	bottom: -10px;
	left: 0;
	width: 100%;
	height: 6px;
	background-image: repeating-linear-gradient(45deg, #f30000 0px, #333 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
	background-size: 8px 8px;
}

p.corse-txt {
	box-sizing: border-box;
	padding: 10px;
	min-height: 160px;
}

.be-link {
	display: flex;
	justify-content: center;
}

/*----------------------------
 * 引越プランページ
 * -------------------------*/
h2.p-lead-ttl {
	text-align: center;
	font-size: 1.8rem;
	font-weight: 700;
	color: #f30000;
	background: none;
}

.plan-lead-txt {
	margin: 0;
	background: #ffe9e9;
	/* border: 2px solid; */
	padding: 20px;
}

ul.moving-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	border: 2px solid #ff3000;
	margin: 30px 0;
	padding: 30px;
	box-sizing: border-box;
	background: #fff;
}

.ttl-icon.flow {
	width: 110px;
	height: 110px;
	margin-bottom: 10px;
}

.flow-inner {
	width: 1100px;
	margin: 0 auto;
	padding: 0 60px;
}

ul.moving-list li {
	width: 29%;
	position: relative;
	display: block;
	text-align: center;
	margin: 10px;
}

.moving-icon img {max-width: 38%;}

h4.flow-head-ttl {
	background: #ffe9e9;
	padding: 20px;
	border: 2px solid #333;
}

span.moving-flow-num {
	background: #ff3300;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	position: absolute;
	display: flex;
	justify-content: center;
	color: #fff;
}

img.alignnone.size-full.wp-image-242.colorbox-185 {
	height: 150px;
	width: 70px;
}

.moving-icon {
	margin: 20px;
	min-height: 160px;
	display: flex;
	justify-content: center;
	align-items: center;
}

ul.plan-list {
	margin: 0;
	display: flex;
	justify-content: space-between;
}

ul.plan-list li {
	width: 32%;
	background: #ffffff;
	/* border: 2px solid #333; */
	padding: 20px;
	box-sizing: border-box;
}

h3.plan-ttl {
	padding: 30px;
	font-size: 1.3rem;
	background: #f30000;
	color: #fff;
	text-align: center;
	margin: 0;
}

.plan-price p {
	font-size: 2.69em;
	font-weight: 700;
	letter-spacing: 0.2rem;
	text-align: center;
	color:#f30000;
}

.plan-price {
	margin: 30px 0;
}

span.price-txt {
	font-size: 1.2rem;
	margin-left: 5px;
	color: #333;
}

.c-columnbox {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
}

.course-left {
	width: 45%;
}

.course-left p {
	line-height: 2;
	margin-top: 20px;
}

.course-txt {
	width: 50%;
}

table.table-type01.responsive {
	width: 100%;
}

.point dl{
	/* background: #fdc2db; */
	padding:20px;
	box-sizing:border-box;
	border:2px solid #333;
}

.point dl dt {
	padding: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	border: 2px solid #333;
	background: #0048b4;
	color: #fff;
	font-weight: normal;
	min-height: 30px;
}

.point dl dd {
	margin: 20px 0;
	/* font-weight: 700; */
	font-size: 1rem;
	text-align: center;
	height: 30px;
}

div#course-detail-box {
	margin: 60px 0 0 0;
}

p.corse01-lead,
p.corse02-lead,
p.corse03-lead,
p.corse04-lead {
	font-size: 1.5rem;
	background: #f30000;
	color: #fff;
	padding: 20px;
	border: 2px solid #333;
}

ul.course-list {
	margin: 20px 0;
}

p.course-sub-txt {
	text-align: center;
	/* padding-bottom: 10px; */
}

h3.corse-ttl {
	font-size: 1.8rem;
	font-weight: 700;
	padding: 20px 0;
	color: #f30000;
}
.anchors {
	padding-top: 250px !important;
	margin-top: -250px !important;
	z-index: -1;
}

h4.course-sub-ttl {
	background: #0048b4;
	color: #fff;
	border: 2px solid #333;
	padding: 20px;
	font-weight: 100;
	/* border-left: none; */
}


table.table-type01.responsive th{
	background: #cccccc;
	border: 2px solid #333!important;
}

table.table-type01.responsive th,table.table-type01.responsive td {
	width: 20%;
	text-align: center;
	border-bottom: none;
	vertical-align: middle;
	font-size: 1rem;
	padding: 10px 0;
}

.plan-type {
	position: relative;
	/* background: #fdc2db; */
	padding: 0 0  30px;
}

.plan-type.inner{
	margin:0 auto;
}

/*----------------------------
 * サービスページ
 * -------------------------*/

.lead-img {
	text-align: center;
}

.lead-txt {
	margin: 60px 0;
	line-height: 2;
	font-size: 1.3rem;
}

ul.b-list.s-list {
	flex-wrap: wrap;
	padding: 60px 0;
}

.s-column {
	display: flex;
	justify-content: space-between;
	padding: 30px;
	border: 2px solid #333;
	margin: 60px 0;
}

.column-img {
	display: flex;
	width: 50%;
}

.column-img img {
	width: 50%;
}

.column-txt {
	width: 50%;
	padding: 30px;
}

h3.service-ttl {
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.2rem;
}

h3.service-ttl:first-letter{
	color:#f30000;
}

h2.lead-ttl {
	line-height: 1.3;
}

/*--------------------
 * オプションページ
 * -----------------*/
.box-column {
	display: flex;
	justify-content: space-between;
	align-items:center;
	border: 2px solid #aaa;
	margin:30px 0;
}

.pic {
	width: 37%;
	padding: 50px;
	box-sizing:border-box;
}

.txt {
	width: 63%;
	padding: 50px;
	box-sizing: border-box;
}

h4.ttl {
	font-size: 1.6em;
	padding: 20px 0;
	margin-bottom: 30px;
	color: #f30000;
	position:relative;
}

dl.price-list {
	display: flex;
	justify-content: flex-start;
	align-items:center;
}

dl.price-list dt,
dl.price-list dd{
	padding:10px;
	margin:10px;
}

dl.price-list dt {
	width: 25%;
	font-weight:100;
	background: #0100ff;
	color:#fff;
	text-align: center;
}

dl.price-list dd {
	width: 60%;
}

dl.price-list dd.price-num{
	font-size: 2rem;
	font-weight:700;
	letter-spacing:0.1rem;
	text-align: right;
	color: #ff0000;
}

dl.price-list dd span.price-txt{
	font-size:1.2rem;
	margin-left:5px;
	color: #333;
}


h3.lead-ttl {
	background: #ff7394;
	border-bottom: 2px solid #333;
	border-top: 2px solid #333;
	padding: 30px;
	margin: 30px 0;
	font-size: 2rem;
	color: #fff;
	font-weight: 700;
}

.other-option {
	width: 1100px;
	margin: 0 auto;
}

h3.other-ttl.ttl02 {
	text-align: center;
	font-size: 2rem;
	font-weight: 700;
	padding-bottom:30px;
	margin-bottom:30px;
	position:relative;
}

h3.other-ttl.ttl02:after{
	position:absolute;
	width:60px;
	height:2px;
	background:#333;
	content:"";
	bottom:0;
	left:50%;
	transform:translateX(-50%);
}

.o-l ul {
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	position: relative;
	margin: 0;
}

.o-l ul li {
	width: 32%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	margin: 0;
}

.o-img {
	max-width: 150px;
	padding: 20px;
	box-sizing: border-box;
}

p.bottom-txt {
	text-align: center;
	margin: 60px;
	font-size: 1.3rem;
	background: #0100ff;
	padding: 20px;
	color: #fff;
}


/*----------------------------
 * 会社概要ページ
 * -------------------------*/
h2.ttl02 {
	position: relative;
	padding: 0 0 30px 0;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.2rem;
	color: #f30000;
}

h2.ttl02:after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 6px;
	background-image: repeating-linear-gradient(45deg, #ea3b4b 0px, #fb9a55 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
	background-size: 8px 8px;
	visibility: visible;
}

table.responsive {
	width: 80%;
	margin: 30px auto;
}

table.responsive th {
	width: 25%;
}

table.responsive td {
	width: auto;
}

ul.service-list li {
	list-style: inside;
}

dl.profile-list dt {
	letter-spacing: 0.2rem;
}

dl.profile-list dd {
	border-bottom: 1px dotted #ddd;
}

table.responsive th,
table.responsive td {
	border-bottom: 1px solid #333;
	padding: 30px 0;
	background: none;
	font-size: 1.15rem;
}

table.responsive.overview-list th,
table.responsive.overview-list td {
	padding: 20px;
}

table.responsive.overview-list th{
	font-size:1.2rem;
	width:25%;
}

table.responsive.overview-list td{
	width:65%;
}

.company-profile {
	margin: 0 auto;
	position:relative;
	padding: 50px 0;
}

.company-profile:before {
	content: "";
	background: url(/struct/wp-content/uploads/4357473_m.jpg)repeat-y;
	width: 100vw;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	height: 100%;
	position: absolute;
	top: 0;
	z-index: 0;
	opacity: 0.4;
}

li.pref {
	border: 2px solid #333;
	padding: 10px;
	background: #dadada;
}

ul.place-list {
	margin: 0;
}

span.sub-txt {
	font-size: 0.86rem;
}

i.fa.fa-map-marker {
	margin-right: 10px;
}

a.map {
	padding: 10px 0;
	position: relative;
	margin: 15px 0 5px 0;
	border: 2px solid #333;
	background: #fff;
	color: #333;
	display: block;
	width: 28%;
	text-align: center;
}

a.map:hover {
	background: #ff8181;
	color: #fff;
	border:2px solid transparent;
}

/*--------------------------------------
 * お問い合わせページ
 * -----------------------------------*/
h2.form-ttl {
	font-size: 2rem;
	font-weight: 900;
	border-bottom: 1px solid #d7000f;
	padding-bottom: 20px;
	display: inline-block;
}

.contact_phone {
	padding: 20px;
	border: 1px solid #333333;
	display: inline-block;
	min-width: 300px;
	margin: 30px;
	font-size: 1.6rem;
	font-weight: 900;
}

.contact_phone span {
	color: #333;
}

.fa-phone-square:before {
	color: #333;
	font-size: 1.7rem;
}

i.fa.fa-phone-square {
	margin: 0 10px 0 0;
}


dl.form {
	width: 90%;
	margin: 30px auto;
	padding: 30px;
	text-align: left;
	border: 1px solid;
}

dl.form dt {
	padding: 10px 0;
	font-size: 1.1rem;
	font-weight: 400;
	border-bottom: 1px solid #aaaaaa;
}

dl.form dd {
	margin: 15px 0;
}

form.wpcf7-form {
	text-align: center;
}

span.wpcf7-form-control-wrap.number-family {
	width: 20%;

	margin-right: 10px;

}

span.wpcf7-form-control-wrap.custom_m {
	/* width: 20%; */
	display: inline-block;
	margin-right: 10px;
}
div#info2 {
	width: 100%;
	position: relative;
}

.post table.form th {
	border: 2px solid #fff;
	text-align: left;
	padding: 30px 60px;
	width: 41%;
	vertical-align: top;
	font-size: 1.1rem;
	position: relative;
	background: #dff2ff;
}

.post table.form td {
	width: auto;
	display: block;
	/* margin-left: 30px; */
	border-bottom: 2px solid #fff;
	padding: 30px;
	background: #dff2ff;
}

input[type="text"], input[type="tel"], input[type="email"], input[type="date"], input[type="url"], input[type="number"], select, textarea {
	vertical-align: middle;
	line-height: 40px;
	height: 40px;
	width: auto;
	box-sizing: border-box;
}

input.wpcf7-form-control.wpcf7-text.wpcf7-validates-as-required.zip-code {
	width: 150px;
}

span.wpcf7-list-item:first-child {
	margin: 0;
}

input.name-01,
input.name-02 {
	width:30%;
}

input.name-01{
	margin-right:20px;
}

.day-column {
	display: flex;
	justify-content: flex-start;
}

p.day-txt {
	width: 25%;
}

.moving-day {
	width: 100%;
}

.c-address dl {
	display: flex;
	justify-content: flex-start;
	gap: 30px;
	margin-bottom: 10px;
}

.c-address dl dt{
	width:25%;
}

c.address dl dd{
	width:70%;
}

.item-list ul {
	margin: 0;
	display: flex;
	justify-content: space-between;
	flex-basis: 100%;
	flex-wrap: wrap;
	gap: 10px;
}

.quantity {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	font-size: 0.9rem;
}

span.wpcf7-form-control-wrap.number-item {
	width: 50%;
}

input.wpcf7-form-control.wpcf7-number.wpcf7-validates-as-number {
	width: 100%;
	margin-top: 10px;
}

input.wpcf7-form-control.wpcf7-number.wpcf7-validates-as-number.short {
	width: 20%;
}

.item-list ul li p {
	text-align: center;
	background: #0048b4;
	color: #fff;
	min-height: 50px;
	padding: 10px;
	font-size: 1rem;
	display: flex;
	justify-content: center;
	align-items: center;
}

.item-list ul li {
	border: 1px solid #333;
	padding: 10px;
	box-sizing: border-box;
	margin: 0 0 10px 0;
	width: 30%;
}

textarea.wpcf7-form-control.wpcf7-textarea.other-txt {
	line-height: initial;
	height: auto;
	width: 90%;
}

.wpcf7-form .must {
	float: none;
}

.post .linkBtn {
	background: #ff2828;
}

.post .linkBtn:hover {
	background: #ff4646;
}
/*-----------------------------------------------
  送信完了ページ
-----------------------------------------------*/
article#post-77 h1 {
	margin-bottom: 60px;
	border-bottom: 1px solid #111;
	padding: 20px 0;
	text-align: left;
}

article#post-77 .post {
	min-height: 400px;
}

.th-txt {
	text-align: center;
	background: #f7f7f7;
	padding: 60px;
	box-sizing: border-box;
	width: 960px;
	margin: 30px auto;
}

h2.thanks-title{
	font-size:1.5rem;
	font-weight:900;
	text-align:center;
	padding:0;
}

i.fa.fa-undo {
	margin-right: 10px;
}

a.re-top {
	background-color: #0103f7;
	border: 2px solid #0102f6;
	color: #fff !important;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
	padding: 10px;
	margin-top: 20px;
	display: inline-block;
	width: 25%;
}

a.re-top:hover{
	background-color: transparent;
	border: 2px solid #998bfa;
	color: #998bfa !important;
}

/*-------------------------
 * 引越約款ページ
 * ----------------------*/
.moving-lead {
	margin: 60px 0;
}

h2.moving-main-ttl{
	font-size: 1.6rem;
	color: white;
	font-weight: normal;
	margin-bottom: 0.8em;
	line-height: 1.4em;
	background-color: #2a588b;
	border: 2px solid #333;
	padding: 30px;
	margin-bottom: 40px;
}

h3.m-sub-ttl{
	font-size: 1.6rem;
	color: #241613;
	margin-bottom: 1em;
	padding-bottom: 1em;
	position: relative;
	border-bottom: 4px white solid;
	margin-bottom: 1.4em;
}

h3.m-sub-ttl:after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 6px;
	background-image: repeating-linear-gradient( 
	45deg
	, #ea3b4b 0px, #fb9a55 1px, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 50%);
	background-size: 8px 8px;
	visibility: visible;
}

/*-----------------------------
 * プライバシーポリシー
 * -------------------------*/
.post ol.privacy-ol {
	margin: 0;
}

.post ol.privacy-ol li {
	width: auto;
	display: block;
	line-height: 1;
	font-size: 1rem;
}

.post ol.privacy-ol li:after {
	content: none;
}
.privacy {
	text-align: left;
	margin: 30px 0;
}

h2.privacy_title {
	font-size: 24px;
	text-align: left!important;
	color: #0202f6;
	margin: 30px 0;
	background: none!important;
	padding-left: 0;
	font-weight:900;
}

h3.pb-info-ttl {
	padding: 20px;
	background: #eee;
	margin: 0;
}

.privacy-bottom-info {
	border: 1px solid #eee;
	padding: 0;
}

.privacy-bottom-info p {
	padding: 10px 20px;
}

/*------------------------------
 * タブレット以下
 * --------------------------*/
@media print,screen and (max-width:767px){
	h1.title.first span {
		text-align: center;
		display: block;
	}

	header#h1Header {
		width: auto;
		height: 100px;
	}

	p.tel-txt {
		font-size: inherit;
	}

	#header .contact .tel img {
		width: 21%;
	}

	#header .contact {
		width: auto;
	}

	#header .contact .tel {
		color: initial;
		font-family: 'Noto Sans JP';
		font-weight: 900;
		vertical-align: middle;
		line-height: 1;
	}

	p.tel-txt {
		font-size: 1.6rem!important;
	}

	.contact p {
		margin: 30px 0;
	}

	.tel-sub-txt {
		width: 40%;
		justify-content: space-between;
		position: relative;
		right: -90px;
		top: 0;
		color: #ff0000;
	}

	#header .contact, #header .contact p {
		color: #ff0000;
	}

	div#front_top_content {
		width: auto;
	}

	.postlist .post_text {
		display: flex;
		flex-direction: column;
		align-items: center;
	}

	.top-estimate {
		padding: 0;
	}

	dl.estimate dt {
		font-size: 1.6rem;
		padding: 30px;
		line-height: 1.5;
	}

	dl.estimate dt:after {
		bottom: 0;
	}

	dl.estimate dd {
		flex-direction: column;
	}

	dl.estimate ol {
		flex-direction: column;
		width: auto;
	}

	.post ol li {
		flex-direction: column;
		width: auto;
		margin: 30px 0;
	}

	.step-head-img {
		width: 30%;
		padding: 0;
	}

	.post ol li:after {
		transform: rotate(135deg) translateX(-50%);
		bottom: -30px;
		top: auto;
		right: auto;
	}

	ul.contact-area {
		width: auto;
		padding: 10px;
	}

	a.e-link, a.e-link-mail {
		width: 250px;
		padding: 20px 40px;
		margin: 0 auto;
		display: block;
	}

	.bg-img {
		width: 118px;
		height: 158px;
		/* position: relative; */
		bottom: 190px;
		right: -10px;
	}

	li.e-list {
		/* text-align: center; */
		/* display: block; */
		/* margin: 30px auto; */
	}

	ul.contact-area li {
		text-align: center;
		display: block;
		margin: 10px auto;
	}

	.plan-item {
		width: auto;
		flex-direction: column;
	}

	.plan-row {max-width: 100%;margin: 10px 0;}

	h2.corse-ttl.ttl01 {
		font-size: 1.2rem;
	}

	span.b-txt.corse {
		font-size: 2rem;
		bottom: 0;
	}

	.corse-menu {
	}

	.plan-Box {
		width: auto;
		max-width: 100%;
		padding: 10px;
	}

	.corse-Box {
		width: auto;
		padding: 10px;
	}

	ul.corse-flex {
		flex-direction: column;
		flex-wrap: inherit;
	}

	ul.corse-flex li {
		width: auto;
	}

	p.corse-txt {
		font-size: 1rem;
		line-height: 2;
	}

	.head-img {
		padding-bottom: 40px;
	}

	h2.benefits-ttl.ttl01 {
		font-size: 1rem;
	}

	.benefits-box {
		width: auto;
	}

	ul.b-list {
		flex-direction: column;
		margin: 0;
	}

	ul.b-list li {
		width: auto;
	}

	.benefits-column {
		margin-top: 30px;
	}

	p.footeradd {
		text-align: center;
	}

	p.footertel {
		text-align: center;
		/* margin-top: 20px; */
		font-size: 1.4rem;
		font-weight: 900;
	}
	/*プランSP*/
	h2.p-lead-ttl {
		font-size: 1.6rem;
		line-height: 1.5;
	}

	p.sub-ttl {
		line-height: 2;
		text-align: left;
	}

	.flow-inner {
		width: auto;
		padding: 10px;
	}

	ul.moving-list {
		flex-direction: column;
	}

	ul.moving-list li {
		width: auto;
		margin: 0;
	}

	.moving-icon {
		min-height: 100px;
	}

	h2.course-ttl.ttl01 {
		font-size: 1.3rem;
	}

	p.course-sub-txt {
		padding: 10px;
		text-align: left;
	}

	p.corse01-lead, p.corse02-lead, p.corse03-lead, p.corse04-lead {
		text-align: center;
		line-height: 1.5;
	}

	.detail-inner {
		width: auto;
	}

	.c-columnbox {
		flex-direction: column;
	}

	.course-left {
		width: auto;
	}

	.course-head-img {
		text-align: center;
	}

	.course-left p {
		padding: 10px;
	}

	.course-txt {
		width: 95%;
		padding: 10px;
	}


	h3.corse-ttl {
		font-size: 1.5rem;
		text-align: center;
	}

	table.table-type01.responsive th, table.table-type01.responsive td {
		display: inline-flex;
		flex-wrap: wrap;
		justify-content: center;
		margin: 5px;
	}

	ul.plan-list {
		flex-direction: column;
	}

	ul.plan-list li {
		width: auto;
	}

	table.table-type01.responsive tr {
		display: flex;
	}
	/*サービスSp----------------------*/
	.lead-txt {
		font-size: 1rem;
		padding: 10px;
		width: auto;
	}

	.service-lead {
		width: auto;
	}
	.s-column {
		flex-direction: column;
		justify-content: flex-start;
		/* padding: 10px; */
	}

	.service-inner {
		width: auto;
		padding: 10px;
	}

	.column-txt {
		width: auto;
		padding: 10px;
	}

	h3.service-ttl {
		font-size: 1.5rem;
		padding: 0;
		text-align: center;
	}

	.column-img {
		width: auto;
		justify-content: center;
	}

	.service-list-inner {
		width: auto;
		padding: 10px;
	}

	h2.lead-ttl.ttl01 {
		font-size: 1.3rem;
	}
	/*オプションSP-------------------------*/
	.option-lead {
		width: auto;
		padding: 10px;
	}

	.box-column {
		flex-direction: column;
	}

	.pic {
		width: auto;
		padding: 30px;
	}

	.txt {
		width: auto;
		padding: 20px;
	}

	dl.price-list dd.price {
		font-size: 1.5rem;
	}

	.other-option {
		width: auto;
		padding: 10px;
	}

	h3.other-ttl.ttl02 {
		font-size: 1.5rem;
		line-height: 1.5;
		padding-left: 0;
	}

	.o-l ul {
		flex-direction: column;
	}

	.o-l ul li {
		width: auto;
	}

	.o-img {
		max-width: 100%;
		width: auto;
	}

	p.bottom-txt {margin: 60px 0;}
	/*-----------------------会社概要SP---------------------*/
	.company-profile {
		width: auto;
		text-align: left;
	}

	.post table.responsive th, .post table.responsive td {
		text-align: left;
	}

	.post table.responsive th {
		font-weight: 700;
	}
	/*------------------------お問い合わせSP--------------------*/
	.wpcf7-form {
		padding: 5px;
	}

	.wpcf7-form .must {
		display: inline-block;
	}

	h2.form-ttl {
		font-size: 1.5rem;
	}

	.contact_phone {
		width: auto;
		display: block;
		margin: 0;
		min-width: 0;
		font-size: 1.4rem;
	}

	dl.form {
		width: auto;
		margin: 30px 0;
		font-size: 0.9rem;
	}

	dl.form dt {
		font-size: 0.9rem;
	}

	table.form th,table.form td {
		display: block;
		width: auto;
	}

	.post table.form th,.post table.form td {
		width: auto;
		padding: 20px;
		margin: 0;
		border: none;
	}

	.c-address dl {
		flex-direction: column;
	}

	.c-address dl dt {
		width: auto;
	}

	.item-list ul {
		flex-direction: column;
	}

	.item-list ul li {
		width: auto;
	}

	.quantity {
		display: block;
		width: 50%;
		margin: 0 auto;
		text-align: center;
	}
}

/*spロゴ調整*/
@media only screen and (max-width: 1023px){
	body.mobile #header .logo img{
		max-height: 50px;
	}
}
/*
 *PCスティッキー時の調整
 */
body #breadcrumb ,
body #mainImg,
body header#h1Header{
	margin-top: 0;
}
@media (min-width:1024px) {
	body:not(.mobile) #mainNav + * {
		margin-top: 164px;
	}
	body:not(.mobile).admin-bar #mainNav + * {
		margin-top: 132px;
	}
	body:not(.mobile).home nav#mainNav + * {
		margin-top: 160px;
	}
	body:not(.mobile).home.admin-bar nav#mainNav + * {
		margin-top: 128px;
	}
}
/*
 *SPスティッキー時の調整
 */
body.mobile #breadcrumb ,
body.mobile #mainImg {
	margin-top: 0;
}
@media (max-width:1023px) {
	body.mobile #header + * {
		margin-top: 60px;
	}
}
/*
 * フォーム関連
 */
.first_hide ,
table.responsive tr.first_hide {
	display:none;
}
form.wpcf7-form #estimate_system {
	text-align: left;
}
#estimate_system p:empty {
	display: none;
}
#estimate_system h2.ttl02 {
	margin: 1em 0;
}

#estimate_system #stepper {
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	align-items: center;
}
#estimate_system #stepper li {
	background: #dcdcdc;
	padding: .5em 2em;
	margin: 0;
}
#estimate_system #stepper li.active {
	background: #0048b4;
	color: #fff;
}
#estimate_system #stepper li.space {
	cursor: auto;
	height: 1px;
	padding: 0;
	flex-grow: 1;
	margin: 0 .5em;
}

#estimate_system table.responsive th,
#estimate_system table.responsive td {
	text-align: left;
	font-size: 1em;
	padding: 1em;
	vertical-align: middle;
	border-bottom: 1px solid #bbb9b9;
}
#estimate_system table.responsive tr:last-of-type th,
#estimate_system table.responsive tr:last-of-type td {
	border-bottom: none;
}
#estimate_system table {
	width: 100%;
	margin: 0;
}
#estimate_system input[type="text"], #estimate_system input[type="tel"], #estimate_system input[type="email"], #estimate_system input[type="date"], #estimate_system input[type="url"], #estimate_system input[type="number"], #estimate_system select, #estimate_system textarea {
	width: 100%;
}
#estimate_system textarea {
	height: 10em;
}
#estimate_system .short_input input,
#estimate_system input.short_input {
	width: 10em !important;
	display: inline-block;
}
#estimate_system th {
	width: 15em;
	position: relative;
}
#estimate_system .must {
	position: absolute;
	top: 50%;
	right: 1em;
	transform: translateY(-50%);
}
#estimate_system div.label .must {
	position: static;
	transform: none;
}
#estimate_system div.label {
	border-left: 3px solid #f30000;
	padding-left: .5em;
	margin: .5em 0;
}
#estimate_system .msg_area {
	background: #97bfde;
	padding:.5em 1em;
	border-radius: 10px;
	text-align: center;
}
#estimate_system .msg_area p {
	padding: 0;
}
#estimate_system .msg_area p.heading {
	font-size: 120%;
	color: #fff;
	padding: 0;
	border-bottom: 1px solid #fff;
	padding-bottom: .5em;
	margin-bottom: .5em;
}

#estimate_system .wpcf7-list-item {
	display: inline-block;
	margin: 0;
}
#estimate_system input[type="radio"] {
	display: none;
}
#estimate_system input[type="radio"] + span {
	padding: .5em 1em;
	background: #dcdcdc;
	display: inline-block;
}
#estimate_system input[type="radio"]:checked + span {
	background: #0048b4;
	color: #fff;
}

#estimate_system .step_wrap:not(.step01) {
	display:none;
}

#estimate_system .btns_area {
	margin-top: 1em;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
}
#estimate_system .linkBtn {
	cursor: pointer;
	margin: 0;
	box-sizing: border-box;
}
#estimate_system .linkBtn.submit {
	padding: 0;
	position: relative;
}
#estimate_system .linkBtn.submit input {
	padding: 0.5em 2.5em 0.5em 2.5em;
	display: inline-block;
	width: 100%;
	height: 100%;
	box-sizing: border-box;
}
#estimate_system .linkBtn[step_type="back"] {
	background: #888888;
}
#estimate_system .linkBtn[step_type="back"]:hover {
	background: #afafaf;
}
#estimate_system ul.validate_msg {
	color: #ff0000;
	list-style: disc;
	padding: 0 1em;
	font-size: .8em;
}
#estimate_system ul.validate_msg li {
	margin: 0;
}
#estimate_system .btns_area .linkBtn:nth-of-type(2) {
	margin-left: .5em;
}
#estimate_system .ajax-loader {
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}
#estimate_system .loads {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
#estimate_system .loads li {
	width: 16%;
	text-align: center;
	box-sizing: border-box;
	display: flex;
	flex-wrap: wrap;
	flex-direction: column;
	justify-content: flex-start;
}
#estimate_system .loads li > figure, 
#estimate_system .loads li > div {
	width: 100%;
}
#estimate_system .loads li > figure {
	flex-grow: 1;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: center;
}
#estimate_system .loads li > figure > figcaption {
	width: 100%;
	text-align: center;
	align-self: flex-end;
}
#estimate_system .loads img {
	height: 7vh;
	max-height: 80px;
	object-fit: contain;
}
#estimate_system .loads li:nth-child(6n+2):last-child {
	margin-right: calc( ( 16% * 4 ) + ( ( ( 100% - ( 16% * 6 ) ) / 5 )  * 4 ) );
}
#estimate_system .loads li:nth-child(6n+3):last-child {
	margin-right: calc( ( 16% * 3 ) + ( ( ( 100% - ( 16% * 6 ) ) / 5 )  * 3 ) );
}
#estimate_system .loads li:nth-child(6n+4):last-child {
	margin-right: calc( ( 16% * 2 ) + ( ( ( 100% - ( 16% * 6 ) ) / 5 )  * 2 ) );
}
#estimate_system .loads li:nth-child(6n+5):last-child {
	margin-right: calc( ( 16% * 1 ) + ( ( ( 100% - ( 16% * 6 ) ) / 5 )  * 1 ) );
}

.vision_tab , .vision_tab * {
	box-sizing:border-box;
}
div.vision_tab {
	border-radius:0;
	border:0;
	padding:0;
	font-size: 1em;
}
.vision_tab ul.tab_menu {
	display:flex;
	width:100%;
	margin:0;
	padding:0;
	border-radius:0;
	border:0;
	background: transparent;
}
.vision_tab .tab_menu li {
	background: #dcdcdc;
	margin:0;
	border-radius: 0;
	margin-bottom: -1px;
	border: 1px solid #0078ae;
	border-bottom: none;
}
.vision_tab .tab_menu li.ui-tabs-active {
	margin:0;
	background: #0048b4;
}
.vision_tab .tab_menu li:first-child {
	border-right: none;
}
.vision_tab .tab_menu li a {
	display:block;
	width:100%;
	height:100%;
	color: #222;
}
.vision_tab .tab_menu li.ui-tabs-active a {
	pointer-events: none;
	color: #fff;
}
.vision_tab .tab_contents {
	border: 1px solid #0048b4;
	padding: .2em;
	box-sizing: border-box;
}
@media (max-width: 768px) {
	#estimate_system {
		font-size: .6em;
	}
	#estimate_system table.responsive th {
		font-size:1.2em;
	}
	#estimate_system #stepper li {
		padding: .5em;
	}
	#estimate_system h2.ttl02 {
		margin: 1em 0;
		font-size: 1.5em;
		padding-bottom: 1em;
	}
	#estimate_system .linkBtn {
		width: 100%;
	}
	#estimate_system .btns_area .linkBtn:nth-of-type(2) {
		margin-left: 0;
		margin-top: .5em;
	}
}
nav#mainNav ul li a span, nav#mainNav ul li a b {
	font-size: 12px;
}



