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


/* 追加・変更
------------------------------------------------------------*/
/*　グローバルメニュー　項目余白調整　*/
@media print, screen and (min-width: 1024px){
nav#mainNav ul li a {
    padding: 15px 20px;
	height: auto;
}
/*nav#mainNav ul li {
    width: 14%;
}*/
}

/*-----------------------------------
 clearfix2021
-----------------------------------*/
/*float clear*/
.clearfix:after {
  content: "";
  display: block;
  clear: both;
} 
.clearfix:before {
  content: "";
  display: block;
  clear: both;
} 
.clearfix {
  display: block;
}

/*改行位置指定用*/
span.nowrap {
display:inline-block;
white-space:nowrap;
}
.nowrap {
white-space:nowrap;
}
@media print, screen and (min-width: 641px){
br.sp {
display:none;
}
}
@media print, screen and (max-width: 640px){
br.pc {
display:none;
}
}

/*赤文字*/
.fc-red {color:#F00}

/*画像装飾なし*/
.post img.nodeco {
	padding:0;
	border-width:0 !important;
	background-color:transparent;
}
.post img.alignright.nodeco {
	padding:0;
	border-width:0 !important;
}

/* カラムレイアウト　余白設定
------------------------------------*/
.colinner {padding: 0 5%;}
.colinner-l {padding: 0 5% 0 0;}
.colinner-r {padding: 0 0 0 5%;}
.colinner-c {padding: 0 2.5%;}

@media print, screen and (max-width: 640px){
.colinner,.colinner-l,.colinner-r,.colinner-c{padding: 0;}
}

/*スマホ時文字揃え*/
@media print, screen and (max-width: 799px){
.column2_50 {text-align: left !important;}
}

/* flexbox
--------------------*/
.flex {
display: flex;
	justify-content: center;
	align-items: stretch;
	flex-wrap: wrap;
}
/* 区切り線　（不可視）
--------------------*/
hr.hidden {
	visibility: hidden;
	margin: 1em auto;
}

/*GoogleMap埋め込み対処
-----------------------------------*/
.ggmap {
position: relative;
padding-bottom: 30%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
 
.ggmap iframe,
.ggmap object,
.ggmap embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}

/*--------------------------------
　共通
----------------------------------*/
/* section
------------*/
.post section {margin-bottom: 3em;}
.post section:last-child {margin-bottom: 0;}

/*ページ下部の余白削除*/
.home #content,#content {padding-bottom: 0;}
/*.post {
	margin-bottom: 0;
	padding-bottom: 0;
}*/

/* ボタン
------------*/
.btn {
	text-align: center;
	margin-top: 1.5em;
}
.btn a {
	position: relative;
	display: inline-block;
	width: 200px;
	border: 1px solid #fff;
	color: #fff;
	padding: 1em;
	transition: all .3s;
}
.btn a:hover {}
.btn a::before {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 10px;
	height: 100%;
	display: block;
	background: #d7a625;
	transition: .3s;
	z-index: -1;
}
.btn a:hover::before {
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: block;
}
.btn a::after{
	content: "";
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: block;
	background: #103454;
	z-index: -2;
}
.btn a img {vertical-align: middle;}

/* 見出し
----------------*/
.page-top h1.title,.page-top .post h1 {
	position: relative;
	text-align: center;
	font-size: 45px;
	color: #d7a625;
}
.page-top h1 span.subttl,
h1 span.subttl {
	display: block;
	font-size: 20px;
	font-weight: normal;
	color: #fff;
	margin: 0;
	padding-left: 0;
}

/*調整*/
ul.st1 {
	list-style: disc;
	margin-left: 2em;
}

/*アンカー位置調整*/
#a01,#a02,#a03,#a04,#a05,#a06 {
	padding-top: 50px;
	margin-top: -50px;
}

/*画面幅一杯に*/
body{overflow-x:hidden;}
#wrapper, #content, .post{overflow: visible;}
.f-w {
    margin-right: calc(((100vw - 100%) / 2) * -1);
    margin-left: calc(((100vw - 100%) / 2) * -1);
    padding: 3em calc((100vw - 100%) / 2);
}

/*フッタ　お問い合わせ*/
.contactbox {
	position: relative;
	margin-right: calc(((100vw - 100%) / 2) * -1);
	margin-left: calc(((100vw - 100%) / 2) * -1);
	padding: 50px calc((100vw - 100%) / 2) !important;
	background: url("images/contactbox_bg.jpg") no-repeat center;
	background-size: cover;
	margin-bottom: 0;
	text-align: center;
	color: #000;
}
.contactbox::after {
	content: "";
	position: absolute;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	background-color: rgba(16,52,84,0.70);
}
.contactbox>div {
	position: relative;
	z-index: 1;
	background-color: rgba(255,255,255,0.80);
	padding: 30px;
	border-radius: 15px;
}
.contactbox h1 {color: #d7a625;}
.contactbox h1 .subttl {
	color: #000 !important;
	display: block;
	font-size: 20px;
	font-weight: normal;
	margin: 0;
	padding-left: 0;
}
.contactbox .btn a {
	margin: 10px 30px;
}
/*　スマホ　*/
@media print, screen and (max-width: 640px){
	.contactbox .btn a {
		margin: 10px 0;
	}
}

/*--------------------------------
　トップページ
----------------------------------*/
/* Information
----------------*/
#front_top_content {margin: 5em auto;}

/* バナー
----------------*/
.bnr {
	margin-right: calc(((100vw - 100%) / 2) * -1);
	margin-left: calc(((100vw - 100%) / 2) * -1);
    padding: 0;
	overflow: hidden;
}
.bnr.b1 {
	background: url("images/b1_bg.jpg") no-repeat left center;
	background-size: cover;
	margin-bottom: 0 !important;
}
.bnr.b2 {
	background: url("images/b2_bg.jpg") no-repeat right center;
	background-size: cover;
}

/* .photo */
.b1 .photo,.b2 .photo {display: none;}

/* .b1 .txt */
.bnr.b1 .txt {
	position: relative;
	z-index: 1;
	width: 34%;
	margin-left: 60%;
	padding: 50px 3%;
}
.bnr.b1 .txt::before{
    transform: skewX(20deg);
    content: "";
    position: absolute;
	left: 0px;
	top:0;
	width: 200%;
	height: 101%;
    z-index: -1;
	background:#103454;
}
.bnr.b1 .txt::after{
    transform: skewX(20deg);
    content: "";
    position: absolute;
	left: -30px;
	top: 0;
	width: 200%;
	height: 101%;
    z-index: -2;
	background:#D7A625;
}
/* .b2 .txt */
.bnr.b2 .txt {
	position: relative;
	z-index: 1;
	width: 34%;
	margin-right: 60%;
	padding: 50px 3%;
}
.bnr.b2 .txt::before{
    transform: skewX(-20deg);
    content: "";
    position: absolute;
	right: 0px;
	top:0;
	width: 200%;
	height: 101%;
    z-index: -1;
	background:#103454;
}
.bnr.b2 .txt::after{
    transform: skewX(-20deg);
    content: "";
    position: absolute;
	right: -30px;
	top: 0;
	width: 200%;
	height: 101%;
    z-index: -2;
	background:#D7A625;
}

/*　スマホ　*/
@media print, screen and (max-width: 900px){
	.bnr.b1,.bnr.b2 {background-image: none !important;}
	.bnr.b1 .txt,.bnr.b2 .txt {
		width: 80%;margin: 0;padding: 25px 10%;
		background-color: #103454;
	}
	.bnr.b1 .txt::before,.bnr.b2 .txt::before,
	.bnr.b1 .txt::after,.bnr.b2 .txt::after {content: none;}
	/* .photo */
	.b1 .photo,.b2 .photo {
		position: relative;
		display: block;
		height: 300px;width: 100%;
	}
	.b1 .photo {background: url("images/b1-2_bg.jpg") no-repeat left center;background-size: cover;}
	.b2 .photo {background: url("images/b2-2_bg.jpg") no-repeat right center;background-size: cover;}
	.b1 .photo::before {
		transform: skewX(10deg);
		content: "";
		position: absolute;
		right: -90%;
		top:0;
		width: 100%;
		height: 101%;
		z-index: 2;
		background:#103454;
	}
	.b1 .photo::after{
		transform: skewX(10deg);
		content: "";
		position: absolute;
		right:  -83%;
		top: 0;
		width: 100%;
		height: 101%;
		z-index: 1;
		background:#D7A625;
	}
	.b2 .photo::before {
		transform: skewX(-10deg);
		content: "";
		position: absolute;
		left: -90%;
		top:0;
		width: 100%;
		height: 101%;
		z-index: 2;
		background:#103454;
	}
	.b2 .photo::after{
		transform: skewX(-10deg);
		content: "";
		position: absolute;
		left:  -83%;
		top: 0;
		width: 100%;
		height: 101%;
		z-index: 1;
		background:#D7A625;
	}
}


/* 事業実績
----------------*/
section.works {margin-bottom: 6em;}
ul.sample.flex {
    margin-right: calc(((100vw - 100%) / 2) * -1);
    margin-left: calc(((100vw - 100%) / 2) * -1);
}
ul.sample.flex li {
	flex: 1;
	text-align: center;
	background: #e8f9fe;
	margin: 0 !important;
	border: 1px solid #fff;
	border-width: 1px 1px 1px 0;
}
ul.sample.flex li:last-child {border-right-width: 0;}
ul.sample.flex li span.img {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	overflow:hidden;
	width: 100%;
	height: 400px;
	background-color: #103454;
}

ul.sample.flex li img {
	height: 400px;
	width: auto;
	max-width: none;
	min-width: 100%;
	position: absolute;
	opacity: 0.3;
	top:50%;
	left: 50%;
	transform: translate(-50%,-50%);
	z-index: 0;
}
ul.sample.flex li img:hover {
	transform: translate(-50%,-50%) scale(1.2,1.2);
	transition:.5s all;
}
ul.sample .txt {
	position: absolute;
	z-index: 2;
	color: #fff;
	font-size: 30px;
	font-weight: bold;
}

/* SP */
@media print, screen and (max-width: 640px){
	ul.sample.flex {flex-direction: column;}
	.txt-bottom {text-align: left;}
	ul.sample.flex li {
		border-width: 1px 0 !important;
	}
	ul.sample.flex li span.img {height: 200px;}
	ul.sample.flex li img {width: 100%;}
}


/*--------------------------------
　事業内容
----------------------------------*/
/* サービス案内
----------------*/
.colinner-l,.colinner-c,.colinner-r {
	position: relative;
}
.service .column3_33 {
	position: relative;
}
.service .column3_33 p {
	position: absolute;
	bottom: 0;
	width: 90%;
	padding: .7em 5%;
	margin: 0;
	background-color: rgba(16,52,84,0.80);
	color: #fff;
	text-align: center;
}

/* ご利用の流れ
----------------*/
section.flow {margin-bottom: 6em;}
.flowbox {
  padding: 3em;
  border: 1px solid #fff;
  margin-bottom: 2em;
}

.flowbox img {max-width: 80% !important;}
.flowbox .colinner-l,
.flowbox .colinner-r {position: relative;}
.flowbox .colinner-l.flex {flex-wrap: nowrap;justify-content: space-between;}
.flowbox .colinner-r.flex {display: block;}

.flowbox .colinner-l::before,
.flowbox .colinner-r::before {
	position: absolute;
	content: '';
	background: #707070;
	width: 1px;
	height: calc(90% - 100px);
	left: 25px;
	bottom: 0;
	top: 100px;
}
.flowbox .colinner-r::before {content: none;}
.step-head {
  color: #D7A625;
  font-size: 60px;
  font-weight: 600;
  text-align: center;
  line-height: 1.0;
}
.step-head span {
  display: block;
  font-size: 20px;
}
.flowbox .colinner-r .step-head {display: none;}

@media print, screen and (max-width: 1240px){
	.flowbox {padding: 1em;}
	.post .flowbox .column2_50 {text-align: left;}
}

@media print, screen and (max-width: 800px){
	.flowbox img {max-width: 100% !important;margin: 0 auto;}
	.flowbox .colinner-r.flex {
		display: flex;
		flex-wrap: nowrap;
		justify-content: space-between;
		margin-top:15px; 
	}
	.flowbox .colinner-l,.flowbox .colinner-r {padding: 0;}
	.flowbox .colinner-r .step-head {display: block;margin-right: 20px;}
	.flowbox .colinner-l .step-head {display: none;}
	.flowbox .colinner-l::before {content: none;}
	.flowbox .colinner-r::before {content: "";}
	
	.post .flowbox .column2_50 {
		display: inline-block;
		margin: 5px 0;
		width: 100%;
	}
}

/*--------------------------------
　事業実績
----------------------------------*/
/* ギャラリー
--------------------*/
/***** 画像入れ替え *****/
.thumb-container img {
    max-height: 60px;
    object-fit: cover;
    padding: 5px;
}

#change-image {
    height: 500px;
    width: 800px;
    object-fit: cover;
}

/* その他ページ
----------------------------------*/
.ggmap.g2 {padding-bottom: 56.25%;}

@media print, screen and (min-width: 640px){
	.flex.other1,.flex.other2,.flex.other3 {
		flex-wrap: nowrap;
		justify-content: flex-start;
	}
	.flex.other1 img,.flex.other2 img,.flex.other3 img {
		width: 33.33333%;
	}
}

.page-works004 table a {color: #999;}
.page-works004 table a:hover {color: #D7A625;}

/*--------------------------------
　事業内容
----------------------------------*/
@import url('https://tool.vim04.com/design-code/wp-content/themes/mrp04/style.css');
@import url('https://tool.vim04.com/design-code/wp-content/themes/mrp04-child/css/custom.css');
@import url('https://tool.vim04.com/design-code/wp-content/themes/mrp04-child/designcode.css');

/*--------------------
flow01
--------------------*/
section.pt5.pb5 {
	padding-top: 3em;
	padding-bottom: 6em;
}
.flowlist {
  padding-left: 10rem;
  position: relative;
}
.flowlist::before {
  content: "";
  width: 15px;
  height: 100%;
  background: #eee;
  margin-left: -8px;
  display: block;
  position: absolute;
  top: 0;
  left: 10rem;
}
.flowlist > li {
  position: relative;
	border-bottom-width: 0;
}
.flowlist > li:not(:last-child) {
  margin-bottom: 8vh;
}
.flowlist > li .icon {
  font-size:1.6rem;
  color: #fff;
  background: #D7A625;
	border-radius: 50%;
  padding: 0.8rem 2rem;
  display: block;
  position: absolute;
  top: 0;
  left: -11rem;
  z-index: 1;
  font-style: italic;
}
.flowlist > li .icon::after {
  content: "";
  border-style: solid;
  border-width: 5px 0 5px 10px;
  border-color: transparent transparent transparent #D7A625;
  position: absolute;
  top: 50%;
  left: 99%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.flowlist > li dl {
  padding-left: 7rem;
  position: relative;
	padding-top: 0.7rem;
}
.flowlist > li dl::before,
.flowlist > li dl::after {
  content: "";
  display: block;
  position: absolute;
  top: 20px;
}
.flowlist > li dl::before {
  width: 7px;
  height: 7px;
  margin-top: 0;
  background: #D7A625;
  border-radius: 50%;
  left: -4px;
}
.flowlist > li dl::after {
  width: 50px;
  border-bottom: 1px dashed #999;
  position: absolute;
  left: 5px;
	top: 22px;
}
.flowlist > li dl dt {
  margin-bottom: 0.5rem;
  font-weight: 600;
  font-size: 1.6rem;
	line-height: 1.5;
}
@media (max-width: 768px) {
	.flowlist > li .icon {
		font-size: 1.2rem;
	}

	.flowlist {
		padding-left: 10rem;
	}

	.flowlist > li .icon {
		left: -11rem;
	}

	.flowlist::before {
		left: 10rem;
	}

	.flowlist > li dl {
		padding-left: 4.5rem;
	}

	.flowlist > li dl::after {
		width: 30px;
	}

	.flowlist > li dl dt {
		font-size: 1.4rem;
	}
}

/*@media (max-width: 640px) {*/
	.flowlist {padding-left: 5rem;}
	.flowlist::before {left: 5rem;}
	.flowlist > li {padding-top: 10px;}
	.flowlist > li .icon {
	  left: -6rem;
	  width: 70px;
	  padding: 0;
	  height: 70px;
	  display: flex;
	  justify-content: center;
	  align-items: center;
	  text-align: center;
	  font-size: 1.2rem;
	}
	.flowlist > li dl {padding-left: 2rem;}
	.flowlist > li dl::after {content: none;}

/*}*/

/*--------------------------------
　会社概要
----------------------------------*/
.page-about-us td a {color: #1a1d23 !important;}

/*バージョンアップCF7送信スピナーによるテキストずれ対応*/
.wpcf7-spinner{
    position: absolute!important;
    margin: 0!important;
}


