@import url('https://fonts.googleapis.com/css2?family=Sacramento&display=swap');
@charset "utf-8";

/*--------------------------------------
  リセット
--------------------------------------*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
margin: 0;
padding: 0;
border: 0;
font-style: normal;
font-weight: normal;
font-size: 100%;
}
img {vertical-align: top;border: 0;}
.clear {clear: both;}
article,aside,details,figcaption,figure,
footer,header,hgroup,menu,nav,section {display:block;}
p {margin-bottom: 24px;}
/*--------------------------------------
  table
--------------------------------------*/
table {border-collapse: collapse;border-top:1px solid #eee;border-right:1px solid #eee;margin-bottom: 50px;width: 100%;}
table th,
table td {padding: 20px;}
table th {background: #eee;border-bottom: 1px solid #fff;width:20%;font-weight: bold;}
table td {width:80%;border-bottom: 1px solid #f3f3f3;}
table.post_tb th {width:auto;}
table.post_tb td {width:auto;text-align: center;}
table.post_tb th.post_tb-c {border-left:1px solid #ccc;border-right:1px solid #ccc;}
table.post_tb td.post_tb-c {border-left:1px solid #ccc;border-right:1px solid #ccc;}
table.company-page th{width:40%;padding:40px 0px;}
/*--------------------------------------
  クリアフィックス
---------------------------------------*/
.clearfix:after {visibility: hidden;height: 0;display: block;font-size: 0;content: " ";clear: both;}
* html .clearfix {zoom: 1;}
*:first-child+html .clearfix {zoom: 1;}
/*--------------------------------------
  画像
--------------------------------------*/
img {max-width: 100%!important;height: auto;}
.alignright {float: right;margin: 0 0 24px 24px;}
.alignleft {float: left;margin: 0 24px 24px 0;}
.aligncenter {clear: both;display: block;margin: 0 auto;}
/*--------------------------------------
  リンク
--------------------------------------*/
a {color: #337ab7;text-decoration: none;}
a:hover {color: #f3f3f3;}
/*--------------------------------------
  全体構成
--------------------------------------*/
html {font-family: Meiryo, "メイリオ", verdana, sans-serif;font-size : 100%;line-height : 1.6;background: #fff;color: #333;}
body {margin: 0;padding: 0;font-family: "Helvetica Neue",Helvetica,Arial,sans-serif;font-size: 14px;line-height: 1.42857143;color: #333;background: #fff;}
/*--------------------------------------
  見出しベース
--------------------------------------*/
h1,h2,h3,h4,h5,h6 {margin-bottom: 24px;}
h1 {font-size: 25px;line-height : 1.5;color:}
h1#page-child_tit{border-bottom: solid 3px #ccc;position: relative;padding: 20px 0;}
h1#page-child_tit:after {position: absolute;content: " ";display: block;border-bottom: solid 3px #c8161d;bottom: -3px;width: 30%;}
h1#post_title{border-bottom: solid 3px #ccc;position: relative;padding: 20px 0;}
h1#post_title:after {position: absolute;content: " ";display: block;border-bottom: solid 3px #c8161d;bottom: -3px;width: 30%;}
h2 {color: #222;}
h2.top_subtit {overflow:hidden;font-size:35px;text-align:center;color:#222;margin:0;font-family: ＭＳ Ｐゴシック;}
h2.top-news_subtit {overflow:hidden;font-size:35px;text-align:center;color:#c8161d;margin:0;font-family: ＭＳ Ｐゴシック;}
h2.top-news_subtit span{color:#222;}
h2.top-news_subtit span:before {content: "";display: block;width: 30px;height: 2px;background: #222;margin: .35em auto 1.25em;}
h2.top_company_tit {font-size:35px;text-align:center;color:#222;margin:0;font-family: ＭＳ Ｐゴシック;margin: 0;}
h2.top_subtit span:before {content: "";display: block;width: 30px;height: 2px;background: #222;margin: .35em auto 1.25em;}
h2 span {display: block;font-size: 50%;letter-spacing: .1em;font-weight: 600;}
#p_article_body h2,#p_article_body01 h2,#article_body02 h2 {font-weight: normal;text-align: center;padding: 26px 0;border-top: 1px solid #eee;border-bottom: 1px solid #eee;font-size:26px;margin-bottom:35px;font-weight:600;}
h2.article-page_tit{text-align:center;}
#article_body02 h2.omoi_tit{border-bottom:1px solid #222;padding:15px 0px;border-top:none;text-align:left;font-size:1.5em;}
h3 {color: #222;font-size: 24px;}
h3.a_txt {font-size: 23px;padding-top: 20px;}
h3.t_form_tit {font-size:16px;padding-bottom: 20px; text-align:center;}
h3.tinrbx_subtit {font-size:17px;padding-bottom: 20px; text-align:center;font-weight: 600;}
h3.sdgs_subtit {border-bottom: 1px solid #222;padding: 15px 0px;border-top: none;text-align: left;font-size: 1.3em;font-weight:600;}
/*--------------------------------------
  ヘッダー
--------------------------------------*/
#header {width:100%;height: 70px;z-index:999;position: absolute;}
.hcontents {width: 100%;height: 70px;}
#header .hgroup {margin: 0 auto;height: 70px;}
.logo {width: 15%;float: left;height: 70px;margin: 0;}
.logo_inner {height: 70px;}
.logo img {height: 70px;}
.logo a{color:#000;line-height:70px;}


#fixed-header {
  position: fixed;
  top: -70px;  
  width: 100%;
  height: 70px;
  line-height: 70px;
  background:#fff;
  box-sizing: border-box;
  transition: .5s;
z-index:9999;
}
#fixed-header.is-show {
  top: 0;
}
/*--------------------------------------
  ナビゲーション
--------------------------------------*/
.nav-collapse {float: right;height: 70px;width: 85%;}
.nav-m {float: right;line-height: 70px;}
.nav-m ul li{display: inline-block;}
.nav_02 a{background:#c8161d;padding:0 30px;border:none;display: block;color: #fff;}
.nav-collapse_s {float: right;height: 70px;width: 45%;}
.nav-m_s {float: right;line-height: 70px;}
.nav-m_s a{color:#000;font-weight:bold;border-bottom: 1px #ddd solid;padding-bottom: 10px;font-size:1.3em;font-family: "ＭＳ Ｐゴシック";}
.nav-m_s a:hover{color:#fff;border-bottom: 1px #fff solid;}
.nav-m_s ul li{display: inline-block;margin-left: 28px;}
.nav_03 a{background:#c8161d;padding:0 30px;border:none;display: block;color: #fff;}



.globalnav_s .dropdown-btn,.globalnav_s .dropdown-btn a {position:relative;display:inline-block;cursor:pointer;padding: 0px 15px;color:#fff;font-weight:600;border-bottom: 1px #ddd solid;font-family: "ＭＳ Ｐゴシック";}
.globalnav_s .dropdown-btn a {border:none;}
.globalnav_s .dropdown-btn:hover {background-color: rgba(0, 0, 0, 0.70);}
.globalnav_s .dropdown {z-index:1000;background-color: rgba(0, 0, 0, 0.70);position:absolute;left:0;top:70px;width:220px;display:none;}
.globalnav_s .dropdown li {display:block;text-align:center;}
.globalnav_s .dropdown li:hover {background:#fff;}
.globalnav_s .dropdown li a {color:#fff;padding: 0 9px;}
.globalnav_s .dropdown li a:hover {color:#444}
.globalnav-wrap.open .globalnav_s {display:block;padding:40px 20px 0;position: fixed;left: 0;top: 0;background-color: rgba(0, 0, 0, 0.9);width: 100%;height: 100%;overflow-x: hidden;overflow-y: auto;}
.globalnav_s .open {display:block;}
.globalnav_s .close {display:block;}
.globalnav .dropdown-btn,.globalnav .dropdown-btn a{position:relative;display:inline-block;cursor:pointer;padding: 0px 15px;color:#333;font-weight: 600;}
.globalnav .dropdown-btn a:hover{color:#fff;}
.globalnav .dropdown-btn:hover {background-color: rgba(0, 0, 0, 0.70);}
 .globalnav .dropdown {z-index:1000;background-color: rgba(0, 0, 0, 0.70);position:absolute;left:0;top:70px;width:220px;display:none;}
.globalnav .dropdown li {display:block;text-align:center;}
.globalnav .dropdown li:hover {background:#fff;}
.globalnav .dropdown li a {color:#fff;padding: 0 9px;}
.globalnav .dropdown li a:hover {color:#444;}
.globalnav-wrap .open .globalnav {display:block;padding:40px 20px 0;position: fixed;left: 0;top: 0;background-color: rgba(0, 0, 0, 0.9);width: 100%;height: 100%;overflow-x: hidden;overflow-y: auto;}
.globalnav .open {display:block;}
.globalnav .close {display:block;}
.nav-manu {float: right;line-height: 70px;}
.nav-manu a{color:#fff;font-weight:bold;font-family: "ＭＳ Ｐゴシック";}
.nav-manu a:hover{color:#fff;border-bottom: 1px #fff solid;}
.nav-manu ul li{display: inline-block;}
/*--------------------------------------
  コンテンツ
--------------------------------------*/
#contents {overflow: hidden;width: 1150px;margin: 0 auto;position: relative;}
#page-contents {background:#fff;}
.inner {width:1150px;margin: 0 auto;padding:50px 0px;overflow: hidden;}
.inner_s {width: 1000px;margin: 0 auto;padding:50px 0px;overflow: hidden;}
.inner_t {width: 1150px;margin: 0 auto;padding:10px 0px;overflow: hidden;}
#page_body {margin: 30px 0px;}
#p_article_body,#p_article_body02  {padding: 20px 0px;}
#p_article_body p{line-height:2.4;font-size:16px;text-align: center;}
#p_article_body01 p{line-height:2.4;font-size:16px;margin: 0 0 2em 0;}
.post_body {margin: 50px 0px;}
#post-l{float:left;width:70%;}
#post-r{float:left;width:28%;margin-left:2%;}
#article_body{padding: 60px 0;}
#article_body02{padding: 20px 0;}
#article_body02 p{font-size:1.2em;line-height: 2.4;margin: 0 0 2em 0;}
#article_body02 img{margin-bottom:15px;}
.clearfix {display:block;}
/*--------------------------------------
  slide
--------------------------------------*/
#top-slider{width: 100%;height: 100vh;}
/*@import url('https://fonts.googleapis.com/css2?family=Sacramento&display=swap');*/
#top-slider h2{position: absolute;z-index: 2;top: 40%;left: 50%;transform: translate(-50%, -50%);text-align: center;font-size:3vw;letter-spacing: 0.1em;text-transform: uppercase;color: #fff;font-family: 'Sacramento', cursive;font-family: "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;font-weight:600;}
#top-slider p{position: absolute;z-index: 2;top: 60%;left: 50%;transform: translate(-50%, -50%);text-align: center;font-size:2vw;letter-spacing: 0.1em;text-transform: uppercase;color: #fff;font-family: 'Sacramento', cursive;font-weight:600;}
/*--------------------------------------
  トップページ
--------------------------------------*/
.t-subtit_img {text-align:center;}
.top-con_box{}
.top-con {height:700px;background-size: cover;background-repeat: no-repeat;background-position:center center;position: absolute;animation:bgAnime 36s infinite;z-index:0;width: 100%;}
@-webkit-keyframes zoomUp {
  0% {-webkit-transform: scale(1);transform: scale(1);}
  100% {-webkit-transform: scale(1.15);transform: scale(1.15);}
}
@keyframes zoomUp { /* 1.15倍させる指定 */
  0% {-webkit-transform: scale(1);transform: scale(1);}
  100% {-webkit-transform: scale(1.15);transform: scale(1.15);}
}


.top-inbx {width: 100%;height: 700px;position: absolute;display: -webkit-box;-webkit-box-pack: center;-webkit-box-align: center;background:rgba(27,63,93,0.2) ;}
.t-inbx_in{animation:none;}
p.t-inbx_subcon {margin:0;color:#fff;font-weight:500;text-align:center;font-size:25px;}



#service {background:#f6f5f2;padding-bottom: 55px;}
.company_inner {width:100%;margin: 0 auto;overflow: hidden;padding: 30px 0px;}
.top_contents01{text-align:center;position:relative;z-index:1;max-width:1024px;margin:0 auto;padding:75px 0 20px 0;}
.cpy_intoro{margin-top:55px;}
.intoro01{font-size:20px;font-weight:600;}
.cpy_intoro p{text-align:center;}
.top_sv-box {
	display: flex;
	justify-content:center;
	justify-content:space-around;
margin-bottom:55px;
background-color: rgba(0, 0, 0, 0.26);
}
.top_sv-item {
    color:  #fff;
}
.top_sv-item:nth-child(1) {
}
.top_sv-item:nth-child(2) {
}
.top_sv-item:nth-child(3) {
}
.top_s_main_tit {font-size:2em;font-weight:600;display:block;z-index:3;text-align:center;}
.top_s_subtit{font-weight:600;display:block;margin-bottom:20px;text-align:center;}
.top_s_contxt {display:block;font-size:1.2em;}

.chenge_image {
background-image:url(/images/top-service1.jpg);
background-repeat: no-repeat;
background-size: 100%;
background-position: center top;
}
.top_sv-item1 {
    color:  #fff;
}
.top_sv-item2 {
    color:  #fff;
}
.top_sv-item3 {
    color:  #fff;
}
.top_sv-item1:nth-child(1) {
border-right:solid 1px #fff;
}
.top_sv-item2:nth-child(2) {
border-right:solid 1px #fff;
}
.top_sv-item3:nth-child(3) {
}




.news_inner {max-width: 1024px;margin: 0 auto;padding: 75px 0 20px 0;}
.news_box {}
.news_list {border-bottom:1px #ddd solid;padding:15px 0;display: flex;flex-wrap: wrap;align-items: center;}
.top-cat{background: #222;padding: 5px 22px;min-width: 90px;text-align:center;}
.top-cat a {color:#fff;}
.news_tit {color:#000;font-size: 1rem;font-weight: 600;line-height: 1.75;margin-bottom: 12px;padding-left:20px;}
.news_list .top-date {display: inline-block;margin-left: 15px;font-family: Oswald;}
.fade {transition: opacity 0.7s;-moz-transition: opacity 0.7s;-webkit-transition: opacity 0.7s;-o-transition: opacity 0.7s;transition: transform 0.7s;-moz-transition: transform 0.7s;-webkit-transition: transform 0.7s;-o-transition: transform 0.7s;}
.t_tit_box {padding:40px 0px;background: linear-gradient(to left, #0077ED, #3399FF);}
.t_tit_s_box {padding:40px 0px;}
.t-subs_tit {color:#732200;}
.t-subs_tit p {color:#c8161d;font-size: 1.4em;text-align:center;margin:0;}
.t-subs_tit_s {color:#fff;font-size: 0.8em;}
.txt_box{padding: 20px 15px;color: #222;font-size: 1.2em;}
.txt_box p{font-size:15px;}
.txt_subtit {overflow:hidden;padding: 30px 0px;}
.aicon_l {float:left;width:10%;}
.aicon_l img {width:70px;}
.aicon_r {float:left;width:90%;}

.t-inrbx img{width: 100%;}
.gmap {height: 0;overflow: hidden;padding-bottom: 56.25%;position: relative;margin-bottom:30px;}
.gmap iframe {position: absolute;left: 0;top: 0;height: 100%;width: 100%;}
.map_bx_r {float:left;width:30%;align-items: center;justify-content: center;display: flex;padding: 0px 5%;}


#company-profile {padding:55px 0px;}
#company-profile_titbox{
width:100%;
height:500px;
background-image:url(/images/top-company-bkimg999.jpg);
background-repeat:no-repeat;
background-size: cover;
background-color: rgba(0, 0, 0, 0.26);
}
#company-tit{
display: flex;
height:500px;
justify-content: center;
align-items: center;
margin: 0;
width: 100%;
background-color: rgba(0, 0, 0, 0.20);
}
.top_company_tit {
  display: flex;
  overflow: hidden;
  color: #aa8f7b;
  font-family: 'Josefin Sans', sans-serif;
}

.top_company_tit span {
  display: block;
  transform: translate(0, 105%);
  transition: transform cubic-bezier(0.215, 0.61, 0.355, 1) 0.5s;
color:#fff;
font-size:1.2em;
}

.top_company_tit.-visible span {
  transform: translate(0, 0);
}
.top_company_tit span:nth-child(2) {
  transition-delay: 0.06s;
}
.top_company_tit span:nth-child(3) {
  transition-delay: 0.12s;
}
.top_company_tit span:nth-child(4) {
  transition-delay: 0.18s;
}
.top_company_tit span:nth-child(5) {
  transition-delay: 0.24s;
}
.top_company_titspan:nth-child(6) {
  transition-delay: 0.30s;
}
.top_company_tit span:nth-child(7) {
  transition-delay: 0.36s;
}
.top_company_tit span:nth-child(8) {
  transition-delay: 0.42s;
}
.top_company_tit span:nth-child(9) {
  transition-delay: 0.48s;
}
.top_company_tit span:nth-child(10) {
  transition-delay: 0.54s;
}
.top_company_tit span:nth-child(11) {
  transition-delay: 0.6s;
}
.top_company_tit span:nth-child(12) {
  transition-delay: 0.66s;
}
.top_company_tit span:nth-child(13) {
  transition-delay: 0.72s;
}
.top_company_tit span:nth-child(14) {
  transition-delay: 0.78s;
}
.top_company_tit span:nth-child(14) {
  transition-delay: 0.84s;
}
.tab_con_box{display:flex;margin-bottom:45px;}
.tab_con_box h2{font-size:1.3em;text-align:center;}
.tab_con_l{width:48%;position: relative;margin-right:2%;}
.tab_con_l img{margin-top:50px;}
.tab_con_r{width:50%;}
.tab_con_r h2{font-size: 1.3em;font-weight:600;}


#form {background:#fdf8f0;padding:40px 0;}
.form_bx {overflow:hidden;display: flex;margin-top:40px;}
.form_bx_l{float:left;width:45%;margin-right:5%;}
.form_inner_l {border: 2px solid #222;padding: 15px;margin: 0 auto;width:300px;}
.form_bx_r{float:left;width:50%;}
.form_inner_l p{text-align:center;font-size:1.5em;margin:0;}
.form_inner_l a{color:#222;}
p.f_in_con {text-align:center;font-size: 1em;}
/*--------------------------------------
  リンク
--------------------------------------*/
.t_more_t {padding: 30px 0px;text-align: center;}
.t_more_t a{font-size: 1em;color: #fff;padding:10px 100px;border: 2px solid #fff;font-weight:600;}
.t_more_t a:hover {background: #f4f4f4;}


.t_more_f {padding: 20px 0px;
cursor: pointer;
transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
max-width: 330px;
display:block;
text-align: center;margin: 0 auto;font-weight: bold;
}
.t_more_f a{font-size: 1.1em;color: #fff;padding: 20px 100px;}
.t_more_f.circle {
  color: #ff701e;
  overflow: hidden;
  position: relative;
  transition-duration: .4s;
  z-index: 2;
	background: #c8161d;
}
.t_more_f.circle::after {
  background: #444;
  border-radius: 50%;
  content: "";
  display: block;
  margin: auto;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  width: 100%;
  padding-top: 100%;
  height: 0;
  z-index: -1;
  transform: translateY(-50%) scale(0.1);
  transition: opacity .5s, transform 0s;
  transition-delay: 0s, .4s;
}
 
.t_more_f.circle:hover {
  color: #fff;
}
.t_more_f.circle:hover::after {
  opacity: 1;
  transform: translateY(-50%) scale(1.1);
  transition-delay: 0s;
  transition: opacity .8s, transform .6s ease-in-out;
}
.t_more_news {padding: 20px 0px;cursor: pointer;transition: .2s cubic-bezier(0.45, 0, 0.55, 1);max-width: 330px;display:block;text-align: center;margin: 0 auto;font-weight: bold;border: 2px solid #444;}
.t_more_news a{font-size: 1.2em;padding: 20px 100px;}
.t_more_news.circle {overflow: hidden;position: relative;transition-duration: .4s;z-index: 2;background: #fff;}
.t_more_news.circle a{color: #444;}
.t_more_news.circle::after {background: #444;border-radius: 50%;content: "";display: block;margin: auto;opacity: 0;pointer-events: none;position: absolute;top: 50%;left: 0;right: 0;width: 100%;padding-top: 100%;height: 0;z-index: -1;transform: translateY(-50%) scale(0.1);transition: opacity .5s, transform 0s;transition-delay: 0s, .4s;}
.t_more_news.circle a:hover {color: #fff;}
.t_more_news.circle:hover::after {opacity: 1;transform: translateY(-50%) scale(1.1);transition-delay: 0s;transition: opacity .8s, transform .6s ease-in-out;}
/*--------------------------------------
  フッター
--------------------------------------*/
.footer-center {padding:40px 0px;}
.footer-nav {text-align: center;}
.footer-center ul li {display: inline-block;}
.footer-center ul li a{display: block;line-height: 30px;padding: 0 30px;color:#222;}
.f_inner {width: 1200px;margin: 0 auto;padding:10px 0px;overflow: hidden;}
#footer-bottom {}
p.copyright {text-align: center;margin: 0px;color: #222;padding: 10px 0px;}
/*--------------------------------------
  post
--------------------------------------*/
.post-hbx {height: 600px;width: 100%;display: inline-block;background-size: cover;background-repeat: no-repeat;background-position:center center;background-image: url(/images/archive-topimg01.jpg);}
.post_hbx_in {height: 600px;display: -webkit-box;-webkit-box-pack: center;-webkit-box-align: center;background-color: rgba(0, 0, 0, 0.10);}
#container h1#post_title {font-size: 34px;margin: 0px 0px 20px 0px;color: #222;font-weight: bold;}
.post-cat-tit {font-size: 28px;margin: 0px;font-weight: bold;color:#fff;font-family: "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;}
.post-cat-tit a{color:#fff;}
.post-hbx01 {height: 600px;width: 100%;display: inline-block;background-size: cover;background-repeat: no-repeat;background-position:center center;background-image: url(/images/post-topimg.jpg);}
.post_hbx01_in {height: 600px;display: -webkit-box;-webkit-box-pack: center;-webkit-box-align: center;}
.post-hbx_contact {height: 600px;width: 100%;display: inline-block;background-size: cover;background-repeat: no-repeat;background-position:center center;background-image: url(/images/post-topimg-contact.jpg);}
.post-hbx_products {height: 600px;width: 100%;display: inline-block;background-size: cover;background-repeat: no-repeat;background-position:center center;background-image: url(/images/products-topimg.jpg);}
.post-hbx_omoi {height: 600px;width: 100%;display: inline-block;background-size: cover;background-repeat: no-repeat;background-position:center center;background-image: url(/images/omoi-top-img05.jpg);}
.post-hbx_businesscontent{height: 600px;width: 100%;display: inline-block;background-size: cover;background-repeat: no-repeat;background-position:center center;background-image: url(/images/page-businesscontent-topimg.jpg);}
.post-hbx_company{height: 600px;width: 100%;display: inline-block;background-size: cover;background-repeat: no-repeat;background-position:center center;background-image: url(/images/page-company-topimg.jpg);}
.post-hbx_access{height: 600px;width: 100%;display: inline-block;background-size: cover;background-repeat: no-repeat;background-position:center center;background-image: url(/images/page-access-topimg.jpg);}
.new-post{margin-bottom:40px;}
.new-post_area{display:flex;justify-content:center;flex-wrap: wrap;}
h2.new-post_tit {display:flex;align-items:center;}
h2.new-post_tit span{font-size:1.5rem;padding-right:12px;letter-spacing:.02em;}
.new-post_list{width:24%;padding:3% 0.5%;align-self: stretch;}
.new-post_list a{display:block;}
.thumb_box{overflow: hidden;}
.thumb_box img{width:100%;height: 150px;display: block;transition: 0.5s;}
.thumb_box img:hover {transform: scale(1.2, 1.2);}
.entry_box{color:#222;}
.entry_box p{margin:0;}
.p_entry_tit{font-weight:600;}
/*--------------------------------------
  page
--------------------------------------*/
#contents #page_title {font-size: 34px;margin: 0px;text-align: center;color: #fff;font-weight: bold;}
.page-hbx {height: 600px;width: 100%;display: inline-block;background-size: cover;background-repeat: no-repeat;background-position:center center;background-image: url(/images/archive-topimg01.jpg);}
.p_hbx_tit {color: #fff;font-size: 3em;text-align: center;font-weight: 700;}
.page_hbx_in {height: 600px;display: -webkit-box;-webkit-box-pack: center;-webkit-box-align: center;background:rgba(27,63,93,0.2) ;}
.page-hbx h1 {color: #fff;font-weight: 700;text-align:center;margin-bottom:5px;font-size: 27px;font-family: "Times New Roman" , "游明朝" , "Yu Mincho" , "游明朝体" , "YuMincho" , "ヒラギノ明朝 Pro W3" , "Hiragino Mincho Pro" , "HiraMinProN-W3" , "HGS明朝E" , "ＭＳ Ｐ明朝" , "MS PMincho" , serif;}
.page_hbx_tit p {color:#fff;font-weight:700;font-size:20px;}
#page-subtit{position: relative;width:200px;height:200px;margin: 0 auto;z-index: 1000;top: -100px;background-color: rgba(0, 0, 0, 0.80);}
h2#page_tit_sub{width: 100%;
    text-align: center;
    position: absolute;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);color: #fff;
    font-size: 2em;margin:0;
}
.about_list{display:flex;align-items:stretch;justify-content:center;flex-wrap: wrap; }
.p-list_l{position:relative;width:50%;height: 250px;margin-bottom:0.5%;}
.p-list_l a{display:block;width: 100%;height: 100%;}
.p-list_l:nth-child(1) {
width:49.5%;
margin-right:0.5%;
}
.p-list_l:nth-child(1) .list_img:after {
background: url(/images/unnamed-4.jpg) no-repeat center center;
}
.p-list_l:nth-child(2) .list_img:after {background: url(/images/rinen.jpg) no-repeat center center;}
.p-list_l:nth-child(3) {width:49.5%;margin-right:0.5%;}
.p-list_l:nth-child(3) .list_img:after {
background: url(/images/kankyo.jpeg) no-repeat center center;}
.p-list_l:nth-child(4) .list_img:after {
background: url(/images/company-gaiyo.jpg) no-repeat center center;}
.p-list_l:nth-child(5) {width:49.5%;margin-right:0.5%;}
.p-list_l:nth-child(5) .list_img:after {background: url(/images/teikei.jpeg) no-repeat center center;}
.p-list_l:nth-child(6) .list_img:after {
background: url(/images/access.jpg) no-repeat center center;
}
h3.p-list_tit{
font-size: 20px;
    font-weight: 600;
    line-height: 1.5;
    color: #fff;
    padding: 0 60px;
    position: absolute;
    z-index: 3;
    left: 0;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    -webkit-transition: all 0.35s ease;
    transition: all 0.35s ease;
}
.list_img {
position: relative;
overflow: hidden;
max-width: 	100%;
height: 250px
}
.list_img:after {
position: absolute;
content: "";
display: block;
width: 100%;
height: 100%;
top: 0;
-webkit-background-size: cover;
-moz-background-size: cover;
-ms-background-size: cover;
background-size: cover;
-webkit-transition: all .3s ease-out;
-moz-transition: all .3s ease-out;
-ms-transition: all .3s ease-out;
transition: all .3s ease-out;
}
.list_img:hover:after {
opacity: .8;
-moz-transform: scale(1.1);
-webkit-transform: scale(1.1);
-ms-transform: scale(1.1);
transform: scale(1.1);
}
.list_img a {
position: relative;
display: flex;
align-items: center;
justify-content: center;
z-index: 1;
height: 100%;
text-decoration: none;
color: #fff
}
.service_con{position: relative;height:500px;overflow: hidden;}
.service_con {
background: url(/images/top-service1.jpg) no-repeat center center;
background-size: cover;
}
.service_con:nth-child(2) {
background: url(/images/top-service2.jpg) no-repeat center center;
background-size: cover;
}
.service_con:nth-child(3) {
background: url(/images/top-service3.jpg) no-repeat center center;
background-size: cover;
}
.service_item{height: 100%;
width: 50%;
position: absolute;
right: 0px;
top: 0px;
z-index: 2;
background: rgba(0,0,0,0.5);}
.service_item_inner{padding: 70px 70px 70px;
position: absolute;
top: 50%;
-ms-transform: translateY(-50%);
-webkit-transform: translateY(-50%);
transform: translateY(-50%);
 -webkit-box-sizing: border-box;
box-sizing: border-box;
left:24.5px;
}
#service_page .service_con:nth-child(even) .service_item {
    right: auto;
    left: 0px;
}
#p_article_body01 .service_item h2{border:none;color:#fff;font-weight:600;}
.lead{color:#fff;}
.page-child_tit{border-bottom:;}
.page-company_list{display:flex;justify-content: space-between;text-align: center;flex-wrap: wrap;}
.page-company_list .item{width: 49%;}
.page-company_list .item:nth-child(2){margin-left:2%;}
.page-company_list .item:nth-child(4){margin-left:2%;}
#article_body02 h2.access_tit {border-bottom: 1px solid #222;padding: 15px 0px;border-top: none;text-align: left;font-size: 1.5em;}



#f_item{background: #edf3fc;padding-bottom: 40px;}
.serviceLink {width: 100%;overflow: hidden;position: relative;display: block;background: #fff;}
.leftPhoto {width: 50%;float: right;transform: skewX(-10deg);z-index: 2;position: relative;display: table;}
.serviceLink .leftPhoto:before {content: "";display: block;width: 0;height: 400px;background: rgba(0,149,218,0.1);z-index: 3;position: absolute;top: 0;left: 0;transition: all 0.3s ease-in-out 0s;}
.serviceBox {height: 400px;width: 100%;padding: 0px 50px;display: table-cell;vertical-align: middle;background: #fff;}
#s1:after {background: url(images/s1.jpeg) center center no-repeat #f9f8f4;-webkit-background-size: cover;background-size: cover;content: "";width: 53%;height: 400px;position: absolute;top: 0;left: 0;z-index: 1;}
#s3:after {background: url(images/s2.jpeg) center center no-repeat #f9f8f4;-webkit-background-size: cover;background-size: cover;content: "";width: 53%;height: 400px;position: absolute;top: 0;left: 0;z-index: 1;}
.leftPhoto h3 {transform: skewX(10deg);}
.leftPhoto .servicetxt {transform: skewX(10deg);padding-left: 0.8em;}
.rightPhoto {width: 50%;float: left;transform: skewX(10deg);z-index: 2;position: relative;display: table;}
.serviceLink .rightPhoto:before {content: "";display: block;width: 0;height: 400px;background: rgba(0,149,218,0.1);z-index: 3;position: absolute;top: 0;right: 0;transition: all 0.3s ease-in-out 0s;}
#s2:after {background: url(/images/ss222.jpeg) center center no-repeat #f9f8f4;-webkit-background-size: cover;background-size: cover;content: "";width: 53%;height: 400px;position: absolute;top: 0;right: 0;z-index: 1;}
#s4:after {background: url(/images/ss4.jpg) center center no-repeat #f9f8f4;-webkit-background-size: cover;background-size: cover;content: "";width: 53%;height: 400px;position: absolute;top: 0;right: 0;z-index: 1;}
.rightPhoto h3 {transform: skewX(-10deg);padding-left: 0.4em;}
.rightPhoto .servicetxt {transform: skewX(-10deg);}
/*--------------------------------------
  article
--------------------------------------*/
#articlepage_body{}
.article_box{}
.article_area{display:flex;justify-content: center;padding: 60px;border-bottom:1px solid #ccc;}
.article__item {width: 49%;padding: 0.5%;}
.article__item img{width:100%;height:250px;display: block;transition: 0.5s;}
.article__item img:hover {transform: scale(1.1, 1.1);}

.article__item_s {width: 45%;position: relative;padding-left: 5%;}
.date {float: left;width: 50%;}
.article_cat{float: left;width: 50%;text-align: right;}
.article_list{margin-bottom:20px;position: absolute;
    top: 50%;
    -ms-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);}
.article_list ul{margin-bottom: 30px;}
.article_list li{list-style:none;display: inline-block;}
.card_category{font-size: 12px;
    text-align: center;
    color: #fff;
    border-radius: 30px;
    min-width: 90px;
    height: 30px;
    line-height: 30px;
    padding: 0 20px;
    display: inline-block;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;background:#ccc;margin-right: 16px;}
.card__time{color:#ccc;}
h2.article_list_title{font-weight: 600;
    line-height: 1.6;
    max-height: 3.2em;
    overflow: hidden;
    visibility: visible;
    word-wrap: break-word;
    word-break: break-all;font-size:1.2em;}
p.card__excerpt{    line-height: 2;
    margin: 20px 0 0 0;
    max-height: 4em;
    overflow: hidden;
    visibility: visible;
    word-wrap: break-word;
    word-break: break-all;color:#222;}
/*--------------------------------------
  TOPへ戻る
--------------------------------------*/
#page-top {position: fixed;bottom: 40px;right: 20px;}
#page-top i {margin: 0;}
#page-top a {text-decoration: none;color: #fff;padding: 15px;display: block;font-size: 18px;background: #444 left top repeat;}
#page-top a:hover {text-decoration: none;background: #aaa;color: #fff;}
/*--------------------------------------
  contact-form
--------------------------------------*/
.wp-cf7-button {clear:both;padding-top: 20px;text-align: center;}
span.wp-cf7-icon {color: #e04949;border-radius: 3px;padding: 2px 4px;}
.wp-cf7-textbox-design {border:none;background:#fff;font-size: 20px;padding:5px;}
input[type="text"],
input[type="email"],
input[type="tel"],
input[type="select"],
textarea {width:100%;padding: 10px 0px;}
span.contact_haveto {color:red;}
span.contact_any {color:;}
table.contact_form th{width:40%;}
#formbtn{display: block; padding:1em 0;width:300px;background:#222;color:#fff;font-size:18px;font-weight:bold;	 border-radius:2px;border: none;margin: 0 auto;}
#formbtn:hover{background:#f4f4f4;color:#222;}
#approval {text-align: center;}
/*--------------------------------------
effect
--------------------------------------*/
.ef_top_item{
  position:relative;/*テキストの基点となる位置を定義*/
}
.ef_top_item span.out_mask,.ef_top_item2 span.out_mask,.ef_top_item3 span.out_mask{
  position:absolute;
display:block;
    transition: .5s ease-in-out;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    color: #fff;
    line-height: 1.5;
z-index:0;
}

.ef_top_item span.mask{
  position:relative;/*背景色の基点となる位置を定義*/
    display: block;
    line-height: 0;/*行の高さを0にする*/
    overflow: hidden;/*拡大してはみ出る要素を隠す*/
height: 500px;
}

.ef_top_item span.mask::before{
  content:"";
  position: absolute;
  z-index: 2;
  left:0;
  top:0;
  transition: .5s ease-in-out;/*移り変わる速さを変更したい場合はこの数値を変更*/
    transform: translateY(100%);
  background-color: rgba(0, 0, 0, 0.70);
  width:100%;
  height: 100%; 
}

.ef_top_item:hover span.mask::before{/*hoverした時の変化*/
  opacity:1;/*透過なしに変化*/
  transform: translateY(0);
}

.ef_top_item span.cap{/*画像の上のテキスト*/
  position: absolute;
  opacity:0;/*透過0*/
  transition: .5s ease-in-out;/*移り変わる速さを変更したい場合はこの数値を変更*/
  z-index:3;/*テキストを前面に出す*/
  top: 50%;
    left: 50%;
  transform: translate(-50%,-50%);/*テキストの位置中央指定*/
  color: #fff;/*テキストの色を変えたい場合はここを修正*/
    line-height: 1.5;/*行の高さを1.5にする*/
}

.ef_top_item:hover span.cap{/*hoverした時の変化*/
  opacity:1;/*透過なしに変化*/
}


.ef_top_item2{
  position:relative;/*テキストの基点となる位置を定義*/
}

.ef_top_item2 span.mask{
  position:relative;/*背景色の基点となる位置を定義*/
    display: block;
    line-height: 0;/*行の高さを0にする*/
    overflow: hidden;/*拡大してはみ出る要素を隠す*/
height: 500px;
}

.ef_top_item2 span.mask::before{
  content:"";
  position: absolute;
  z-index: 2;
  left:0;
  top:0;
  opacity:0;
  transition: .5s ease-in-out;/*移り変わる速さを変更したい場合はこの数値を変更*/
transform: translateY(-100%);
background-color: rgba(0, 0, 0, 0.70);
width:100%;
  height: 100%; 
}

.ef_top_item2:hover span.mask::before{/*hoverした時の変化*/
  opacity:1;
  transform: translateY(0);
}

.ef_top_item2 span.cap{
  position: absolute;
  opacity:0;
  transition: .5s ease-in-out;/*移り変わる速さを変更したい場合はこの数値を変更*/
  z-index:3;/*テキストを前面に出す*/
  top: 50%;
    left: 50%;
  transform: translate(-50%,-50%);
  color: #fff;/*テキストの色を変えたい場合はここを修正*/
    line-height: 1.5;/*行の高さを1.5にする*/
}

.ef_top_item2:hover span.cap{/*hoverした時の変化*/
  opacity:1;
}


.material-icons {
font-family: 'Material Icons';
font-weight: normal;
font-style: normal;
font-size: 24px;  /* 推奨サイズ */
width: 1em;
height: 1em;
text-transform: none;
margin-right: 10px;
display: inline-flex;
vertical-align: middle;
  /* WebKitブラウザサポート */
  -webkit-font-smoothing: antialiased;
  /* Chrome、Safariサポート */
  text-rendering: optimizeLegibility;
  /* Firefoxサポート */
  -moz-osx-font-smoothing: grayscale;
  /* IEサポート */
  font-feature-settings: 'liga';
}
/*--------------------------------------
 tab
--------------------------------------*/
.tab{
display: flex;
flex-wrap: wrap;
top: -70px;
position: relative;
justify-content: center;
align-items: center;
}
.tab li a{
  display: block;
cursor: pointer;
    font-size: 16px;
    height: 70px;
    line-height: 70px;
    min-width: 200px;
    color: #fff;
    background: rgba(255,255,255,0.3);
    text-align: center;
    margin: 0 7px;
    padding: 0 20px;
    border-radius: 10px 10px 0 0;
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: all 0.2s ease;
    transition: all 0.2s ease;
}
.tab li.active a{
  background:#fff;
color:#222;
}
.area {
  display: none;/*はじめは非表示*/
  opacity: 0;/*透過0*/
  background: #fff;
  padding:50px 20px;
}
.area.is-active {
    display: block;/*表示*/
    animation-name: displayAnime;/*ふわっと表示させるためのアニメーション*/
    animation-duration: 2s;
    animation-fill-mode: forwards;
}
.tab_box{
  width:100%;
  max-width: 960px;
  margin:0 auto;
background:#fefefe;
position: relative;
}
.tab_box ul{list-style:none;}
.area h2{
  font-size:1.3rem;
  margin:0 0 20px 10px;
}
.area li{
  padding: 10px; 
  border-bottom: 1px solid #ddd;
}
@keyframes displayAnime{
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
/*--------------------------------------
  pankuzu
--------------------------------------*/
.pankuzu {padding:10px 0px;}
.pankuzu li {display:inline-block;list-style:none;padding:0 5px;}
.pankuzu li a{color:#222;}
.pankuzu_page {padding:10px 60px;}
.pankuzu_page li {display:inline-block;list-style:none;padding:0 5px;color:#222;}
.pankuzu_page li a{color:#222;}
.pankuzu_inner{width: 1150px;margin: 0 auto;}
/*--------------------------------------
 sidebar
--------------------------------------*/
#categories-3 {margin-bottom:40px;list-style: none;padding:15px;}
h2.widgettitle {text-align:center;border-bottom:1px solid #222;padding-bottom:10px;font-weight:600;}
#categories-3 ul {padding:15px;}
#categories-3 ul li a{color:#222;}
.cat-item{list-style: none;}
#recent-posts-3,#recent-posts-3 ul li {list-style: none;padding:15px;}
#recent-posts-3 ul li a{color:#222;}
#category_list ul{}
#category_list ul li{list-style:none;color:#222;font-size:1rem;padding:20px 5px;}
#category_list ul li a{color:#222;}
.sideber_tit{padding:10px 20px;background: #c8161d;text-align:center;}
.sideber_tit span{color:#fff;}
.sideber_tit h2{font-weight:600;font-size:1.3em;color:#fff;margin:0;}
#category_list ul li:nth-child(1){border-bottom:1px #ccc solid;}
/*--------------------------------------
 fade
--------------------------------------*/
.fadeUp{
animation-name:fadeUpAnime;
animation-duration:0.7s;
animation-fill-mode:forwards;
opacity:0;
}
@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(100px);
  }
  to {
    opacity: 1;
  transform: translateY(0);
  }
}
.fadeUpTrigger{
    opacity: 0;
}
/*--------------------------------------
 pagenation
--------------------------------------*/
.pagination{display:flex;justify-content: center;color: #A4A4A4;line-height: 1;margin: 0;padding: 2em 0;}
.page-numbers.current{background: #FFF;color: #6E6E6E;font-weight: bold;border: 1px solid #6E6E6E;margin: 0 1px 0 0;margin: 0 1px 0 0;padding: calc(1em - 1px) 1em;}
.pnavi a{box-sizing: border-box;color: #FFF;text-decoration: none;text-align: center;background: #6E6E6E;border: 1px solid #6E6E6E;min-width: 3em;transition: all .2s;margin: 0 1px 0 0;padding: calc(1em - 1px) 1em;}
.pnavi a:hover{color: #6E6E6E;background: #FFF;border: 1px solid #6E6E6E;}