@charset "utf-8";

/*-----------------------------------------------------------------
　　　固定ページ共通
*-----------------------------------------------------------------*/
.home #wrapper, 
.page-template-page-business #wrapper, 
.page-template-page-company #wrapper, 
.page-template-page-greeting #wrapper {
  width: 100%!important;
  margin: 0;
  padding: 0 0 50px;
}
.page-template-page-business .breadcrumbs, 
.page-template-page-company .breadcrumbs, 
.page-template-page-greeting .breadcrumbs {
  display: none;
}
.page_h1 { /*1カラムページのh1*/
  width: 100%;
  margin: 40px 0 0;
  padding: 100px;
  font-weight: 500;
  clear: both;
  color: #fff;
}
.overview {
margin: 100px 0;
padding: 5% 20%;
}
/*-----------------------------------------------------------------
　　　トップページ
*-----------------------------------------------------------------*/
.toppag_top {
  margin: 0;
  padding: 350px 0;
  color: #fff;
  background: url("images/toppage05.jpg") top no-repeat;
  background-size: cover;
  background-attachment: fixed;
}
.toppag_top h1 {
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
  font-size: 100px;
  text-align: center;
  font-weight: bold;
  line-height: 3.5rem;
}
.toppag_top h1 span {
  display: block;
  margin: 1rem 0;
  font-size: 24px;
}
.toppage01 {
margin: 0;
padding: 150px 0;
color: #fff;
  background: url("images/toppage01.jpg") top no-repeat;
  background-size: cover;
  background-attachment: fixed;
}
.toppage01_1 {
	margin: 0 10%;
	padding: 10%;
	background-color:rgba(4,4,4,0.5);
}
.toppage_nav {
margin: 0;
padding: 150px 0;
  background: url("images/c001_main.jpg") top no-repeat;
  background-size: cover;
  background-attachment: fixed;
}
.toppage_nav ul {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-around;
  align-items: stretch;
}
.toppage_nav ul li {
  width: 23%;
  margin: 0;
  padding: 0;
  text-align: center;
}
.toppage_nav ul li img {
  width: 100%;
  height: 300px;
  object-fit: cover;
}
.toppage_nav ul li a {
  display: block;
  width: 75%;
  margin: 15px auto;
  padding: .5rem;
  font-size: 13px;
  color: #444;
  line-height: 1.2rem;
  background-color:rgba(255,255,255,0.9);
  border: 1px solid #000;
}
.toppage_nav ul li a span {
  font-size: 11px;
}
.toppage_nav ul li a:hover {
  color: #fff;
  background-color:rgba(4,4,4,0.5);
  border: 1px solid #fff;
  transition: .3s;
}
.dengonban {
  margin: 0;
  padding: 300px 0;
  color: #fff;
  background: url("images/toppage03.jpg") top no-repeat;
  background-size: cover;
  background-attachment: fixed;
}
.sintyaku {
  margin: 0;
  padding: 300px 0;
  color: #fff;
  background: url("images/toppage04.jpg") top no-repeat;
  background-size: cover;
  background-attachment: fixed;
}
.dengonban dl dt, .sintyaku dl dt {
  margin: 0 20%;
  padding: 0;
}
.dengonban dl dd, .sintyaku dl dd {
  margin: 0 20%;
  padding: 0;
}
.sintyaku_blog {
  display: block;
  margin: 50px 0 0;
  padding: .5rem;
  font-size: 13px;
  color: #444;
  text-align: center;
  line-height: 1.2rem;
  background-color:rgba(255,255,255,0.9);
  border: 1px solid #000;
}
.sintyaku_blog:hover {
  color: #fff;
  background-color:rgba(4,4,4,0.5);
  border: 1px solid #fff;
  transition: .3s;
}
/*--- プラグインwhatsnewk関係 ---*/
.whatsnew h2,
.whatsnew hr {
  display: none;
}
.whatsnew dl {
	width: 100%;
	margin: 0;
	padding: 0;
}
.whatsnew dl dt {
color: #fff!important;
}
.whatsnew a {
color: #fff;
}
.whatsnew a:hover {
  background-color: transparent!important;
  color: #c00;
}
.toppage_menu {
margin: 0 0 -50px;
padding: 300px 0;
color: #fff;
text-align: center;
  background: url("images/toppage02.jpg") top no-repeat;
  background-size: cover;
  background-attachment: fixed;
}
.toppage_menu h2 {
  text-align: center;
}
.toppage_menu ul {
  margin: 0 10%;
  padding: 0;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-around;
  align-items: stretch;
}
.toppage_menu ul li {
  width: 240px;
  margin: .5%;
  padding: 1.5%;
  background-color:rgba(4,4,4,0.8);
}
.toppage_menu ul li img {
  width: 100%;
height: 180px;
object-fit: cover;
}
/*--------------------------------------------------------------
　　　事業内容
*-----------------------------------------------------------------*/
.page-template-page-business .page_h1 {
  background: url("images/toppage05.jpg") center no-repeat;
}
.business01 {
  margin: 0 0 100px;
  padding: 0;
}
.business01 img {
  margin: 0;
  padding: 0;
  width: 75%;
  height: 700px;
  object-fit: cover;
  overflow: hidden;
}
.business01 h2 {
	margin: 0;
	padding: 0;
	font-family: 'Roboto', sans-serif;
	font-size: 20px;
	font-weight: 100;
}
.business01 h2 span {
	display: block;
	margin: 1.5rem 0 3rem;
	padding: 0;
	font-size: 30px;
}
.business01 dl {
	position: relative;
	width: 60%;
	margin: -5% 0 0 auto;
	padding: 5%;
	background-color: #fff;
	z-index: 100;
}
.business01 dl dt {
	margin: 0;
	padding: 0;	
}
.business01 dl dd {
	margin: 0;
	padding: 0;
}
.business02 {
margin: 0 0 200px;
padding: 0;
}
.business02 ul {
  margin: 0 10%;
  padding: 0;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-around;
  align-items: stretch;
}
.business02 ul li {
  width: 23%;
  margin: 0;
  padding: 0;
  text-align: center;
}
.business02 ul li img {
  width: 100%;
  height: 300px;
  object-fit: cover;
}
.business02 h3 {
margin: .5rem 0 0;
padding: 1rem;
font-size: 20px;
}
.business02 ul li h3 {
  display: inline-block;
  width: 150px;
  height: 50px;
  margin: 20px auto;
  font-size: 16px;
  color: #444;
  line-height: 50px;
  border: 1px solid #444;
}
.business02 ul li h3:hover {
  color: #fff;
  background-color:rgba(4,4,4,0.5);
  border: 1px solid #fff;
  transition: .3s;
}
/*-----------------------------------------------------------------
　　　会社概要
*-----------------------------------------------------------------*/
.page-template-page-company .page_h1 {
  background: url("images/toppage04.jpg") center no-repeat;
}
.company01 {
  width: 100%;
  max-width: 1080px;
  min-width: 250px;
  margin: 0 auto;
  padding: 0;
}
.company01 table {
  width: 100%;
  margin: 0 0 50px;
  padding: 0;
  border-collapse: collapse;
}
.company01 table tbody tr th {
  width: 20%;
  margin: 0;
  padding: 15px 5px;
  font-weight: normal;
  text-align: center;
  background-color: #f1f1f1;
  border: 1px solid #CCC;
}
.company01 table tbody tr td {
  width: 80%;
  margin: 0;
  padding: 15px 5px 15px 20px;
  border: 1px solid #CCC;
}
.map { /*地図をレスポンシブ化*/
  position: relative;
  width: 100%;
  padding-bottom: 75%;
  height: 0;
  overflow: hidden;
  margin-bottom: 50px;
}
.map iframe, .mapr object, .map embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/*-----------------------------------------------------------------
　　　代表者挨拶
*-----------------------------------------------------------------*/
.page-template-page-greeting .page_h1 {
  background: url("images/toppage01.jpg") center no-repeat;
}
.greeting_photo {
  width: 75vw;
  height: 75vh;
  margin: 0;
  padding: 0;
  overflow: hidden;
}
.greeting01 {
	width: 50%;
	margin: 100px 200px 100px auto;
	padding: 0;
}
.greeting02 {
  width: 100%;
  max-width: 1080px;
  margin: 0 auto 80px;
  padding: 0;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: stretch;
}
.greeting02L {
  width: 45%;
  margin: 0;
  padding: 0;
}
.greeting02L table {
  width: 100%;
  margin: 0;
  padding: 0;
  border-collapse: collapse;
}
.greeting02L table tbody tr th {
  width: 25%;
  margin: 0;
  padding: 5px 20px;
  font-weight: normal;
  text-align: center;
  background-color: #f1f1f1;
  border: 1px solid #CCC;
}
.greeting02L table tbody tr td {
  margin: 0;
  padding: 5px 20px;
  border: 1px solid #CCC;
}
.greeting02R {
  width: 45%;
  margin: 0;
  padding: 0;
}
.greeting02R ul {
  margin: 0 0 0 15px;
  padding: 0;
}
.greeting02R ul li {
  margin: 0;
  padding: 0;
  list-style: none;
}
