@charset "utf-8";


/* all
-------------------------------------------------------------------*/
html {
	background:#FFFFFF;
	color:#333333;
	font-family:  "Noto Sans JP", "Yu Gothic Medium" ,"游ゴシック体", "Yu Gothic", YuGothic , 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
	font-size:62.5%;/*16px*62.5%=10px*/
	line-height:1.4;
}
html .goti,
html .goti form *{
	font-family:  "Noto Serif JP", "Yu Gothic Medium" ,"游ゴシック体", "Yu Gothic", YuGothic , 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
}
html .min,
html .min form *{
	font-family: "Noto Serif JP", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "Times New Roman", "HG明朝B", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

body {
	width: 100%;
	font-size: 100%;
	text-align: center;
	color: #282828;
}

.sitewrap {
}

@media screen and (max-width:768px) {
	html {
		color:#000000;
	}
	.sitewrap {
		width: 100%;
		min-width:0;
	}
}

a {
	text-decoration: none;
}
/* header
-------------------------------------------------------------------*/
header {
}
#fix_menu{
	display: flex;
	justify-content: space-between;
	margin: auto;
	position:static;
	top:-300px;
	left:0;
	right:0;
	z-index:999;
	transition:top .4s .2s;
	padding: 20px 50px 15px 50px;
}
#fix_menu.fixedMenu{
	position:fixed;
	top: 0px;
	background: #fff;	
}
.menu_top {
   	position:relative;
	z-index: 500;
}
#site_ttl {
	padding: 10px 0;
	white-space:nowrap;
}
.menu_top #site_ttl a,
.menu_top #site_ttl p{
	display:inline-block;
	vertical-align:middle;
}

.menu_bottom {
}
.drop_menu{
	max-width:1100px;
	margin:auto;
	display: flex;
	justify-content: space-between;
}

.drop_menu #NavWrap {
	padding: 0;
}
#NavWrap ul {
    margin: 0;
    padding: 0;
    display:flex;
    justify-content: flex-start;
	margin-right: 50px;
    box-sizing:border-box;
	
}
#NavWrap ul::after{
	display:none;
}
#NavWrap li a,
#NavWrap li p {
	display: block;
	padding: 0 20px;
	box-sizing:border-box;
	text-decoration: none;
	font-size: 1.4rem;
	width: auto;
	line-height: 1;
	position:relative;
	color: #282828;
	text-align:center;
	transition:background 0.5s ,color 0.5s, opacity 0.5s, color 0.5s;
}
#NavWrap li a:hover {
   opacity:1;
}
#NavWrap li a span{
	padding: 20px 0px 10px;
	display:flex;
	position: relative;
}
#NavWrap li a span:after {
    content: "";
    width: 0;
    height: 2px;
    display: block;
    position: absolute;
    bottom: 2px;
    left: 0;
    transition: width .2s;
    background: #120aa5;
}
#NavWrap li a span:hover::after {
  width: 100%;
}
#NavWrap li a span br{
	display:none;
}

/*#NavWrap li a:hover{
   opacity:0.7;
   background: #00a0e9;
}*/
.drop_wrap {
	position:relative;
}
.drop_wrap::after {
	content: url("../img/common/list_top.png");
	position: absolute;
	bottom: -25px;
	left: 50%;
	transform: translateX(-50%);
	opacity: 0;
}
.drop_wrap:hover::after{
	opacity: 1;
}
.drop_menu #NavWrap li.drop_wrap i{
	display:none;
}
.drop_wrap ul{
	display: flex;
	flex-direction: column;
	position:absolute;
	width:auto;
	min-width:30em;
	opacity:0;
	visibility:hidden;
	left:50%;
	transform:translateX(-50%);
	transition:opacity .4s;
}
#NavWrap li:hover ul{
	opacity:1;
	visibility:visible;
	z-index:999;
	padding-top: 23px;
}
#NavWrap li ul a{
	min-width:20em;
	padding: 10px;
	color:#fff;
	text-align: left;
	background: #120aa5;
	border-bottom: solid 1px #fff;
}
#NavWrap li ul a span{
	padding: 10px 0;
}
.drop_menu #switch {
   position: absolute;
   display: none;
   opacity: 0;
}



@media screen and (max-width:768px) {
	.drop_wrap:hover::after{
		opacity: 0;
	}
    header .menu_top{
    	padding:0;
    }
	.drop_menu #switch ~ label {
	   display: block;
	   cursor: pointer;
	   position: fixed;
	   top:0;
	   right:0;
	   z-index:900;
	   -webkit-transition: 0.5s transform;
	   transition: 0.5s transform, right 0.2s;
	   padding: 12px;
	   width: 100px;
	   height: 100px;
	   box-sizing:border-box;
	   background:#120aa5;
	   text-align:center;
	}
	.drop_menu #switch ~ label p{
	   z-index:2;
	   width:100%;
	   margin-bottom: 0;
	}
	.drop_menu #switch ~ label span{
	   cursor: -webkit-grabbing;
	   display:block;
	   width:60px;
	   height:3px;
	   background: #fff;
	   -webkit-transition: 0.2s transform, 0.5s background;
	   transition: 0.2s transform, 0.5s background;
	   position:absolute;
	   top: 50%;
	   left:0;
	   right:0;
	   margin:auto;
	   margin-top:-5px;
	}
	.drop_menu #switch ~ label span:before,
	.drop_menu #switch ~ label span:after{
	   content:"";
	   display:block;
	   width:60px;
	   height:3px;
	   background:#fff;
	   position:absolute;
	   margin-top:0;
	}
	.drop_menu #switch ~ label span:before{
	   top:-18px;
	}
	.drop_menu #switch ~ label span:after{
	   top:18px;
	}
	.drop_menu #switch:checked ~ label span{
	   -webkit-transform:rotate(-45deg) ;
			   transform:rotate(-45deg) ;
	}
	.drop_menu #switch:checked ~ label span:before{
	   top:0;
	}
	.drop_menu #switch:checked ~ label span:after{
	   -webkit-transform:rotate(270deg);
			   transform:rotate(270deg);
	   top:0;
	   margin-top:0;
	}
	.drop_menu #switch:checked ~ label{
		right: 300px;
	}
	.drop_menu #NavWrap{
		position: fixed;
		top: 0;
		width:100%;
		z-index: 800;
		height:100%;
		overflow: auto;
		visibility: hidden;
		padding-top: 100px;
		box-sizing: border-box;
		transition:all 0.25s;
	}
	.drop_menu #NavWrap::-webkit-scrollbar {
		height:10px;
		width:10px;
	}
	.drop_menu #NavWrap::-webkit-scrollbar-track {
		border-radius: 10px;
		background: #b3b3b3;
	}
	.drop_menu #NavWrap::-webkit-scrollbar-thumb {
		border-radius: 10px;
	}
	.drop_menu #switch:checked ~ label+#NavWrap{
		visibility:visible;
		max-height: 100vh;
		top: 0;
	}
	.drop_menu #NavWrap > ul {
		width: 100%;
		margin-right: 0;
		margin-left: auto;
	}
	.drop_menu #NavWrap li a {
		padding: 15px 0;
		text-decoration: none;
		text-align: center;
		width: auto;
		background:rgba(255,255,255,0.9);
	}
	.drop_menu #NavWrap li a span{
		padding: 10px 0px;
		border-left:none;
		white-space: normal;
	}

}
@media screen and (max-width:767px) {
	body {
    }
    header#fix_menu,
    header#fix_menu.fixedMenu{
    	top:0;
    	transition: none;
    	position: fixed;
    }
	#fix_menu{
		padding: 5px 5%;
	}
	.menu_top {
		position: absolute;
		top:0;
		left:0;
		width:100%;
		z-index: 700;
		background: none;
		padding: 0;
		box-sizing: border-box;
	}
	header .menu_top #logo{
		padding: 10px 0;
	}
	#logo img{
		max-height:40px;
		width:auto;
	}
	header .menu_top #logo p{
		display:none;
	}
	.menu_top .right_menu {
    	padding:5px 60px 5px 5px
    }
    .menu_top .right_menu li{
    	display:none;
    }
    .menu_top .right_menu li.inquiry{
    	display:block;
    	margin: 0;
    }
    .menu_top .right_menu li.inquiry a,
    .menu_top .right_menu li.inquiry a:hover{
		background: #fff;
		color: #337b3b;
		padding: 10px;
		border-radius: 5px;
		font-size: 11px;
    }

	.type_general header .menu_top {
		background:none;
	}
	header .menu_top .logo a+a{
		margin-left: 6px;
	}
	header .menu_top .logo a img{
		width: 58px;
		height:auto;
		vertical-align:middle;
	}
	header .menu_top .logo a+a img{
		width:181px;
	}
	header .menu_top .logo span{
		font-size:8px;
		vertical-align:middle;
	}
	header .menu_top .menu_fix{
		position:relative;
	}
	header .menu_top .outwrap{
		padding: 5px 10px 5px;
		height: 50px;
	}
	.type_general header .menu_top .outwrap{
		background:rgba(255,255,255,0.6);
	}
	.drop_menu #NavWrap{
		padding-top: 0;
		position:fixed;
		top: 0;
		left:auto;
		right:-100%;
		padding:0;
		width:300px;
		height:100%;
		background:rgba(0,0,0,0.7);
	}
	.drop_menu #switch:checked ~ label+#NavWrap{
		top: 0;
		left:auto;
		right:0;
	}
	.drop_menu #switch ~ label {
	   padding: 12px 12px;
	   width: 50px;
	   height: 50px;
	}
	.drop_menu #switch ~ label span{
	   width:22px;
	   height:2px;
	   top: 22px;
	   margin:auto;
	}
	.drop_menu #switch ~ label span:before,
	.drop_menu #switch ~ label span:after{
	   width:22px;
	   height:2px;
	   margin-top:0;
	}
	.drop_menu #switch ~ label span:before{
	   top: -9px;
	}
	.drop_menu #switch ~ label span:after{
	   top: 9px;
	}
	.type_general .drop_menu #switch ~ label{
		background:none;


	}
	.type_general .drop_menu #switch ~ label span,
	.type_general .drop_menu #switch ~ label span:before,
	.type_general .drop_menu #switch ~ label span:after{
		background: #1D3CC8;
	}
	.type_general .fixed .drop_menu #switch ~ label span,
	.type_general .fixed .drop_menu #switch ~ label span:before,
	.type_general .fixed .drop_menu #switch ~ label span:after{
		background: #1D3CC8;
	}
	.drop_menu #NavWrap ul {
	   display: block;
	   border-left:none;
	   height: 100%;
	   width: 300px;
	   padding: 0;
	}
	.drop_menu #NavWrap ul li {
		display:block;
		padding:0;
		border-bottom:solid 1px #fff;
	}
	.drop_menu #NavWrap li a,
	.drop_menu #NavWrap li a:hover{
		font-size: 12px;
		text-align: left;
		width: auto;
		padding: 0;
		text-decoration: none;
		background:none;
		color:#fff;
		border:none;
	}
	.drop_menu #NavWrap li a:hover,
	.drop_menu #NavWrap ul li.inquiry a:hover{
		background:none;
	}
	.drop_menu #NavWrap li a span,
	.drop_menu #NavWrap ul li.inquiry a span{
		display:block;
		padding: 17px 20px;
		font-weight:normal;
		background:none;
		line-height: 1.4;
		text-shadow: none;
	}
	.drop_menu #NavWrap li a span br{
		display:block;
	}
	.drop_menu #NavWrap li a span:after{
		display:none;
	}
	.drop_menu #NavWrap ul li.drop_wrap{
	}
	.drop_menu #NavWrap li.drop_wrap i{
    	display:block;
    	width:50px;
    	height:50px;
    	cursor:pointer;
    	position:absolute;
    	top:0;
    	right:0;
    	z-index:10;
    }
	.drop_menu #NavWrap ul li.drop_wrap i:before,
	.drop_menu #NavWrap ul li.drop_wrap i:after{
		content:"";
		width:20px;
		height:2px;
		display:block;
		position:absolute;
		right:10px;
		top:0;
		bottom:0;
		margin:auto;
		z-index:20;
		background:#fff;
		transition:transform .4s;
	}
	.drop_menu #NavWrap li.drop_wrap ul,
	.drop_menu #NavWrap li.drop_wrap:hover ul{
		opacity:0;
		visibility:hidden;
		display:block;
		position:static;
		transform: none;
		width:100%;
		max-height:0;
		overflow:hidden;
    	transition:opacity .4s,visibility .4s, max-height .4s;
	}
	.drop_menu #NavWrap ul li.drop_wrap.opened ul{
		opacity:1;
		visibility:visible;
		max-height:100vh;
	}

	.drop_menu #NavWrap ul li.drop_wrap i:after{
		transform:rotate(90deg);
	}
	.drop_menu #NavWrap ul li.drop_wrap.opened i:before{
		transform:rotate(180deg);
	}
	.drop_menu #NavWrap ul li.drop_wrap.opened i:after{
		transform:rotate(-180deg);
	}
	.drop_menu #NavWrap li.drop_wrap ul li + li{
		border-top:solid 1px #ccc;
	}
	.drop_menu #NavWrap li.drop_wrap ul li a{
		font-size: 12px;
		text-align: left;
		width: auto;
		padding: 0;
		text-decoration: none;
		background:#fff;
		color:#333;
		border:none;
	}
	.drop_menu #NavWrap li.drop_wrap ul li a span{
		padding:15px 20px;
	}
}

/* contents
-------------------------------------------------------------------*/

main{
	display: block;
	background: #fff;
	position: relative;
	overflow: hidden;
}

#commons .visula{
	background:url(../img/common/bg_common.jpg) no-repeat top center;
	background-size:100%;
	min-width:1100px;
}
#commons .visula .sitewrap{ padding-bottom:21.5%;}
#commons .visula h1,
#commons .visula .h1{
	position: absolute;
	top:50%;
	left:50%;
	z-index:200;
	font-size:40px;
	text-shadow: 2px 2px 1px rgba(0,0,0,0.5);
	font-weight:bold;
    margin-left: -2em;
	margin-top:-0.5em;
	line-height:1em;
	color:#fff;
	
}
#commons .visula h1 br{ display:none;}
.common_nav{ 
	background:#F4F4F4;
	margin-bottom:70px;
}
.common_nav ul{
	text-align:center;
	margin:0 auto;
	display: table;
}
.common_nav ul li{display: table-cell;vertical-align: middle;text-align: center;}
.common_nav ul li a{
	display: block;
	font-size:16px;
	font-weight:bold;
	color:#777777;
	padding:20px 30px;
}
.common_nav ul li a br{ display:none;}
.common_nav ul li a:hover,
.common_nav ul li a.active{
	background:#1F1F1F;
	color:#fff;
	text-decoration:none;
}


@media screen and (max-width:768px) {
	main{
		padding-top:65px;
		/*margin-bottom:40px;*/
	}
	#commons .visula{ 	background-size:cover; min-width:inherit;}
	#commons .visula .sitewrap{ padding-bottom:40%;}
	#commons .visula h1{ font-size:32px;}
	.common_nav { margin-bottom:10px;}
	.common_nav ul { 
		display:table;
		width: 100%;
		padding:0
	}
	.common_nav ul li{ width:50%; }
	.env_csr .common_nav ul li,
	.service .common_nav ul li,
	.used .common_nav ul li,
	.rental .common_nav ul li{width:33.3%;}
	.about .common_nav ul li{ width:25%;}
	.common_nav ul li a{
		font-size:14px;
		padding: 18px 0;
		text-align:center;
		width:100%;
	}
	.common_nav ul li a.long{
		line-height: 18px;
		padding: 10px 0;
	}
	.common_nav ul li a br{ display:inline;}
	.common_nav ul li a:hover,
	.common_nav ul li a.active{
		background:#1F1F1F;
		color:#fff;
		text-decoration:none;
	}
	.common_nav ul li a span {
		text-align: center;
		display: block;
		width: 6em;
		margin: 0 auto;
	}
	.common_nav ul:after{ content:none;}
}
@media screen and (max-width:360px) {
	.common_nav ul li a{
		font-size:12px;
	}
}

/* footer
-------------------------------------------------------------------*/

.in_footer{
	margin:120px auto 20px;
}
.in_footer ul{ 
	margin:10px 0 0px;
	text-align:right;
}
.in_footer li{
	display:inline-block;
	border-left: solid 1px #999999;
	padding: 2px 16px;
	text-align:center;
}
footer{
	background:#333;
	padding:5px 0 0;
}

#foot_left{
	float:left;
}
#foot_right{
	float:right;
	width:871px;
	font-size:14px;
	text-align:right;
}
#foot_right ul{ 
	margin:10px 0 30px;
}
#foot_right li{
	display:inline-block;
	border-left: solid 1px #999999;
	padding: 2px 16px;
	text-align:center;
}
#foot_right li a,
#foot_right small{	color:#fff;}


@media screen and (max-width:768px) {

.in_footer{
	margin:40px auto 0;
}
.in_footer ul{
	border-top:solid 1px #ddd;
}
.in_footer ul:after{
	content:none;
}
.in_footer li{
	font-size: 15px;
    display: block;
    text-align: left;
    padding: 0;
	border-bottom:solid 1px #ddd;
}
.in_footer li a{
    display: block;
    padding: 20px;
	position:relative;
}
.in_footer a:before,
.in_footer a:after{
    display: inline-block;
    content: "";
    width:0;
    height:0;
	border: 8px solid transparent;
	border-left: 8px solid #888888;
	position:absolute;
	top:50%;
	margin-top:-8px;
	right:10px;
}
.in_footer a:after{
	border: 8px solid transparent;
	border-left: 8px solid #fff;
	right:13px;
}
/*footer{ padding:30px 0;}*/
#foot_left,
#foot_right ul{ display:none;}
#foot_right{ 
	text-align:center; 
	width:auto;
	float:none;
}
#foot_right small{
	font-size:10px;
}

.page_link {
    margin-top: -60px;
    padding-top: 60px!important;
    display: block;
}
}