@charset "utf-8";


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

body {
	width: 100%;
	font-size: 100%;
	text-align: center;
}
.overwrap{
	width:100%;
	overflow:hidden;
}
.sitewrap {
	width: 1100px;
	min-width:1100px;
	overflow:hidden;
	margin: 0 auto;
	text-align: left;
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
.overwrap .sitewrap {
	overflow:visible;
}
body:not(.home) main{
	text-align:left;
}
body:not(.home) main .sitewrap{
	min-width:0;
	width:1000px;
}
/* display_none */
.display_pc {
	display:block;
}
.display_pc.in {
	display:inline;
}
.display_sp,
.display_sp.in {
	display:none;
}
@media screen and (max-width:767px) {
.display_pc,
.display_pc.in {
	display:none;
}
}
@media screen and (max-width:767px) {
.display_sp {
	display:block;
}
.display_sp.in {
	display:inline;
}
}
@media screen and (max-width:1100px) {
	.sitewrap,
	body:not(.home) main .sitewrap{
		width: 100%;
		min-width:0;
	}
	.sitewrap > *{
		padding-left:2%;
		padding-right:2%;
	}
	.sitewrap img{
		max-width:100%;
		height:
		auto;
	}
}
@media screen and (max-width:767px) {
	html {
		color:#000000;
		font-size:14px;
	}
	.sitewrap {
		width: 100%;
		min-width:0;
	}
	.sitewrap > *{
		padding-left:15px;
		padding-right:15px;
	}
}


/* header
-------------------------------------------------------------------*/
header {
}
header#fix_menu{
	position:
	absolute;
	top: 0;
	left:0;
	right:0;
	width: 100%;z-index:999;
	background:#fff;
	transition:
	top .4s .2s;
}
header#fix_menu.fixedMenu{
	position:fixed;
	top: 0px;
}
.menu_wrap{
   	position:
   	relative;
   	display:
   	flex;
   	justify-content: space-between;
	width:100%;
   	height: 123px;
   	align-items: center;
}
.menu_wrap .left_area{
	padding: 0 30px;
	white-space:
	nowrap;
	display:
	flex;
	align-items: flex-end;
	flex-wrap: wrap;
}
.menu_wrap #site_ttl {
}
.menu_wrap #site_ttl a,
.menu_wrap #site_ttl p,
.menu_wrap #site_ttl img{
	display:inline-block;
	vertical-align:middle;
}
.menu_wrap #site_ttl img{
	width: 364px;
	max-width: 100%;
	height:auto;
}
.menu_wrap .left_area .language{
	margin-left:20px;
}
.select_wrap{
	position:relative;
	z-index:5;
	display:inline-block;
	background:#fff;	
}
.menu_wrap .left_area .language select{
	appearance:none;
	height:2.0em;
	line-height:2.0em;
	border-radius:3px;
	padding:0 2em 0 2.25em;
	min-width:132px;
	font-size:0.875rem;
	color:#bebebe;
	border:solid 1px #bebebe;
	background:transparent;
	cursor:pointer;
	margin-bottom:0;
}
.menu_wrap .left_area .language .select_wrap:before,
.menu_wrap .left_area .language .select_wrap:after{
	content:"";
	display:inline-block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 6px 0 6px;
	border-color: #bebebe transparent transparent transparent;
	position:absolute;
	top:0;
	bottom:0;
	right:0.5em;
	margin:auto;
	z-index:-1;
}
.menu_wrap .left_area .language .select_wrap:before{
	border:none;
	width:18px;
	height:18px;
	background:url(../img/common/ico_language.png) no-repeat;
	background-size:contain;
	left:0.5em;
	right:auto;
}
.menu_wrap .right_area{
	padding: 0 30px 0 0;
	margin-left: auto;
	display:
	flex;
	justify-content:
	center;
	flex-direction:
	column;
	width: 80%;
}
.menu_wrap .right_area .menu_top{
	display:flex;
	align-items: center;
	justify-content: flex-end;
}
.menu_wrap .right_area .menu_top .tel{
	display:flex;
	align-items:center;
	text-decoration:none;
	color:#333;
}
.menu_wrap .right_area .menu_top .tel img{
	width:29px;
	height:29px;
}
.menu_wrap .right_area .menu_top .tel span{
	font-size:2rem;
	font-weight:
	bold;
	margin-left:0.25em;
	white-space: nowrap;
}
.menu_wrap .right_area .menu_top .access{
	display:flex;
	align-items:center;
	padding:10px 25px;
	border-radius:30px;
	text-decoration:none;
	background:#fff;
	border:solid 1px #a8a7a7;
	margin:0 10px 0 15px;
}
.menu_wrap .right_area .menu_top .access:hover{
	background:#f6ffe9;
	color:#289a4d;
}
.menu_wrap .right_area .menu_top .access img{
	margin-right:5px;
}
.menu_wrap .right_area .menu_top .access span{
	white-space:nowrap;
}
.menu_wrap .right_area .menu_top .textSize{
	display:flex;
	align-items:center;
	margin:0;
	margin-right:1.5rem;
	white-space:nowrap;
}
.menu_wrap .right_area .menu_top .textSize dt{
	font-size:0.875rem;
	margin-right:1em;
	margin-bottom:0;
	font-weight:normal;
}
.menu_wrap .right_area .menu_top .textSize dd{
	font-size:11px;
	height:1.75rem;
	padding:0 0.75rem 0 1rem;
	display:flex;
	align-items:center;
	border-radius:20px 0 0 20px;
	border:solid 1px #a8a7a7;
	cursor:pointer;
}
.menu_wrap .right_area .menu_top .textSize #textLarge{
	font-size:13px;
	border-left:none;
	color:#a8a7a7;
	padding:0 1rem 0 0.75rem;
	border-radius:0 20px 20px 0;
}
.menu_wrap .right_area .menu_top .textSize dd.active,
.menu_wrap .right_area .menu_top .textSize dd.active#textLarge{
	background:#289a4d;
	color:#fff;
}
.menu_wrap .right_area .menu_top .search_btn{
	background:#289a4d;
	border-radius:50%;
	border:none;
	cursor:pointer;
	padding:0;
}
.menu_wrap .right_area .menu_top .gsc-search-button-v2{
	background:#289a4d;
	border-radius:50%;
	border:none;
	cursor:pointer;
	padding:10.5px;
}
.menu_wrap .right_area .menu_top .gsc-search-button-v2 svg{
	width:21px;
	height:21px;
	display:block;
}
.menu_wrap .right_area .menu_top table{
	border:none;
}
.menu_wrap .right_area .menu_top table td{
	border:none;
	padding: 2px;
}
.menu_wrap .right_area .menu_top .gsc-input-box{
	padding:0;
	border:none;
}
.menu_wrap .right_area .menu_top input.gsc-input{
	display:flex;
	align-items:center;
	padding: 10px 25px !important;
	border-radius:30px;
	text-decoration:none;
	background:#fff;
	border: solid 1px #a8a7a7 !important;
	margin: 0 0px 0 0px !important;
	background-position-x: 15px !important;
	background-position-y: 13px !important;
}
.menu_wrap .right_area .menu_top .gsc-control-cse{
	padding:0;
}
.menu_wrap .menu_bottom ul{
	display:flex;
	max-width: 1000px;
	margin-left:auto;
	margin-top:20px;
	margin-bottom:0;
	justify-content: space-between;
	text-align: center;
	padding-left:0;
	border-left:solid 1px #333333;
}
.menu_wrap .menu_bottom ul li{
	width: 20%;
	border-right:solid 1px #333333;
	display: flex;
	justify-content: center;
	align-items: center;
}
.menu_wrap .menu_bottom ul li a{
	display:block;
}
.menu_wrap .menu_bottom ul li a:hover{
	color:#289a4d;
	text-decoration:none;
}
.menu_wrap .menu_bottom ul li a span{
	display:inline-block;
	position:relative;
	padding-bottom:2px;
}
.menu_wrap .menu_bottom ul li a span:before{
	content:"";
	display:block;
	width:0;
	height:1px;
	background:#289a4d;
	position:absolute;
	bottom:0;
	left:0;
	right:0;
	margin:auto;
	transition:width .2s;
}
.menu_wrap .menu_bottom ul li a:hover span:before{
	width:100%;
}
#switch {
	position: absolute;
	display: none;
	opacity: 0;
}
.drop_menu{
	display:none;
}
.drop_menu label{
	display:block;
	position:absolute;
	top:0;
	right:0;
	background:#289a4d;
}
.drop_menu label b{
	position:relative;
	display:block;
	width:60px;
	height:60px;
}
.drop_menu label b span:before,
.drop_menu label b span:after,
.drop_menu label b span{
	display:block;
	position:absolute;
	top:0;
	bottom:0;
	left:0;
	right:0;
	margin:auto;
	height:2px;
	width:24px;
	background:#fff;
	transition:transform .4s;
}
.drop_menu label b span:before,
.drop_menu label b span:after{
	content:"";
}
.drop_menu label b span:before{
	transform:translateY(-10px);
}
.drop_menu label b span:after{
	transform:translateY(10px);
}
#switch:checked ~ header .drop_menu label b span{
	background:none;
	transform:rotate(180deg);
}
#switch:checked ~ header .drop_menu label b span:before{
	transform:rotate(45deg);
	margin:auto;
}
#switch:checked ~ header .drop_menu label b span:after{
	transform:rotate(135deg);
	margin:auto;
}
@media screen and (max-width:1400px) {
	.menu_wrap .left_area{
		padding:0 15px;
	}
	.menu_wrap .right_area{
		padding-right:15px;
		width: 90%;
	}
	.menu_wrap #site_ttl img{
		width:300px;
	}
	.menu_wrap #site_ttl{
		margin-right:20px;
	}
}
@media screen and (max-width:1450px) {
	.menu_wrap .menu_bottom ul li a span{
		font-size:0.875rem;
	}
}
@media screen and (max-width:1200px) {
	.menu_wrap .left_area .language{
		margin:10px 0 0;
	}
	.menu_wrap .right_area .menu_top .tel span{
		font-size:2.5vw;
	}
	.menu_wrap .right_area .menu_top .access{
		font-size:1.33vw;
	}
	.menu_wrap .right_area .menu_top .textSize{
		flex-wrap:
		wrap;
		min-width: 100px;
	}
	.menu_wrap .right_area .menu_top .textSize dt{
		width:100%;
		margin:0 0 5px;
	}
	.menu_wrap .right_area .menu_top .textSize dd{
		width:50%;
		text-align: center;
	}
}
@media screen and (max-width:767px) {
	body {
		padding-top: 0;
		font-size:0.875rem;
	}
	header#fix_menu{
		position:fixed;
	}	
	.menu_wrap{
	   	height: 60px;
		border-bottom:solid 1px #d9d9d9;
	}
	.menu_wrap .left_area{
		padding: 0 15px;
	}
	.menu_wrap #site_ttl{
		margin:0;
	}
	.menu_wrap #site_ttl img{
		max-width: 148px;
		width:calc(100vw - 210px);
	}
	.menu_wrap .left_area .language{
		margin-top:5px;
	}
	.menu_wrap .left_area .language select{
		height:1.8em;
		line-height:1.8em;
	}
	.menu_wrap .right_area{
		padding:0 60px 0 0;
	}
	.menu_wrap .right_area .menu_top{
		/* flex-direction:row-reverse; */
	}
	.menu_wrap .right_area .menu_top .tel{
		display:flex;
		align-items:center;
		text-decoration:none;
	}
	.menu_wrap .right_area .menu_top .tel img{
		width:60px;
		height:60px;
	}
	.menu_wrap .right_area .menu_top .tel span{
		display:none;
	}
	.menu_wrap .right_area .menu_top .access{
		display:none;
	}
	.menu_wrap .right_area .menu_top .textSize{
		display:none;
	}
	.menu_wrap .right_area .menu_top .search_btn{
		background:#fff;
		border-radius:0;
		border-left:solid 1px #d9d9d9;
	}
	.menu_wrap .right_area .menu_top .search_btn img{
		width:59px;
	}
	.menu_wrap .menu_bottom {
		display:none;
	}
	.drop_menu{
		display:block;
	}
}

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

main{
	padding-top: 123px;
	display: block;
}

#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;
}
main a.page_link {
	margin-top: -99px;
	padding-top: 99px;
	display: block;
	position:relative;
	z-index:-10;
}
@media screen and (max-width:1100px) {
	main{
		padding-top:100px;
	}
}
@media screen and (max-width:767px) {
	main{
		padding-top: 60px;
	}
	#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;
	}
	main a.page_link {
		margin-top: -60px;
		padding-top: 60px;
		display: block;
	}
	.common_nav ul:after{ content:none;}
}
@media screen and (max-width:360px) {
	.common_nav ul li a{
		font-size:12px;
	}
}

/* footer
-------------------------------------------------------------------*/
#top_link {
    position: fixed;
    bottom: 15px;
    right: 5%;
    z-index: 500;
}
#top_link a{
	background:#0162bb;
	border:solid 1px #0162bb;
	width:85px;
	height:85px;
	border-radius:50%;
	display:flex;
	align-items:center;
	justify-content:center;
	color:#fff;
	position:relative;
	transition:background .4s,color .4s;
}
#top_link a:before{
	content:"";
	display:inline-block;
	background:rgba(255,255,255,1);
	width:3px;
	height:30px;
	position:absolute;
	top:-1px;
	left:0;
	right:0;
	margin:auto;
	z-index:1;
	transition:background .4s;
}
#top_link a span{
	z-index:5;
	position:relative;
	display:inline-block;
	margin-top:0.25em;
}
#top_link a:hover{
	background:#fff;
	color:#0162bb;
	text-decoration:none;
}
#top_link a:hover:before{
	background:#0162bb;
}

.foot_sitemap > label{
	font-size:1.375rem;
	background:#289a4d;
	border-top:#289a4d solid 1px;
	border-bottom:#289a4d solid 1px;
	color:#fff;
	padding:20px;
	display: block;
	transition:background .4s,color .4s;
}
.foot_sitemap > label span{
	display:inline-block;
	position:relative;
	padding-right:50px;
}
.foot_sitemap > label span:before,
.foot_sitemap > label span:after{
	content:"";
	display:inline-block;
	position:absolute;
	right:0px;
	top:0;
	bottom:0;
	margin:auto;
	transition:background .4s,border-color .4s;
	box-sizing:content-box;
}
.foot_sitemap > label span:before{
	width:25px;
	height:25px;
	background:#fff;
	border-radius:50%;
	z-index:1;
	border: solid 1px #289a4d;
}
.foot_sitemap > label span:after{
	width: 9px;
	height: 9px;
	z-index: 2;
	right: 8px;
	top:8px;
	bottom:auto;
	border-top: solid 2px #289a4d;
	border-right: solid 2px #289a4d;
	transform: rotate(135deg);
}
.foot_sitemap > label:hover{
	background:#f6ffe9;
	color:#289a4d;
}
.foot_sitemap > label:hover span:before{
	background:#289a4d;
}
.foot_sitemap > label:hover span:after{
	border-color:#fff;
}
.foot_sitemap nav{
	padding: 0;
	overflow:hidden;
	max-height:0;
}
#switch ~ footer .foot_sitemap nav{
	padding: 30px 0 30px;
	max-height:1000px;
}
#switch ~ footer .foot_sitemap > label span:after{
	transform:rotate(-45deg);
	top:12px;
}
#switch:checked ~ footer .foot_sitemap nav{
	padding: 0px;
	max-height:0;
}
#switch:checked ~ footer .foot_sitemap > label span:after{
	transform:rotate(135deg);
	top:8px;
}
.foot_sitemap nav .quick{
	display:flex;
	align-items:center;
	justify-content:space-between;
	margin:0 auto 30px;
	max-width:960px;
	padding-left:0;
}
.foot_sitemap nav .quick li{
	width:32%;
}
.foot_sitemap nav .quick li a{
	display:flex;
	align-items:center;
	justify-content:center;
	background:#f56f61;
	border-radius:30px;
	color:#fff;
	padding:10px;
	min-height:60px;
	font-size:1rem;
	text-decoration:none;
}
.foot_sitemap nav .quick li a img{
	display:inline-block;
	margin-right:10px;
}
.foot_sitemap nav .quick li a.access{
	background:#5bccdb;
}
.foot_sitemap nav .quick li a.search{
	background:#eebe00;
	color:#222;
	position:relative;
}
.foot_sitemap nav .quick li a.search:before,
.foot_sitemap nav .quick li a.search:after{
	content:"";
	display:inline-block;
	position:absolute;
	right:20px;
	top:0;
	bottom:0;
	margin:auto;
	transition:background .4s,border-color .4s;
	box-sizing:content-box;
}
.foot_sitemap nav .quick li a.search:before{
	width:25px;
	height:25px;
	background:#fff;
	border-radius:50%;
	z-index:1;
}
.foot_sitemap nav .quick li a.search:after{
	width: 9px;
	height: 9px;
	z-index: 2;
	right: 29px;
	border-top: solid 2px #eebe00;
	border-right: solid 2px #eebe00;
	transform: rotate(45deg);
}
.foot_sitemap nav .quick li a.er:hover{
	background:#ee3311;
}
.foot_sitemap nav .quick li a.access:hover{
	background:#33aacc;
}
.foot_sitemap nav .quick li a.search:hover{
	background:#f0dd00;
}
.foot_sitemap nav .quick li a.search:hover:after{
	border-color:#f0dd00;
}
.foot_sitemap nav .sp_accordion{
	display:flex;
	flex-wrap:wrap;
	justify-content:flex-start;
	align-items: stretch;
	margin-bottom:20px;
}
.foot_sitemap nav .sp_accordion > *{
	width:25%;
	margin-top:0;
	margin-bottom:20px;
	padding-bottom:20px;
	border-bottom:dotted 1px #ddd;
}
.foot_sitemap nav .sp_accordion dt{
	margin-bottom:0;
}
.foot_sitemap nav .sp_accordion dt,
.foot_sitemap nav .sp_accordion .single{
	font-size:1.1275rem;
	line-height:1.4;
}
.foot_sitemap nav .sp_accordion dd p{
	font-size:0.875rem;
	position:relative;
	padding-left:15px;
	margin-top:5px;
	margin-bottom:0;
	line-height:1.4;
}
.foot_sitemap nav .sp_accordion dd p:before{
	content:"";
	display:block;
	width:0.5em;
	height:2px;
	background:#289a4d;
	position:absolute;
	top:0.75em;
	left:0;
}
.foot_sitemap nav .sp_accordion a{
	text-decoration:underline;
	color:#333;
}
.foot_sitemap nav .sp_accordion dt a,
.foot_sitemap nav .sp_accordion .single a{
	color:#333;
	transition:color .4s;
	font-weight:normal;
}

.foot_sitemap nav .sp_accordion .single:last-child{
	border:none;
}
.foot_sitemap nav .sitewrap > a{
	display:none;
}
.foot_sitemap nav .sp_accordion a:hover{
	color:#289a4d;
	text-decoration:none;
}
.footer_bottom {
	background:#f2f4f4;
	padding:40px 0 25px;
}
.footer_bottom .sitewrap .wrap{
	display:flex;
	justify-content:space-between;
	flex-wrap:wrap;
}
.footer_bottom .site_ttl{
	width:28.5%;
	min-width: 315px;
}
.footer_bottom .site_ttl img{
	max-width:315px;
	height:auto;
}
.footer_bottom .site_address{
	width:62.5%;
	font-size:0.875rem;
	font-weight:bold;
}
.footer_bottom .site_address p{
	margin-bottom:10px;
	line-height:1.4;
}
.footer_bottom .site_address p a{
	text-decoration:none;
	color:#333;
	line-height:1.4;
}
.footer_bottom .site_address .text_link a{
	color:#558ed5;
	display:inline-block;
	text-decoration:none;
	margin-left:20px;
	padding-left:15px;
	position:relative;
	transition:transform .4s;
}
.footer_bottom .site_address .text_link a:before{
	content:"";
	display:inline-block;
	width:7px;
	height:7px;
	border-top:solid 1px #558ed5;
	border-right:solid 1px #558ed5;
	transform:rotate(45deg);
	top:0;
	bottom:0;
	margin:auto;
	left:0;
	position:absolute;
	box-sizing:content-box;
}
.footer_bottom .site_address .text_link a span{
	border-bottom:solid 1px;
	display:inline-block;
	padding-bottom:5px;
	transition:border-color .4s;
}
.footer_bottom .site_address .text_link a:hover{
	transform:translateX(-2px);
}
.footer_bottom .site_address .text_link a:hover span{
	border-color:transparent;	
}
.footer_bottom .site_address p.copy{
	margin-bottom:0;
	font-weight:normal;
	text-align:right;
	font-weight:normal;
}
@media screen and (max-width:1100px) {
	.footer_bottom .site_ttl{
		width:100%;
		text-align:center;
		margin:0 0 20px;
	}
	.footer_bottom .site_address{
		width:100%;
		font-size:0.875rem;
		font-weight:bold;
	}
}
@media screen and (max-width:767px) {
	.foot_sitemap{
		position:fixed;
		top:60px;
		bottom:0;
		left:0;
		width:100%;
		background:#fff;
		z-index:500;
		padding:0;
		transform:translateX(100%);
		opacity:0;
		transition:transform .2s,opacity .4s;
	}
	#switch:checked ~ footer .foot_sitemap{
		transform:translateX(0%);
		opacity:1;
	}
	footer .foot_sitemap .sitemap{
		overflow:auto;
		height:100%;
	}
	footer .foot_sitemap .sitemap::-webkit-scrollbar {
		width: 8px;
	}	
	footer .foot_sitemap .sitemap::-webkit-scrollbar-track {
		border-radius: 10px;
		background: #c1c1c1;
	}
	footer .foot_sitemap .sitemap::-webkit-scrollbar-thumb {
		border-radius: 10px;
		background: #666;
	}
	.foot_sitemap > label{
		display:none;
	}
	#switch:checked ~ footer .foot_sitemap nav{
		padding:0;
		max-height:inherit;
	}
	.foot_sitemap nav .quick{
		flex-wrap:wrap;
		margin: 0;
		padding: 0;
		max-width:100%;
		align-items:stretch;
	}
	.foot_sitemap nav .quick li{
		width:50%;
	}
	.foot_sitemap nav .quick li:last-child{
		width:100%;
		padding:15px 15px 0;
	}
	.foot_sitemap nav .quick li a.er,
	.foot_sitemap nav .quick li a.access{
		border-radius:0;
		height:100%;
	}
	.foot_sitemap nav .quick li a img{
		width:22px;
		height:auto;
	}
	.foot_sitemap nav .quick li a.access img{
		width:19px;
	}
	.foot_sitemap nav .quick li a.search:before{
		width:20px;
		height:20px;
	}
	.foot_sitemap nav .quick li a.search:after{
		width: 6px;
		height: 6px;
		right: 27px;
	}
	.foot_sitemap nav .sp_accordion{
		display:block;
		margin-bottom:0;
		border-bottom:solid 1px #999999;
		padding:0;
	}
	.foot_sitemap nav .sp_accordion > *{
		margin-bottom:0;
		padding-bottom:0;
		border-bottom:none;
		width:100%;
		border-bottom:solid 1px #999999;
	}
	.foot_sitemap nav .sp_accordion dt,
	.foot_sitemap nav .sp_accordion .single{
		font-size:1rem;
		font-weight: 400;
	}
	.foot_sitemap nav .sp_accordion a{
		text-decoration:none;
	}
	.foot_sitemap nav .sp_accordion dt{
		padding:15px;
		padding-right:45px;
		position:relative;
	}
	.foot_sitemap nav .sp_accordion .link_pc a{
		pointer-events: none;
		text-decoration: none;
	}
	.foot_sitemap nav .sp_accordion dt i{
		width:100%;
		position:absolute;
		top:0;
		bottom:0;
		margin:auto;
		cursor:pointer;
		left: 0;
	}
	.foot_sitemap nav .sp_accordion dt i span{
		background:#289a4d;
		width:24px;
		height:24px;
		display: block;
		position:absolute;
		right:15px;
		top:0;
		bottom:0;
		margin:auto;
		border-radius:50%;
		cursor:pointer;
		transition:transform .4s;
	}
	.foot_sitemap nav .sp_accordion dt i span:before,
	.foot_sitemap nav .sp_accordion dt i span:after{
		content:"";
		display:inline-block;
		width:12px;
		height:2px;
		background:#fff;
		position:absolute;
		top:0;
		bottom:0;
		margin:auto;
		right:6px;
		transition:transform .4s;
	}
	.foot_sitemap nav .sp_accordion dt a{
		text-decoration:underline;
		text-underline-offset:5px;
	}
	.foot_sitemap nav .sp_accordion dt i span:after{
		transform:rotate(90deg);
	}
	.foot_sitemap nav .sp_accordion dt.opened i span{
		transform:rotate(360deg);
	}
	.foot_sitemap nav .sp_accordion dt.opened i span:after{
		transform:rotate(0deg);
	}
	.foot_sitemap nav .sp_accordion dd{
		display:none;
	}
	.foot_sitemap nav .sp_accordion dd p{
		padding-left:0;
		margin-top:0;
		border-top:solid 1px #999999;
	}
	.foot_sitemap nav .sp_accordion dd p:before{
		display:none
	}
	.foot_sitemap nav .sp_accordion dd p a,
	.foot_sitemap nav .sp_accordion .single a{
		display:block;
		position:relative;
		background:#f5f5f5;
		padding:12px 15px;
	}
	.foot_sitemap nav .sp_accordion .single a{
		background:#fff;
		padding:15px;
		padding-right:45px;
	}
	.foot_sitemap nav .sp_accordion dd p a:before,
	.foot_sitemap nav .sp_accordion .single a:before{
		content:"";
		display:inline-block;
		width:9px;
		height:9px;
		background:none;
		border-top:solid 1px #289a4d;
		border-right:solid 1px #289a4d;
		transform:rotate(45deg);
		top:0;
		bottom:0;
		margin:auto;
		right:25px;
		position:absolute;
	}
	.foot_sitemap nav .sitewrap > a{
		display:block;
		max-width:296px;
		margin:30px auto;
	}
	.footer_bottom{
		background:#ffffff;
		padding:20px 0 0;
	}
	.footer_bottom .sitewrap .wrap{
		padding:0;
	}
	.footer_bottom .site_ttl{
		text-align:left;
		padding:0 15px;
	}
	.footer_bottom .site_ttl img{
		width:251px;
	}
	.footer_bottom .site_address{
		font-weight:500;
	}
	.footer_bottom .site_address p{
		padding:0 15px;
	}
	.footer_bottom .site_address .text_link a{
		display:block;
		margin:15px 0 20px;
	}
	.footer_bottom .site_address p.copy{
		padding:15px;
		text-align:center;
		background:#f2f4f4;
	}
}
/*2023/06/08追記*/
.section.sub_banner .image{
	margin-top:30px;
	text-align:center;
}
.section.sub_banner .image a{
	transition:.5s transform;
	display: inline-block;
	margin-bottom: 5px;
}
.section.sub_banner .image a + a{
	margin-left:30px;
}
.section.sub_banner .image a:hover{
	transform:translateY(5px);
}
.sidebar{
	position: fixed;
	top: 15%;
	right: calc(-60% + 160px);
	width: 60%;
	z-index: 1500;
	transition: 1s right;
}
.sidebar.opened{
	right: 0;
}
.site_button{
	position:absolute;
	left: 0px;
	top: 85px;
	background: #289a4d;
	border: 2px solid #289a4d;
	color: #fff;
	width: 250px;
	height: 80px;
	border-radius: 0px 0px 10px 10px;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: .5s background,.5s color;
	transform: rotate(90deg);
}
.site_button span{
	font-size: 1.125rem;
	font-weight: bold;
	
}
.site_button:hover{
	background: #fff;
}
.site_button:hover span{
	color: #289a4d;
}
.side_banner{
	background: #006536;
	padding: 20px;
	width: calc(100% - 160px);
	margin-right: auto;
	margin-left: 160px;
}
.side_banner .col{
	display:flex;
	justify-content:center;
	align-items:stretch;
}
.side_banner .col a{
	width:50%;
	background:#fff;
}
.side_banner .col .img{
	overflow:hidden;
}
.side_banner .col .img img{
	max-width:100%;
	transition:.5s transform;
}
.side_banner .col a:hover .img img{
	transform:scale(1.05,1.05);
}
.side_banner .col a span{
	background:#fff;
	display:block;
	padding:10px 20px;
	text-align: left;
	font-weight:bold;
}
.side_banner .col a:hover{
	text-decoration:none;
}
.side_banner .col a:hover span{
	color:#006536;
}
.side_banner .col a:first-child{
	border-right:1px solid #006536;
}
@media screen and (max-width:767px) {
	.section.sub_banner .image{
		margin-top:10px;
	}
	.sidebar{
		top: calc(100% - 80px);
		right: 0;
		width:100%;
	}
	.sidebar.opened{
		top:auto;
		bottom:0;
	}
	.site_button{
		left: auto;
		top: 30px;
		width: 170px;
		height: 50px;
		border-radius: 10px 10px 0 0px;
		right: 0;
		transform: rotate(0deg);
	}
	.site_button span{	
		font-size: 1rem;
	}
	.side_banner{
		padding: 15px;
		width: 100%;
		margin-right: auto;
		margin-left: 0px;
		margin-top: 60px;
		margin: 80px auto 0 0;
		height: auto;
	}
	.side_banner .col a span{
		padding:10px;
	}
	.section.sub_banner .image a + a{
		margin-left:0px;
		margin-top:20px;
	}
}