@charset "UTF-8";



/*body*/
body{ background:url(../images/backline.gif) 0 0 repeat-x; }
body.backconts{ background-color: #f2f2f2; }

.sponly{ display: none; }
@media screen and (max-width: 640px) {
  .pconly{ display: none; }
  .sponly{ display: block; }
}

p{ margin-bottom: 1em; }

/* -----------------------------------------
   All pages
----------------------------------------- */

/* title
------------------------------------------ */

.title1{
  font-size: 28px;
  line-height: 1.5;
  /*font-family: "Yu Mincho Demibold", "YuMincho", serif;*/
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
}
.title2{
	font-size: 32px;
	line-height: 1.8;
/*	font-family: "Yu Mincho Demibold", "YuMincho", "メイリオ", Meiryo, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	margin-bottom: 40px;
	color: rgba(10,31,87,1.00);
}
@media screen and (max-width: 767px) {
	.title2{
		font-size: 24px;
		line-height: 1.4;
		margin-bottom: 24px;
	}
}
.title21{
	font-size: 24px;
	line-height: 1.8;
	margin-top: 30px;
	margin-bottom: 30px;
/*	font-family: "Yu Mincho Demibold", "YuMincho", "メイリオ", Meiryo, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
}
@media screen and (max-width: 767px) {
	.title21{
		font-size: 20px;
		line-height: 1.4;
		margin-bottom: 24px;
	}
}





/* button
------------------------------------------ */

.btn1wrap{
  width: 100%;
  padding-top: 30px;
  text-align: center;
}
.btn1{
  display: inline-block;
  /*margin: 0 auto;*/
  background-color: #FFFFFF;
  transform:skewX(-15deg);
  transition: .4s;
  border: 1px solid #757b41;
}
.btn1 span{
  display: block;
  font-size: 14px;
  line-height: 1.0;
  padding: 10px 1.5em 10px 2em;
  width:100%;
  transform:skewX(15deg);
	color: #757b41;
}
.btn1 span i{

}
.btn1:hover{
  background-color: #757b41;
  color: #fff;
  border: 1px solid #757b41;
}
.btn1:hover span {
  color: #fff;
}
@media screen and (max-width: 640px) {
  .btn1 span{
    font-size: 16px;
    padding: 10px 1.5em;
    letter-spacing: 0em;
  }
  .btn1wrap2{
    width: 98%;
  }
}


/* table
------------------------------------------ */

.table1{
	width: 100%;
	margin-bottom: 20px;
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
}
.table1 th,.table1 td{
	padding: 5px 10px;
	vertical-align: top;
	text-align: left;
	border-bottom: 1px solid #ccc;
	border-right: 1px solid #ccc;
}
.table1 th{
	background-color: #f3f3f3;
	white-space: nowrap;
}
.table1 th.textcenter,.table1 td.textcenter{
	text-align: center;
}

/* Recruit table
------------------------------------------ */

.recruittable table{
	border-collapse: collapse;
	width: 100%;
	margin-bottom: 20px;
	border: 1px solid #ccc;
}
.recruittable table th,.recruittable table td{
	border-collapse: collapse;
	padding: 5px 10px;
	vertical-align: top;
	text-align: left;
	border: 1px solid #ccc;
	font-size: 13px;
}
.recruittable table th{
	background-color: #f3f3f3;
	white-space: nowrap;
}
.recruittable table th.textcenter,.recruittable table td.textcenter{
	text-align: center;
}


/* fontsize
------------------------------------------ */

.f13{ font-size: 13px; }


/* -----------------------------------------
   header 
----------------------------------------- */

header.header{
	position: relative;
	max-width: 2016px;
	margin-left: auto;
	margin-right: auto;
}
header.header::before{
	position: absolute;
	content: url("../images2/home-back1.svg");
	width: 50%;
}
@media screen and (max-width: 550px) {
	header.header::before{
		width: 60%;
	}
}
.headlogo{
	position: absolute;
	z-index: 99;
	max-width:120px;
	width: 15%;
	min-width: 80px;
}
.sliderbox{
	position: relative;
	/*width: calc(100vw - 134px);*/
	/*width: 86.6%;*/
	max-width: 1920px;
	/*margin: 0 67px;*/
	margin: 0 48px;
	padding-top: 62px;
}
@media screen and (max-width: 767px) {
	.sliderbox{
		margin: 0px 0px;
		padding: 24px 20px 0 20px;
	}
}
.slidetext{
	position: absolute;
	left: 50%;
	top: calc(50% + 34px);
	transform: translate(-50% , -50%);
	z-index: 99;
	width: 30%;
	min-width: 80px;
	max-width: 300px;
	/*background-color: rgba(117,123,65,0.80);*/
	background-color: rgba(255,255,255,0.8);
	border: 3px solid rgba(255,255,255,1);
}


@media screen and (max-width: 767px) {
	.slidetext{
		top: calc(50% + 12px);
		transform: translate(-50% , -50%);
		width: 40%;
		min-width: 80px;
	}
}

.titleimage{
	height: 400px;
	position: relative;
	background: center center no-repeat;
}
.titleimagetextwrap{
	position: absolute;
	left: 50%;
	top: 150px;
	transform: translateX(-50%);
	z-index: 99;
	text-align: center;
}
.titleimagetext{
	font-size: 60px;
	line-height: 1.2;
/*	font-family: "Yu Mincho Demibold", "YuMincho", "メイリオ", Meiryo, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	color: #fff;
}
.titleimagetext span{
	display: block;
	font-size: 14px;
	line-height: 1.2;
	font-family:Arial, Helvetica, "sans-serif";
	color: #fff;
}

@media screen and (max-width: 767px) {
	.titleimage{
		height: 160px;
	}
	.titleimagetextwrap{
		top: 50px;
	}
	.titleimagetext{
		font-size: 32px;
	}
	.titleimagetext span{
		font-size: 12px;
	}
}



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

footer{
	background-color: #2f2f2f;
	width: 100%;
	padding: 80px 0 10px 0;
}
@media screen and (max-width: 767px) {
	footer{
		padding: 40px 0 10px 0;
	}
}
.footerbox{
	display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: space-between;
	-moz-justify-content: space-between;
	-ms-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: nowrap;
	-moz-flex-wrap: nowrap;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
	max-width: 1500px;
	width: 90%;
	margin: 0 auto;
	color: #fff;
}
.footerboxleft{
	width: 38%;
}
.footerboxleft1{
	display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: flex-start;
	-moz-justify-content: flex-start;
	-ms-justify-content: flex-start;
	justify-content: flex-start;
	-webkit-flex-wrap: nowrap;
	-moz-flex-wrap: nowrap;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
}
.footerboxleft11{
	width: 100px;
	margin-right: 20px;
}
.footerboxleft12 h2{
	font-size: 24px;
/*	font-family: "Yu Mincho Demibold", "YuMincho", "メイリオ", Meiryo, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
}
.footerboxleft12 h2 span{
	font-size: 12px;
	font-family: "メイリオ", Meiryo, sans-serif;
	display: block;
	line-height: 16px;
}
.footerboxleft12 p{
	font-size: 12px;
	line-height: 18px;
}

.footerboxright{
	width: 60%;
	height: 400px;
	border-radius: 10px;
	overflow: hidden;
}
.footerboxright iframe{
	width: 100%;
	height: 100%;
}

.footerboxleft2{
	background-color: rgba(255,255,255,0.40);
	border-radius: 10px;
	padding: 4px 4px 2px 4px;
	max-width: 320px;
	margin-top: 30px
}
@media screen and (max-width: 767px) {
	.footerboxleft2{
		margin-top: 20px
	}
}
.footerboxleft2 ul{
	display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: flex-start;
	-moz-justify-content: flex-start;
	-ms-justify-content: flex-start;
	justify-content: flex-start;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.footerboxleft2 ul li{
	width: 25%;
	text-align: center;
	border-left: 1px solid #2f2f2f;
	padding: 2px;
	margin-bottom: 2px;
}
.footerboxleft2 ul li:nth-child(1),
.footerboxleft2 ul li:nth-child(5){
	border-left: none;
}
.footerboxleft2 ul li.navtel{
	width: 50%;
}
.footerboxleft2 ul li.navtel a img{
	width: 69%;
}
.footerboxleft2 ul li a{
	display: block;
	text-align: center;
	transition: .8s;
}
.footerboxleft2 ul li a:hover{
	background-color: rgba(255,255,255,0.40);
}
@media screen and (max-width: 767px) {
	.footerbox{
		-webkit-flex-wrap: wrap;
		-moz-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}
	.footerboxleft{
		width: 100%;
	}
	.footerboxright{
		width: 100%;
		height: 300px;
		margin-top: 30px;
	}
}

footer address{
	font-size: 12px;
	color: #ccc;
	text-align: center;
	margin-top: 80px;
}
@media screen and (max-width: 767px) {
	footer address{
		margin-top: 40px;
	}
}


/* -----------------------------------------
   home
----------------------------------------- */

/* OUR POLICY & button  -------------- */

.box1{
	width: 80%;
	max-width: 500px;
	margin: 80px auto;
}
@media screen and (max-width: 767px) {
	.box1{
		margin: 40px auto;
	}
}
.subtitle-ourpolicy{
	max-width: 250px;
	margin: 0 auto 30px auto;
}
.box1 h3{
	font-size: 32px;
	line-height: 1.8;
	text-align: center;
/*	font-family: "Yu Mincho Demibold", "YuMincho", "メイリオ", Meiryo, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
}
.box1 p{
	max-width: 450px;
	margin: 30px auto 0 auto;
	font-size: 18px;
	line-height: 1.8
}
@media screen and (max-width: 767px) {
	.box1 h3{
		font-size: 20px;
/*		background-color: #2f2f2f;
		color: #fff;
		padding: 10px 5px;*/
	}
	.box1 p{
		max-width: 450px;
		margin: 20px auto 0 auto;
		font-size: 16px;
		line-height: 1.8
	}
}

.nav-button1{
	background-color: #e1e1e1;
	width: 100%;
}
.nav-button1 ul{
	display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: space-between;
	-moz-justify-content: space-between;
	-ms-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: nowrap;
	-moz-flex-wrap: nowrap;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
	max-width: 1920px;
	margin: 0 auto;
}
.nav-button1 ul li:nth-child(1){
	background-image: url("../images2/nav-button1-1.jpg");
}
.nav-button1 ul li:nth-child(2){
	background-image: url("../images2/nav-button1-2.jpg");
}
.nav-button1 ul li:nth-child(3){
	background-image: url("../images2/nav-button1-3.jpg");
}
.nav-button1 ul li{
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	width: 34%;
}
.nav-button1 ul li a{
	position: relative;
	display: block;
	height: 480px;
	border-left: 1px solid #e1e1e1;
	font-size: 24px;
	line-height: 1.2;
	color: #fff;
	z-index: 4;
}
.nav-button1 ul li:nth-child(1) a{
	border-left: none;
}
.nav-button1 ul li a p{
	position: absolute;
	top: 50%;
	width: 100%;
	left: 0;
	text-align: center;
	transform: translateY(-50%);
/*	font-family: "Yu Mincho Demibold", "YuMincho", "メイリオ", Meiryo, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
}
.nav-button1 ul li a p i{
	vertical-align: top;
	font-size: 80%;
	padding-top: 4px;
}
@media screen and (max-width: 1200px) {
	.nav-button1 ul li a{
		height: 320px;
	}
}
@media screen and (max-width: 767px) {
	.nav-button1 ul li a{
		height: 200px;
		font-size: 16px;
	}
}



/* news  -------------- */
.box2{
	display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: space-between;
	-moz-justify-content: space-between;
	-ms-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	max-width: 1500px;
	width: 90%;
	margin: 80px auto 80px auto;
}
.box2 h2{
	width: 20%;
	text-align: left;
}
.box2 ul{
	width: 80%;
	list-style: none;
	border-top: 1px solid #ccc;
}
.box2 ul li a{
	display: block;
	width: 100%;
	padding: 2px 0;
	border-bottom: 1px solid #ccc;
	display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: flex-start;
	-moz-justify-content: flex-start;
	-ms-justify-content: flex-start;
	justify-content: flex-end;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	transition: 0.5s;
}
.box2 ul li a:hover{
	background-color: rgba(0,100,255,0.10);
}
.blog-alltime{
	display: block;
	width: 27%;
	font-size: 13px;
	line-height: 22px;
	padding: 8px 0;
	color: #2f2f2f;
	text-align: center;
}
.blog-date{
	display: block;
	width: 12%;
	font-size: 13px;
	line-height: 22px;
	padding: 8px 0;
	color: #2f2f2f;
	text-align: center;
}
.blog-cat{
	display: block;
	width: 15%;
	text-align: center;
	background-color: #ccc;
	font-size: 13px;
	line-height: 22px;
	padding: 8px 0;
	color: #2f2f2f;
}
.blog-listttl{
	width: 73%;
	display: block;
	font-size: 16px;
	line-height: 22px;
	padding: 8px 0 8px 20px;
	color: #2f2f2f;
}
/*.box2 ul li.alltime{
	background-color: rgba(255,0,0,0.15);
}*/
.box2 ul li.alltime .blog-alltime{
	background-color: rgba(255,0,0,0.15);
}
.box2 ul li.alltime a:hover{
	background-color: rgba(255,0,0,0.15);
}
@media screen and (max-width: 999px) {
	.box2 h2{
		width: 100%;
		text-align: center;
		margin-bottom: 50px;
	}
	.box2 ul{
		width: 96%;
		margin: 0 auto;
	}
	.blog-alltime{
	width: 100%;
}
	.blog-date{
		width: 15%;
	}
	.blog-cat{
		width: 18%;
	}
	.blog-listttl{
		width: 67%;
	}
}
@media screen and (max-width: 767px) {
	.box2{
		margin: 40px auto 50px auto;
	}
	.box2 h2{
		margin-bottom: 30px;
	}
	.blog-date{
		width: 50%;
		padding: 3px 0;
		text-align: left;
	}
	.blog-cat{
		width: 50%;
		padding: 3px 0;
	}
	.blog-listttl{
		width: 100%;
		padding: 8px 0;
	}
}

.blog-box1{
	position: relative;
	padding: 80px 0 80px 0;
	border-bottom: 1px solid #757b41;
}
.blog-box1::after{
	position: absolute;
	content: "";
	bottom: 0;
	right: 0;
	height: 40px;
	border-right: 1px solid #757b41;
}
.blog-box1::before{
	position: absolute;
	content: "";
	bottom: -40px;
	left: 0;
	height: 40px;
	border-right: 1px solid #757b41;
}
.blog-detailtitle{
	font-size: 32px;
	line-height: 1.2;
/*	font-family: "Yu Mincho Demibold", "YuMincho", "メイリオ", Meiryo, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	margin-bottom: 10px;
	color: rgba(10,31,87,1.00);
}
.blog-detaildate{
	font-size: 12px!important;
	line-height: 1.2;
}
.blog-detailbody{
	margin-top: 30px;
}
@media screen and (max-width: 767px) {
	.blog-detailtitle{
		font-size: 24px;
	}
}

.pagenav ul{
  display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-flex-wrap: nowrap;
	-moz-flex-wrap: nowrap;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
	-webkit-justify-content: center;
	-moz-justify-content: center;
	-ms-justify-content: center;
	justify-content: center;
  max-width: 800px;
  width: 90%;
  margin: 50px auto;
  list-style: none;
}
.pagenav ul li{
  margin: 3px;
	font-size: 12px;
}
.pagenav ul li .current_page{
  display: block;
  background-color: #ddd;
	color: #2f2f2f;
	border: 1px solid #2f2f2f;
  padding: 10px 12px;
}
.pagenav ul li a{
  display: block;
	background-color: #fff;
	color: #2f2f2f;
	border: 1px solid #2f2f2f;
  padding: 10px 12px;
}



/* home-text  -------------- */

.box3{
	position: relative;
	width: 100%;
	padding: 50px 0;
	overflow: hidden;
}
/*.box3::before*/
.box3 .backimg{
	position: absolute;
	display: block;
	left: 0;
	top: 0;
	width: 70%;
	min-height: 100vh;
	content: "";
	background: url("../images2/topbackimg1.jpg") center center no-repeat;
	background-attachment: fixed;
	background-size: cover;
	z-index: -1;
	-webkit-clip-path: polygon(0% 0%, 100% 0%, 85% 100%, 0% 100%);
	clip-path: polygon(0% 0%, 100% 0%, 85% 100%, 0% 100%);
}
.box3text{
	position: relative;
	float: right;
	width: 45%;
	margin-right: 6%
}
.box3text h2{
	font-size: 42px;
  line-height: 1.5;
/*	font-family: "Yu Mincho Demibold", "YuMincho", "メイリオ", Meiryo, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	background-color: rgba(255,255,255,0.82);
	padding: 0px 20px;
	margin-bottom: 20px;
}
.box3text p{
	background-color: rgba(255,255,255,0.82);
	padding: 5px 10px;
	margin-bottom: 5px;
}
@media screen and (max-width: 1000px) {
	.box3text{
		width: 65%;
		margin-right: 6%
	}
}
@media screen and (max-width: 767px) {
	.box3 .backimg{
		width: 100vw;
		height: 100vh;
		-webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
		clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
	}
	 .box3text{
		position: relative;
		float: none;
		width: 70%;
		margin-right: auto;
		margin-left: auto;
	}
}

.box4{
	background-color: #e1e1e1;
	width: 100%;
	padding: 80px 0 50px 0;
}
@media screen and (max-width: 767px) {
	.box4{
		padding: 40px 0 50px 0;
	}
}
.box4 h2{
	text-align: center;
}
.box4 ul{
  display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: space-between;
	-moz-justify-content: space-between;
	-ms-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	max-width: 1500px;
	width: 90%;
	margin: 50px auto 0 auto;
}
.box4 ul li{
	width: 24.1%;
	/*border: 2px solid #fff;*/
	/*background-color: #fff;*/
}
@media screen and (max-width: 767px) {
	.box4 ul{
		margin: 30px auto 0 auto;
	}
	.box4 ul li{
		width: 49%;
		margin-bottom: 2%;
	}
}
.box4 ul li a{
	display: block;
	color: #2f2f2f;
	font-size: 14px;
	padding: 5px 5px 10px 5px;
}
.squareimage{
	position: relative;
	width: 100%;
}
.squareimage::before{
	content: "";
	display: block;
	padding-top: 100%;
}
.squareimage span{
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
}
.works-cat{
	display: inline-block;
	width: 50%;
	max-width: 150px;
	background-color: #757b41;
	font-size: 12px;
	line-height: 24px;
	text-align: center;
	color: #fff;
	z-index: 4;
}
.works-date{
	display: inline-block;
	width: 50%;
	font-size: 12px;
	line-height: 24px;
	z-index: 4;
}
.works-listttl{
	font-size: 14px;
	line-height: 1.6;
	z-index: 4;
}

.nav-button2{
	background-color: #fff;
	width: 100%;
	padding: 80px 0;
}
.nav-button2 h2{
	text-align: center;
	margin-bottom: 50px
}
@media screen and (max-width: 767px) {
	.nav-button2{
		padding: 40px 0;
	}
	.nav-button2 h2{
		margin-bottom: 30px
	}
}
.nav-button2 ul{
  display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: space-between;
	-moz-justify-content: space-between;
	-ms-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: nowrap;
	-moz-flex-wrap: nowrap;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
	max-width: 1500px;
	width: 90%;
	margin: 0 auto;
}
.nav-button2 ul li:nth-child(1){
	background-image: url("../images2/nav-button2-1.jpg");
}
.nav-button2 ul li:nth-child(2){
	background-image: url("../images2/nav-button2-2.jpg");
}
.nav-button2 ul li:nth-child(3){
	background-image: url("../images2/nav-button2-3.jpg");
}
.nav-button2 ul li:nth-child(4){
	background-image: url("../images2/nav-button2-4.jpg");
}
.nav-button2 ul li:nth-child(5){
	background-image: url("../images2/nav-button2-5.jpg");
}
.nav-button2 ul li{
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	width: 34%;
}
.nav-button2 ul li a{
	position: relative;
	display: block;
	height: 400px;
	border-left: 1px solid #e1e1e1;
	font-size: 24px;
/*	font-family: "Yu Mincho Demibold", "YuMincho", "メイリオ", Meiryo, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	line-height: 1.4;
	color: #fff;
	z-index: 4;
}
.nav-button2 ul li:nth-child(1) a{
	border-left: none;
}
@media screen and (max-width: 1200px) {
	.nav-button1 ul li a{
		height: 320px;
	}
}
@media screen and (max-width: 767px) {
	.nav-button2 ul li a{
		height: 200px;
		font-size: 16px;
	}
}
.nav-button2 ul li a p{
	position: absolute;
	top: 10%;
	left: 50%;
	writing-mode: vertical-rl;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: vertical-rl;
	transform: translateX(-50%);
}
.nav-button2 ul li a p i{
	vertical-align: top;
	font-size: 80%;
}









/* -----------------------------------------
   CONTS
----------------------------------------- */


.contsbox1{
	width: 80%;
	max-width: 800px;
	margin: 80px auto;
}

.contsbox1 p{
	font-size: 18px;
	line-height: 1.8;
	padding-bottom: 5px;
}

.contsbox1 section{
	position: relative;
	padding-bottom: 40px;
	margin-bottom: 40px;
}

.contsbox1 section::after{
	position: absolute;
	content: "";
	bottom: 0;
	left: 0;
	width: 50%;
	height: 1px;
	background-color: #AAA;
}

.contsbox1 figure{
	margin-bottom: 30px;
}

@media screen and (max-width: 767px) {
	
	.contsbox1{
		width: 86%;
		margin: 40px auto;
	}
	
	.contsbox1 p{
		font-size: 16px;
		line-height: 1.8
	}
	
}








/* -----------------------------------------
   BLOG ...
----------------------------------------- */

.worksmain1{
	max-width: 2016px;
	margin:80px auto;
}

.workscat1{
	margin: 50px auto;
}
.workscat1 h2{
	text-align: center;
	margin-bottom: 30px;
}
.workscat1 ul {
	display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: center;
	-moz-justify-content: center;
	-ms-justify-content: center;
	justify-content: center;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}
.workscat1 ul li{
	border-left: 1px dotted #CCF;
}
.workscat1 ul li:nth-child(1){
	border-left: 0px;
}
.workscat1 ul li a{
	display: block;
	padding: 10px;
	font-size: 12px;
	line-height: 2.0;
}
@media screen and (max-width: 767px) {
	.workscat1 ul{
		display: -webkit-flex;
		display: -ms-flex;
		-webkit-display: flex;
		-ms-display: flex;
		-js-display: flex;
		display: flex;
		-webkit-justify-content: space-between;
		-moz-justify-content: space-between;
		-ms-justify-content: space-between;
		justify-content: space-between;
		-webkit-flex-wrap: wrap;
		-moz-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
		border-top: 1px dotted #CCF;
	}
	.workscat1 ul li{
		display: block;
		width: 33.333%;
		border-bottom: 1px dotted #CCF;
	}
	.workscat1 ul li a{
		display: block;
		padding: 10px 3px;
		font-size: 12px;
		line-height: 1.2;
	}
	.workscat1 ul li:nth-child(4){
		border-left: 0px;
	}
}


.worksbox1{
  display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-bottom: 50px;
}
.worksbox1 li{
	width: 20%;
	border-left: 1px solid #ccc;
	background-color: #f2f2f2;
}
.worksbox1 li a{
	display: block;
	padding-bottom: 40px;
}
.worksdate{
	font-size: 11px;
	margin: 15px 20px;
	color: #2f2f2f;
}
.workstitle{
	font-size: 16px;
	line-height: 1.3;
	margin: 15px 20px;
	color: #2f2f2f;
}
.workstext{
	font-size: 13px;
	color: #888;
	margin: 15px 20px;
}
@media screen and (max-width: 1600px) {
	.worksbox1 li{
		width: 25%;
	}
}
@media screen and (max-width: 1200px) {
	.worksbox1 li{
		width: 33.33333%;
	}
}
@media screen and (max-width: 800px) {
	.worksbox1 li{
		width: 50%;
	}
}
@media screen and (max-width: 480px) {
	.worksbox1{
		max-width: 480px;
		margin: 0 auto;
	}
	.worksbox1 li{
		width: 100%;
	}
}



.worksdetail1{
	max-width: 800px;
	width: 90%;
	margin: 80px auto;
}

@media screen and (max-width: 767px) {
	.worksdetail1{
		margin: 40px auto;
	}
}
.worksdetailtitle{
	position: relative;
	font-size: 28px;
	line-height: 1.4;
/*	font-family: "Yu Mincho Demibold", "YuMincho", "メイリオ", Meiryo, sans-serif;*/
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;
	margin-bottom: 10px;
	padding: 40px 20px;
	color: rgba(10,31,87,1.00);
	text-align: center;
}
.worksdetailtitle::before{
	position: absolute;
	content: "";
	left: 0;
	top: 0;
	width: 60%;
	height: 100%;
	border-left: 5px solid #ccc;
	border-top: 1px solid #ccc;
}
.worksdetailtitle::after{
	position: absolute;
	content: "";
	right: 0;
	bottom: 0;
	width: 60%;
	height: 100%;
	border-bottom: 1px solid #ccc;
	border-right: 5px solid #ccc;
}
@media screen and (max-width: 767px) {
	.worksdetailtitle{
		font-size: 20px;
	}
}
.worksdetaildate{
	font-size: 12px;
	padding-left: 30px;
	text-align: right;
}
.worksdetailbody{
	margin: 50px auto;
}
.worksdetailbody h2{
	font-size: 120%;
	background-color: rgba(38,38,38,1.00);
	padding: 5px 10px;
	color: #fff;
	margin: 0 0 10px 0;
}
.worksdetailbody h3{
	font-size: 110%;
	border-left: 5px solid rgba(38,38,38,1.00);
	padding-left: 10px;
	margin: 0 0 10px 0;
	font-weight: bold;
}
.worksdetailbody h4{
	font-size: 100%;
	border: 1px solid rgba(38,38,38,1.00);
	padding: 2px 5px;
	margin: 0 0 10px 0;
	font-weight: normal;
}
.worksdetailbody h5{
	font-size: 100%;
	border-bottom: 1px solid rgba(38,38,38,1.00);
	padding-bottom: 2px;
	margin: 0 0 10px 0;
	font-weight: normal;
}
.worksdetailbody img{
	margin-right: 5px;
	margin-bottom: 5px;
}
.worksdetailbody ul li{
	margin-left: 25px;
	list-style: disc;
}
.worksdetailbody ol li{
	margin-left: 40px;
	list-style: decimal;
}

@media screen and (max-width: 767px) {
	.worksdetailbody{
		margin: 30px auto;
	}
}
.worksdetailnav{
  display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-justify-content: space-between;
	-moz-justify-content: space-between;
	-ms-justify-content: space-between;
	justify-content: space-between;
	-webkit-flex-wrap: nowrap;
	-moz-flex-wrap: nowrap;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
}
.worksdetailnav div{
	width: 50%;
	border-top: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
}
.worksdetailnav div.right{
	text-align: right;
	border-left: 1px solid #ccc;
}
.worksdetailnav div a{
	display: block;
	font-size: 13px;
	color: #888;
	padding: 20px;
}



/* SDGs */


.sdgsbox1{ width: 80%; max-width: 1000px; margin: 80px auto; background: url("../images2/sdgs-back1.png") left top repeat; padding: 20px;}
.sdgsbox1inner{ background-color: #fff; padding: 5%;}

.sdgsbox1 h2{ margin-top: 20px;}
.sdgsbox1 h3{ font-size: 24px; line-height: 1.5;}
.sdgsbox1 h3.sdgsttl1{ font-weight: bold; padding: 5px; border-top: 1px solid #333; border-bottom: 1px solid #333; text-align: center;}
.sdgsbox1 p{ font-size: 18px; line-height: 1.8;}

.sdgsbox1 section{ position: relative;}

.sdgsbox2{ display: flex; justify-content: space-between; flex-wrap: wrap; flex-direction: row-reverse;}
.sdgsbox2 p{ font-size: 18px; line-height: 1.8; padding: 20px 0 5px 0;}
.sdgsbox2 h3{ width: 100%; margin: 30px 0 15px 0;}
.sdgsmark1{ width: 35%; display: flex; justify-content: flex-start; flex-wrap: wrap; align-items: flex-start; align-content: flex-start;}
.sdgsmark1 img{ display: block; margin: 0.5%; width: 32%;}
.sdgsbox2 ul{ width: 60%; margin: 0.5% 0; list-style: disc; margin-left: 20px;}
@media screen and (max-width: 767px) {
  .sdgsbox1{ width: 100%; margin: 80px auto; padding: 12px;}
  .sdgsbox1inner{ }
  .sdgsbox1 h3{ font-size: 18px;}
  .sdgsbox1 h3.sdgsttl1{ }
  .sdgsbox1 p{ font-size: 14px; line-height: 1.8; padding: 20px 0 5px 0;}

  .sdgsbox1 section{ position: relative; padding-bottom: 40px;}

  .sdgsbox2{ display: flex; justify-content: space-between; flex-wrap: wrap; flex-direction: row-reverse;}
  .sdgsbox2 p{ font-size: 14px; line-height: 1.8; padding: 20px 0 5px 0;}
  .sdgsbox2 h3{ width: 100%; margin: 30px 0 15px 0;}
  .sdgsmark1{ width: 100%; display: flex; justify-content: flex-start; flex-wrap: wrap; align-items: flex-start; align-content: flex-start; margin-bottom: 10px;}
  .sdgsmark1 img{ display: block; margin: 0.5%; width: 32%; max-width: 80px;}
  .sdgsbox2 ul{ width: 100%; margin: 0.5% 0; list-style: disc; margin-left: 20px; font-size: 14px; line-height: 1.6;}
}

.sdgsbox3{ display: flex; justify-content: space-between; flex-wrap: wrap; font-size: 12px; line-height: 1.2; margin-top: 50px;}
.sdgsbox3 .sdgsbox3img{ width: 30%; max-width: 240px; text-align: center;}
.sdgsbox3 .sdgsbox3text{ width: 67%;}
@media screen and (max-width: 767px){
  .sdgsbox3 .sdgsbox3img{ width: 100%;}
  .sdgsbox3 .sdgsbox3text{ width: 100%; margin-top: 15px;}
}


/* ============ MT Pagebute pagelist ============ */

.pagenate{
	position:relative;
	overflow:hidden;
}
.pagenate ul{
	position:relative;
  display: -webkit-flex;
	display: -ms-flex;
	-webkit-display: flex;
	-ms-display: flex;
	-js-display: flex;
	display: flex;
	-webkit-flex-wrap: nowrap;
	-moz-flex-wrap: nowrap;
	-ms-flex-wrap: nowrap;
	flex-wrap: nowrap;
  -webkit-justify-content: center;
  -moz-justify-content: center;
  -ms-justify-content: center;
  justify-content: center;
}
.pagenate li{
	list-style:none;
	font-size: 11px;
	font-family: Arial, Helvetica, "sans-serif";
	margin: 2px;
/*	border: 1px solid rgba(50,50,50,1.00);*/
}
.pagenate li a{
	display:block;
	padding:8px 12px;
  background-color: rgba(50,50,50,1.00); 
	text-decoration:none;
  color: #fff;
}
.pagenate li a:hover{
	background-color: rgba(50,50,50,0.5); 
}
.pagenate li span{
	display:block;
	padding:8px 12px;
	background-color: rgba(50,50,50,0.3);  
}








/* -----------------------------------------
   CONTACT
----------------------------------------- */


.contact-tel a{
	font-size: 42px;
	font-family: Arial, Helvetica, "sans-serif";
	font-weight: bold;
	color: #2f2f2f;
}


#formWrap {
	width:100%;
	color:#2f2f2f;
	line-height:1.8;
	font-size: 16px;
}
table.formTable{
	width:100%;
	margin:0 auto 30px auto;
	border-collapse:collapse;
}
table.formTable td,table.formTable th{
	border:1px solid #ccc;
	padding:10px;
	vertical-align: top;
}
table.formTable th{
	width:35%;
	font-weight:normal;
	background:#efefef;
	text-align:left;
}
input[type="text"], textarea {
	width:95%;
	display:block;
	padding: 10px;
}
input[type="submit"], input[type="reset"], input[type="button"] {
	height:40px;
	width: 200px;
	margin: 0 10px;
	border: none;
	color: #fff;
}
input[type="submit"] {
	background-color: rgba(0,120,122,1.00);
}
input[type="reset"] {
	background-color: rgba(98,98,98,1.00);
}
@media screen and (max-width:767px) {
	#formWrap {
		
	}
	table.formTable th, table.formTable td {
		width:100%;
		display:block;
	}
	table.formTable th {
		margin-top:5px;
		border-bottom:0;
	}
	input[type="text"], textarea {
		width:95%;
		display:block;
	}
	input[type="submit"], input[type="reset"], input[type="button"] {
		display:block;
		width:60%;
		height:40px;
		margin: 10px;
	}
}

