@charset "utf-8";
/* PC */

body {
  font-size: 18px;
  }
a:hover {
  text-decoration: underline;
}
a img {
  transition: all .5s;
}
a:hover img {
  opacity: .8;
}
input[type="text"], input[type="email"], input[type="password"], input[type="number"], input[type="tel"], textarea, select {
  padding: 10px;
  font-size: 20px;
}
.sp {
  display: none;
}


/* 基本レイアウト---------------- */
#wrapper {
  position: relative;
  width: 100%;
  text-align: center;
}
#container {
	width: 100%;
}
.flex {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
}
.flex_st {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  align-self: center;
}


/* ヘッダー---------------- */
#head {
	width: 100%;
  position: relative;
}
.head_main_top{
position: relative;
width: 100%;
padding-bottom: 160px;
overflow-x: hidden;
}
.swiper-slide img {
height: auto;
width: 100%;
}
.swiper-button-prev,
.swiper-button-next {
height: 40px;
width: 40px;
top:calc(50% - 110px);
}
.swiper-button-prev:after,
.swiper-button-next:after {
background-repeat: no-repeat;
background-size: contain;
content: "";
height: 40px;
margin: auto;
width: 40px;
}
.swiper-button-prev:after {
background-image: url("../img/swiper-button-prev.png");
}
.swiper-button-next:after {
background-image: url("../img/swiper-button-next.png");
}
.top_main_copy {
position: absolute;
bottom: 0;
left: -20%;
right: -20%;
width: 140%;
margin: 0 auto;
max-width: 1200px;
height: 454px;
z-index: 1;
}
.top_main_copy img{
width: 100%;
}
#head_navi_top {
  width: 100%;
	height: 125px;
	margin: 0 auto;
	padding-top: 36px;
	background: #333030;
}
#head_navi {
  width: 100%;
	height: 125px;
	margin: 0 auto;
	padding-top: 36px;
	background: #333030;
}
#head_navi_top a, #head_navi a {
	text-decoration: none;
}
.head_navi_in {
	display: flex;
	flex-wrap: nowrap;
  align-items: center;
	width: 98%;
	max-width: 1200px;
	margin: 0 auto;
	text-align: left;
}
.head_navi_top {
	width: 26%;
	font-size: 33px;
	font-weight: bold;
}
.head_navi_nav {
	width: 54%;
}
.head_navi_sns {
	width: 20%;
	padding-top: 5px;
	text-align: right;
}
.head_navi_nav ul {
  display: flex;
	flex-wrap: nowrap;
  align-items: center;
}
.head_navi_nav ul li {
  width: 25%;
  text-align: center;
}
.head_navi_nav ul li a {
  position: relative;
  display: block;
  text-align: center;
  text-decoration: none;
  font-size: 23px;
}
.head_navi_nav ul li a:before {
  opacity: 0;
  position: absolute;
  bottom: -15px;
  left: 0;
	right: 0;
  display: block;
  content: "";
  width: 80%;
  height: 2px;
	margin: 0 auto;
  background: #fff;
  transition: all .5s;
}
.head_navi_nav ul li a:hover:before {
  opacity: 1;
}
.head_navi_nav ul li.current:before {
  position: absolute;
  top: 0;
  left: 15px;
  display: block;
  content: "";
  width: calc(100% - 30px);
  height: 5px;
  background: #2921B5;
}
.head_sns {
  display: inline;
}
.head_sns li {
  display: inline-block;
	margin: 0 2px;
}
#head_contact {
	position: fixed;
	bottom: 10px;
	right: -1px;
	z-index: 100;
}
@media screen and (max-width:1200px) {
  #head_navi_top {
    height: 100px;
    padding-top: 25px;
  }
  #head_navi {
    height: 100px;
    padding-top: 25px;
  }
	.head_navi_nav ul li a {
    font-size: 20px;
  }
}
@media screen and (max-width:1100px) {
  .head_navi_nav ul li a {
    font-size: 16px;
  }
}
@media screen and (max-width:900px) {
  #head_navi_top {
    height: 80px;
    padding-top: 20px;
  }
  #head_navi {
    height: 80px;
    padding-top: 20px;
  }
  .head_main_top{
  padding-bottom: 110px;
  }
	.top_main_copy {
  max-width: 1000px;
  height: 362px;
  }
  .head_navi_top {
		width: 22%;
		font-size: 24px;
	}
	.head_navi_nav {
		width: 54%;
	}
	.head_navi_sns {
		width: 24%;
	}
	.head_navi_nav ul li a {
    font-size: 14px;
  }
}

.sp_navi_btn, #sp_navi, #sp_menu {
  display: none;
}


/* フッター----------------- */
footer {
color: #fff;
background: #333030;
}
footer a {
color: #fff;
}
.foot_content {
position: relative;
width: 98%;
max-width: 1300px;
margin: 0 auto;
padding-top: 46px;
text-align: left;
display: flex;
flex-wrap: nowrap;
align-items: flex-start;
}
.foot_col:nth-of-type(1) {
padding-left: 4.1%;
padding-right: 30px;
}
.foot_logo {
margin-bottom: 20px;
width: 400px;
}
.foot_logo img{
width: 100%;
}
.foot_col:nth-of-type(2) {
padding-top: 10px;
}
footer h3 {
font-size: 30px;
}
.foot_navi_col {
display: flex;
flex-wrap: nowrap;
}
.foot_navi_col > div{
margin-right: 30px;
justify-content: space-between;
}
footer h4 {
font-size: 16px;
margin-bottom: 10px;
}
.foot_navi_col p a{
display: block;
font-size: 14px;
}
.foot_illust {
display: block;
width: 100%;
text-align: center;
overflow-x: hidden;
}
.foot_illust img{
display: inline-block;
margin-left: -100px;
}
@media screen and (max-width:1400px) {
.foot_illust img{width: 110%;margin-left: -50px;}
}
@media screen and (max-width:1000px) {
.foot_logo {width: 200px;}
}

/* トップ---------------- */
#movie_top {
  padding: 50px 0 35px;
}
.movie_if {
  position: relative;
	width: 100%;
	max-width: 960px;
	margin: 0 auto;
  height: 540px;
  overflow: hidden;
}
.movie_if video {
  width: 100%;
  height: 100%;
}

.top_content {
	position: relative;
	width: 100%;
	max-width: 2000px;
	margin: 0 auto;
	background: url("../img/bg_top.png") no-repeat;
	background-position: center top;
	overflow-x: hidden;
}
/* トップ共通 */
.h2_1 {
	margin-bottom: 5px;
	line-height: 1;
	letter-spacing: .1em;
	font-size: 28px;
}
.h2_1_t {
	margin-bottom: 20px;
	line-height: 1;
	font-size: 130px;
}
.waku1 {
	width: 510px;
	padding: 25px 40px 110px;
	text-align: left;
	font-size: 20px;
  letter-spacing: 0.1rem;
	border: 3px solid #000;
	border-radius: 30px;
	color: #000;
	background: #EEEAD7;
	filter: drop-shadow(14px 14px 0 rgba(0,0,0,1));
}
.top_waku1 {
	position: absolute;
	top: 0;
	left: 12.3%;
}
.btn1 a {
	display: block;
	width: 190px;
	height: 70px;
	padding: 0 0 0 60px;
	text-align: left;
	text-decoration: none;
	font-size: 23px;
	background: url("../img/btn_more1.png") no-repeat center center / 190px auto;
	transition: all .3s;
  line-height: 2.8em;
}
.btn_r a {
	position: absolute;
	bottom: 20px;
	right: 30px;
}
.btn_r a:hover {
	right: 25px;
}

#top_services {
text-align: center;
position: relative;
}
.top_services1 {
display: flex;
width: calc((100% - 1000px) / 2 + 1000px);
margin-bottom: 50px;
}
.top_services1 .inner1{
background: url("../img/pipe_m_01l.png") repeat-x top right;
width: calc((100% - 1000px));
}
.top_services1 .inner2{
background: url("../img/pipe_m_01.png") no-repeat top left;
width: 100%;
max-width: 1000px;
position: relative;
text-align: left;
padding: 140px 15px 0;
}
.top_services1 .tate{
position: absolute;
top: 0;
right: 0;
width: 120px;
mix-blend-mode: overlay;
z-index: -1;
}
.top_services1 .tate img{
width: 100%;
}
.top_services1 .inner2 p{
	max-width: 780px;
  font-size: 20px;
}
.top_services2 {
	position: relative;
	margin: 0 auto;
  max-width: 1050px;
  padding: 0;
}
.top_services2 .top_img1{
text-align: right;
padding: 30px 0 0;
}
.top_services2 .top_img1 img{
width: 600px;
}
.top_services2 .waku1{
left: 15px;
}
.top_illust1 {
position: relative;
	margin: 0 auto;
  max-width: 1050px;
}
.top_illust1 img{
	position: absolute;
	bottom: 0;
	left: -120px;
	width: 650px;
  overflow: hidden;
  }
@media screen and (max-width:1000px) {
.top_services1 {
display: block;
width: 100%;
}
.top_services1 .inner1{
display: none;
}
}

#top_company {
  position: relative;
  padding: 200px 0 200px;
  margin-top: -110px;
}
#top_company .section_background {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  width: 100%;
  height: 100%;
  justify-content: center;
  overflow: hidden;
}
#top_company .section_background img {
  flex-shrink: 0;
  width: 100%;
  min-width: 2000px;
  height: 100%;
  object-fit: cover;
 clip-path: polygon(0 100%, 100% calc(100% - 216px), 100% 256px, 0 0);
  background-color: #8C2C0D; /* 画像が表示されなかった時用の背景色 */
}
#top_company .tate{
position: absolute;
top: 300px;
right: calc((100% - 1000px) / 2);
width: 120px;
mix-blend-mode: overlay;
}
#top_company .tate img{
width: 100%;
}
#top_company .section_inner {
  position: relative;
  width: 100%;
  max-width: 1050px;
  margin: auto;
  color: #fff;
}
.top_company_t1 {
  text-align: left;
}
#top_company .box ul{
width: 100%;
display: table;
margin-top: -70px;
}
#top_company .box li{
display: table-cell;
}
#top_company .box li:nth-of-type(1){
background: url("/img/top_img2.jpg") no-repeat center right / cover;
width: 30%;
}
#top_company .box li.text{
width: 70%;
position: relative;
padding-top: 110px;
padding-left: 50px;
}
#top_company .box li.text .top_illust2{
position: absolute;
top:-200px;
right: 0;
width: 450px;
}
#top_company .box li.text .top_illust2 img{
width: 100%;
}
#top_company .box li.text > p{
position: relative;
margin-bottom: 40px;
font-size: 20px;
text-align: left;
text-shadow: 0 0 5px #000;
}
@media screen and (max-width:1000px) {
#top_company .tate{right: 0;}
.top_company_t1 {padding-left: 15px;}
}

#top_works {
margin-top: -100px;
position: relative;
}
.top_works1 {
display: flex;
width: calc((100% - 1000px) / 2 + 1000px);
margin-left: calc((100% - 1000px) / 2 );
min-height: 380px;
}
.top_works1 .tate{
position: absolute;
top: 400px;
right: 0;
width: 120px;
mix-blend-mode: overlay;
z-index: -1;
}
.top_works1 .tate img{
width: 100%;
}
.top_works1 .inner1{
background: url("../img/pipe2.png") no-repeat top right / auto 380px;
width: 100%;
max-width: 1000px;
position: relative;
text-align: left;
}
.top_works1 .inner1 .h2_1{
margin-top: 10px;
}
.top_works1 .inner2{
background: url("../img/pipe2_02.png") repeat-x top left / auto 380px;
width: calc((100% - 1000px));
}
#top_works .box {
position: relative;
width: 100%;
max-width: 1050px;
margin: -180px auto 0;
}
#top_works .box ul{
width: 100%;
display: table;
}
#top_works .box li{
display: table-cell;
padding-bottom: 50px;
}
#top_works .box li:nth-of-type(1){
background: url("/img/top_img3.jpg") no-repeat center right / cover;
width: 40%;
}
#top_works .box li.text{
width: 60%;
position: relative;
padding-top: 0;
}
#top_works .waku2 {
	width: 510px;
	padding: 45px 45px 150px;
	text-align: left;
	font-size: 20px;
	border: 3px solid #000;
	border-radius: 30px;
	color: #000;
	background: #EEEAD7;
	filter: drop-shadow(14px 14px 0 rgba(0,0,0,1));
  margin-left: -50px;
  position: relative;
  z-index: 1;
}
#top_works .btn_c a {
	position: absolute;
	bottom: 20px;
	left: 0;
	right: 0;
	margin: 0 auto;
}
#top_works .btn_c a:hover {
	right: -5px;
}
.top_illust3 {
position: relative;
width: 100%;
overflow: hidden;
margin-top: -120px;
}
.top_illust3 img{
display: inline-block;
max-width: 1200px;
margin-left: -200px;
}
@media screen and (max-width:1000px) {
.top_works1 {width: 100%;margin-left: 0;}
.top_works1 .tate{right: 0;}
.top_works1 .inner1 {padding-left: 15px;
background: url("../img/pipe2.png") no-repeat top 30% right / 55% auto;width: 100%;}
.top_works1 .inner2{display: none;}
.top_illust3 img{max-width: 100%;}
}

#top_recruit {
position: relative;
padding: 150px 0 200px;
margin-top: -250px;
}
#top_recruit .section_background {
position: absolute;
top: 0;
left: 0;
display: flex;
width: 100%;
height: 100%;
justify-content: center;
overflow: hidden;
}
#top_recruit .section_background img {
flex-shrink: 0;
width: 100%;
min-width: 2000px;
height: 100%;
object-fit: cover;
clip-path: polygon(0 100%, 100% 100%, 100% 256px, 0 0);
background-color: #8C2C0D; /* 画像が表示されなかった時用の背景色 */
}
#top_recruit .tate{
position: absolute;
top: 200px;
right: calc((100% - 1000px) / 2);
width: 120px;
mix-blend-mode: overlay;
}
#top_recruit .tate img{
width: 100%;
}
#top_recruit .section_inner {
display: flex;
position: relative;
width: 100%;
margin: auto;
color: #fff;
padding-left: 15px;
}
#top_recruit .top_company_t1 {
text-align: left;
position: relative;
width: 50%;
max-width: 450px;
margin-left: calc((100% - 1000px) / 2);
}
#top_recruit .top_company_t1 h3{
font-size: 30px;
margin-bottom: 30px;
line-height: 1.3;
}
#top_recruit .top_company_t1 p{
margin-bottom: 15px;
line-height: 1.3;
}
#top_recruit .btn_r2{
position: relative;
width: 100%;
height: 100px;
}
#top_recruit .btn_r2 a {
position: absolute;
bottom: 0;
right: 0;
z-index: 1;
}
#top_recruit .btn_r2 a:hover {
right: -5px;
}
#top_recruit .illust_box {
width: calc((100% - 1000px) / 2 + 550px);
position: relative;
overflow: hidden;
min-height:670px; 
text-align: left;
}
.top_illust4 {
width: 100%;
max-width: 550px;
position: absolute;
bottom: 0;
left: 0;
}
.top_illust4 img{
width: 100%;
max-width: 570px;
position: absolute;
bottom: 0;
right: -70px;
}
@media screen and (max-width:1000px) {
#top_recruit .tate{right: 0;}
#top_recruit .top_company_t1 {margin-left:0;padding-left: 15px;}
#top_recruit .illust_box {width: 50%;min-height:450px;}
}

#copy {
position: relative;
padding: 170px 0 50px;
margin-top: -400px;
}
#copy .section_background {
position: absolute;
top: 0;
left: 0;
display: flex;
width: 100%;
height: 100%;
justify-content: center;
overflow: hidden;
}
#copy .section_background img {
flex-shrink: 0;
width: 100%;
min-width: 500px;
height: 100%;
object-fit: cover;
clip-path: polygon(0 100%, 100% 100%, 100% 0, 0 400px);
background-color: #8C2C0D; /* 画像が表示されなかった時用の背景色 */
}
#copy .txt {
	mix-blend-mode: overlay;
}
#copy h2 {
	margin-bottom: 30px;
	font-size: 95px;
  line-height: 1;
}
#copy h3 {
	margin-bottom: 20px;
	font-size: 40px;
	font-weight: bold;
}
#copy h3 span {
	position: relative;
}
#copy h3 span:before {
	display: inline-block;
	content: "";
	width: 70px;
	height: 1px;
	margin-right: 20px;
	background: #fff;
	vertical-align: 20px;
}
#copy h3 span:after {
	display: inline-block;
	content: "";
	width: 70px;
	height: 1px;
	margin-left: 20px;
	background: #fff;
	vertical-align: 20px;
}
#copy p {
	font-size: 30px;
	font-weight: bold;
}
@media screen and (max-width:1000px) {
#copy {padding: 200px 0 50px;}
}

#contact {
display: flex;
	padding-bottom: 30px;
  background: none;
  position: relative;
}
#contact .tate{
position: absolute;
top: 10px;
right: calc((100% - 1000px) / 2);
width: 100px;
mix-blend-mode: overlay;
}
#contact .tate img{
width: 100%;
}
#contact .top_illust5 {
position: relative;
width: 400px;
min-height: 400px;
margin-left: calc((100% - 1000px) / 2);
}
#contact .top_illust5 img{
display: block;
	position: absolute;
	bottom: 0;
	left: -120px;
	width: 500px;
  overflow: hidden;
  }
#contact .inner1{
max-width: 620px;
margin-top: 60px;
}
#contact .h2_2_t {
	margin-bottom: 10px;
	line-height: 1;
	font-size: 95px;
}
#contact .tel1 {
	font-size: 50px;
}
#contact .btn2{
margin-top: 30px;
}
#contact .btn2 a {
	display: block;
	height: 90px;
	margin: 0 auto;
	padding-top: 20px;
	text-align: center;
	text-decoration: none;
	font-size: 25px;
	color: #fff;
	background: #000;
	border: 3px solid #000;
	border-radius: 58px;
	transition: all .5s;
}
#contact .btn2 a:hover {
	color: #000;
	background: #fff;
}
#map {
	height: 374px;
}
@media screen and (max-width:1000px) {
#contact .tate {right: 0;}
}

/* 下層ページ共通---------------- */
h1 {
	margin-bottom: 5px;
	line-height: 1;
	letter-spacing: .1em;
	font-size: 28px;
  text-align: left;
}
h2.title {
	margin-bottom: 20px;
	line-height: 1;
	font-size: 130px;
  text-align: left;
}
.logo2 {
	position: absolute;
	bottom: 20px;
	right: 20px;
	z-index: 10;
}
@media screen and (max-width:1200px) {
  .logo2 {bottom: 20px;}
}
@media screen and (max-width:900px) {
  .logo2 {bottom: 20px;}
}


/* 業務案内 */
.head_services {
  position: relative;
	width: 100%;
	height: 495px;
	background: url("../img/main_services.jpg") no-repeat;
	background-size: cover;
	background-position: center center;
}
#services_title {
padding-top: 50px;
}
#services_title .box1 {
width: calc((100% - 1100px) / 2 + 1100px);
margin-left: calc((100% - 1100px) / 2);
display: flex;
}
#services_title .inner1{
position: relative;
min-width: 1100px;
background: url("/img/pipe4.png") no-repeat top right ;

}
#services_title .inner2{
min-height: 100px;
width: 100%;
background: url("../img/pipe4_r.png") repeat-x top left;
}
#services_title .tate{
position: absolute;
top: 110px;
right: 0;
width: 120px;
mix-blend-mode: overlay;
z-index: 1;
}
#services_title .tate img{
width: 100%;
}
#services_title .box2 {
position: relative;
width:100%;
max-width: 1100px;
margin: 0 auto;
}
.services_illust {
margin: 0 auto;
max-width: 1100px;
min-height: 310px;
}
.services_illust img{
position: absolute;
bottom: 0;
left: -120px;
width: 650px;
overflow: hidden;
}
#services_title .box2 p {
position: absolute;
top:100px;
right: 0;
width: 58%;
text-align: right;
font-size: 30px;
}
@media screen and (max-width:1100px) {
#services_title .box1 {width: 100%;margin-left: 0;padding-left: 15px;}
#services_title .inner1{min-width:  100%;width: 100%; background: url("/img/pipe4.png") no-repeat top right ;}
#services_title .inner2{display: none;}
.services_illust img{
left: -150px;}
#services_title .box2 p {
width: 70%;
font-size: 25px;
}
}
/*事業案内ページ内リンク
.content7 {
	position: relative;
	width: 98%;
	max-width: 1090px;
	margin: 0 auto;
	text-align: left;
	z-index: 10;
}
.page_navi_services {
	padding: 35px 0 24px;
}
.page_navi1 {
	display: flex;
	flex-wrap: nowrap;
	align-items: stretch;
}
.page_navi1 li {
	width: 24.3%;
	margin: 0 .35%;
}
.page_navi1 li a {
	display: block;
	padding: 20px 0;
	text-align: center;
	text-decoration: none;
	font-size: 16px;
	color: #fff;
	border: 1px solid #fff;
	transition: all .3s;
}
.page_navi1 li a:hover {
	color: #822B0C;
	background: #fff;
}
@media screen and (max-width:900px) {
	.page_navi1 li a {
		font-size: 14px;
	}
}
*/
#services1 {
  position: relative;
	padding: 50px 0 100px 0;
  background-image: url("/img/back2.jpg"),url("/img/back2.jpg");
  background-repeat: no-repeat,no-repeat;
  background-position: top center,bottom center;
  background-size: 100% auto, 100% auto;
}
.waku-cream {
position: relative;
  max-width: 1100px;
  margin: 0 auto;
	padding: 55px 4.8% 170px;
	color: #000;
	background: #EDE9D7;
	border: 8px solid #000;
	filter: drop-shadow(14px 14px 0 rgba(0,0,0,1));
  z-index: 2;
}
#services1 h2 {
	margin-bottom: 10px;
	text-align: center;
	mix-blend-mode: multiply;
}
.waku-cream_t1 {
	padding: 40px 0 30px;
	text-align: center;
	font-size: 30px;
	border-top: 1px solid #231815;
}
.waku-cream_1 {
	width: 98%;
	max-width: 930px;
	margin: 0 auto;
}
#services1 h3 {
	margin-bottom: 30px;
	padding: 8px 10px 10px;
	text-align: center;
	font-size: 30px;
	font-weight: bold;
	color: #fff;
	background: #231815;
  letter-spacing: 0.2rem;
}
.waku-cream_2 {
	padding: 0 20px 0 30px;
  text-align: left;
}
.p9 {
	margin-bottom: 50px;
}
.p10 {
	margin-bottom: 30px;
}
.ul3 {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	margin: 0 20px 65px 30px;
}
.ul3 li {
	width: 49%;
	margin-right: 2%;
}
.ul3 li:nth-child(2n) {
	margin-right: 0;
}

.ul4 {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	margin: 0 20px 90px;
}
.ul4 li {
	width: 32.6%;
	margin-right: 1.1%;
}
.ul4 li:nth-child(3n) {
	margin-right: 0;
}
.btn3 a {
	display: block;
	width: 220px;
	height: 82px;
	padding: 27px 0 0 40px;
	text-align: left;
  letter-spacing: .3rem;
	text-decoration: none;
	font-size: 16px;
	background: url("../img/btn_more3.png") no-repeat;
	transition: all .3s;
}
.btn_c2 a {
	position: absolute;
	left: 0;
	right: 0;
	margin: 0 auto;
}
.btn_c2 a:hover {
	right: -5px;
}


/* 会社概要 */
.head_company {
	width: 100%;
	height: 495px;
	background: url("../img/main_company.jpg") no-repeat;
	background-size: cover;
	background-position: center center;
}
.company_back{
background-image: url("/img/company_back.png"),url("/img/company_back.png"),url("/img/company_back.png"),url("/img/company_back.png");
background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
background-position: top -150px center, top 29% center, top 64% center, bottom 17.5% center;
}
.logo1 {
	position: absolute;
	top: 46px;
	left: 64px;
	z-index: 10;
}
#company_title {
position: relative;
padding-top: 50px;
min-height: 400px;
}
.company_title1 {
display: flex;
width: calc((100% - 1100px) / 2 + 1100px);
margin-bottom: 50px;
}
.company_title1 .inner1{
background: url("../img/pipe_m_01l.png") repeat-x top right;
width: calc((100% - 1100px));
}
.company_title1 .inner2{
background: url("../img/pipe_m_01.png") no-repeat top left;
width: 100%;
max-width: 1100px;
position: relative;
text-align: left;
padding: 140px 15px 0;
}
.company_title1 .tate{
position: absolute;
top: 0;
right: 0;
width: 120px;
mix-blend-mode: overlay;
}
.company_title1 .tate img{
width: 100%;
}
.company_illust1 {
	position: absolute;
	bottom: 0;
	right: calc((100% - 1100px) / 2);
	width: 400px;
	z-index: 1;
}
@media screen and (max-width:1100px) {
#company_title {min-height: 400px;}
.company_title1 {display: block;width: 100%;}
.company_title1 .inner1{display: none;}
.company_illust1 {right: 0;width: 350px;}
}

#company1 {
	position: relative;
	padding-bottom: 115px;
}
.content4 {
	width: 90.46%;
	margin-left: 9.54%;
	overflow-x: hidden;
}
@media screen and (min-width:1500px) {
	.content4 {
		width: 84%;
		margin-left: 16%;
	}
}
@media screen and (min-width:1800px) {
	.content4 {
		width: 78%;
		margin-left: 22%;
	}
}
.waku3 {
	padding: 80px 58px 75px;
	text-align: left;
	color: #000;
	background: #EDE9D7;
	border-top: 4px solid #000;
	border-left: 4px solid #000;
	border-bottom: 4px solid #000;
	border-top-left-radius: 80px;
	border-bottom-left-radius: 80px;
	filter: drop-shadow(14px 14px 0 rgba(0,0,0,1));
}
.waku3_content {
	width: 100%;
	max-width: 1052px;
}
.waku3_col1 {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	margin-bottom: 40px;
}
.waku3_col1_1 {
	width: 15.2%;
	margin-right: 2.8%;
}
.waku3_col1_2 {
	width: 48.8%;
	margin-right: 2.8%;
}
.waku3_col1_3 {
	width: 30.4%;
	padding-top: 14px;
	text-align: center;
}
.tate2 {
	mix-blend-mode: multiply;
}
.company_person1 {
	margin-bottom: 15px;
}
.company_post1 {
	margin-bottom: 10px;
	letter-spacing: .1em;
	font-size: 20px;
}
.waku3_col2 {
	display: flex;
	flex-wrap: nowrap;
	align-items: stretch;
}
.waku3_col2_1 {
	position: relative;
	width: 15.2%;
	margin-right: 2.8%;
}
.waku3_col2_1:after {
	position: absolute;
	top: 0;
	left: 40%;
	display: block;
	content: "";
	width: 1px;
	height: 100%;
	background: #221714;
}
.waku3_col2_2 {
	width: 82%;
}
.p6 {
	margin-bottom: 40px;
}
.waku3_col3 {
	display: flex;
	flex-wrap: nowrap;
	align-items: stretch;
}
.waku3_col3_1 {
	width: 64.2%;
}
.waku3_col3_2 {
	width: 32.4%;
	margin-right: 3.4%;
}
.company_name2 {
	position: relative;
	margin-bottom: 25px;
}
.company_name2:after {
	position: absolute;
	top: 30px;
	right: 0;
	display: block;
	content: "";
	width: calc(100% - 300px);
	height: 1px;
	background: #221714;
}
.company1_2 {
	margin-bottom: 60px;
}
.p7 {
	width: 80%;
}

#company2 {
	padding-bottom: 90px;
}
.content5 {
	width: 98%;
	max-width: 974px;
	margin: 0 auto;
}
.waku4 {
	padding: 50px 5.9% 50px;
	color: #000;
	background: #EDE9D7;
	border: 4px solid #000;
	filter: drop-shadow(14px 14px 0 rgba(0,0,0,1));
}
.h2_2 {
  text-align: center;
	mix-blend-mode: multiply;
  margin-bottom: 10px;
}
.h2_2 img{
width: 65%;
}
.table1 {
	width: 100%;
	max-width: 600px;
	margin: 0 auto;
	text-align: left;
}
.table1 tr th, .table1 tr td {
	padding: 25px 0;
	font-size: 20px;
	vertical-align: top;
	border-bottom: 1px solid #221714;
}
.table1 tr:last-child th, .table1 tr:last-child td {
	border-bottom: none;
}
.table1 tr th {
	width: 8em;
}

#company3 {
	padding-bottom: 240px;
}
.h2_3 {
  text-align: center;
	margin-bottom: 40px;
	mix-blend-mode: multiply;
}
.h2_3 img{
width: 65%;
}
.table2 {
	width: 100%;
	max-width: 730px;
	margin: 0 auto 60px;
	text-align: left;
}
.table2 tr th, .table2 tr td {
	padding: 15px 0;
	font-size: 20px;
	vertical-align: top;
	border-bottom: 1px solid #221714;
}
.table2 tr:last-child th, .table2 tr:last-child td {
	border-bottom: none;
}
.table2 tr th {
	width: 11em;
}
.company3_2 {
	width: 100%;
	max-width: 860px;
	margin: 0 auto;
}
.ul1 {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	width: 100%;
	margin-bottom: 54px;
}
.ul1 li {
	width: 32.7%;
	margin-right: .95%;
	text-align: left;
}
.ul1 li:nth-child(3n) {
	margin-right: 0;
}
.ul1_img {
	margin-bottom: 10px;
}
.ul1_tit {
	text-align: center;
}
.h3_1 {
	margin-bottom: 25px;
}
.ul2 {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	width: 100%;
}
.ul2 li {
	width: 32.7%;
	margin-right: .95%;
	margin-bottom: 10px;
	text-align: left;
}
.ul2 li:nth-child(3n) {
	margin-right: 0;
}

#company4 {
	padding-bottom: 75px;
}
.content6 {
	position: relative;
	width: 98%;
	max-width: 1080px;
	margin: 0 auto;
	text-align: left;
}
.company_illust2 {
	position: absolute;
	top: -86px;
	right: 30px;
	width: 67%;
	z-index: 1;
}
.company4_1 {
	position: relative;
	z-index: 10;
}
.h2_4 {
	margin: 0 0 24px 5.28%;
}
.waku5 {
	margin-bottom: 28px;
	color: #000;
	background: #EDE9D7;
	border: 5px solid #000;
	filter: drop-shadow(14px 14px 0 rgba(0,0,0,1));
}
.waku5_content {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
}
.waku5_col1 {
	width: 64.8%;
}
.waku5_col2 {
	width: 35.2%;
}
.waku5_col3 {
	display: flex;
	flex-wrap: wrap;
	align-items: stretch;
	width: 100%;
	color: #fff;
	background: #000;
}
.waku5_col4 {
	width: 75%;
	padding: 8px 0 8px 6.3%;
}
.waku5_col5 {
	width: 25%;
	padding-top: 18px;
	text-align: center;
	font-size: 12px;
}
.waku5_col6 {
	width: 100%;
	padding: 0 2% 0 7%;
}
.table3 {
	width: 100%;
}
.table3 tr th, .table3 tr td {
	padding: 16px 0;
	border-bottom: 1px solid #221714;
}
.table3 tr:last-child th, .table3 tr:last-child td {
	border-bottom: none;
}
.table3 tr th {
	width: 7em;
}
#copy.copy_com {
position: relative;
padding: 5px 0 50px;
margin-top: 0;
}
#copy.copy_com .section_background {
display: none;
}

#movie_sub {
  padding: 30px 0 60px;
}


/* 施工一覧 */
.head_works {
	width: 100%;
	height: 495px;
	background: url("../img/main_works.jpg") no-repeat;
	background-size: cover;
	background-position: center center;
  position: relative;
}
.works_back{
background: url("/img/back2.jpg") no-repeat top 654px center,url("/img/back2.jpg") no-repeat bottom center;
padding-bottom: 40px;
}
#works_title {
margin-top: 50px;
position: relative;
}
.works_title1 {
display: flex;
width: calc((100% - 1000px) / 2 + 1000px);
margin-left: calc((100% - 1000px) / 2 );
min-height: 380px;
}
.works_title1 .tate{
position: absolute;
bottom: -400px;
right: 0;
width: 120px;
mix-blend-mode: overlay;
z-index: -1;
}
.works_title1 .tate img{
width: 100%;
}
.works_title1 .inner1{
background: url("../img/pipe2.png") no-repeat top right / auto 380px;
width: 100%;
max-width: 1000px;
position: relative;
text-align: left;
}
.works_title1 .inner1 .h2_1{
margin-top: 10px;
}
.works_title1 .inner2{
background: url("../img/pipe2_02.png") repeat-x top left / auto 380px;
width: calc((100% - 1000px));
}
.works_illust1 {
	position: absolute;
	bottom: -300px;
	left: 0;
	width: 47.23%;
	mix-blend-mode: overlay;
	z-index: 1;
}
.works_illust2 {
	position: absolute;
	bottom: -300px;
	left: 0;
	width: 24.62%;
	z-index: 1;
}

@media screen and (max-width:1000px) {
.works_title1 {width: 100%;margin-left: 0;}
.works_title1 .tate{right: 0;}
.works_title1 .inner1 {padding-left: 15px;
background: url("../img/pipe2.png") no-repeat top 30% right / 55% auto;width: 100%;}
.works_title1 .inner2{display: none;}
}

/*
#works_title {
	min-height: 360px;
	padding-top: 70px;
}
.works_title1 {
	position: relative;
	width: 100%;
	padding-left: 6.9%;
	z-index: 10;
}
.works_title1:after {
	position: absolute;
	top: 0;
	right: 0;
	display: block;
	content: "";
	width: 53.5%;
	height: 446px;
	background: url("../img/pipe2.png") no-repeat;
	background-size: contain;
	z-index: 1;
}
@media screen and (max-width:1200px) {
	.works_title1:after {
		width: 48%;
	}
}
@media screen and (max-width:1100px) {
	.works_title1:after {
		top: 6vw;
		width: 40%;
	}
}
@media screen and (max-width:900px) {
	.works_title1:after {
		width: 32%;
	}
}
.works_title2 {
	position: absolute;
	top: 390px;
	right: 94px;
	z-index: 1;
}
.works_illust1 {
	position: absolute;
	bottom: -464px;
	left: 0;
	width: 47.23%;
	mix-blend-mode: overlay;
	z-index: 1;
}
.works_illust2 {
	position: absolute;
	bottom: -464px;
	left: 0;
	width: 24.62%;
	z-index: 1;
}
*/

#works1 {
margin-top: -146px;
padding-bottom: 50px;
}
.content12 {
	position: relative;
	width: 98%;
	max-width: 1090px;
	margin: 0 auto;
	text-align: left;
	z-index: 10;
}
#works1 .box {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
  }
#works1 .box li {
	position: relative;
	width: 23.9%;
	margin-right: 1.4%;
	margin-bottom: 55px;
	padding-top: 40px;
}
#works1 .box li:nth-child(4n) {
	margin-right: 0;
}
#works1 .box_no {
	position: absolute;
	top: 0;
	left: 0;
	font-size: 82px;
	color: #EDE9D7;
	-webkit-text-stroke: 2px #000;
  text-stroke: 2px #000;
	filter: drop-shadow(4px 4px 0 rgba(0,0,0,1));
	z-index: 1;
}
#works1 .box_box {
	position: relative;
	padding: 14px 14px 50px 14px;
	text-decoration: none;
	color: #221714;
	background: #EDE9D7;
	border: 4px solid #000;
	filter: drop-shadow(6px 6px 0 rgba(0,0,0,1));
	z-index: 2;
}
#works1 .box_box p{
margin-top: 10px;
}
#works1 .box_box p:first-child{
margin-top: 0;
text-decoration:none;
}
#works1 .box_box p span{
display: block;
padding: 3px;
margin-bottom: 3px;
border-bottom: 1px solid #aaa;
font-size: 14px;
}
#works1 .box_img1 {
	margin-bottom: 8px;
}
#works1 .box p {
	line-height: 1.4;
	font-size: 17px;
}
.btn5 a {
	position: absolute;
	bottom: 8px;
	right: 14px;
	display: block;
	width: 96px;
	height: 36px;
	padding: 8px 0 0 23px;
	text-align: left;
	text-decoration: none;
	font-size: 19px;
	background: url("../img/btn_more2.png") no-repeat;
	transition: all .3s;
}
.btn5 a:hover {
	right: 9px;
}

/* モーダルCSS */
.modal_area {
  display: none;
  position: fixed;
  z-index: 1000;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.modal_bg {
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,.5);
}
.modal_wrapper {
  position: absolute;
  top: 4%;
  left: 0;
	right: 0;
  /*transform: translate(-50%,-50%);*/
  width: 96%;
  max-width: 1190px;
	max-height: 92%;
	margin: 0 auto;
  padding: 50px 3% 70px 5%;
	text-align: left;
	color: #fff;
  background: rgba(0,0,0,.8);
	overflow-y: scroll;
	-ms-overflow-style: none;
  scrollbar-width: none;
}
.modal_wrapper::-webkit-scrollbar {
  display: none;
}
.close_modal {
	width: 140px;
	margin: 0 auto;
	font-size: 20px;
  cursor: pointer;
}
.close_modal:after {
	display: inline-block;
	content: "";
	width: 24px;
	height: 22px;
	margin-left: 8px;
	background: url("../img/icon3.png") no-repeat;
	vertical-align: -4px;
	transition: all .3s;
}
.close_modal:hover:after {
	margin-left: 13px;
}
.modal_head {
	display: flex;
	flex-wrap: nowrap;
	align-items: flex-start;
	margin-bottom: 20px;
}
.modal_no {
	width: 20%;
	line-height: 1;
	font-size: 167px;
}
.modal_title {
	width: 80%;
	padding: 10px 0 20px;
	line-height: 1.5;
	font-size: 30px;
	border-bottom: 5px solid #fff;
}
.modal_body1 {
	display: flex;
	flex-wrap: nowrap;
	align-items: flex-start;
	margin-bottom: 50px;
}
.modal_body1_1 {
	width: 37%;
	margin-right: 3%;
}
.modal_body1_2 {
	width: 60%;
}
.modal_body2 {
	margin-bottom: 50px;
}
.modal_body2_1 {
	margin-bottom: 30px;
}
.ul7 {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
}
.ul7 li {
	position: relative;
	width: 32.2%;
	margin-right: 1.7%;
}
.ul7 li:nth-child(3n) {
	margin-right: 0;
}
.table7 {
	width: 100%;
	margin-bottom: 20px;
}
.table7 tr th, .table7 tr td {
	padding: 10px 0;
	border-bottom: 1px solid #fff;
	font-size: 26px;
}
.table7 tr:last-child th, .table7 tr:last-child td {
	border-bottom: none;
}
.table7 tr th {
	width: 5.5em;
}
.modal_body p {
	line-height: 1.5;
	font-size: 18px;
}
.modal_slide {
	position: relative;
	width: 100%;
	margin-bottom: 50px;
}
.modai_slide_ul {
	display: flex;
	flex-wrap: nowrap;
	align-items: flex-start;
	width: 100%;
	max-width: 1090px;
	overflow-x: scroll;
	-webkit-overflow-scrolling: touch;
	-ms-overflow-style: none;
  scrollbar-width: none;
}
.modai_slide_ul::-webkit-scrollbar {
  display: none;
}
.modai_slide_ul li {
	flex-shrink: 0;
	width: 240px;
	margin-right: 7px;
}
.modai_slide_ul li:last-child {
	margin-right: 0;
}
.modal_slide_prev {
	position: absolute;
	top: calc(50% - 13px);
	left: 24px;
	z-index: 2;
}
.modal_slide_next {
	position: absolute;
	top: calc(50% - 13px);
	right: 24px;
	z-index: 2;
}
.modal_slide_prev img, .modal_slide_next img {
	cursor: pointer;
}
.works_hyo{
max-width: 1100px;
margin: 50px auto 100px;
position: relative;
}
.works_hyo .box_no {
	position: absolute;
	top: -85px;
	left: 10px;
	font-size: 70px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
	color: #EDE9D7;
	filter: drop-shadow(4px 4px 0 rgba(0,0,0,1));
	z-index: 1;
}
.works_hyo .box_box {
	position: relative;
	padding: 50px 14px 50px 14px;
	text-decoration: none;
	color: #221714;
	background: #EDE9D7;
	border: 4px solid #000;
	filter: drop-shadow(6px 6px 0 rgba(0,0,0,1));
	z-index: 2;
}
.works_hyo .box_box table{
text-align: left;
margin: 0 auto;
}
.works_hyo .box_box table th,
.works_hyo .box_box table td{
padding: 5px 10px;
font-family: 'Noto Sans JP', sans-serif;
font-size: 16px;
border-bottom: 1px solid #aaa;
}
.works_hyo .box_box table th{
vertical-align: top;
}
.works_hyo .box_box table td:nth-of-type(2){
font-size: 15px;
}
.works_hyo .box_box table tr:first-of-type th,
.works_hyo .box_box table tr:first-of-type td{
border-top: 1px solid #aaa;
}


#copy.copy_work {
position: relative;
padding: 55px 0 50px;
margin-top: 0;
}
#copy.copy_work .section_background {
display: none;
}




/* 採用情報 */
.head_recruit {
	width: 100%;
	height: 495px;
	background: url("../img/main_recruit.jpg") no-repeat;
	background-size: cover;
	background-position: center center;
  position: relative;
}
.recruit_back{
background-image: url("/img/company_back.png"),url("/img/company_back.png");
background-repeat: no-repeat, no-repeat;
background-position: top 110px center, top 27% center;
}
#recruit_title {
padding-top: 50px;
position: relative;
}
.recruit_title1 {
display: flex;
width: calc((100% - 1000px) / 2 + 1000px);
margin-left: calc((100% - 1000px) / 2 );
min-height: 380px;
}
.recruit_title1 .tate{
position: absolute;
bottom: -350px;
left: 0;
width: 120px;
mix-blend-mode: overlay;
}
.recruit_title1 .tate img{
width: 100%;
}
.recruit_title1 .inner1{
background: url("../img/pipe2.png") no-repeat top 30px right / auto 300px;
width: 100%;
max-width: 1000px;
position: relative;
text-align: left;
}
.recruit_title1 .inner1 .h2_1{
margin-top: 10px;
}
.recruit_title1 .inner2{
background: url("../img/pipe2_02.png") repeat-x top 30px left / auto 300px;
width: calc((100% - 1000px));
}
.recruit_illust1 {
	position: absolute;
	top: 180px;
	left: -100px;
  width: 100%;
  overflow-x: hidden;
}
.recruit_illust1 img{
	width: 1100px;
}
@media screen and (max-width:1000px) {
.recruit_title1 {width: 100%;margin-left: 0;}
.recruit_title1 .inner1 {padding-left: 15px;
background: url("../img/pipe2.png") no-repeat top 30% right / 55% auto;width: 100%;}
.recruit_title1 .inner2{display: none;}
}

#recruit_info {
margin-top: 80px;
	padding-bottom: 58px;
}
.waku7 {
max-width: 1100px;
margin: 0 auto;
	padding: 35px 4.6%;
	color: #000;
	background: #EDE9D7;
	border: 8px solid #000;
	filter: drop-shadow(14px 14px 0 rgba(0,0,0,1));
}
.waku7_t1 {
	margin-bottom: 30px;
	padding-bottom: 20px;
	text-align: center;
	font-size: 40px;
	font-weight: bold;
	border-bottom: 1px solid #231815;
}
.p11 {
	font-size: 20px;
}

.page_navi_recruit {
max-width: 1100px;
margin: 0 auto;
	padding-bottom: 95px;
}
.page_navi2 {
	display: flex;
	flex-wrap: nowrap;
	align-items: stretch;
}
.page_navi2 li {
	width: 19.4%;
	margin: 0 .3%;
}
.page_navi2 li a {
	display: block;
	padding: 20px 0;
	text-align: center;
	text-decoration: none;
	font-size: 16px;
	color: #fff;
	border: 1px solid #fff;
	transition: all .3s;
}
.page_navi2 li a:hover {
	color: #822B0C;
	background: #fff;
}
@media screen and (max-width:900px) {
	.page_navi2 li a {
		font-size: 14px;
	}
}

#recruit1 {
max-width: 1100px;
margin: 0 auto;
	padding-bottom: 50px;
}
.content8 {
	position: relative;
	width: 98%;
	max-width: 1160px;
	margin: 0 auto;
	text-align: left;
	z-index: 10;
}
.h2_9 {
	margin-bottom: 45px;
	text-align: center;
}
.h2_9.img_res img{
max-width: 600px;
}
.recruit1_1 {
	margin-bottom: 90px;
}
.waku8 {
	position: relative;
	width: 90%;
	max-width: 1065px;
	margin: 0 auto;
	padding: 30px 4.4%;
	border: 1px solid #fff;
}
.maru1 {
	position: absolute;
	top: -37px;
	left: -2%;
	width: 16.9%;
	z-index: 1;
}
.waku8_t1 {
	position: relative;
	margin-bottom: 20px;
	padding-left: 130px;
	line-height: 1.3;
	font-size: 40px;
	font-weight: bold;
	z-index: 10;
}
.waku8_t2 {
	width: 58%;
	padding-top: 20px;
	line-height: 1.6;
	font-size: 18px;
	border-top: 1px solid #fff;
}
.waku8_img1-1 {
	position: absolute;
	bottom: -40px;
	right: -3.2%;
	width: 42.3%;
	z-index: 1;
}
.waku8_img1-2 {
	position: absolute;
	bottom: -40px;
	right: -3.2%;
	width: 42.3%;
	z-index: 0;
}

.recruit1_2 {
	margin-bottom: 60px;
}
.maru2 {
	position: absolute;
	top: -35px;
	right: -4.8%;
	width: 16.9%;
	z-index: 1;
}
.waku8_t3 {
	position: relative;
	width: 58%;
	margin-left: 42%;
	margin-bottom: 20px;
	line-height: 1.3;
	text-align: center;
	font-size: 40px;
	font-weight: bold;
	z-index: 10;
}
.waku8_t4 {
	width: 58%;
	margin-left: 42%;
	padding-top: 20px;
	line-height: 1.6;
	font-size: 18px;
	border-top: 1px solid #fff;
}
.waku8_img2-1 {
	position: absolute;
	bottom: 0;
	left: -3.2%;
	width: 42.3%;
	z-index: 1;
}
.waku8_img2-2 {
	position: absolute;
	bottom: 0;
	left: -100px;
	width: 55%;
	z-index: 0;
  overflow-x: hidden;
}
.waku8_img3-1 {
	position: absolute;
	bottom: 10px;
	right: -3.2%;
	width: 42.3%;
	z-index: 1;
}
.waku8_img3-2 {
	position: absolute;
	bottom: 30px;
	right: 110px;
	width: 50%;
	z-index: 0;
  overflow-x: hidden;
}

#recruit2 {
max-width: 1100px;
margin: 0 auto;
padding-bottom: 160px;
}
.content9 {
	width: 96%;
	max-width: 1060px;
	margin: 0 auto;
	text-align: left;
}
.recruit2_1 {
	position: relative;
	min-height: 446px;
	padding-top: 90px;
}
.recruit_illust2 {
	position: absolute;
	bottom: -98px;
	left: -8px;
	width: 40%;
	z-index: 1;
}
.recruit_illust2 img{
width: 100%;
}
.h2_10 {
	width: 56%;
	margin: 0 0 40px 44%;
}
.recruit2_t1 {
	margin: 0 0 50px 53.7%;
	font-size: 37px;
}
.recruit2_2 {
	position: relative;
}
.waku9 {
	position: relative;
	width: 100%;
	padding: 70px 5%;
	text-align: left;
	border: 5px solid #000;
	border-radius: 50px;
	color: #000;
	background: #EEEAD7;
	filter: drop-shadow(10px 10px 0 rgba(0,0,0,1));
	z-index: 2;
}
.waku9_col {
	display: flex;
	flex-wrap: nowrap;
	align-items: flex-start;
}
.waku9_col1 {
	width: 100%;
  padding-left: 100px;
}
.dl_time1 {
	display: flex;
	flex-wrap: nowrap;
	align-items: flex-start;
	margin-bottom: 14px;
	font-size: 24px;
}
.dl_time1 dt {
	width: 130px;
}
.dl_time1 dt:before {
	display: inline-block;
	content: "";
	width: 22px;
	height: 22px;
	margin-right: 12px;
	background: url("../img/icon_time.png") no-repeat;
	vertical-align: -3px;
}
.dl_time1 dd {
	width: calc(100% - 130px);
}
.arrow1 {
	margin: 0 0 25px 64px;
}
.recruit_illust3 {
	position: absolute;
	bottom: -21px;
	right: 20px;
	z-index: 2;
}

#recruit3 {
	position: relative;
}
.recruit_illust4 {
	position: absolute;
	top: -58px;
	right: 0;
	width: 650px;
	z-index: 0;
}
.recruit3_1 {
	position: relative;
	width: 51%;
	z-index: 2;
}
.h2_11 {
	margin: 0 0 40px 22px;
}
.recruit3_2 {
	padding-top: 30px;
	border-top: 2px solid #fff;
}
.p12 {
	margin-bottom: 30px;
	line-height: 1.6;
	font-size: 20px;
}
.p13 {
	line-height: 1.6;
	font-size: 20px;
}
#recruit_step {
position: relative;
padding: 170px 0 300px;
margin-top: -165px;
}
#recruit_step .section_background {
position: absolute;
top: 0;
left: 0;
display: flex;
width: 100%;
height: 100%;
justify-content: center;
overflow: hidden;
}
#recruit_step .section_background img {
flex-shrink: 0;
width: 100%;
min-width: 2000px;
height: 100%;
object-fit: cover;
clip-path: polygon(0 100%, 100% calc(100% - 216px), 100% 256px, 0 0);
background-color: #8C2C0D; /* 画像が表示されなかった時用の背景色 */
}
@media screen and (max-width:1135px) {
.recruit3_1 {	width: 80%;}
}

.recruit3_3 {
	position: relative;
	width: 98%;
	max-width: 1100px;
	min-height: 618px;
	margin: 0 auto;
	text-align: left;
  margin-top: -40px;
}
.recruit_box1 {
	position: absolute;
	bottom: 0;
	left: 0;
	/*width: 25.4%;*/
	width: 298px;
	height: 618px;
	background: url("../img/recruit_box1.png") no-repeat;
	background-size: 100%;
	z-index: 1;
}
.recruit_box2 {
	position: absolute;
	bottom: 0;
	left: 22.85%;
	/*width: 26.94%;*/
	width: 316px;
	height: 618px;
	background: url("../img/recruit_box2.png") no-repeat;
	background-size: 100%;
	z-index: 2;
}
.recruit_box3 {
	position: absolute;
	bottom: 0;
	right: 26.17%;
	/*width: 24.72%;*/
	width: 290px;
	height: 618px;
	background: url("../img/recruit_box3.png") no-repeat;
	background-size: 100%;
	z-index: 3;
}
.recruit_box4 {
	position: absolute;
	bottom: 0;
	right: 0;
	/*width: 28.99%;*/
	width: 340px;
	height: 618px;
	background: url("../img/recruit_box4.png") no-repeat;
	background-size: 100%;
	z-index: 3;
}
.recruit_box_t1 {
	text-align: center;
	font-size: 14px;
	color: #000;
}
.recruit_box_t2 {
	font-size: 20px;
	text-shadow: 3px 3px 0 #4f200a, -3px -3px 0 #4f200a, -3px 3px 0 #4f200a, 3px -3px 0 #4f200a, 0px 3px 0 #4f200a, 0 -3px 0 #4f200a, -3px 0 0 #4f200a, 3px 0 0 #4f200a;
}
.recruit_box_t3 {
	letter-spacing: .1em;
	text-align: center;
	font-size: 28px;
	color: #000;
}
.recruit_box1_t1 {
	position: absolute;
	top: 43%;
	left: 8.3%;
	width: 64%;
}
.recruit_box1_t2 {
	position: absolute;
	bottom: 18%;
	left: 10%;
}
.recruit_box1_t3 {
	position: absolute;
	bottom: 5.7%;
	left: 0;
	width: 92%;
}
.recruit_box2_t1 {
	position: absolute;
	top: 27.5%;
	left: 12.3%;
	width: 60%;
}
.recruit_box2_t2 {
	position: absolute;
	bottom: 25.8%;
	left: 11%;
}
.recruit_box2_t3 {
	position: absolute;
	bottom: 12.4%;
	left: 5.7%;
	width: 87%;
}
.recruit_box3_t1 {
	position: absolute;
	top: 14.5%;
	left: 9.3%;
	width: 52%;
}
.recruit_box3_t2 {
	position: absolute;
	bottom: 35.6%;
	left: 2.7%;
}
.recruit_box3_t3 {
	position: absolute;
	bottom: 22.7%;
	left: 0;
	width: 94%;
}
.recruit_box4_t1 {
	position: absolute;
	top: 13%;
	left: 9.7%;
	width: 53%;
}
.recruit_box4_t2 {
	position: absolute;
	bottom: 43.7%;
	left: 11.7%;
}
.recruit_box4_t3 {
	position: absolute;
	bottom: 31.6%;
	left: 8.8%;
	width: 80.6%;
}
.recruit_box4_t4 {
	position: absolute;
	bottom: 5.5%;
	left: 14.7%;
	font-size: 20px;
	color: #000;
}
@media screen and (max-width:1000px) {
	.recruit_box2 {
		left: 18%;
	}
	.recruit_box3 {
		right: 24%;
	}
	.recruit_box_t1 {
		font-size: 12px;
	}
	.recruit_box_t2 {
		font-size: 16px;
	}
	.recruit_box_t3 {
		padding-left: 15px;
		text-align: left;
		font-size: 20px;
	}
	.recruit_box4_t4 {
		font-size: 16px;
	}
}

#recruit4 {
max-width: 1100px;
margin: -150px auto 0;
	position: relative;
	padding-bottom: 50px;
}
.content10 {
	width: 98%;
	text-align: left;
}
.recruit4_1 {
	position: relative;
}
.recruit_illust5 {
	position: absolute;
	bottom: -118px;
	left: 14px;
	width: 30%;
	z-index: 1;
}
.h2_12 {
	width: 51.4%;
	margin: 0 auto 25px;
  padding-left: 50px;
}
.waku10 {
	position: relative;
	margin-bottom: 30px;
	text-align: left;
	color: #000;
	background: #EEEAD7;
	border: 5px solid #000;
	filter: drop-shadow(10px 10px 0 rgba(0,0,0,1));
	z-index: 2;
}
.waku10_col {
	display: flex;
	flex-wrap: nowrap;
	align-items: flex-start;
}
.waku10_col1 {
	width: 100px;
	padding:0 0 20px;
	text-align: center;
}
.waku10_col2 {
	width: 196px;
}
.waku10_col3 {
	width: calc(100% - 100px);
	padding: 10px 35px 10px 30px;
}
.waku10_img1 {
	margin-bottom: 12px;
}
.waku10_t1 {
	margin-bottom: 20px;
	font-size: 16px;
  letter-spacing: 0.3rem;
}
.table5 {
	width: 100%;
}
.table5 tr th, .table5 tr td {
	padding: 11px 0;
	border-bottom: 1px solid #221714;
	font-size: 15px;
}
.table5 tr:last-child th, .table5 tr:last-child td {
	border-bottom: none;
}
.table5 tr th {
	width: 8em;
}

#recruit5 {
  background: url("/img/back2.jpg");
}
.recruit5_1 {
width: 100%;
max-width: 1100px;
margin: 0 auto;
	padding: 65px 0 130px;
	text-align: left;
}
.content11 {
	width: 98%;
	max-width: 1020px;
	margin: 0 auto;
	text-align: left;
}
.h2_13 {
	margin-bottom: 85px;
	text-align: center;
}
.accordion {
  width: 100%;
	border-top: 1px solid #fff;
}
.accordion > li {
  width: 100%;
  margin-bottom: 10px;
  border-bottom: 1px solid #fff;
}
.button_1 {
  position: relative;
  width: 100%;
  padding: 30px 70px 30px 5px;
  text-align: left;
	color: #fff;
  cursor: pointer;
  border: none;
  font-size: 25px;
  background: none;
}
.button_1:after {
  position: absolute;
  top: 37px;
  right: 30px;
  content: "";
  display: block;
  width: 32px;
  height: 32px;
  background: url(../img/icon1.png) no-repeat;
  background-size: 100%;
}
.button_1.active {
  transition: .4s;
}
.button_1.active:after {
  top: 37px;
  content: "";
  display: block;
  width: 32px;
  height: 32px;
  background: url(../img/icon2.png) no-repeat;
  background-size: 100%;
}
.accordion_in {
  width: 100%;
	padding: 20px 0 65px;
}
.table6 {
	width: 100%;
	margin-bottom: 60px;
	color: #000;
	background: #EDE9D7;
}
.table6 tr th, .table6 tr td {
	padding: 15px 30px;
	border-bottom: 1px solid #fff;
	font-size: 20px;
}
.table6 tr:last-child th, .table6 tr:last-child td {
	padding: 15px 30px 20px;
	border-bottom: none;
}
.table6 tr th {
	width: 7em;
	background: #DCD5B5;
}
.p14 {
	margin-bottom: 20px;
}
.btn4 a {
	position: relative;
	display: block;
	width: 222px;
	height: 76px;
	margin: 0 auto;
	padding: 26px 50px 0 0;;
	text-align: center;
	text-decoration: none;
	font-size: 20px;
	color: #fff;
	background: #000;
	border: 2px solid #000;
	border-radius: 38px;
}
.btn4 a:after {
	position: absolute;
	top: 26px;
	right: 43px;
	display: block;
	content: "";
	width: 24px;
	height: 22px;
	background: url("../img/icon3.png") no-repeat;
	background-size: 100%;
	transition: .5s;
}
.btn4 a:hover:after {
	right: 38px;
	transition: .5s;
}


/* お問合せ */
.head_contact {
position: relative;
	width: 100%;
	height: 495px;
	background: url("../img/main_contact.jpg") no-repeat;
	background-size: cover;
	background-position: center center;
}
#contact_title {
display: flex;
	padding-bottom: 30px;
  background: none;
  position: relative;
}
#contact_title .top_illust5 {
position: relative;
width: 400px;
min-height: 400px;
margin-left: calc((100% - 1000px) / 2);
}
#contact_title .top_illust5 img{
display: block;
	position: absolute;
	bottom: 0;
	left: -100px;
	width: 500px;
  overflow: hidden;
  }
#contact_title .inner1{
max-width: 600px;
margin-top: 100px;
margin-left: 50px;
text-align: left;
}
#contact_title .h2_2_t {
	margin-bottom: 10px;
	line-height: 1;
	font-size: 130px;
}
#contact_title .tel1 {
	font-size: 55px;
  margin-top: 20px;
}
#contact_title .btn2{
margin-top: 30px;
}
#contact_title .btn2 a {
	display: block;
	height: 90px;
	margin: 0 auto;
	padding-top: 20px;
	text-align: center;
	text-decoration: none;
	font-size: 25px;
	color: #fff;
	background: #000;
	border: 3px solid #000;
	border-radius: 58px;
	transition: all .5s;
}
#contact_title .btn2 a:hover {
	color: #000;
	background: #fff;
}
#map {
	height: 374px;
}
@media screen and (max-width:1000px) {
#contact_title .tate {right: 0;}
}
#contact1 {
	padding-bottom: 180px;
}
.content13 {
	width: 98%;
	max-width: 930px;
	margin: 0 auto;
	text-align: left;
}
.h2_14 {
	margin-bottom: 20px;
	font-size: 25px;
	font-weight: bold;
  letter-spacing: 0.3rem;
}
.waku11 {
	width: 100%;
	margin-bottom: 100px;
	padding: 35px;
	text-align: left;
	color: #231513;
	background: #fff;
}



/* 汎用スタイル---------------- */
.clearfix:after {
  content: "";
  display: block;
  height: 0;
  font-size: 0;
  clear: both;
  visibility: hidden;
}
.clear {
  clear: both;
}
.center {
  text-align: center;
}
.left {
  text-align: left;
}
.right {
  text-align: right;
}
.img100 img {
  width: 100%;
  height: auto;
}
.img_res img {
  max-width: 100%;
  height: auto;
}
.bold {
  font-weight: 600;
}
