@charset "utf-8";

/*--------------------------------------------------------------------------------------------------

   page
         - index
         

--------------------------------------------------------------------------------------------------*/
.container .navi-area-r {
  padding-top: 20px;
}
.container .flex-navi {
	display: flex;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
    flex-wrap: wrap;
	flex-wrap: -webkit-wrap;
	flex-wrap: -moz-wrap;
	flex-wrap: -ms-wrap;
}

nav .container .flex-navi li a {
	color: #FFF;
	text-decoration: none;
}

.container .flex-navi li a {
	color: #696969;
	text-decoration: underline;
}

.topfade1 {
	animation-name: topfade-in1;
	animation-duration: 1s;
	animation-timing-function: ease-out;
	animation-delay: 0.4s;
	animation-direction: normal;
	animation-fill-mode: forwards;
}

 @keyframes topfade-in1 {
 0% {
opacity: 0;
transform: translate3d(-30px, 0, 0);
}
 100% {
opacity: 1;
transform: translate3d(0, 0, 0);
}
	}
	
.topfade2 {
	animation-name: topfade-in2;
	animation-duration: 1.5s;
	animation-timing-function: ease-out;
	animation-delay: 1.5s;
	animation-direction: normal;
	animation-fill-mode: forwards;
}
 @keyframes topfade-in2 {
 0% {
opacity: 0;
transform: translate3d(-30px, 0, 0);
}
 100% {
opacity: 1;
transform: translate3d(0, 0, 0);
}
	}


@media all and (min-width: 1100px) {
	.container .navi-area {
		  font-size: 16px;
	}
	#about-recruit .container .navi-area {
           margin-top: 20px;
    }

	.container .navi-area {
	 color: #696969;
	  margin-bottom: 80px;
	}

	.container .nabi-next {
		margin: 7px 10px 0 10px;
	}	
}





/*--------------------------------------------------------------------------------------------
  index
--------------------------------------------------------------------------------------------*/
.bx-viewport {
  /*min-height: 540px;*/
		padding-bottom: 80px;
}

#bxslider img {
  width: 100%;
}

#bxslider .container {
  position: relative;
}

#bxslider .text {
  position: absolute;
  right: 8px;
  bottom: -24px;
  text-align: right;
}

#bxslider .text .font-jp {
  margin-bottom: 8px;
  font-size: 40px;
  font-weight: 900;
		opacity: 0;
}

#bxslider .text .font-en {
  font-size: 30px;
  font-style: italic;
  font-weight: 500;
		opacity: 0;
}

#bxslider .text p {
  color: #fff;
  background-color: #00388A;
  padding: 5px;
  display: inline-block;
  line-height: 1.2;
}

#about-top {
  padding: 20px 0 75px 0;
  background: url(../image/bg-about-top.png) no-repeat left top;
}

#about-top .container {
  padding-left: 45px;
  padding-right: 85px;
}

#about-top .info {
  justify-content: space-between;
  margin-top: 60px;
}

#about-top .photo {
  box-shadow: 17px 17px #B2D7DC;
  flex-shrink: 0
}

#about-top .text {
  width: 620px;
}

#about-top .text h3 {
  font-size: 30px;
  font-weight: 700;
  text-align: left;
  margin-bottom: 25px;
  line-height: 1.6;
}

#about-top .text p {
  line-height: 1.5;
  margin-bottom: 30px;
}

#about-top .btn-box {
  margin-top: 60px;
}

#about-top .btn-box .link-about {
  margin-bottom: 10px;
}

#about-top .btn-box .link-about {
  margin-bottom: 10px;
}
#profile-company .btn {
	margin-bottom: 100px;
}



#business-top {
  padding: 55px 0 90px 0;
}

#business-top {
  padding: 55px 0 90px 0;
  background-color: #E6E6E6;
}

#business-top .container {
  padding: 0 55px;
  justify-content: space-between;
}

#business-top .info li {
  width: 179px;
  margin-right: 48px;
  position: relative;
}

#business-top .info li:nth-child(2n+0) {
  margin-top: 32px;
}

#business-top .info li:last-child {
  margin-top: 64px;
}

#business-top .info li:nth-child(3n+0) {
  margin-right: 0;
}

#business-top .info li .number {
  width: 40px;
  height: 40px;
  text-align: center;
  line-height: 40px;
  font-size: 30px;
  color: #fff;
  background-color: #007C8A;
  position: absolute;
  left: 0;
  top: -23px;
}

#business-top .info li .title {
  padding: 20px 15px 40px 15px;
  font-size: 20px;
  color: #000;	
  background: #fff url(../image/icon-next-business-top.png) no-repeat right bottom;
}

#business-top .intro {
  width: 310px;
  margin-top: 25px;
}

#business-top .intro h2 {
  text-align: left;
  margin-bottom: 40px;
}

#business-top .intro p {
  margin-bottom: 25px;
}

#business-top .intro .btn {
  margin-top: 15px;
}

#recruit-top h2 {
  margin-top: 50px;
  margin-bottom: 35px;
}

#recruit-top .content {
  max-width: 100%;	
  background: #CBDFF3 url(../image/bg-recruit.png) no-repeat left top;
  background-size: contain;
  padding: 55px 0 55px 0;
}

#recruit-top .content .container {
  padding-right: 35px;
  justify-content: flex-end;
}

#recruit-top .info {
  width: 450px;
}

#recruit-top .info p {
  margin-bottom: 30px
}

#recruit-top .info .btn {
  margin-top: 10px;
}


	#motto-company, #motto-business, #about-top, #about-recruit, #motto-works {
  padding: 0 0 62px 0;
  }
  #motto-company h2 span {
  font-size: 36px;
  }
  #motto-company h2 {
  font-size: 20px;
  padding-left: 120px;
  }
  #motto-company p {
  font-size: 22px;
  line-height: 1.4;
  margin-top: 15px;
  }


/*--------------------------------------------------------------------------------------------
  company
--------------------------------------------------------------------------------------------*/
#motto-company, #motto-business, #motto-works {
  padding: 20px 0 112px 0;
}
#motto-works {
  padding: 20px 0 60px 0;
}

#motto-company h2 {
  font-size: 25px;
  color: #00388A;
  border-bottom: 1px solid #00388A;
  position: relative;
  padding-left: 140px;
}

#motto-business h2 {
  font-size: 25px;
  color: #00388A;
  border-bottom: 1px solid #00388A;
  position: relative;
  padding-left: 200px;
}

#motto-works h2 {
  font-size: 25px;
  color: #00388A;
  border-bottom: 1px solid #00388A;
  position: relative;
  padding-left: 130px;
}

#motto-company h2 span, #motto-business h2 span, #motto-works h2 span {
  font-size: 45px;
  padding-right: 30px;
  line-height: 1.1;
  letter-spacing: 3px;
  font-weight: 400;
  position: absolute;
  bottom: -4px;
  left: 0;
}

#motto-company p, #motto-business p, #motto-works p {
  font-size: 27px;
  line-height: 1.5;
  font-weight: 700;
  margin-top: 22px;
}

.h2-page {
	  width: 100%;
	  height: 85px;
	  padding-left: 54px;
	  color: #fff;
	  background: url(../image/bg1-h2-page.jpg) no-repeat left top, url(../image/bg2-h2-page.png) repeat-x;
	  position: relative;
	  padding-top: 20px;
 }
.h2-page .font-Oswald {
	  font-size: 40px;
	  letter-spacing: 3px;
	  font-weight: 400;
}
.h2-page .font-jp {
	  font-size: 16px;
	  position: absolute;
	  right: 9px;
	  font-weight: normal;
	  top: 50px;
}


#philosophy-company dl {
	width: 1000px;
	margin: 0 auto;
}

#philosophy-company dt {
  display: inline-block;
		font-weight: 600;
		margin-bottom: 10px;
}

#philosophy-company dd {
	margin-left: 20px;
  margin-bottom: 30px;
  display: inline-block;
}

#philosophy-company dt {
  width: 158px;
  font-size: 20px;
  vertical-align: top;
  color: #007B8A;
}

#philosophy-company dd {
	padding: 8px 0;
  padding-left: 20px;
  border-left: 1px solid #004030;
  line-height: 1.5;
}

#policy-company p {
  padding: 22px 0 75px 60px;
		font-size: 24px;
}

#profile-company .info1 {
  margin: 55px 0 78px 0;
  justify-content: space-between;
} 

#profile-company .info1 table {
  width: 500px;
}

#profile-company .info1 table th,
#profile-company .info1 table td {
  padding-bottom: 15px;
  vertical-align: top;
}

#profile-company .info1 table th span {
  width: 150px;
  background-color: #757584;
  /*font-size: 20px;*/
  color: #fff;
  /*line-height: 34px;*/
  display: block;
  font-weight: normal;
}

#profile-company .info1 table td {
  padding-left: 5px;
  line-height: 1.5;
}

#profile-company .info1 img {
  flex-shrink: 0
}

#profile-company .table-2 {
  width: 100%;
  margin-bottom: 60px;
}

#profile-company .table-2 tr:first-child td {
  padding-top: 0;
  background-color: rgba(0, 56, 178, 0.2);
  line-height: 40px;
  padding-left: 23px;
}

#profile-company .table-2 th,
#profile-company .table-2 td {
  padding-top: 35px;
  background-color: #E5EBF3;
}

#profile-company .table-2 th {
  padding-left: 30px;
  text-align: left;
  vertical-align: top;
}

#profile-company .table-2 td .text {
  width: 755px;
  padding-left: 35px;
  border-left: 2px solid #fff;
  line-height: 1.7;
}

#profile-company .table-2 td .text span {
  text-align: right;
}

#profile-company .table-2 td .text p {
  position: relative;
}

#profile-company .table-2 td .text span {
  position: absolute;
  right: 0;
}

#profile-company .table-2 tr:last-child th,
#profile-company .table-2 tr:last-child td {
  padding-bottom: 35px;
}

#profile-company .work-container {
    display: flex;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
    flex-wrap: wrap;
	flex-wrap: -webkit-wrap;
	flex-wrap: -moz-wrap;
	flex-wrap: -ms-wrap;


} 

#profile-company .info1 .text-info {
	margin-right: 5px;
	margin-bottom: 30px;
}

#profile-company  .work-top {
	margin-bottom: 40px;
	display: flex;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	align-items: center;
	align-items: -webkit-center;
	align-items: -moz-center;
	align-items: -ms-center;

	background-color: #afd2d6;
}

#profile-company  .number {
  background-color: #007C8A;	
  font-size: 25px;
  letter-spacing: 3px;
  font-weight: 400;
  color: #ffff;	
  padding: 7px;
}
#work-01 .work-top .work-top-title, #work-02 .work-top .work-top-title, #work-03 .work-top .work-top-title {
    font-size: 20px;
	margin-left: 20px;
}
#work-01 .work-top .work-top-title span, #work-02 .work-top .work-top-title span, #work-03 .work-top .work-top-title span {
   font-size: 30px;
  letter-spacing: 3px;
  color: #007C8A;
  margin-right: 30px;	
}

#profile-company .work-area {
		width: 380px;
	    margin-bottom: 30px;
}
#profile-company .work-area:not(:nth-child(3)) {
		margin-right: 30px;
}


#profile-company .work-box {
	max-width: 100%;
	padding: 20px 10px;
	border: solid 1px #007C8A;
	border-bottom: none;
}
#profile-company .work-box .work-ph {
	max-width: 100%;
	text-align: center;
}

#profile-company .work-info {
	max-width: 100%;
	border: solid 1px #007C8A;
	background-color: #f5f5f5;
	border-top: none;
}
#profile-company .work-info .work-info-area {
    padding: 10px 20px;
}

#profile-company .work-info .work-detail {
	padding: 10px 20px;
	border-top: dashed 1px #000;
}

#philosophy-company dl {
	  padding: 37px 0 60px 0;
	  }
/*--------------------------------------------------------------------------------------------
  contact
--------------------------------------------------------------------------------------------*/
.contact-contain {
	margin-top: -160px;
}

#about-top .contact-top {
    margin-top: 30px;
				margin-bottom: 30px;
	text-align: center;
}

.contactpan {
  padding: 20px 0 112px;
		margin-left: -40px;
}

#about-top .t-hosi {
	color: red;
}

#about-top .text-in{
 width: 100%;
  height: 25px;

 }

 #about-top .text-in3{
 width: 100%;
 height: 80px;
 }


 #about-top .text-in2{
  width: 40px;
  height: 25px;
}

 #about-top .text-in4{
 width: 100%;
 height: 120px;
 }
 #about-top input, textarea{
  border: solid 1px #c0c0c0;
}

#about-top .t-font-bold {
  font-weight: bold;
  width: 140px;
}

 #about-top .botton {
  width: 50px;
  padding: 10px 40px;
  background-color: red;
  text-align: center;
  margin-top: 20px;
  margin-left: auto;
  margin-right: auto;
}

 #about-top .botton a{
  color: #FFF;
  text-decoration: none;
}



#about-top .title-main {
  text-align: center;
  font-weight: bold;
}


#about-top .p-aki {
		margin-top: 10px;
	}	


@media (min-width: 640px) {

#about-top .title-main {
  font-size: 26px;
}


#about-top .title-sub {
  text-align: center;
  margin-bottom: 20px;
}


#about-top .table-area1 {
  width: 800px;
  border-top: solid 1px #c0c0c0;
  margin: 0 auto 20px auto;
  padding: 10px;

}
#about-top .table-area2 {
  width: 800px;
  border-top: solid 1px #c0c0c0;
  border-bottom: solid 1px #c0c0c0;
  margin: 0 auto 20px auto;
  padding: 10px;


}


#about-top table tr{
 height: 40px;
}




#about-top table td.tb-top{
 width: 100px;
}



#about-top table td{
 vertical-align: top;
 padding-top: 20px;
}




#about-top table tr td{
  text-align: left;
}


#about-top table .text-in{
  width: 350px;
  height:25px;
}

#about-top table .text-in3{
	width: 350px;
	height: 100px;
}

#about-top table .text-in2{
  width: 40px;
  height:25px;
}

#about-top table .text-in4{
  width: 450px;
  height:200px;

}
/*--------------------------------------------------------------------------------------------
  work
--------------------------------------------------------------------------------------------*/
	
#profile-company .work-area:last-of-type {
		margin-bottom: 100px;
}
	
	.jisseki {
	margin: 0 60px 40px;
	display: flex;
	flex-wrap: wrap;
}

.jisseki li {
	width: 50%;
	padding-left: 20px;
	position: relative;
	line-height: 2;
	border-left: 1px dotted #CCC;
}

.jisseki li::before {
	position: absolute;
	content: "";
	background-color: #007C8A;
	width: 8px;
	height: 8px;
	left: -5px;
	top: 13px;
	border-radius: 8px;
}

.worksh3 {
	margin: 0 0 10px;
	background-color: #afd2d6;
	padding: 8px;
	font-weight: 400;
}


/*--------------------------------------------------------------------------------------------
  contact
--------------------------------------------------------------------------------------------*/

#about-top .kakunin {
    margin-top: 30px;
	text-align: center;
	}
#about-top .kakunin-btn {
		  text-align: center;
	}	
	
.contactTb table {
	width: 80%;
	margin: 0 auto;
}

.contactTb table th {
	width: 26%;
	text-align: left;
	border-bottom: 1px solid #CCC;
	padding: 12px 8px !important;
	vertical-align: top;
}

.contactTb table th .hs {
	color: #F00;
	margin-left: 8px;
}

.contactTb table td {
	padding: 12px 8px !important;
	border-bottom: 1px solid #CCC;
}

.contactTb table td input[type="text"] {
	width: 100%;
	padding: 4px;
 font-family: 'Noto Sans JP', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
 font-size: 18px;
}

.contactTb table td input.s[type="text"] {
	width: 30%;
}

.contactTb table td textarea {
	width: 100%;
	display: block;
	height: 200px;
 font-family: 'Noto Sans JP', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS P Gothic", sans-serif;
 font-size: 18px;
	padding: 4px;
}

.contactTb table td .error {
	margin-top: 4px;
	padding: 2px 4px;
	color: #F00;
	background-color: #FFEAEA;
}

.kakunin-btn input[type="submit"] {
	margin: 0 10px;
	padding: 10px 20px;
	cursor: pointer;
}




/*--------------------------------------------------------------------------------------------
  recruit
--------------------------------------------------------------------------------------------*/

#about-recruit .recruit-name {
	margin: 50px 0 10px 150px;
	font-weight: bold;
	color: #00388A;
	padding: 20px;
	whidth: 40px;
}
#about-recruit .recruit-table {
	width: 800px;
	margin: 0 auto; 
	margin-bottom: 50px;
	font-size: 15px;
	border-radius: 5px;
}

#about-recruit .recruit-table td {
	border-bottom: 1px solid #CCC;
	padding: 12px;
}

#about-recruit  table .t-titl {
	padding: 12px;
	background-color: #f5f5f5;
	text-align: left;
	vertical-align: top;
}
	

#about-recruit .recrute-btn {
	margin-bottom: 50px;
}

#about-recruit .recrute-titl {
  min-width: 260px;
  line-height: 40px;
  min-height: 40px;
  background: #007C8A;
  color: #fff;
  text-align: center;
  margin-bottom: 10px;
}


#recrute-contant {
	display: flex;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
}

#about-recruit .recrute-ph {
	margin-left: 100px;
}

#about-recruit .recrute-ph img{
	margin-bottom: 30px;
}

.recWrap {
	display: flex;
}

}
	

