@charset "utf-8";

.pc {display:none !important;}
.sp {display:block !important;}
.spBlock {display: block;}
.spNone {display: none;}
.spAlignL {text-align: left;}

.btn02 {
	max-width: 90%;
	margin: 0 auto;
}

html,body {cursor: pointer;}
/* =======================================

	Header CSS

========================================== */
#globalHeader {
background: -moz-linear-gradient(top,  rgba(255,255,255,1) 0%, rgba(255,255,255,0.4) 80%, rgba(255,255,255,0) 90%); /* FF3.6-15 */
 
background: -webkit-linear-gradient(top,  rgba(255,255,255,1) 0%,rgba(255,255,255,0.4) 80%,rgba(255,255,255,0) 90%); /* Chrome10-25,Safari5.1-6 */
 
background: linear-gradient(to bottom,  rgba(255,255,255,1) 0%,rgba(255,255,255,0.4) 80%,rgba(255,255,255,0) 90%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
 
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#00ffffff',GradientType=0 ); /* IE6-9 */
}

/* =======================================

	Structure CSS

========================================== */
.wrapperUnder {
	padding: 25px 0 0 0;
}

/* =======================================

	共通

========================================== */
.mb40 {margin-bottom: 20px !important;}
.mb60 {margin-bottom: 30px !important}
.mb100 {margin-bottom: 50px !important;}

.table01 {
	display: block;
}

.table01 tbody,
.table01 tr {
	display: block:
}

.table01 tr th {
	display: block;
	border-width: 0;
	padding: 10px 0;
	font-weight: bold;
}

.table02 tr th {
	text-align: center;
	font-size: 110%;
}

.table01 tr td {
	display: block;
	padding: 0 0 10px 0;
}

/* =======================================

	トップページ

========================================== */
.boxHomeMain {
	height: 100vh;
	overflow: hidden;
}

.boxHomeMain img {
	height:auto;
	object-position:100% 100%;
}

.home .slick-initialized .slick-slide {
    float: none;
    display: inline-block !important;
    vertical-align: bottom;
}

.home .slick-slide img {
	position: absolute;
	bottom: 0;
}

.boxHomeNews {
	margin: -80px 0 40px 0;
	padding: 20px 0;
	border-radius: 0;
}

.headerHome {
	text-align: center;
	margin: 0 0 20px 0;
	line-height: 180%;
	font-size: 120%;
	letter-spacing: 5px;
}

.boxHomeNews .inner div {
	display: block;
}

.boxHomeNews .inner div time {
	width: auto;
	display: inline-block;
	float: left;
	margin: 0 0 8px 0;
	padding: 4px 0 0 0;
}

.boxHomeNews .inner div dl {
	width: auto;
}

.boxHomeNews .inner div dl dt {
	float: none;
	width: auto;
	margin: 0 0 8px 10px;
	display: inline-block;
}

.boxHomeNews .inner div dl dd {
	float: none;
	width: auto;
	display: block;
}

.boxHomePickup {
	margin: 0 5px 50px 5px;
}

.boxHomePickup .inner {
	display: block;
}

.boxHomePickup .inner div {
	width: 100%;
	margin: 0 0 5px 0;
}

.boxHomePickup .btn01 {
	display: block;
	width: 240px;
	margin: 25px auto 0 auto;
	text-align: center;
	line-height: 130%;
	background-color: #ffffff;
	border-radius: 20px;
	padding: 10px 0 10px 0;
	border-width: 1px;
	border-style: solid;
	border-color: #000000;
}

.boxHomeRecruit {
	margin: 0 0 5px 0;
	padding: 45px 0 130px 0;
	border-radius: 0;
	background-image: url(../img/home/sp/bg_recruit.jpg);
}

.boxHomeRecruit dl {
	color: #ffffff;
	margin: 0 0 30px 0;
	padding: 20px 50px;
	position: relative;
	display: inline-block;
}

.boxHomeRecruit dl:before {
	content: "";
	background-image: url(../img/home/bg_recruit_01.png);
	background-size: 40px 40px;
	background-repeat: no-repeat;
	width: 40px;
	height: 40px;
	display: block;
	position: absolute;
	top: 0;
	left: 0;
}

.boxHomeRecruit dl:after {
	content: "";
	background-image: url(../img/home/bg_recruit_02.png);
	background-size: 40px 40px;
	background-repeat: no-repeat;
	width: 40px;
	height: 40px;
	display: block;
	position: absolute;
	bottom: 0;
	right: 0;
}

.boxHomeRecruit dl dt {
	font-weight: bold;
	font-size: 130%;
	margin: 0 0 25px 0;
}

.boxHomeAbout {
	margin: 0 0 50px 0;
	padding: 50px 2em 50px 2em;
	border-radius: 0;
	box-sizing: border-box;
}

.boxHomeProducts {
	margin: 0 0 70px 0;
}

.boxHomeProducts .headerHome h2 span:after {
	right: -20px;
}

.boxHomeProducts .inner {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin: 0 5%;
}

.boxHomeProducts .inner a {
	width: 49.5%;
	margin: 0 1% 5px 0;
}

.boxHomeProducts .inner a:nth-child(2n) {
	margin: 0 0 5px 0;
}

.boxHomeProducts .inner a:nth-child(6n) {
	margin: 0 0 5px 0;
}

.boxHomeBanner {
	margin: 0 0 30px 0;
}

.boxHomeBanner .inner a {
	display: block;
	width: 47%;
	margin: 0 6% 40px 0;
}

.boxHomeBanner .inner a:nth-child(2n) {
	margin: 0 0 40px 0;
}

.boxHomeBanner .inner a:last-child {
	margin: 0 0 40px 0;
}

/* =======================================

	お問い合わせ

========================================== */
.localNavi {
	padding: 0;
}

.localNavi li a {
	padding: 12px 0;
}

.localNavi li a span {
	padding: 0 0 0 18px;
	font-size: 90%;
}

.boxInquiry .inner a {
	width: 100%;
	margin: 0 0 25px 0;
}

.boxContactForm fieldset legend {
	width: 100%;
	float: none;
	padding: 20px 0 0 0;
}

.boxContactForm fieldset .boxInput {
	width: 100%;
	float: none;
	padding: 0 0 10px 0;
}

.boxContactForm fieldset .boxInput .input01 {
	width: 100%;
	margin: 0;
	font-size: 16px !important;
}

.boxContactForm fieldset .boxInput .input02 {
	width: 100%;
	margin: 0 0 10px 0;
	font-size: 16px !important;
}

.boxContactForm fieldset .boxInput .input02:nth-child(2) {
	margin: 0;
}

.boxContactForm fieldset .boxInput .input03 {
	width: 100%;
	margin: 0;
	font-size: 16px !important;
}

.boxContactForm fieldset .boxInput .input04 {
	width: 100%;
	margin: 0;
	font-size: 16px !important;
}

.boxContactForm fieldset .boxInput .input05 {
	width: 100%;
	margin: 0;
	font-size: 16px !important;
}

.btnSubmit {
	margin: 30px auto 0 auto;
}

.checkbox-parts{
	font-size: 85%;
}

/* =======================================

	お知らせ

========================================== */
.boxNewsIndex div {
	display: block;
	position: relative;
}

.boxNewsIndex div time {
	width: auto;
	display: inline-block;
	float: left;
	margin: 0 0 8px 0;
	padding: 2px 0 0 0;
}

.boxNewsIndex div dl {
	width: 100%;
}

.boxNewsIndex div dl dt {
	float: none;
	width: auto;
	display: inline-block;
	margin: 0 0 8px 10px;
	position: absolute;
	top: 15px;
	left: 5.75em;
}

.boxNewsIndex div dl dd {
	float: none;
	width: auto;
	box-sizing: border-box;
	display: block;
}

.boxCategoryNavi {
	margin: -30px 0 20px 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.boxCategoryNavi a {
	display: block;
	text-align: center;
	min-width: 48%;
	margin: 0 2% 15px 0;
	padding: 12px 40px;
	border-radius: 20px;
	background-color: #efefef;
}

.boxCategoryNavi a:nth-child(2n) {
	margin: 0 0 15px 0;
}

.headerNews {
	padding: 0 0 18px 0;
}

.headerNews p {
	margin: 0 0 20px 0;
	font-size: 90%;
}

.headerNews p time {
	font-size: 120%;
	letter-spacing: 2px;
}

.headerNews h1 {
	line-height: 150%;
	font-size: 150%;
}

/* =======================================

	作品紹介

========================================== */
.boxWorksIndex a,
.boxWorksIndex span {
	width: 48%;
	margin: 0 1% 20px 1%;
}

.boxWorksIndex p {
	margin: 10px 0 0 0;
}

.boxProductsDetail01 figure img {
	width: 100%;
	height: auto;
}

.boxProductsDetail01 section {
	display: block;
}

.boxProductsDetail01 figure {
	width: 100%;
	margin: 0 0 30px 0;
}

.boxProductsDetail01 div {
	width: 100%;
}

.linkProductsDetail li {
	display: block;
	margin: 0 5% 15px 5%;
}

.linkProductsDetail li a {
	min-width: auto;
}

.boxProductsDetail02 section div {
	padding: 30px 20px;
}

.boxProductsDetail02 section div p {
	text-align: left;
}

.boxProductsDetail03 .inner {
	display: block;
}

.boxProductsDetail03 .inner section {
	width: 100%;
	margin: 0 0 30px 0;
}

.boxProductsDetail03 .inner section figure {
	width: 50%;
	float: none;
	margin: 0 25% 20px 25%;
}

.boxProductsDetail03 .inner section div {
	float: none;
	width: 100%;
}

.boxProductsDetail03 .inner section div h3 {
	text-align: center;
}

.boxProductsDetail03 .inner section div a {
	text-align: center;
	border-width: 1px 0 1px 0;
	padding: 12px 0 12px 0;
}

.boxProductsDetail03 {
	margin: 0;
}

.boxProductsDetail03 p {
	text-align: center;
}

.boxProductsDetail04 ul {
	display: block;
	width: 80%;
	margin: 0 10%;
}

.boxProductsDetail04 ul li {
	margin: 0 0 12px 0;
	width: 100%;
}

.boxProductsDetail04 ul li a {
	display: block;
	text-align: center;
	position: relative;
	padding: 12px 0 12px 0;
	background-color: #ffffff;
	color: #000000;
	border-radius: 20px;
}

.boxProductsDetail04 ul li a:after {
	content: "";
	background-image: url(../img/common/ico_blank.png);
	background-repeat: no-repeat;
	background-size: 14px 14px;
	background-position: right center;
	display: block;
	width: 14px;
	height: 14px;
	position: absolute;
	top: 50%;
	right: 12px;
	margin: -7px 0 0 0;
}

.boxProductsDetail04 ul li a:hover {
	text-decoration: none;
	opacity: 0.7;
}

.boxProductsDetail04 ul li.other:after {
	top: auto;
	bottom: -25px;
	width: 100%;
	left: 0;
	text-align: center;
	right: auto;
}

.boxProductsDetail05 {
	margin: 0 -5% 40px -5%;
}

.boxProductsDetail05 iframe,
.boxProductsDetail05 video {
	height: 200px;
}

.boxProductsDetail06 {
	margin: -10px -5% 40px -5%;
	display: block;
}

.boxProductsDetail06 div {
	margin: 0;
	width: auto;
}

.boxProductsDetail06 div:nth-child(4n),
.boxProductsDetail06 div:last-child {
	margin: 0;
}

.boxProductsDetail06 div figure {
	padding: 0 5px;
}

.boxProductsDetail09 {
	margin: 0 5% 100px 5%;
}

/* =======================================

	採用情報

========================================== */
.boxHrDetailComment {
	padding: 20px;
	display: block;
}

.boxHrDetailComment .text {
	padding: 0 0 30px 0;
	width: 100%;
	border-width: 0 0 1px 0;
}

.boxHrDetailComment .text:before{
  content: "";
  position: absolute;
	top: inherit;
  bottom: -18px;
  left: 50%;
  margin-left: -11px;
  border: 9px solid transparent;
  border-top: 9px solid #FFF;
  z-index: 2;
}

.boxHrDetailComment.bg .text:before{
  width: 0;
height: 0;
border-style: solid;
border-width: 12px 11px 0 11px;
border-color: #eff3f8 transparent transparent transparent;
	margin-left: -12px;
	bottom: -11px;
}

.boxHrDetailComment .text:after{
  content: "";
  position: absolute;
	top: inherit;
  bottom: -21px;
  left: 50%;
  margin-left: -12px;
  border: 10px solid transparent;
  border-top: 10px solid #555;
  z-index: 1;
}

.boxHrDetailComment.bg .text:after{
width: 0;
height: 0;
border-style: solid;
border-width: 12px 11px 0 11px;
border-color: #000000 transparent transparent transparent;
	margin-left: -12px;
	bottom: -12px;
}

.boxHrDetailComment figure {
	width: 100%;
	padding: 30px 0 0 0;
	text-align: center;
}

.boxHrDetailComment figure img {
	position: relative;
	width: 50%;
}

.boxHrIndex01 {
	margin: 0 0 65px 0;
}

.boxHrIndex02 a {
	width: 100%;
	margin: 0 0 6px 0;
	padding: 37.5px 0;
}

.boxHrIndex02 span {
	width: 100%;
	margin: 0 0 6px 0;
	padding: 40px 0;
	font-size: 140% !important;
}

.btnHrIndex01 {
	width: 90%;
}

.bnrHrIndex01 {
	margin: 50px -5% 50px -5%;
}

.boxHrIndex03 dt span {
	display: inline-block;
	background-image: url(../img/hr/ico_instagram.png);
	background-repeat: no-repeat;
	background-position: top center;
	background-size: 50px 50px;
	padding: 67px 0 0 0;
	box-sizing: border-box;
	color: #004ea2;
	font-size: 140%;
	line-height: 150%;
	text-align: left;
}

.boxHrIndex03 dt span br {
	display: none;
}

.boxHrPhotos {
	display: block;
}

.boxHrPhotos figure {
	width: 100%;
}

.boxHrPhotos figure.vertical img {
	width: 100%;
}

.boxWorksPlace01 {
	text-align: center;
	line-height: 300%;
	padding: 0 20px;
}

.boxWorksPlace01 h2 {
	font-weight: bold;
	font-size: 120%;
}

.boxWorksPlace01 p {
	text-align: left;
	line-height: 200%;
}

.boxWorksPlace02 {
	margin: 0 0 40px 0;
}

.boxWorksPlace02 figure {
	float: none;
	width: 100%;
	box-sizing: border-box;
	margin: 0 0 20px 0;
	padding: 0 25%;
}

.boxWorksPlace02.imgRight figure {
	float: none;
}

.boxWorksPlace02 div {
	float: none;
	width: 100%;
}

.boxWorksPlace02.imgRight div {
	float: none;
}

.boxWorksPlace02 div h3 {
	border-width: 0 0 1px 0;
	border-style: solid;
	border-color: #000000;
	margin: 0 0 20px 0;
	padding: 0 0 5px 0;
	line-height: 130%;
	font-size: 150%;
	letter-spacing: 2px;
}

.boxWorksPlace02 div dl dt {
	line-height: 200%;
	margin: 0 0 15px 0;
}

.boxWorksPlace02 div dl dd {
	line-height: 180%;
}