/* -------------------Utility------------------*/
.cf:before,
.cf:after {
  content: "";
  display: table;
}
.cf:after {
  clear: both;
}
.cf {
  zoom: 1;
}
.left_box {
  float: left;
}
.right_box {
  float: right;
}
.in_box {
  display: inline-block;
}
.table {
  display: table;
}
.table_box {
  display: table-cell;
}
.inview {
  opacity: 0;
}
input,
textarea {
  border-radius: 0;
}
/* img */

.aligncenter {
  display: block;
  margin: 0 auto;
}
.alignright { float: right; }
.alignleft { float: left; }
img[class*="wp-image-"],
img[class*="attachment-"] {
  height: auto;
  max-width: 100%;
}
/* -------------------Common------------------*/
html {
  font-family: '游明朝', YuMincho, 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
  -webkit-text-size-adjust: none;
  background-color: #ffffff;
  color: #333;
}
a {
  text-decoration: none;
  color: #333;
}
a:hover{
  opacity: 0.8;
}
a.line {
  position: relative;
  display: inline-block;
  padding-bottom: 8px;
  text-decoration: none;
  -webkit-transition: all .5s linear 0s;
  transition: all .5s linear 0s;
}
a.line::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  -webkit-transform: scaleX(0);
  -ms-transform: scaleX(0);
  transform: scaleX(0);
  background-color: #000;
  -webkit-transition: all .5s ease;
  transition: all .5s ease;
}
a.line:hover::after {
  -webkit-transform: scaleX(1);
  -ms-transform: scaleX(1);
  transform: scaleX(1);
}
.wrap {
  margin: 0 auto;
}
.heading {
  font-family: 'Lustria', '游明朝', YuMincho, 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
}
.caption {
  font-family: 'Century Gothic', 'Quicksand', '游明朝', YuMincho, 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
}
.inner {
  min-width: 1200px;
  max-width: 1600px;
  margin: 0 auto;
}
#top_descriptions_s{
  display: none;
}
#s_catch{
  display: none;
}
#s_logo{
  display: none;
}

#s_btn{
  display: none;
}
#s_sns{
  display: none;
}
.copy{
  display: none;
}
#head{
  background-image: url('../img/common/bg_header.svg');
  background-size: 2560px 125px;
  -webkit-background-size: 2560px 125px;
  background-position: center -2px;
  background-color: transparent;
  position: fixed;
  z-index: 100;
  height: 123px;
  width: 100%;
  min-width: 1200px;
}
#head nav{
  position: relative;
}
#head nav>ul{
  list-style: none;
  text-align: center;
}
#head nav>ul>li{
  display: inline-block;
  letter-spacing: 3.52px;
  padding-top: 22px;
  vertical-align: top;
  width: 140px;
  background-color: rgba(255,255,255,1.0);
  -webkit-transition: all .4s linear 0s;
  transition: all .4s linear 0s;
}
#head nav>ul>li ul{
  -webkit-transition: all .4s linear 0s;
  transition: all .4s linear 0s;
  height: 0;
  overflow: hidden;
  display: block;
  padding-top: 14px;
  padding-left: 22px;
}
#head nav>ul>li ul li{
  text-align: left;
  margin-bottom: 12px;
}
#head nav>ul>li ul li a{
  font-size: 12px;
  letter-spacing: 2px;
}
#head nav>ul>li:hover ul,
#head nav>ul>li.current ul{
  height: 60px;
}
#head nav>ul>li:hover ul.long,
#head nav>ul>li.current ul.long{
  height: 95px;
}
#head nav>ul>li:hover,
#head nav>ul>li.current{
  background-color: rgba(241,241,228,1.0);
}
#head_logo{
  width: 100px;
  height: 90px;
  background-color: #333333 !important;
  background-image: url('../img/common/logo.svg');
  background-size: 80px 50px;
  background-repeat: no-repeat;
  background-position: center center;
  background-color: rgba(0,0,0,1.0);
}
#head_logo a{
  display: block;
  height: inherit;
  width: inherit;
}
#head nav>div a{
  display: block;
}
#head nav>div img[alt="fb"]{
  position: absolute;
  top: 18px;
  right: 21px;
}
#head nav>div img[alt="insta"]{
  position: absolute;
  top: 48px;
  right: 18px;
}
#head_adress{
  position: fixed;
  right: 0;
  top: 37%;
  width: 40px;
  height: 198px;
  border: 1px solid #333333;
  background: #fff;
  text-align: center;
  z-index: 99;
}
#head_adress div{
  width: 40px;
  height: 40px;
  background: #333333;
}
#head_adress div img{
  margin-top: 11px;
}
#head_adress p{
  -webkit-writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  text-align: justify;
  display: inline-block;
  font-size : 15px;
  letter-spacing : 3.3px;
  margin-top: 12px;
}
.check_board{
  display: table;
  width: 100%;
}
.check_board .row{
  display: table-row;
}
.check_board .row .cell_picture, .check_board .row .cell_writing{
  display: table-cell;
}
.check_board .row .cell_picture{
  width: 50%;
  height: 400px;
}
.check_board .row .cell_writing{
  width: 50%;
  position: relative;
}
.check_board .row .cell_writing:after{
  content: '';
  background-image: url('../img/common/tri_point.svg');
  background-size: 50px 50px;
  background-repeat: no-repeat;
  background-position: center center;
  width: 50px;
  height: 50px;
  display: block;
  position: absolute;
  top:42%;
  left:-13px;
}
.check_board .row .cell_writing:first-child:after{
  right:-13px;
  left: auto;
}
/*footer*/
#foot{
  min-width: 1200px;
}
#foot nav ul{
  list-style: none;
  margin: 55px auto;
  text-align: center;
}
#foot nav li{
  display: inline-block;
  margin: 0 47px;
}
#foot nav li a{
  font-size : 14px;
  letter-spacing : 3.08px;
}
#foot div.foot_arrow{
  border-top: 1px solid #333333;
  text-align: center;
  padding: 7px 0;
}
#foot div.foot_menu{
  background: #231815;
  color: #fff;
  font-weight: 200;
  height: 50px;
}
#foot div.foot_menu ul{
  float: left;
  height: 50px;
}
#foot div.foot_menu ul li{
  display: inline-block;
  width: 300px;
}
#foot div.foot_menu ul li div{
  width: 100px;
  height: 50px;
  background-color: #333333;
  background-repeat: no-repeat;
  background-position: center center;
  display: inline-block;
}
#foot div.foot_menu ul li:first-child div{
  background-image: url('../img/common/logo.svg');
  background-size: 56px 35px;
}
#foot div.foot_menu ul li:nth-child(2) div{
  background-image: url('../img/common/icon_telephone.svg');
  background-size: 23px 19px;
}
#foot div.foot_menu ul li:last-child div{
  background-image: url('../img/common/icon_mail.svg');
  background-size: 24px 20px;
}
#foot div.foot_menu ul li a{
  display: block;
  height: inherit;
  width: inherit;
}
#foot div.foot_menu ul li>p{
  font-size : 17px;
  letter-spacing : 3.74px;
  display: inline-block;
  vertical-align: 17px;
  padding-left: 30px;
}
#foot div.foot_menu ul li>p.address{
  font-size: 12px;
  letter-spacing: 1px;
  padding-left: 10px;
  vertical-align: top;
  padding-top: 12px;
}
#foot div.foot_menu>p{
  display: block;
  float: right;
  font-size: 10px;
  letter-spacing : 2.2px;
  margin-top: 20px;
  margin-right: 10px;
}
main{
  min-width: 1200px;
}
a.link{
  text-decoration: underline;
}
/* -------------------Top------------------*/
#dummy_slide{
	height: 610px;
	width: 100%;
	background:url(../img/top/loading.gif) center center #333 no-repeat;
}
#topslide{
  background-color: #333333;
  border-bottom: 10px solid #333333;
  min-width: 1200px;
}
#topslide .slick-slide{
  height: 600px;
  width: 1000px;
  -webkit-background-size: cover;
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  margin: 0 5px;
}
#top_descriptions.check_board .row .cell_writing h3, #top_descriptions.check_board .row .cell_writing p{
  -webkit-writing-mode: vertical-rl;
  -moz-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  text-align: justify;
  display: inline-block;
  vertical-align: top;
  margin-top: 70px;
}
#top_descriptions.check_board .row .cell_writing p{
  width: 320px;
  height: 260px;
  font-weight : 500;
  font-size : 17px;
  line-height : 37px;
  letter-spacing : 3.74px;
  color : #333333;
  padding-left: 90px;
  padding-right: 40px;
}
#top_descriptions.check_board .row .cell_writing h3{
  width: 100px;
  height: 290px;
  font-weight : 500;
  font-size : 40px;
  line-height : 60px;
  letter-spacing : 7.8px;
  color : #333333;
}
#top_descriptions.check_board .row .cell_writing .cell_inner{
  position: relative;
  width: 600px;
}
#top_descriptions.check_board .row .cell_writing:first-child .cell_inner{
  margin-left: auto;
  padding-right: 75px;
  width: 525px;
}
#top_descriptions.check_board .row .cell_writing:first-child .cell_inner p{
  padding-left: 0;
}
#top_descriptions.check_board .row .cell_writing img[alt="house"]{
  position: absolute;
  bottom: 10px;
  right: 10px;
}
#top_descriptions.check_board .row .cell_writing img[alt="canna"]{
  position: absolute;
  bottom: 30px;
  right: 195px;
}
#top_descriptions.check_board .row .cell_writing img[alt="craftsman"]{
  position: absolute;
  bottom: 5px;
  right: 30px;
}
#top_descriptions.check_board .row .cell_writing a{
  text-decoration: none;
  border-bottom: 1px black solid;
  font-size : 12px;
  letter-spacing : 2.64px;
  color : #333333;
  position: absolute;
  left: 50px;
  bottom: 10px;
}
#top_descriptions.check_board .row .cell_writing:first-child .cell_inner a{
  left: -40px;
}
#top_descriptions.check_board .row .cell_picture{
  background-repeat: no-repeat;
  vertical-align: middle;
  background-size: cover;
  -webkit-background-size: cover;
}
#top_descriptions.check_board .row .cell_picture a{
  display: block;
  width: 100%;
  height: inherit;
}
#top_works_blog{
  background-image: url('../img/top/top_bg_01.jpg');
  background-size: cover;
  -webkit-background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  display: block;
  min-width: 1200px;
}
#top_works_blog>div, #top_sns>div{
  text-align: center;
  padding: 55px 0;
}
#top_works_blog h2, #top_sns h2{
  font-weight : 500;
  font-size : 40px;
  line-height : 50px;
  letter-spacing : 8.8px;
  color : #333333;
  display: block;
}
#top_works_blog p, #top_sns p{
  font-size : 10px;
  line-height : 20px;
  letter-spacing : 2.2px;
}
#top_works_blog ul, #top_sns ul{
  list-style: none;
  width: 1050px;
  margin: 30px auto;
}
#top_works_blog ul li{
  width: 300px;
  height: 200px;
  background-size: cover;
  -webkit-background-size: cover;
  background-position: center center;
  float: left;
  display: table;
  margin: 0 24px;
}
#top_works_blog ul li a{
  color: #fff;
  height: inherit;
  display: table-cell;
  vertical-align: middle;
  background-color: rgba(0,0,0,0.3);
  -webkit-transition: all .5s linear 0s;
  transition: all .5s linear 0s;
  text-align: center;
  padding: 0 10%;
}
#top_works_blog ul li a h5, #top_works_blog ul li a time{
  display: inline !important;
  /*opacity: 0;*/
  -webkit-transition: all .5s linear 0s;
  transition: all .5s linear 0s;
}
#top_works_blog ul li a h5{
  font-weight: 400;
  font-size: 18px;
  line-height : 30px;
  letter-spacing: 3.96px;
  width: 80%;
}
#top_works_blog ul li a time{
  font-size : 12px;
  letter-spacing : 2.64px;
  line-height: 30px;
}
/*#top_works_blog ul li a:hover h5, #top_works_blog ul li a:hover time{
  opacity: 1.0;
}*/
#top_works_blog ul li a:hover{
  background-color: rgba(0,0,0,0);
}
#top_works_blog div a.more_button{
  background-color: rgba(51,51,51,1.0);
  color: #fff;
  font-size : 15px;
  letter-spacing : 3.3px;
  padding: 6px 214px;
  text-decoration: none;
  -webkit-transition: all .5s linear 0s;
  transition: all .5s linear 0s;
}
#top_works_blog div a.more_button:hover{
  background-color: rgba(100,100,100,1.0);
}
#top_works_blog>div>div{
  margin-top: 50px;
}
#top_sns{
  background-color: #F1F1E4;
  height: 600px;
  min-width: 1200px;
}
#top_sns ul li{
  width: 170px;
  height: 170px;
  background-size: cover;
  -webkit-background-size: cover;
  background-position: center center;
  float: left;
  display: table;
  margin: 0 18px;
}
#top_sns ul a{
  width: inherit;
  height: inherit;
  display: block;
  background-size: cover;
  -webkit-background-size: cover;
  background-position: center center;
}
/* -------------------sub_static_top------------------*/
main section.sub_static_top{
  position: relative;
  height: 390px;
  background: #F8F9ED;
  border-top: 10px solid #333333;
  padding-bottom: 20px;
}
main section.sub_static_other{
  position: relative;
  height: 300px;
  background: #F8F9ED;
}
main>div.sub_main_image{
  height: 600px;
  width: 100%;
  background-size: cover;
  -webkit-background-size: cover;
  background-position: center center;
}
main>div.sub_sub_image{
  height: 400px;
  width: 100%;
  background-size: cover;
  -webkit-background-size: cover;
  background-position: center -300px;
  background-repeat: no-repeat;
}
main section.sub_static_top div.sub_static_intro{
  position: absolute;
  top: -70px;
  /*中央寄せ*/
  left: 50%;
  transform: translateX(-50%);
  /*--------*/
  z-index: 95;
  width: 900px;
  background: #F8F9ED;
  border-top: 10px solid #333333;
  text-align: center;
}
main section.sub_static_other div.sub_static_intro{
  position: absolute;
  top: -35px;
  /*中央寄せ*/
  left: 50%;
  transform: translateX(-50%);
  /*--------*/
  z-index: 95;
  width: 900px;
  background: #F8F9ED;
  text-align: center;
}
main section.sub_static_top div.sub_static_intro>div{
  display: inline-block;
  margin: 20px 60px 50px;
}
main section.sub_static_top div.sub_static_intro>div p{
  margin-top: 30px;
  font-size : 19px;
  letter-spacing : 4.4px;
}
h3.sub_static_copy{
  font-size : 40px;
  letter-spacing : 8.8px;
  margin-bottom: 15px;
  line-height: 60px;
}
h3.sub_static_copy a{
  display: inline-block;
  width: 44px;
  height: 46px;
  letter-spacing: -1px;
  text-align: center;
}
.sns-btn{
  display: inline-flex;
  vertical-align: text-bottom;
}
.sns-btn a:first-child{
  margin-right: 10px;
}
main section.sub_static_other div.sub_static_intro>h3{
  margin: 35px 0;
}
main section.sub_static_top div.sub_static_intro>p, main section.sub_static_other div.sub_static_intro>p{
  width: 800px;
  font-size : 19px;
  line-height : 40px;
  letter-spacing : 2.7px;
  text-align: left;
  display: block;
  margin: 0 auto;
}
main>div.sub_static_interval{
  text-align: center;
  background: #E6E6E6;
  height: 100px;
}
main>div.sub_static_interval p{
  background-color: #333333;
  color: #fff;
  font-size : 15px;
  letter-spacing : 5.3px;
  padding: 8px;
}
/* ---------------kominka,tekizami,syokunin--------------*/
#kominka section.check_board .row .cell_inner, #tekizami section.check_board .row .cell_inner, #syokunin section.check_board .row .cell_inner{
  width: 450px;
  text-align: left;
  margin: 60px 0 50px 100px;
}
#kominka section.check_board .row .cell_picture, #tekizami section.check_board .row .cell_picture, #syokunin section.check_board .row .cell_picture{
  vertical-align: middle;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  -webkit-background-size: cover;
  height: 400px;
}
#kominka section.check_board .row .cell_writing:first-child .cell_inner, #tekizami section.check_board .row .cell_writing:first-child .cell_inner, #syokunin section.check_board .row .cell_writing:first-child .cell_inner{
  margin-left: auto;
  padding-right: 100px;
}
#kominka section.check_board .row .cell_inner p, #tekizami section.check_board .row .cell_inner p, #syokunin section.check_board .row .cell_inner p{
  font-size : 14px;
  line-height : 31px;
  letter-spacing : 3.08px;
}
#kominka section.check_board .row .cell_writing:first-child .cell_inner p, #tekizami section.check_board .row .cell_writing:first-child .cell_inner p, #syokunin section.check_board .row .cell_writing:first-child .cell_inner p{
  padding-left: 0;
}
/* -------------------kominka------------------*/
div.table_nested{
  display: table;
  width: 100%;
}
p.rowspan_spacing{
  padding-top: 50px;
}
#kominka section.check_board .row .rowspan_diamond:after{
  content: '';
  background-image: url('../img/common/tri_point.svg');
  background-size: 50px 50px;
  background-repeat: no-repeat;
  background-position: center center;
  width: 50px;
  height: 50px;
  display: block;
  position: absolute;
  top:47%;
  left:-13px;
}
#kominka section.check_board .row .rowspan_diamond:first-child:after {
  right: -13px;
  left: auto;
}
/* -------------------tekizami------------------*/
#tekizami section.check_board .row .cell_inner{
  position: relative;
}
#tekizami section.check_board .row .cell_inner p{
  padding-top: 80px;
}
#tekizami section.check_board .row .cell_inner img{
  position: absolute;
}
#tekizami section.check_board .row .cell_inner img[alt="woods"]{
  top: -10px;
  right: 120px;
}
#tekizami section.check_board .row .cell_inner img[alt="sumi"]{
  top: -5px;
  right: 85px;
}
#tekizami section.check_board .row .cell_inner img[alt="chona"]{
  top: 10px;
  right: 0;
}
#tekizami section.check_board .row .cell_inner img[alt="hammer"]{
  top: -5px;
  right: 210px;
}
#tekizami section.cf>div{
  float: left;
  width: 50%;
  height: 800px;
}
#tekizami section.cf>div:first-child{
  background-color: #40210F;
}
#tekizami section.cf>div:last-child{
  background-color: #6A3906;
}
#tekizami section.cf div.sub_float_image{
  height: 400px;
  background-size: cover;
  -webkit-background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}
#tekizami section.cf div.float_inner_writing{
  width: 450px;
  text-align: left;
  margin: 60px 0 50px 100px;
  position: relative;
}
#tekizami section.cf img{
  position: absolute;
}
#tekizami section.cf img[alt="old_woods"]{
  top: -100px;
  left: 0;
}
#tekizami section.cf img[alt="desk"]{
  top: -80px;
  left: 0;
}
#tekizami section.cf h3.sub_static_copy{
  color: #fff;
}
#tekizami section.cf p{
  color: #fff;
  font-size : 14px;
  line-height : 31px;
  letter-spacing : 3.08px;
}
#tekizami>a p{
  background-color: #333333;
  color: #fff;
  font-size : 15px;
  letter-spacing : 5.3px;
  padding: 8px;
  text-align: center;
}

/* -------------------syokunin------------------*/
#syokunin>div.sub_main_image{
  background-position: center top;
}
#craftsman_top{
  text-align: center;
  background-color: #fff;
}
#craftsman_top div.craftsman_cover{
  background-image: url('../img/subpage/craftsman_group_bg_2.png');
  background-color: transparent;
  background-position: center top;
  /* background-size: 1200px 500px; */
  background-size: contain;
  background-repeat: no-repeat;
  height: 700px;
  position: relative;
  z-index: 97;
}
#craftsman_top h3{
  padding-top: 110px;
}
#craftsman_top h3 img{
  vertical-align: top;
}
#craftsman_top div.craftsman_cover_spacing{
  margin-top: -100px;
  background-color: #E7E4DB;
}
#craftsman_top p{
  width: 800px;
  font-size : 19px;
  line-height : 40px;
  letter-spacing : 2.7px;
  text-align: left;
  display: block;
  margin: 0 auto;
  padding: 80px 0;
}
div.introduce_white_bg{
  background-color: #fff;
  padding: 80px 0 70px 0;
}
div.introduce_colored_bg{
  background-color: #E7E4DB;
  padding-top: 30px;
  padding-bottom: 140px;
}
section.introduce_craftsman_right div.introduce_white_bg div.introduce_profile, section.introduce_craftsman_right div.introduce_white_bg div.introduce_paragraph, section.introduce_craftsman_right div.introduce_colored_bg div.introduce_paragraph{
  width: 50%;
  margin-left: auto;
  text-align: left;
  position: relative;
}
section.introduce_craftsman_left div.introduce_white_bg div.introduce_profile, section.introduce_craftsman_left div.introduce_white_bg div.introduce_paragraph, section.introduce_craftsman_left div.introduce_colored_bg div.introduce_paragraph{
  width: 1000px;
  margin: 0 auto;
  text-align: left;
  position: relative;
}
div.introduce_white_bg div.introduce_profile{
  position: relative;
}
section.introduce_craftsman_right div.introduce_white_bg img.craftsman_portrait{
  position: absolute;
  left: -550px;
}
section.introduce_craftsman_left div.introduce_white_bg img.craftsman_portrait{
  position: absolute;
  right: -50px;
}
div.introduce_white_bg div.introduce_paragraph, div.introduce_colored_bg div.introduce_paragraph{
  padding-top: 40px;
}
#syokunin .small_letter{
  font-size : 10px;
  line-height : 20px;
  letter-spacing : 2.2px;
}
#syokunin span.small_letter{
  padding-left: 5px;
  vertical-align: 11px;
}
#syokunin p.small_letter{
  border-bottom: 1px solid #333333;
  margin-bottom: 15px;
  display: inline-block;
}
#syokunin p.introduce_detail{
  width: 500px;
  font-size : 14px;
  line-height : 1.8;
  letter-spacing : 1px;
}
div.introduce_white_bg div.introduce_profile h3.sub_static_copy{
  margin-bottom: 0;
}
div.introduce_white_bg div.introduce_profile p.introduce_position{
  font-size : 16px;
  line-height : 30px;
  letter-spacing : 3.52px;
  text-indent: -8px;
}
div.introduce_colored_bg div.introduce_paragraph a:not(.link){
  font-size : 14px;
  line-height : 30px;
  letter-spacing : 3.08px;
  color : #FFFFFF;
  background-color: #333333;
  text-align: center;
  padding: 0 15px;
  display: inline-block;
  margin-top: 30px;
}
div.introduce_colored_bg div.introduce_paragraph .introduce_link{
  position: absolute;
  bottom: -80px;
}
/* div.introduce_profile h3.syacho_name{
  position: relative;
}
div.introduce_profile a img[alt="fb"]{
  position: absolute;
  top: 22px;
  left: 280px;
}
div.introduce_profile a img[alt="insta"]{
  position: absolute;
  top: 24px;
  left: 302px;
} */
.top_lists{
  position: relative;
}
.bottom-flex-parents{
  position: relative;
  background:linear-gradient(180deg,#fff 0%,#fff 57%,#E7E4DB 57%,#E7E4DB 100%);
}
.bottom-flex-parents h2{
  font-size: 40px;
  text-align: center;
  letter-spacing: 5px;
  margin: 90px;
}
/* .bottom-flex-parents .introduce_white_bg{
  height: 750px;
}
.bottom-flex-parents .introduce_colored_bg{
  height: 600px;
} */
.bottom-flex-child{
  display: flex;
  justify-content: center;
  position: relative;
}
.bottom-flex-child .introduce_profile, .bottom-flex-child .introduce_paragraph{
  display: block;
}
.mr150{
  margin-right: 150px;
}
.bottom-flex-child .introduce_paragraph{
  margin-top: 60px;
}
#syokunin .bottom-flex-child p.introduce_detail{
  width: 450px;
}
.bottom-flex-child .sns-btn{
  position: absolute;
  bottom: 800px;
}
/* -------------------contact------------------*/
#company section.company_info{
  border-top: 10px solid #333333;
  padding-bottom: 20px;
}
#company section.company_info div.logo_black{
  text-align: center;
  padding: 40px 0;
}
#company section.company_info table{
  width: 800px;
  margin: 0 auto;
  border-collapse: collapse;
  text-align: left;
  font-size : 14px;
  line-height : 50px;
  letter-spacing : 3.08px
}
#company section.company_info table tr{
  border-color: #333333;
  border-style: solid;
  border-width: 1px 0;
}
#company section.company_info table tr.multiple_lines td{
  line-height: 20px;
  padding-bottom: 15px;
}
#company section.company_info table tr th{
  width: 350px;
  text-indent: 0.7em;
}
#company section.company_info div.info_inquiry{
  width: 800px;
  margin: 70px auto;
  border: 1px solid #333333;
  text-align: center;
  padding: 20px 0 10px 0;
}
#company section.company_info div.info_inquiry p:first-child{
  font-size : 20px;
  line-height : 20px;
  letter-spacing : 2.8px;
  color : #231815;
  padding-bottom: 30px;
}
#company section.company_info div.info_inquiry p.info_inline{
  display: inline-block;
  font-size: 30px;
  line-height: 50px;
  letter-spacing: 5.6px;
  padding: 0 14px;
}
#company section.company_info div.info_inquiry span.small_letter02{
  font-size : 15px;
  letter-spacing : 3px;
  margin-right: -6px;
  vertical-align: 6px;
}
section.company_location{
  padding-bottom: 10px;
}
section.company_location div.cell_picture{
  background-position: center center;
  background-size: cover;
  -webkit-background-size: cover;
  background-repeat: no-repeat;
  height: auto!important;
}
div.cell_location{
  display: table-cell;
  width: 50%;
}
div.cell_location div.location_spot{
  height: 150px;
  vertical-align: middle;
  background-color: #333333;
}
div.cell_location div.location_spot div:first-child{
  float: left;
  width: auto;
  color: #fff;
  height: inherit;
  margin-left: 40px;
}
div.cell_location div.location_spot h3{
  font-size : 30px;
  line-height : 40px;
  letter-spacing : 6.6px;
  margin: 20px 0;
}
div.cell_location div.location_spot p, section.company_location_bottom p{
  font-size : 14px;
  line-height : 26px;
  letter-spacing : 3.08px;
}
div.cell_location div.location_spot div:last-child{
  float: right;
  width: 150px;
  background-color: #231815;
  height: inherit;
  position: relative;
}
div.cell_location div.location_spot div:last-child img{
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
}
section.company_location_bottom{
  height: 150px;
  vertical-align: middle;
  background-color: #333333;
  color: #fff;
  margin-bottom: 30px;
}
section.company_location_bottom>div{
  width: 50%;
  margin-left: auto;
}
section.company_location_bottom h3{
  font-size : 30px;
  line-height : 40px;
  letter-spacing : 6.6px;
  padding: 20px 0 10px 0;
}
section.company_location_bottom h3, section.company_location_bottom p{
  text-indent: 40px;
}
/* -------------------Wowks-----------------------*/
main#works section.sub_static_top{
  height: 0;
  background: #fff;
  padding-bottom: 0;
}
main#works section.sub_static_top div.sub_static_intro{
  background: #fff;
}

ul.category{
  height: 80px;
  padding-top: 25px;
}
ul.category li{
  display: inline-block;
  font-size : 15px;
  letter-spacing : 3.3px;
  margin: 0 10px;
}

ul.category li a{
  color : #333333;
  position: relative;
  display: inline-block;
  padding-bottom: 8px;
  text-decoration: none;
  -webkit-transition: all .5s linear 0s;
  transition: all .5s linear 0s;
}

ul.category li a::after{
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 1px;
  -webkit-transform: scaleX(0);
  -ms-transform: scaleX(0);
  transform: scaleX(0);
  background-color: #000;
  -webkit-transition: all .5s ease;
  transition: all .5s ease;
}
ul.category li a:hover::after,
ul.category li a.current::after{
  -webkit-transform: scaleX(1);
  -ms-transform: scaleX(1);
  transform: scaleX(1);
}

ul.category li form{
  position: relative;
}
ul.category li input#posts_search_input{
  -webkit-border-radius: 30px;-moz-border-radius: 30px;border-radius: 30px;
  height: 30px;
  width: 120px;
  border: 1px solid #000;
  padding-right: 40px;
  padding-left: 10px;
  padding-top: 0;
  padding-bottom: 0;
}

ul.category li input#posts_search_input:focus{
  border: 1px solid #999999;
}

ul.category li input:focus {
  outline: none;
}

ul.category li input.submit{
  position: absolute;
  right:0;
  top:0;
  border: none;
}


#article_grid p, #top_sns p{
  font-size : 10px;
  line-height : 20px;
  letter-spacing : 2.2px;
}
#article_grid ul, #top_sns ul{
  list-style: none;
  width: 1050px;
  margin: 40px auto;
}
#article_grid ul li{
  width: 300px;
  height: 200px;
  background-size: cover;
  background-position: center center;
  float: left;
  display: table;
  margin: 24px;
}
#article_grid ul li a{
  color: #fff;
  height: inherit;
  display: table-cell;
  vertical-align: middle;
  background-color: rgba(0,0,0,0.3);
  -webkit-transition: all .5s linear 0s;
  transition: all .5s linear 0s;
  text-align: center;
  padding: 0 10%;
}
#article_grid ul li a h5, #article_grid ul li a time{
  display: inline !important;
  /*opacity: 0;*/
  -webkit-transition: all .5s linear 0s;
  transition: all .5s linear 0s;
}
#article_grid ul li a h5{
  font-weight: 400;
  font-size: 18px;
  line-height : 30px;
  letter-spacing: 3.96px;
  width: 80%;
}
#article_grid ul li a time{
  font-size : 12px;
  letter-spacing : 2.64px;
  line-height: 30px;
}
/*#article_grid ul li a:hover h5, #article_grid ul li a:hover time{
  opacity: 1.0;
}*/
#article_grid ul li a:hover{
  background-color: rgba(0,0,0,0);
}
#article_grid div a.more_button{
  background: #333333;
  color: #fff;
  font-size : 15px;
  letter-spacing : 3.3px;
  padding: 6px 214px;
  text-decoration: none;
}
#article_grid>div>div{
  margin-top: 50px;
  text-align: center;
}

#works .inner{
  width: 1000px;
  margin: 0 auto;
  min-width: 1000px;
}

#works .sub_main_image{
  position: relative;
}

#works .sub_main_image .center_box{
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 1000px;
  height: 50px;
  left: 0;
  right:0;
}

#works .sub_main_image h2.title{
  font-size : 36px;
  line-height : 40px;
  letter-spacing : 7.92px;
  color: #fff;
  padding:0;
  font-weight: normal;
  text-shadow: 0 0 7px #666;
  min-width: 0;
  text-align: center;
}

#works .sub_main_image .date{
  text-align: center;
  font-size : 18px;
  line-height : 38px;
  letter-spacing : 2px;
  color : #FFFFFF;
  text-shadow: 0 0 7px #666;
  margin-bottom: 25px;
}

#works article.work .article_header{
  padding-top: 60px;
  padding-bottom: 60px;
  background-color: #f1f1e4;
  background-image: url("../img/subpage/bg_pattern.png");
  -webkit-background-size: 1236px 489px;
  background-size: 1236px 489px;
  background-repeat: repeat-x;
  background-position: center center;
}

#works article.work .article_header .works_photo{
  width:500px;
  height: 330px;
  background-position: center center;
  -webkit-background-size: cover;
  background-size: cover;
  background-repeat: no-repeat;
  float: left;
  margin-bottom: 50px;
}

#works article.work .article_header .works_photo a{
  display: block;
  height: inherit;
  width: inherit;
}

#works article.work .article_header .works_description{
  width:500px;
  float: right;
}

#works article.work .article_header .works_description .left_box{
  float: left;
  width:200px;
  padding-left: 25px;
  padding-top: 10px;
}

#works article.work .article_header .works_description .left_box p{
  font-size : 14px;
  line-height : 26px;
  letter-spacing : 3.08px;
  color : #333333;
}


#works article.work .article_header .works_description .right_box{
  float: right;
  width: 250px;
  font-size : 18px;
  line-height : 41px;
  letter-spacing : 3.96px;
  color : #333333;
  padding-top: 5px;
  padding-bottom: 30px;
}

#works article .article_body ul.photo_list{
  position: relative;
  margin-top: -50px;
}

#works article .article_body ul.photo_list li{
  width:500px;
  height: 330px;
  background-position: center center;
  -webkit-background-size: cover;
  background-size: cover;
  background-repeat: no-repeat;
  float: left;
  margin-bottom: 50px;
}
#works article .article_body ul.photo_list li a{
  display: block;
  height: inherit;
  width: inherit;
}

#works article .category{
  margin-top: 70px;
}

#works article{
  padding-bottom: 50px;
}

#works article .category a{
  border-bottom: 1px solid #333333;
  margin-bottom: 15px;
  display: inline-block;
  font-size : 10px;
  line-height : 20px;
  letter-spacing : 2.2px;
}

#works article .sns_share{
  margin-top: 43px;
}

#works .category_nav{
  text-align: center;
}

#works .frame-img a{
	cursor: pointer;
}

/* モーダル・ウィンドウ */

/* 本体 */
#MODAL-WINDOW {
position: fixed;
top: 0;
left: 0;
z-index: 500;
width: 100%;
height: 100%;
background-color:  rgba(0, 0, 0, 0.85);
background-position: center center;
background-size: auto;
background-repeat: no-repeat;
background-image:  url(./files/loader.gif);
box-sizing: border-box;
padding: 10px;
display: none;
}

/* 閉じるボタン */
#MODAL-WINDOW > .close-button {
position: fixed;
top: 30px;
right: 30px;
z-index: 550;
width: 18px;
padding: 13px;
background-color: rgba(0, 0, 0, 0.85);
box-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
border: 2px solid #fff;
border-radius: 50%;
line-height: 1;
text-align: center;
font-size: 18px;
font-weight: bold;
color: #fff;
cursor: pointer;
}

/* データ読み込み用コンテナ */
#MODAL-WINDOW > .container {
width: 100%;
height: 100%;
overflow: auto;
-webkit-overflow-scrolling: auto; /* 慣性スクロールを無効化 */
background-color: #fff;
}

/* スクロール・バーの表示 for iOS */
#MODAL-WINDOW > .container::-webkit-scrollbar {
width: 6px;
background: #ccc;
}

#MODAL-WINDOW > .container::-webkit-scrollbar-thumb {
background: #999;
}

/* 画像表示用 */
#MODAL-WINDOW.IMAGE > .container {
background-color: transparent;
}

#MODAL-WINDOW > .container > span.IMG {
display: block; /* ブロック要素化 */
width: 100%;
height: 100%;
background-size: contain;
background-repeat: no-repeat;
background-position: center center;
}


main#blog section.sub_static_top{
  position: relative;
  height: 390px;
  background:url("../img/subpage/bg_pattern.png") #F8F9ED center center repeat-x;
  border-top: 10px solid #333333;
  padding-bottom: 20px;
  -webkit-background-size: 1236px 489px;
  background-size: 1236px 489px;
}

main#blog .container {
  position: relative;
  width: 1000px;
  margin: -200px auto 0;
}

main#blog article{
  width: 700px;
  float: left;
}

main#blog aside{
  width: 220px;
  float: right;
}
main#blog article{
  padding-bottom: 30px;
}
main#blog article .blog_body img{
  max-width:100%;
  height: auto;
}

main#blog article .blog_body .date{
  font-size : 12px;
  line-height : 19px;
  letter-spacing : 2.64px;
  margin-bottom: 10px;
}

main#blog article .blog_body h2{
  font-size : 20px;
  line-height : 20px;
  letter-spacing : 4.4px;
  margin-bottom: 40px;
}

main#blog article .blog_body p{
  font-size : 18px;
  line-height : 41px;
  letter-spacing : 3.96px;
  margin: 20px 0;
}

main#blog article .blog_body{
  padding-bottom: 20px;
}

main#blog article .blog_ex{
  border-top:1px solid #000;
  padding-top: 0;
}
main#blog article .blog_ex .archives{
  float: left;
  padding-top: 10px;
}
main#blog article .blog_ex .archives a{
  border-bottom: 1px solid #333333;
  margin-bottom: 15px;
  display: inline-block;
  font-size : 10px;
  line-height : 20px;
  letter-spacing : 2.2px;
}

main#blog article .blog_ex .sns{
  float: right;
}

main#blog aside h3{
  font-size : 17px;
  line-height : 37px;
  letter-spacing : 3.74px;
  margin-bottom: 17px;
}

main#blog aside ul.side_category{
  border-top:1px solid #000;
  padding-top: 17px;
  padding-bottom: 17px;
}

main#blog aside ul.archive {
  border-top:1px solid #000;
  padding-top: 25px;
  padding-bottom: 25px;
}
main#blog aside ul.side_category li{
  font-size : 17px;
  line-height : 37px;
  letter-spacing : 3.74px;
}

ul.archive li form{
  position: relative;
  padding-bottom: 8px;
}
ul.archive li input#posts_search_input{
  -webkit-border-radius: 30px;-moz-border-radius: 30px;border-radius: 30px;
  height: 30px;
  width: 168px;
  border: 1px solid #000;
  padding-right: 40px;
  padding-left: 10px;
  padding-top: 0;
  padding-bottom: 0;
}

ul.archive li input#posts_search_input:focus{
  border: 1px solid #999999;
}

ul.archive li input:focus {
  outline: none;
}

ul.archive li input.submit{
  position: absolute;
  right:0;
  top:0;
  border: none;
}

main#blog aside ul.archive li{
  margin-bottom: 17px;
}

main#blog aside ul.archive li select{
  width: 100%;
}

main#blog aside .fb_box{
  margin-top: 50px;
}






#contact .inner form,
#contact .inner .form_ex {
  width: 900px;
  margin: 0 auto;
}

#contact .inner .form_ex p {
  font-size : 14px;
  line-height : 20px;
  letter-spacing : 1.96px;
  text-align: center;
  padding-right: 100px;
}

#contact .inner form .row_check {
  margin-bottom: 10px;
}

#contact .inner form .row_check label {
  font-size: 12px;
  margin-right: 10px;
}

#contact .inner form .row {
  margin-bottom: 25px;
  text-align: left;
  font-size : 14px;
  line-height : 20px;
  letter-spacing : 1.96px;
}

#contact .inner form .row_check {
  margin-bottom: 15px;
  text-align: left;
  font-size : 12px;
  line-height : 20px;
  letter-spacing : 1.68px;
}

#contact .inner form .row_check label{
  margin-right: 20px;
}

#contact .inner form .right_box {
  width: 440px;
  text-align: left;
  font-size : 14px;
  line-height : 20px;
  letter-spacing : 1.96px;
}

#contact .inner form .row.last {
  margin-bottom: 5px;
}

#contact .inner form .row input {
  padding: 10px;
  width: 420px;
  border: 1px solid #3e3a39;
  font-size : 12px;
  line-height : 20px;
  letter-spacing : 0.72px;
  max-height: 40px;
}

#contact .inner form textarea {
  width: 420px;
  height: 220px;
  padding: 10px;
  border: 1px solid #3e3a39;
  font-size : 12px;
  line-height : 20px;
  letter-spacing : 0.72px;
}

#contact form p {
  font-size: 12px;
  line-height: 18px;
}

#contact .btn {
  padding: 35px 0 0;
}

#contact .btn a.privacy{
  border: 1px solid #000;
  background-color: #fff;
  padding: 10px 0;
  width: 440px;
  display: inline-block;
  font-size : 12px;
  line-height : 20px;
  letter-spacing : 3.6px;
  text-align: center;
  float: left;
}

#contact .btn a.privacy:hover{
  background-color: #eee;
}

#contact .btn button {
  border: 1px solid #000;
  background-color: #000;
  color: #fff;
  padding: 10px 0;
  width: 442px;
  display: inline-block;
  font-size : 12px;
  line-height : 20px;
  letter-spacing : 3.6px;
  text-align: center;
  float: right;
}

#contact .btn button.submit_edit {
  border: 1px solid #000;
  background-color: #000;
  color: #fff;
  padding: 10px 0;
  width: 442px;
  display: inline-block;
  font-size : 12px;
  line-height : 20px;
  letter-spacing : 3.6px;
  text-align: center;
  float: left;
}

#contact .btn button:hover {
  background-color: #666;
  border-color: #666;
}

.icon_contact{
  text-align: center;
  padding: 10px 0 60px;
}
/* -------------------Pagination------------------*/
.pagination {
  margin: 100px auto 100px;
  text-align: center;
  width: 900px;
}
.pagination:after, .pagination ul:after {
  clear: both;
  content: ".";
  display: block;
  height: 0;
  visibility: hidden;
}
.pagination ul {
  display: inline-block;
  margin: 0;
}
.pagination li {
  float: left;
  list-style: none outside none;
  margin-left: 10px;
  font-size: 12px;
  line-height: 20px;
  letter-spacing: 1.68px;
}
.pagination li:first-child {
  margin-left: 0;
}
.pagination li.active {
  color: #000;
  /*cursor: not-allowed;*/
  padding: 6px 5px 3px;
  border-bottom: 1px solid #000;
}
.pagination li a {
  color: #000 !important;
  display: block;
  padding: 6px 5px 3px;
  text-decoration: none;
}
.pagination li a:hover {
  color: #000;
}
.pagination li.next a,
.pagination li.prev a {
  background: none !important;
  color: #fff !important;
  display: block;
  padding: 0 5px;
  text-decoration: none;
}
