/* ==== Google font ==== */
@import url('https://fonts.googleapis.com/css?family=Lato:100,300,400,700,900,100italic,300italic,400italic,700italic,900italic|Montserrat:700|Merriweather:400italic');
@import url('https://fonts.googleapis.com/css?family=Orbitron:400,500,700');
@import url('https://fonts.googleapis.com/earlyaccess/notosansjp.css');


html {
    width: 100%;
    height: 100%;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    margin: 0 0 ;
    text-transform: uppercase;
    font-family: Montserrat,sans-serif;
    font-weight: 700;
    letter-spacing: 1px;
}

p {
    font-weight: normal;
    margin-top: 0px;
    margin-bottom: 0px;
    line-height: 2em;
}
@media screen and (max-width: 768px) {
p {
	font-size: 0.9em;
	line-height: 1.8em;
}
}

p.lead {
	font-weight: 600;
}

p.txt_j {
	text-align: justify;
}

a {
    color: #044892;
    -webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;
}

a:hover,
a:focus {
    text-decoration: none;
    color: #004a82;
	opacity:0.7;
	transition: 0.4s;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

.light {
    font-weight: 400;
}

.navbar {
    margin-bottom: 0;
    border-bottom: 1px solid rgba(255,255,255,.3);
	background: rgba(255,255,255,1);
	
}

.navbar-brand {
    font-weight: 700;
}

@media(min-width:1180px) {
.navbar-brand {
  height: 50px;
  padding: 0px 15px;
  font-size: 18px;
  line-height: 1em;    margin-top: -9px;
}
.sphyouzi{
		display: none !important; 
	}
}


@media(max-width:1179px) {
.navbar-brand {
  height: 50px;
  padding: 4px 2px;
  font-size: 18px;
  line-height: 1em;
}
.sphyouzi{
		
	}
}

.navbar-brand h1{
	color: #fff;
	font-size: 20px;
	line-height: 40px;
}

.navbar-brand:focus {
    outline: 0;
}

@media (min-width:1180px){
.nav.navbar-nav {
    background:#ffffff;
}
}

@media (max-width:1179px){
.nav.navbar-nav {
   background:#eaeaea;
}
}

.navbar-custom.top-nav-collapse .nav.navbar-nav {
    background-color: rgba(0,0,0,0);
}

@media (min-width:1180px){
.navbar-custom ul.nav li a {
    font-size: 1.5em;
    display: block;
    padding: 0 0.7em;
	text-transform: uppercase;
	color: #000;
    line-height: 1;
}
.navbar-custom ul.nav li a:hover {
	opacity: 0.7;
	transition: 0.4s;
}
	
.navbar-custom ul.nav li .jp {
    font-size: .5em;
    display: block;
    padding-top: 8px;
    letter-spacing: .1em;
}
	
.en {
    font-size: .7em;
    font-family: 'Orbitron', sans-serif;
	font-weight: 500;
    display: block;
	text-align: center;
    letter-spacing: 0.02em;
}
	
.container-fluid {
	padding-top:30px;
	padding-bottom: 20px;
	position: relative;
	white-space: nowrap;
	padding-left: 30px;
    padding-right: 30px;
    max-width: 1260px;
	}
.caret {
   display:none;
}
	
}

@media (max-width:1179px){
.navbar-custom ul.nav li a {
	font-size: 13px;
	letter-spacing: 1px;
    color: #4c4c4c;
	font-weight:600;
	text-transform: uppercase;
    line-height: 1;
}
.navbar-custom ul.nav li a:hover {
	opacity: 0.7;
	transition: 0.4s;
}
	
.en {
   display:none;
}
	
.navbar-custom ul.nav li .jp {
 
}	
.caret {
    display: inline-block;
    width: 0;
    height: 0;
    margin-left: 2px;
    vertical-align: middle;
    border-top: 4px solid;
    border-right: 4px solid transparent;
    border-left: 4px solid transparent;
}
	
}

.navbar-custom.top-nav-collapse ul.nav li a {
	-webkit-transition: all .2s ease-in-out;
    -moz-transition: all .2s ease-in-out;
    transition: all .2s ease-in-out;

}

.navbar-custom ul.nav ul.dropdown-menu {
	  border-radius: 0;	
}

.navbar-custom ul.nav ul.dropdown-menu li {
	border-bottom: 1px solid #f5f5f5;

}

.navbar-custom ul.nav ul.dropdown-menu li:last-child{
	border-bottom: none;
}

.navbar-custom ul.nav ul.dropdown-menu li a {
	padding: 10px 20px;
	    font-size: 13px;
}

.navbar-custom ul.nav ul.dropdown-menu li a:hover {
	color:#808080;
	backgroud-color:none !important;
	background: #ffffff;
}

.navbar-custom.top-nav-collapse ul.nav ul.dropdown-menu li a {
	color: #666;
}

.navbar-custom .nav li a {
    -webkit-transition: background .3s ease-in-out;
    -moz-transition: background .3s ease-in-out;
    transition: background .3s ease-in-out;
}

.navbar-custom .nav li a:hover,
.navbar-custom .nav li a:focus,
.navbar-custom .nav li.active {
    outline: 0;
   	color:#808080;
	background: #ffffff;
}
.navbar-custom .nav li a:hover,
.navbar-custom .nav li a:focus,
.navbar-custom .nav li.active {
    outline: 0;
 	color:#808080;
}

.navbar-toggle {
    padding: 4px 10px;
    font-size: 17px;
    color: #111111;
}

.navbar-toggle:focus,
.navbar-toggle:active {
    outline: 0;
}



/*フッター*/
.footer {
	/*padding-bottom: 50px;*/
	background-color: #F3F3F3;
	color: #232323;
}
.footer a{
	color: #232323;
}
.footer .list02 {
	 padding:0;
	 margin:0;
 }

.footer .list02 {
	margin: 0;
	padding: 0;
	margin-top: 5px;
	margin-left: 10px;
	position: relative;
	list-style-type: none!important;
}
.footer .list02 li {
	margin: 0;
	padding: 0 0 0.3em 0;
	list-style-type: none!important;
	font-size:0.9em;
	position: relative;
}
.footer .list02 li a {
	 padding: 0 0 0 0.7em;
	 text-decoration: none;
	 color: #232323;
 }
.footer .list02 li a:hover {
	text-decoration: underline;
	color: #1886c8;
}
.footer .list02 li::before {/*疑似要素*/
  font-family: "Font Awesome 5 Free"; 
  content: "\f105";
  font-weight: bold;
  position: absolute;
  left : 0;/*左端からのアイコンまでの距離*/
  color: #232323;/*アイコン色*/
}

.footer .list02 li ul {
	margin: 0;
	padding: 0;
	margin-top: 5px;
	margin-left: 10px;
	position: relative;
	list-style-type: none!important;
}
.footer .list02 li ul li {
	margin: 0;
	padding: 0 0 0.3em 0;
	list-style-type: none!important;
	font-size:1em;
	position: relative;
}
.footer .list02 li ul li a {
	 padding: 0 0 0 1.1em;
	 text-decoration: none;
	 color: #232323;
 }
.footer .list02 li ul li a:hover {
	text-decoration: underline;
	color: #1886c8;
}
.footer .list02 li ul li::before {/*疑似要素*/
  font-family: "Font Awesome 5 Free"; 
  content: "\f101";
  font-weight: bold;
  position: absolute;
  left : 0;/*左端からのアイコンまでの距離*/
  color: #232323;/*アイコン色*/
}

.copyright{
    text-align:center;
    margin:0 auto;
    display:block;
	border-top:dotted 1px #ccc;
	padding-bottom: 70px;
}

.box_page {
	width: 100%;
}

.box {
	width: 100%;
}

.box h2 {
	border-bottom: solid 3px #cce4ff;
	position: relative;
	font-size: 1.6em;
	margin-bottom: 20px;
	padding-bottom: 0.1em;
}
.box h2:after {
	position: absolute;
	content: " ";
	display: block;
	border-bottom: solid 3px #5472cd;
	bottom: -3px;
	width: 18%;
}
@media screen and (max-width: 768px) {
.box h2 {
	font-size: 1.4em;
}
}






/*---------------TOPページ*/
.box_news{
	width: 100%;
	padding-bottom: 40px;
	text-align: left;
}
.box_news .news1{
	overflow: auto;
    clear: both;
    height: 230px;
    overflow-y: scroll;
	width: 100%;
    box-sizing: border-box;
    border: 1px solid #cccccc;
}

.box_news .inner{
	padding: 0.4em 0.7em 0.4em 0.7em;
}
.box_news .inner ul {
	padding: 0;
	list-style: none;
	text-align: left;
}
.box_news .inner ul li{
	padding: 10px 10px;
	line-height: 1.4em;
	font-size: 1em;
}
.box_news .inner ul li a {
	color: #044892;
}
@media screen and (min-width: 481px)  and (max-width: 600px){
	/*　画面サイズが481pxからはここを読み込む　*/
 .box_news .inner ul li{
	font-size: 1.4rem;
	padding: 7px 7px;
}
}
@media screen and (max-width: 480px) {
 .box_news .inner ul li{
	font-size: 1.3rem;
	padding: 7px 7px;
}
}

.box_news .inner ul li .date{
	display: block;
	position: relative;
	font-weight: bold;
	margin-bottom: 5px;
	color: #1886c8;
	padding-left: 1.6em;
}
.box_news .inner ul li .date::before {/*疑似要素*/
  font-family: "Font Awesome 5 Free";
  content: "\f073";
  position: absolute;
  left : 0em; /*左端からのアイコンまで*/
  color: #1886c8; /*アイコン色*/
  -webkit-font-smoothing: antialiased;
  display: inline-block;
  font-style: normal;
  font-variant: normal;
  text-rendering: auto;
  /*line-height: 1;*/
}

.box_aisatsu{
	width: 100%;
	padding-bottom: 40px;
	text-align: left;
}

.box_jigyo{
	width: 100%;
	padding-bottom: 40px;
	text-align: left;
}

.box_area{
	width: 100%;
	padding-bottom: 40px;
	text-align: left;
}

.box_area p span {
	color: #044892;
	font-weight: 700;
	display:inline-block;
}


/*---------------第二階層*/
.page-title {
    clear: both;
    overflow: hidden;
    position: relative;
	background-image: url(../img/common/bg_pagetitle.jpg);
	background-position: center right;
	background-repeat: no-repeat;
	background-size:cover;
}
.page-title .inner{
	padding: 5rem 0 4rem 0;
}

.page-title .inner h3{
	text-align : center;
	font-weight : 500;
	font-size: 2.8rem;
	letter-spacing: 0.15em;
	color: #ffffff;
	text-shadow:0 0 5px #232323;
	font-family: 'Orbitron', sans-serif;
}
.page-title .inner p.jp {
	text-align : center;
	font-weight : 400;
	font-size: 1.6rem;
	color: #ffffff;
	text-shadow:0 0 5px #232323;
	margin-top: 5px;
}

@media screen and (max-width: 768px){
.page-title .inner{
	padding: 2.8em 0 2.3em 0;
	}
.page-title .inner h3{
	font-size : 2.4rem;
	}
.page-title .inner p.jp {
	font-size: 1.4rem;
}
}

@media screen and (max-width: 480px){
.page-title .inner{
	padding: 2.5em 0 2em 0;
	}
.page-title .inner h3{
	font-size : 1.9rem;
	}
.page-title .inner p.jp {
	font-size: 1.3rem;
}
}


/*---------------What's New詳細ページ*/
.box_news_s {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_news_s h3{
	margin-top: 10px;
	margin-bottom: 15px;
	font-size: 1.4em;
	font-weight: bold;
	line-height: 1.4em;
	letter-spacing: 0.05em;
	border-bottom: 2px solid #1886c8;
	padding-bottom: 0.3em;
}
.box_news_s p {
	line-height: 1.6em;
	text-align: justify;
}
@media screen and (max-width: 768px) {
.box_news_s h3 {
    font-size: 1.7rem;
	line-height: 1.6rem;
	margin-bottom: 10px;
}
.box_news_s p {
    font-size: 1.4rem;
}
  
}
.box_news_s .date{
	display: block;
	position: relative;
	font-weight: bold;
	margin-bottom: 5px;
	color: #232323;
	padding-left: 1.6em;
}
.box_news_s .date:before {/*疑似要素*/
  font-family: "Font Awesome 5 Free";
  content: "\f133";
  position: absolute;
  left : 0em; /*左端からのアイコンまで*/
  color: #1886c8; /*アイコン色*/
}




/*---------------私たちの強み*/
.box_strength {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
	counter-reset: number;
}

.box_strength .strengthbox {
	border: 1px solid #dddddd;
	padding: 1em;
	margin-bottom: 20px;
}
.box_strength .strengthbox .left_strengthbox {
	width: 60%;
	float: left;
}
.box_strength .strengthbox .right_strengthbox {
	width: 38%;
	float: right;
}
@media screen and (max-width: 768px) {
.box_strength .strengthbox .left_strengthbox {
	width: 100%;
	float: none;
	margin-bottom: 10px;
}
.box_strength .strengthbox .right_strengthbox {
	width: 100%;
	float: none;
}
}

.box_strength .strengthbox .left_strengthbox p {
	line-height: 1.6em;
}
.box_strength .strengthbox .left_strengthbox p a {
	color: #37419a;
	text-decoration: underline;
}

.box_strength .strengthbox .catch01 {
	font-size: 1.3em;
	line-height: 1.5em;
	font-weight: bold;
	color: #044892;
	position: relative;/*相対位置*/
	padding-left: 1.8em;
}
@media screen and (max-width: 768px) {
.box_strength .strengthbox .catch01 {
	font-size: 1.1em;
	line-height: 1.4em;
	padding-left: 2em;
}
}

.box_strength .strengthbox .catch01:before {
	display: inline-block;
	position: absolute;/*絶対位置*/
	counter-increment: number;
	content: counter(number);
	font-size: 1em;/*サイズ*/
	left: 0;
	color: #ffffff;
	background-color: #044892;
	width: 30px;
	height: 30px;
	line-height: 30px;
	text-align:center;
	/*以下 上下中央寄せのため*/
	top: 50%;
	-moz-transform: translateY(-50%);
  	-webkit-transform: translateY(-50%);
  	-o-transform: translateY(-50%);
  	-ms-transform: translateY(-50%);
  	transform: translateY(-50%);
}





/*---------------会社概要*/
.box_company {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_company ol {
	counter-reset:number; /*数字をリセット*/
	list-style-type: none!important; /*数字を一旦消す*/
	margin: 0;
	padding: 0;
}
.box_company ol li {
	position: relative;
	padding-left: 30px;
	line-height: 1.5em;
	font-size: 1.2em;
	padding: 0.5em 0.5em 0.5em 40px;
	border-bottom: dashed 1px #044892;
}
@media screen and (max-width: 768px){
.box_company ol li {
	font-size: 1.1em;
}
}
@media screen and (max-width: 480px){
.box_company ol li {
	font-size: 1em;
	line-height: 1.4em;
}
}
.box_company ol li:before {
	/* 以下数字をつける */
	position: absolute;
	counter-increment: number;
	content: counter(number);
	/*以下数字のデザイン変える*/
	display:inline-block;
	background: #044892;
	color: white;
	font-weight:bold;
	border-radius: 50%;
	left: 0;
	width: 30px;
	height: 30px;
	line-height: 30px;
	text-align:center;
	/*以下 上下中央寄せのため*/
	top: 50%;
	-moz-transform: translateY(-50%);
  	-webkit-transform: translateY(-50%);
  	-o-transform: translateY(-50%);
  	-ms-transform: translateY(-50%);
  	transform: translateY(-50%);
}

.box_company .dl_com dl,dt,dd {
	margin: 0;
	padding: 0;
}
.box_company .dl_com dt,dd {
	padding: 0.5em;
}
.box_company .dl_com {
	border-bottom: 1px solid #dddddd;
	font-size: 1em;
}
.box_company .dl_com dt {
	border-top: 1px solid #dddddd;
	clear: left;
	float: left;
	width: 25%;
}
.box_company .dl_com dd {
	border-top: 1px solid #dddddd;
	margin-left: 25%;
}
@media screen and (max-width: 768px) {
.box_company .dl_com {
	border-bottom: none;
	font-size: 0.9em;
}
.box_company .dl_com dt {
	float: none;
	width: 100%;
	border-top: 1px solid #dddddd;
	background-color: #dddddd;
}
.box_company .dl_com dd {
	border-top: none;
	margin-left: 0;
}
}


/*---------------事業概要*/
.box_business {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_business .businessbox {
	padding: 1em;
	border: 1px solid #C9DDFA;
}
.box_business .businessbox .catch01 {
	font-size: 1.2em;
	font-weight: bold;
	color: #044892;
}
.box_business .businessbox .box_left {
	width: 38%;
	float: left;
}
.box_business .businessbox .box_right {
	width: 60%;
	float: right;
}
@media screen and (max-width: 768px) {
.box_business .businessbox .box_left {
	width: 100%;
	float: none;
	margin-bottom: 10px;
}
.box_business .businessbox .box_right {
	width: 100%;
	float: none;
}
}


/*---------------塗装工事*/
.box_paint {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_paint .catch01{
	font-size: 1.2em;
	line-height: 1.6em;
	margin-bottom: 20px;
	padding-bottom: 7px;
	text-align: justify;
}
@media screen and (min-width: 481px)  and (max-width: 600px){
	/*　画面サイズが481pxからはここを読み込む　*/
.box_paint .catch01{
	font-size: 1em;
	line-height: 1.6em;
	padding: 7px 7px;
}
}
@media screen and (max-width: 480px) {
.box_paint .catch01{
	font-size: 0.9em;
	line-height: 1.6em;
	padding: 7px 7px;
}
}
.box_paint .paintbox {
	margin-bottom: 20px;
}
.box_paint .paintbox h3 {
	color: #1886C8;
	font-size: 1.2em;
	font-weight: bold;
	background-color: #eeeeee;
	padding: 0.5em;
	margin-bottom: 15px;
}
@media screen and (max-width: 768px) {
.box_paint .paintbox h3 {
	font-size: 1.1em;
}
}
.box_paint .paintbox .left_paintbox {
	width: 70%;
	float: left;
}
.box_paint .paintbox .right_paintbox {
	width: 28%;
	float: right;
}
@media screen and (max-width: 768px) {
.box_paint .paintbox .left_paintbox {
	width: 100%;
	float: none;
	margin-bottom: 10px;
}
.box_paint .paintbox .right_paintbox {
	width: 100%;
	float: none;
}
}
.box_paint .paintbox .left_paintbox p {
	line-height: 1.6em;
	text-align: justify;
}


/*---------------防水工事*/
.box_water {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_water .catch01{
	font-size: 1.2em;
	line-height: 1.6em;
	margin-bottom: 20px;
	padding-bottom: 7px;
	text-align: justify;
}
@media screen and (min-width: 481px)  and (max-width: 600px){
	/*　画面サイズが481pxからはここを読み込む　*/
.box_water .catch01{
	font-size: 1em;
	line-height: 1.6em;
	padding: 7px 7px;
}
}
@media screen and (max-width: 480px) {
.box_water .catch01{
	font-size: 0.9em;
	line-height: 1.6em;
	padding: 7px 7px;
}
}
.box_water .waterbox {
	margin-bottom: 20px;
}
.box_water .waterbox h3 {
	color: #1886C8;
	font-size: 1.2em;
	font-weight: bold;
	background-color: #eeeeee;
	padding: 0.5em;
	margin-bottom: 15px;
}
@media screen and (max-width: 768px) {
.box_water .waterbox h3 {
	font-size: 1.1em;
}
}
.box_water .waterbox .left_waterbox {
	width: 70%;
	float: left;
}
.box_water .waterbox .right_waterbox {
	width: 28%;
	float: right;
}
@media screen and (max-width: 768px) {
.box_water .waterbox .left_waterbox {
	width: 100%;
	float: none;
	margin-bottom: 10px;
}
.box_water .waterbox .right_waterbox {
	width: 100%;
	float: none;
}
}
.box_water .waterbox .left_waterbox p {
	line-height: 1.6em;
	text-align: justify;
}
.box_water .waterbox .left_waterbox ul,li {
	margin: 0;
	padding: 0;
}
.box_water .waterbox .left_waterbox ul {
	list-style: none;
}
.box_water .waterbox .left_waterbox ul li {
	position: relative;
	list-style-type: none;
	padding: 0 0 0.5em 1.5em;
}
.box_water .waterbox .left_waterbox ul li:before {
	font-family: "Font Awesome 5 Free"; 
	content: "\f5aa";
	font-weight: bold;
	position: absolute;
	left : 0;/*左端からのアイコンまでの距離*/
	color: #1886C8;/*アイコン色*/
}
@media screen and (max-width: 768px) {
.box_water .waterbox .left_waterbox ul li {
	font-size: 0.9em;
	padding: 0 0 0.3em 1.5em;
}
}



/*--------------足場工事*/
.box_scaffold {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_scaffold .catch01{
	font-size: 1.2em;
	line-height: 1.6em;
	margin-bottom: 20px;
	padding-bottom: 7px;
	text-align: justify;
}
@media screen and (min-width: 481px)  and (max-width: 600px){
	/*　画面サイズが481pxからはここを読み込む　*/
.box_scaffold .catch01{
	font-size: 1em;
	line-height: 1.6em;
	padding: 7px 7px;
}
}
@media screen and (max-width: 480px) {
.box_scaffold .catch01{
	font-size: 0.9em;
	line-height: 1.6em;
	padding: 7px 7px;
}
}
.box_scaffold .scaffoldbox {
	margin-bottom: 20px;
}
.box_scaffold .scaffoldbox h3 {
	color: #1886C8;
	font-size: 1.2em;
	font-weight: bold;
	background-color: #eeeeee;
	padding: 0.5em;
	margin-bottom: 15px;
}
@media screen and (max-width: 768px) {
.box_scaffold .scaffoldbox h3 {
	font-size: 1.1em;
}
}
.box_scaffold .scaffoldbox .left_scaffoldbox {
	width: 70%;
	float: left;
}
.box_scaffold .scaffoldbox .right_scaffoldbox {
	width: 28%;
	float: right;
}
@media screen and (max-width: 768px) {
.box_scaffold .scaffoldbox .left_scaffoldbox {
	width: 100%;
	float: none;
	margin-bottom: 10px;
}
.box_scaffold .scaffoldbox .right_scaffoldbox {
	width: 100%;
	float: none;
}
}
.box_scaffold .scaffoldbox .left_scaffoldbox p {
	line-height: 1.6em;
	text-align: justify;
}



/*--------------改修・その他*/
.box_repair {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_repair .catch01{
	font-size: 1.2em;
	line-height: 1.6em;
	margin-bottom: 20px;
	padding-bottom: 7px;
	text-align: justify;
}
@media screen and (min-width: 481px)  and (max-width: 600px){
	/*　画面サイズが481pxからはここを読み込む　*/
.box_repair .catch01{
	font-size: 1em;
	line-height: 1.6em;
	padding: 7px 7px;
}
}
@media screen and (max-width: 480px) {
.box_repair .catch01{
	font-size: 0.9em;
	line-height: 1.6em;
	padding: 7px 7px;
}
}
.box_repair p {
	line-height: 1.6em;
	text-align: justify;
}


/*--------------施工実績*/
.box_works {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_works .table th,td {
	margin: 0;
	padding: 0;
}
.box_works .table th {
	text-align: center;
	padding: 0.3em 0;
}
.box_works .table td {
	text-align: left;
	padding: 0.3em 0.5em;
}
.box_works .table td:last-child {
	text-align: center;
}
.box_works .label-iro{
	background-color: #044892;
	color:#FFF;
	text-align:left;
	padding:5px 10px;
	border-radius:5px;
}
@media screen and (max-width: 768px) {
.box_works .label-iro {
	font-size: 0.9em;
}
}

/*----------------要素の表示・非表示を切り替える*/
.box_works .hidden_box {
    margin: 2em 0;/*前後の余白*/
    padding: 0;
}
.box_works .hidden_box label {
	width: 100%;
	text-align: center;
    padding: 15px;
    font-weight: bold;
	background-color: #1886c8;
	color: #ffffff;
    cursor :pointer;
	transition: .4s;
}
.box_works .hidden_box label:hover {
    background: #41a6d8;
}
/*チェックは見えなくする*/
.box_works .hidden_box input {
    display: none;
}
/*中身を非表示にしておく*/
.box_works .hidden_box .hidden_show {
    height: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    transition: 0.8s;
}
/*クリックで中身表示*/
.box_works .hidden_box input:checked ~ .hidden_show { 
    padding: 10px 0;
    height: auto;
    opacity: 1;
}
/*----------------/要素の表示・非表示を切り替える*/

.box_works .list{
	margin: 0;
	padding: 0;
	display: flex;
	justify-content: center;
	 -webkit-flex-wrap: wrap;
  	flex-wrap:wrap;
	list-style: none;
}
.box_works .list li{
	flex-basis: 48%;
	margin: 0 1% 3%;
	padding: 1em;
	border: 1px solid #dddddd;
}
@media screen and (max-width: 768px) {
.box_works .list li{
	flex-basis: 100%;
}
}
.box_works .list li p {
	line-height: 1.6em;
}



/*---------------施工までの流れ*/
.box_flow {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
	counter-reset: number;
}

.box_flow .flowbox {
	margin-bottom: 20px;
}
.box_flow .flowbox .left_flowbox {
	width: 80%;
	float: left;
}
.box_flow .flowbox .right_flowbox {
	width: 18%;
	float: right;
}
@media screen and (max-width: 600px) {
.box_flow .flowbox .left_flowbox {
	width: 100%;
	float: none;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: contain;
}
.box_flow .flowbox .right_flowbox {
	display: none;
}
.box_flow .flowbox .left_flowbox#step2 {
	background-image: url(../img/flow/step2_s.png);
}
.box_flow .flowbox .left_flowbox#step3 {
	background-image: url(../img/flow/step3_s.png);
}
.box_flow .flowbox .left_flowbox#step4 {
	background-image: url(../img/flow/step4_s.png);
}
.box_flow .flowbox .left_flowbox#step5 {
	background-image: url(../img/flow/step5_s.png);
}
.box_flow .flowbox .left_flowbox#step6 {
	background-image: url(../img/flow/step6_s.png);
}
.box_flow .flowbox .left_flowbox#step7 {
	background-image: url(../img/flow/step7_s.png);
}
}

.box_flow .flowbox .left_flowbox p {
	line-height: 1.6em;
	text-align: justify;
}
.box_flow .flowbox .catch01 {
	font-size: 1.3em;
	line-height: 1.5em;
	font-weight: bold;
	color: #044892;
	background-color: #dddddd;
	position: relative;/*相対位置*/
	padding:0.4em 0 0.4em 3.6em;
}
@media screen and (max-width: 768px) {
.box_flow .flowbox .catch01 {
	font-size: 1.1em;
	line-height: 1.4em;
	padding-left: 4em;
}
}

.box_flow .flowbox .catch01:before {
	display: inline-block;
	position: absolute;/*絶対位置*/
	counter-increment: number;
	content: "Step"counter(number);
	font-size: 1em;/*サイズ*/
	left: 0;
	color: #044892;
	background-color: #dddddd;
	width: 70px;
	height: 30px;
	line-height: 30px;
	text-align:center;
	/*以下 上下中央寄せのため*/
	top: 50%;
	-moz-transform: translateY(-50%);
  	-webkit-transform: translateY(-50%);
  	-o-transform: translateY(-50%);
  	-ms-transform: translateY(-50%);
  	transform: translateY(-50%);
}
.box_flow .flowbox .btn.btn-warning{
	font-size: 1.3em;
}
.box_flow .flowbox .btn.btn-warning.btn-tel {
	letter-spacing: 0.2em;
}



/*---------------ビジネスパートナー募集*/
.box_partner {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_partner .intro {
	width: 100%;
	padding: 0.5em;
	background-image: url(../img/partner/bg_catch.png);
	background-position: center right;
	background-repeat: no-repeat;
	background-size: cover;
}
@media screen and (max-width: 768px) {
.box_partner .intro {
	background-image: url(../img/partner/bg_catch_s.png);
	background-position: center center;
	background-size: cover;
}
}
.box_partner .intro .catch01{
	font-size: 1.1em;
	line-height: 1.6em;
	text-align: justify;
}
@media screen and (min-width: 481px)  and (max-width: 600px){
	/*　画面サイズが481pxからはここを読み込む　*/
.box_partner .intro .catch01{
	font-size: 1em;
	line-height: 1.6em;
}
}
@media screen and (max-width: 480px) {
.box_partner .intro .catch01{
	font-size: 0.9em;
	line-height: 1.6em;
}
}

.box_partner .intro .catch02{
	font-size: 1.3em;
	font-weight: bold;
	line-height: 1.6em;
	text-align: justify;
	color: #044892;
}
@media screen and (min-width: 481px)  and (max-width: 600px){
	/*　画面サイズが481pxからはここを読み込む　*/
.box_partner .intro .catch02{
	font-size: 1.2em;
	line-height: 1.5em;
}
}
@media screen and (max-width: 480px) {
.box_partner .intro .catch02{
	font-size: 1em;
	line-height: 1.5em;
}
}
.box_partner ul,li {
	margin:0;
	padding: 0;
}
.box_partner ul {
	list-style: none;
}
.box_partner ul li {
	position: relative;
	list-style-type: none;
	padding: 0 0 0.5em 1.5em;
}
.box_partner ul li:before {
	font-family: "Font Awesome 5 Free"; 
	content: "\f14a";
	font-weight: bold;
	position: absolute;
	left : 0;/*左端からのアイコンまでの距離*/
	color: #042B6B;/*アイコン色*/
}
@media screen and (max-width: 768px) {
.box_partner ul li {
	font-size: 0.9em;
	padding: 0 0 0.3em 1.5em;
}
}
.box_partner .syokusyu {
	width: 100%;
	padding: 0.5em;
	background-image: url(../img/partner/bg_syokusyu.png);
	background-position: center right;
	background-repeat: no-repeat;
	background-size: contain;
}
@media screen and (max-width: 768px) {
.box_partner .syokusyu {
	background-image: url(../img/partner/bg_syokusyu_s.png);
}
}
.box_partner .btn.btn-warning.btn-lg{
	font-size: 1.2em;
}
@media screen and (max-width: 768px) {
.box_partner .btn.btn-warning.btn-lg{
	font-size: 1em;
}
}



/*---------------求人募集*/
.box_recruit {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_recruit .intro {
	width: 100%;
	padding: 0.5em;
	background-image: url(../img/recruit/bg_intro.png);
	background-position: center right;
	background-repeat: no-repeat;
	background-size: cover;
}
@media screen and (max-width: 768px) {
.box_recruit .intro {
	background-image: url(../img/recruit/bg_intro_s.png);
	background-position: center center;
	background-size: cover;
}
}
.box_recruit .intro .catch01{
	font-size: 1.1em;
	line-height: 1.6em;
	text-align: justify;
	max-width: 69%;
}
@media screen and (min-width: 481px)  and (max-width: 600px){
	/*　画面サイズが481pxからはここを読み込む　*/
.box_recruit .intro .catch01{
	font-size: 1em;
	line-height: 1.6em;
	max-width: none;
}
}
@media screen and (max-width: 480px) {
.box_recruit .intro .catch01{
	font-size: 0.9em;
	line-height: 1.6em;
	max-width: none;
}
}

.box_recruit .intro .catch02{
	font-size: 1.3em;
	font-weight: bold;
	line-height: 1.6em;
	text-align: justify;
	color: #044892;
}
@media screen and (min-width: 481px)  and (max-width: 600px){
	/*　画面サイズが481pxからはここを読み込む　*/
.box_recruit .intro .catch02{
	font-size: 1.2em;
	line-height: 1.5em;
}
}
@media screen and (max-width: 480px) {
.box_recruit .intro .catch02{
	font-size: 1em;
	line-height: 1.5em;
}
}
.box_recruit .dl_rec dl,dt,dd {
	margin: 0;
	padding: 0;
}
.box_recruit .dl_rec dt,dd {
	padding: 0.5em;
}
.box_recruit .dl_rec {
	border-bottom: 1px solid #dddddd;
	font-size: 1em;
}
.box_recruit .dl_rec dt {
	border-top: 1px solid #dddddd;
	clear: left;
	float: left;
	width: 25%;
}
.box_recruit .dl_rec dd {
	border-top: 1px solid #dddddd;
	margin-left: 25%;
}
@media screen and (max-width: 768px) {
.box_recruit .dl_rec {
	border-bottom: none;
	font-size: 0.9em;
}
.box_recruit .dl_rec dt {
	float: none;
	width: 100%;
	border-top: 1px solid #DEEFFC;
	background-color: #DEEFFC;
}
.box_recruit .dl_rec dd {
	border-top: none;
	margin-left: 0;
}
}
.box_recruit .btn.btn-warning.btn-lg{
	font-size: 1.2em;
}
@media screen and (max-width: 768px) {
.box_recruit .btn.btn-warning.btn-lg{
	font-size: 1em;
}
}



/*---------------ご相談・お問合せ*/
.box_contact {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_contact h2{
	margin-bottom: 10px;
	border-bottom: 3px solid #f05800;
	padding-bottom: 7px;
	letter-spacing: 0.1em;
	font-size: 1.6em;
}

.box_contact p a {
	text-decoration: underline;
}
.box_contact .form-horizontal {
	padding: 0.5em;
	font-size: 16px;
}
.box_contact .form-horizontal span{
	font-size: 0.8em;
}
.box_contact .col-sm-3.control-label {
	text-align: left;
}



/*---------------サイトマップ*/
.box_sitemap {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_sitemap .list02 {
	 padding:0;
	 margin:0;
 }

.box_sitemap .list02 {
	margin: 0;
	padding: 0;
	margin-top: 5px;
	margin-left: 10px;
	position: relative;
	list-style-type: none!important;
}
.box_sitemap .list02 li {
	margin: 0;
	padding: 0 0 0.5em 0;
	list-style-type: none!important;
	position: relative;
}

.box_sitemap .list02 li a {
	 padding: 0 0 0 0.9em;
	 text-decoration: none;
	 color: #232323;
 }

.box_sitemap .list02 li a:hover {
	text-decoration: underline;
	color: #1886c8;
}
.box_sitemap .list02 li::before {/*疑似要素*/
  font-family: "Font Awesome 5 Free"; 
  content: "\f105";
  font-weight: bold;
  position: absolute;
  left : 0;/*左端からのアイコンまでの距離*/
  color: #232323;/*アイコン色*/
}

.box_sitemap .list02 li ul {
	margin: 0;
	padding: 0;
	margin-top: 5px;
	margin-left: 10px;
	position: relative;
	list-style-type: none!important;
}
.box_sitemap .list02 li ul li {
	margin: 0;
	padding: 0 0 0.3em 0;
	list-style-type: none!important;
	font-size:1em;
	position: relative;
}
.box_sitemap .list02 li ul li a {
	 padding: 0 0 0 1.2em;
	 text-decoration: none;
	 color: #232323;
 }
.box_sitemap .list02 li ul li a:hover {
	text-decoration: underline;
	color: #1886c8;
}
.box_sitemap .list02 li ul li::before {/*疑似要素*/
  font-family: "Font Awesome 5 Free"; 
  content: "\f101";
  font-weight: bold;
  position: absolute;
  left : 0;/*左端からのアイコンまでの距離*/
  color: #232323;/*アイコン色*/
}



/*---------------プライバシーポリシー*/
.box_privacy {
	width: 100%;
	padding-bottom: 40px;
	text-align: left;
	position:relative;
}
.box_privacy h2 {
	margin-bottom: 20px;
	border-bottom: 3px solid #f05800;
	padding-bottom: 7px;
	letter-spacing: 0.1em;
	font-size: 1.6em;
}
.box_privacy h3 {
	font-size: 1.5em;
	line-height: 1.6em;
}
@media screen and (min-width: 481px)  and (max-width: 600px){
.box_privacy h3 {
	font-size: 1.3em;
	line-height: 1.5em;
}
}
@media screen and (max-width: 480px) {
.box_privacy h3 {
	font-size: 1.2em;
	line-height: 1.4em;
}
}
.box_privacy p.txt_j {
	line-height: 1.6em;
}



/*---------------M&Aに関するコラム*/
.box_column {
	width: 100%;
	padding-bottom: 60px;
	text-align: left;
	position:relative;
}
.box_column ul{
	list-style: none;
	padding: 0;
}
.box_column ul li {
	display: inline-block;
	margin-right: 0.3em;
	margin-bottom: 0.9em;
	padding: 0;
}
.box_column ul li a {
	text-decoration: none;
	font-size: 0.9em;
	line-height: 1.4em;
	padding: 0.4em 0.6em 0.5em 0.6em;
	background-color: #042B6B;
	color: #ffffff;
	border-radius: 3px;
	transition: .3s;
}
.box_column ul li.active a {
	text-decoration: none;
	font-size: 0.9em;
	line-height: 1.4em;
	padding: 0.4em 0.6em 0.5em 0.6em;
	background-color: #1886C8;
	color: #ffffff;
	border-radius: 3px;
	transition: .3s;
}
.box_column ul li a:hover {
	text-decoration: none;
	background-color: #1886C8;
}
.box_column .columnbox {
	padding-bottom: 1em;
	margin-bottom: 1em;
	border-bottom: 1px dashed #dddddd;
}
.box_column .columnbox .left_columnbox {
	width: 40%;
	float: left;
}
.box_column .columnbox .right_columnbox {
	width: 58%;
	float: right;
}
.box_column .columnbox .right_columnbox .ttl{
	font-size: 1.2em;
	font-weight: 600;
	line-height: 1.2em;
	margin-bottom: 7px;
}
.box_column .columnbox .right_columnbox .category a{
	display: inline-block;
	font-size: 0.8em;
	line-height: 1.4em;
	padding: 0.4em 0.6em 0.5em 0.6em;
	background-color: #042B6B;
	color: #ffffff;
	border-radius: 3px;
	transition: .3s;
	margin-bottom: 10px;
}
.box_column .columnbox .right_columnbox .category a:hover{
	text-decoration: none;
	background-color: #1886C8;
}
.box_column .columnbox .right_columnbox .text{
	font-size: 1em;
	line-height: 1.6em;
	text-align: justify;
	margin-bottom: 20px;
}
.box_column .columnbox .right_columnbox .date{
	font-size: 0.9em;
	color: #999999;
	font-weight: normal;
}
.box_column .columnbox .right_columnbox .square_btn {
	text-align: right;
}
.box_column .columnbox .right_columnbox .square_btn a{
	position: relative;
	display: inline-block;
	font-size: 1em;
	padding: 0.3em 1em;
	text-decoration: none;
	color: #ffffff;
	background: #042B6B;
	transition: .4s;
	border-radius: 3px;
	margin-top: 10px;
}
.box_column .columnbox .right_columnbox .square_btn a:hover {
	background: #1886C8;
	color: #ffffff;
}
@media screen and (max-width: 992px) {
.box_column .columnbox .right_columnbox .ttl{
	font-size: 1.1em;
	font-weight: 600;
	line-height: 1.6em;
	margin-bottom: 7px;
}
.box_column .columnbox .right_columnbox .text{
	display: none;
}
.box_column .columnbox .right_columnbox .inner .text{
	display: block;
}
}

/*↓↓↓M&A成功事例記事ページ↓↓↓*/
.box_column .inner .ttl{
	background-color: #DEEFFC;
	padding: 0.6em 1em;
	font-size: 1.1em;
	font-weight: 600;
	line-height: 1.6em;
	color: #042B6B;
	margin-bottom: 0;
}
@media screen and (min-width: 481px)  and (max-width: 600px){
.box_column .inner .ttl {
	font-size: 1em;
	line-height: 1.5em;
}
}
@media screen and (max-width: 480px) {
.box_column .inner .ttl {
	font-size: 1em;
	line-height: 1.4em;
}
}
.box_column .inner .text{
	text-align: justify;
	line-height: 1.6em;
	margin-bottom: 20px;
}
.box_column .inner .category a{
	display: inline-block;
	font-size: 0.8em;
	line-height: 1.4em;
	padding: 0.4em 0.6em 0.5em 0.6em;
	background-color: #042B6B;
	color: #ffffff;
	border-radius: 3px;
	transition: .3s;
	margin-bottom: 10px;
}
.box_column .inner .category a:hover{
	text-decoration: none;
	background-color: #1886C8;
}










