@charset "UTF-8";

/*------------------------------------------------------
  HTML Element
  ------------------------------------------------------*/
html {
	font: 300 62.5%/2 "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
	font-weight: 500;
}

body {
	font-family: inherit;
	color: #626262;
}

html, body, h1, h2, h3, h4, h5, h6, a, p, span, em, small, strong, sub, sup, mark, del, ins, strike, abbr, dfn, blockquote, q, cite, code, pre, ol, ul, li, dl, dt, dd, div, section, article, main, aside, nav, header, hgroup, footer, img, figure, figcaption, address, time, audio, video, canvas, iframe, details, summary, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	border: 0;
}

a, p, span, ul, li, dl, dt, dd, div, section, tr, th, td {
	font-size: 1.6rem;
}

p {
	margin-bottom: 30px;
}

article, aside, footer, header, nav, section, main {
	display: block;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}


/*--------------------------------------------------------------
# Elements
--------------------------------------------------------------*/
html {
    box-sizing: border-box;
}

*,
*:before,
*:after {
    box-sizing: inherit;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
}

body {
    background: #fff;
}

img {
    height: auto;
    max-width: 100%;
    vertical-align: bottom;
}

h1,h2,h3,h4,h5,h6 {
    margin: 0;
    padding: 0;
    font-weight: normal;
}
h3{
	font-size: 22px;
	margin-bottom: 10px;
}

p {
    margin: 0;
    padding: 0;
}

ul,li {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

dl,dt,dd {
    margin: 0;
    padding: 0;
}

.pc {
    display: block;
}

.sp {
    display: none;
}

.fl {
    float: left;
}

.fr {
    float: right;
}
.pc-txt{
	display:inline;
}
.g-img{
	border: 1px solid #ddd;
}

/*--------------------------------------------------------------
# Clearings
--------------------------------------------------------------*/

.clear:after,
.clearfix:after,
[class*='-inner']:after {
    content: "";
    display: table;
    clear: both;
}


/*--------------------------------------------------------------
# Content
--------------------------------------------------------------*/

html,
body {
    height: 100%;
}

/*
[class*='-inner'] {
    width: 1140px;
    margin: auto;
}*/

.inner {
	width: calc(100% - 100px);
	max-width: 1000px;
	margin: 0 auto;
}


.w100 {
	width: 100%;
}

.mw100 {
	max-width: 100%;
}

.tt-u {
	text-transform: uppercase;
}

.no-marker {
	list-style-type: none;
}

.inner {
	width: calc(100% - 100px);
	max-width: 1000px;
	margin: 0 auto;
}

.content-header-title,
.content-header-white {
	margin-bottom: 40px;
	padding-bottom: 33px;
	text-align: center;
	font: normal 4.2rem/1.5 "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
}

.content-header-title {
	background: transparent url(../img/bg_content_header_title.png) center bottom no-repeat;
	color: #BF242B;
}

.content-header-white {
	background: transparent url(../img/bg_content_header_white.png) center bottom no-repeat;
	color: #fff;
}

.ta-c {
	text-align: center;
}
.ta-r {
	text-align: right;
}

.m_b20 {
	 margin-bottom: 20px;
}
.m_b40 {
	 margin-bottom: 40px;
}
.red{
	color: #BF242B;
}

.sec-in {
    max-width: 1000px;
    margin: 0 auto 120px;
}

.layout-type-1 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.layout-type-1:not(:last-of-type) {
    margin-bottom: 60px;
}
.layout-type-1 .img-area,.layout-type-1 .txt-area {
    width: 47%;
}
.layout-type-1 img{
	vertical-align: bottom;
    border: none;
    width: 100%;
}
.txt-type-1{
	display: inline-block;
    border-bottom: 2px solid #BF242B;
    letter-spacing: 0.1em;
    font-weight: bold;
	width: 100%;
	line-height: 1.5em;
	padding-bottom: 10px;
}
.txt-type-1_1line{
	padding: 21px 0;
}
.link-btn {
    display: table;
    margin: 30px auto;
    text-align: center;
}
.link-btn a {
    padding: 7px 64px;
    background: #FFF;
    color: #BF242B;
	border: 2px solid #BF242B;
	text-decoration: none;
    display: block;
	-webkit-transition: .3s;
    transition: .3s;
}
.link-btn a:hover {
	background: #BF242B;
	color: #FFF;
}
a{
	color:#BF242B;
	text-decoration: none;
}
a:hover{
	text-decoration: none;
}

/*--------------------------------------------------------------
# header
--------------------------------------------------------------*/

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	/*height: 100px;*/
	background: #FFFFFF;
	z-index: 10010;
	border-bottom: 1px solid #ebebeb;
}

.header-inner {
  /*  padding: 20px 0;*/
}

.header-inner .site-logo {
padding: 25px 20px;
}

.header-inner .site-logo a {
	display: block;
	line-height: 1.2;
	text-decoration: none;
	font-size: 2rem;
	font-weight: 700;
	color: #BF242B;
}

.header-inner .site-logo img{
	height: 50px;
}

/*--------------------------------------------------------------
# main-navigation
--------------------------------------------------------------*/

.main-navigation li {
	float: left;
	border-left: 1px solid #e1e1e1;
/*    margin-right: 45px;*/
}

.main-navigation li:last-child {
	margin-right: 0;
}

.main-navigation .page-header-nav-tel {
	width: 270px;
	border-left: none;
}

#menu a {
    display: block;
		padding: 34px 40px;
		text-align: center;
		text-decoration: none;
		color: inherit;
    -webkit-transition: .3s;
    transition: .3s;
}
#menu a:hover {
	background: #BF242B;
	color: #FFF;
}

#menu .current {
    color: #ff9090;
}


/*------------------------------------
# header tel
--------------------------------------*/

.page-header-nav-tel a {
	padding: 26px 0!important;
	background-color: #ff9090;
	font-size: 2.4rem;
	font-weight: bold;
	color: #fff!important;
}

.page-header-nav-tel a:hover,
.page-header-nav-tel a:active {
	color: #fff;
}

.page-header-nav-tel a::before {
	content: '';
	display: inline-block;
	width: 28px;
	height: 28px;
	margin-right: 10px;
	background: transparent url(../img/icon_tel_28x29.png) center center / cover no-repeat;
	/*vertical-align: top;*/
}

.page-header-nav-tel a span {
	font-size: 1.4rem;
	font-weight: 400;
}

/*------------------------------------------------------
  Footer
  ------------------------------------------------------*/

.page-footer {
	padding: 40px 0 10px;
	background-color: #FFF;
	border-top: 3px solid #BF242B;
}

.page-footer .inner {
	display: flex;
	justify-content: space-between;
	max-width: 1200px;
}

.page-footer-logo img{
	height: 50px;
}

.page-footer .copy {
	padding-top: 30px;
	text-align: center;
	font-size: 12px;
}
/*--------------------------------------------------------------
# top btn
--------------------------------------------------------------*/

#page-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    font-size: 100%;
}

#page-top a {
    background: #FFFFFF;
		border: 1px solid #BF242B;
    text-decoration: none;
    color: #BF242B;
    width: 60px;
    height: 60px;
    padding: 15px 15px 10px;
    text-align: center;
    display: block;
    border-radius: 50%;
    font-size: 10px;
	line-height: 11px;
    -webkit-transition: .3s;
    transition: .3s;
}
#page-top a span{
	font-size: 10px;
	text-align: center;
}

#page-top i {
    display: block;
    font-style: normal;
}

#page-top a:hover {
    text-decoration: none;
    color: #FFFFFF;
	background: #BF242B;
}


/*------------------------------------------------------
  TOP以外
  ------------------------------------------------------*/
.jumbotron {
	background: url(../img/jumbotron.jpg) no-repeat top center;
    height: auto;
    background-size: cover;
	margin-top: 100px;
	margin-bottom: 100px;
	height: 300px;
	position: relative;
}
.jumbotron h1{
	position: absolute;
    top: 50%;
	left: 50%;
	margin-top: -1em;
	text-align: center;
	font-size: 34px;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
}

/*------------------------------------------------------
  Top
  ------------------------------------------------------*/

#HOME .jumbotron {
	background: url(../img/jumbotron.jpg) no-repeat top center;
    height: auto;
    background-size: cover;
	margin-top: 100px;
	margin-bottom: 100px;
	height: 300px;
	position: relative;
}
#HOME .jumbotron h1{
	position: absolute;
    top: 32%;
	left: 80%;
}
#HOME .jumbotron h1 img{
	max-width: 999%;
	width: 240px;
}

#HOME .top-business {
	margin-bottom: 80px;
}
#HOME .top-business ul {
	margin: 0 auto;	
}
#HOME .top-business li {
	width: 50%;
	float: left;
	padding:2.5%;
	padding-top: 0;
}
#HOME .top-business li p{
	margin-top: 16px;
	font-size:18px;
	text-align: center;
}
#HOME .top-greeting{
	margin-bottom: 60px;
}

#HOME .box{
	display: flex;
}

#HOME .img-box{
	width: 40%;
	padding: 0 2.5%;
}
#HOME .txt-box{
	width: 60%;
	padding: 0 2.5%;
}

/*------------------------------------------------------
  BUSINESS
  ------------------------------------------------------*/
#BUSINESS .sec01 .txt-area{
	font-size: 30px;
	position: relative;
}
#BUSINESS .sec01 .message{
	font-size: 30px;
	position: absolute;
    top: 50%;
	margin-top: -2em;
}

#BUSINESS .sec02 .layout-type-1{
	padding-bottom: 0;
	margin-bottom: 0;
	border-bottom: 2px dotted #ddd;
}
#BUSINESS .sec02 .layout-type-1:last-child{
	border-bottom: none;
}
#BUSINESS .sec02 .layout-type-1 .txt-area{
	width: 50%;
    padding: 20px;
}
#BUSINESS .sec02 .layout-type-1 .txt-area:first-child{
	border-right: 2px dotted #ddd;
}
#BUSINESS .sec03 .layout-type-1 .txt-area{
	width: 50%;
    padding: 20px;
}
#BUSINESS .sec03 .layout-type-1 .txt-area:first-child{
	border-right: 2px dotted #ddd;
}

#BUSINESS .sec04 .about-type-1 dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    border-bottom: 1px solid #ddd;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-bottom: 10px;
    margin-bottom: 10px;
}
#BUSINESS .sec04 .about-type-1 dl dt {
    width: 20%;
}
#BUSINESS .sec04 .about-type-1 dl dd {
    width: 75%;
}


/*------------------------------------------------------
  ABOUT
  ------------------------------------------------------*/
#ABOUT .top-company {
	margin-bottom: 80px;
}

#ABOUT .top-company-info {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

#ABOUT .top-company-info-table {
	width: 100%;
	table-layout: fixed;
	border-collapse: collapse;
	margin-bottom: 60px;
}

#ABOUT .top-company-info-table th,
.top-company-info-table td {
	padding: 9px 0;
	text-align: center;
}

#ABOUT .top-company-info-table th {
	border-right: 1px solid #fff;
	border-bottom: 1px solid #fff;
	color: #fff;
}

#ABOUT .top-company-info-table td {
	border-right: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
}

#ABOUT .top-company-info-table tr th:nth-of-type(1) {
	width: 190px;
	background-color: #BF242B;
	font-weight: 400;
}

#ABOUT .top-company-info-table tr th:nth-of-type(2) {
	background-color: #BF242B;
	font-weight: 700;
}

#ABOUT .top-company-info-table tr th:nth-of-type(3) {
	background-color: #BF242B;
	font-weight: 700;
}

#ABOUT .top-company-info-table ul {
	display: flex;
	justify-content: center;
	align-items: flex-start;
}

#ABOUT .top-company-info-table ul li {
	margin: 0 20px;
}

#ABOUT .top-company-info-table ul img {
	margin-right: 15px;
	vertical-align: sub;
}

/*- added - */

#ABOUT .top-company-info-map-1clm {
	width: 50%;
	margin-bottom: 40px;
	margin-left: auto;
	margin-right: auto;
}

#ABOUT .top-company-info-map {
	width: calc(50% - 40px);
	margin-bottom: 40px;
}

#ABOUT .top-company-info-map div {
	position: relative;
	padding-top: 88%;
}

#ABOUT .top-company-info-map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}

#ABOUT .top-company-info-merchandise {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	width: calc(50% - 40px);
	padding: 0 29px 20px;
	border: 1px solid rgba(0, 0, 0, 0.5);
}

#ABOUT .top-company-info-merchandise dt {
	width: 100%;
	margin-bottom: 22px;
	border-bottom: 1px dotted #83b3cf;
	text-align: center;
	font-size: 2.6rem;
	font-family: "Hannnari", serif;
	color: #07689f;
}

#ABOUT .top-company-info-merchandise dd {
	width: 32.5%;
}

#ABOUT .top-company-info-merchandise ul {
	padding-left: 2.4rem;
}

#ABOUT .top-company-info-merchandise p {
	margin-bottom: 0;
}

#ABOUT .bussiness-type-1 dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    border-bottom: 1px solid #BF242B;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    padding-bottom: 15px;
    padding-top: 15px;
	background:#F7DDDE;
}
#ABOUT .bussiness-type-1 dl:first-child {
	border-top: 1px solid #BF242B;
}
#ABOUT .bussiness-type-1 dl:nth-child(2n){
	background:#fff;
}
#ABOUT .bussiness-type-1 dt span {
	background: #BF242B;
	color: #fff;
	padding: 4px 10px;
	margin-left: 20px;
}
#ABOUT .bussiness-type-1 dd a{
	color:#626262;
}
#ABOUT .bussiness-type-1 dd a:hover{
	filter: opacity(40%);
	-webkit-transition: .3s;
    transition: .3s;
}
#ABOUT .bussiness-type-1 dd li {
	float: left;
	margin-right: 30px;
}
#ABOUT .bussiness-type-1 dd span {
	color: #BF242B;
	border: 1px solid #BF242B;
	font-size: 14px;
	padding: 4px 10px;
	margin-left: 10px;
}
#ABOUT .sec02 .bussiness-type-1 dl dt {
    width: 20%;
}
#ABOUT .sec02 .bussiness-type-1 dl dd {
    width: 75%;
}
#ABOUT .sec03 .bussiness-type-1 dl dt {
    width: 40%;
}
#ABOUT .sec03 .bussiness-type-1 dl dd {
    width: 55%;
}

/*------------------------------------------------------
   recruit
  ------------------------------------------------------*/
#RECRUIT .sec01 h2{
	margin-bottom: 10px;
}
#RECRUIT .sec01 .occupation{
	margin: 0 auto;
	border: 1px solid #ddd;
	padding: 20px;
	width: 70%;
}
#RECRUIT .sec01 table{
	margin: 0 auto;
}
#RECRUIT .sec02 .txt-area p{
	margin-top: 70px;
}

/*--------------------------------------------------------------
# FORM
--------------------------------------------------------------*/

#FORM .contact-detail {
	width: 80%;
	height: 150px;
	margin: 20px auto 70px auto;
	font-size: 0.6em;
	line-height: 1.8;
	background-color: #f2f2f2;
	padding: 20px;
	overflow: scroll;
	overflow-x: hidden;
}

#FORM .contact .table {
	width: 80%;
	margin: 0 auto;
}

#FORM .contact-inner .table tr th {
	width: 40%;
}

#FORM .contact-inner input[type="text"],
#FORM .contact-inner textarea {
    width: 500px;
    padding-left: 3px;
}

#FORM .form-btn a {
    padding: 14px 64px;
    background: #fff;
    color: #BF242B;
	border: 2px solid #BF242B;
    display: block;
}

#FORM .contact-inner input[type="submit"] {
    border: none;
    box-shadow: none;
    padding: 14px 64px;
    background: #fff;
    color: #BF242B;
	border: 2px solid #BF242B;
    -webkit-appearance: none;
    border-radius: 0;
}

#FORM .contact-inner .form-btn {
    display: table;
    margin: 0 auto 50px;
    text-align: center;
}

#FORM .contact-inner .form-btn li {
    display: table-cell;
    vertical-align: top;
    padding: 0 20px;
}
/*
#FORM .form-page,
#FORM .form-page #FORM {
    height: 100%;
}
*/
#FORM .form-page .table {
    margin: 0 auto 50px;
}

#FORM .form-page .table tr th,
#FORM .form-page .table tr td {
    border-bottom: 1px solid #ccc;
}
#FORM .contact {
	margin-bottom: 100px;
}

#FORM .contact-info {
    margin-bottom: 25px;
    font-size: 15px;
}

#FORM .contact-detail {
    background-color: #f2f2f2;
    padding: 20px;
    overflow: scroll;
    overflow-x: hidden;
    font-size: 12px;
    line-height: 1.8;
    margin-bottom: 20px;
}

#FORM .contact .table {
    width: 80%;
    margin: 0 auto 0 auto;
}

#FORM .contact .table tr th {
    width: 30%;
}

#FORM .contact .table tr td {
    padding: 10px;
}


#FORM .contact input[type="text"],
#FORM .contact textarea {
    width: 70%;
    padding: 6px;
}

#FORM .form-btn a {
    padding: 7px 64px;
	background: #fff;
    color: #BF242B;
	border: 2px solid #BF242B;
	text-decoration: none;
    display: block;
	webkit-transition: .3s;
    transition: .3s;
}
#FORM .form-btn a:hover {
	background: #BF242B;
	color: #FFF;
}

#FORM .contact input[type="submit"] {
    border: none;
    box-shadow: none;
    padding: 14px 64px;
	background: #fff;
    color: #BF242B;
	border: 2px solid #BF242B;
    -webkit-appearance: none;
    border-radius: 0;
	cursor: pointer;
	cursor: hand;
	webkit-transition: .3s;
    transition: .3s;
}
#FORM .contact .hover:hover {
	background: #BF242B;
	color: #FFF;
}

#FORM .contact .form-btn {
    display: table;
    margin: 0 auto 30px;
    text-align: center;
}

#FORM .contact .form-btn li {
    display: table-cell;
    vertical-align: top;
    padding: 0 20px;
}

/*--------------------------------------------------------------
# 応募完了
--------------------------------------------------------------*/
#RECRUIT_COMP h2{
	text-align: center;
	margin-bottom: 30px;
	color: #BF242B;
	font-weight: bold;
}
#RECRUIT_COMP p.txtblock{
	text-align: center;
	font-size: 20px;
	margin-bottom: 150px;
}

/*--------------------------------------------------------------
# 応募エラー
--------------------------------------------------------------*/
#RECRUIT_ERROR h2{
	text-align: center;
	margin-bottom: 20px;
	font-weight: bold;
}
#RECRUIT_ERROR p.contact-info{
	text-align: center;
	margin-bottom: 60px;
}
#RECRUIT_ERROR .form-btn{
	margin-bottom: 60px;
}
#RECRUIT_ERROR .form-btn a{
	padding: 7px 64px;
    background: #FFF;
    color: #BF242B;
    border: 2px solid #BF242B;
    text-decoration: none;
    display: block;
    -webkit-transition: .3s;
    transition: .3s;
	width: 180px;
    margin: 0 auto;
	text-align: center;
}
#RECRUIT_ERROR .form-btn a:hover{
	background: #BF242B;
    color: #FFF;
}
/*--------------------------------------------------------------
# 応募確認
--------------------------------------------------------------*/
#RECRUIT_CONFIRM h2{
	text-align: center;
	margin-bottom: 10px;
	font-weight: bold;
}
#RECRUIT_CONFIRM .confirm_txt{
	text-align: center;
	margin-bottom: 20px;
}
#RECRUIT_CONFIRM table{
	margin: 0 auto;
	margin-bottom: 60px;
}
#RECRUIT_CONFIRM th,#RECRUIT_CONFIRM td{
	padding:10px;
}
#RECRUIT_CONFIRM .form-btn{
	width: 410px;
    margin: 0 auto;
	margin-bottom: 60px;
}
#RECRUIT_CONFIRM .form-btn li{
	float: left;
}
#RECRUIT_CONFIRM .form-btn li:first-child{
	margin-right: 30px;
}
#RECRUIT_CONFIRM .form-btn a{
	padding: 7px 64px;
    background: #FFF;
    color: #BF242B;
    border: 2px solid #BF242B;
    text-decoration: none;
    display: inline-block;
    -webkit-transition: .3s;
    transition: .3s;
	width: 180px;
    margin: 0 auto;
	text-align: center;
}
#RECRUIT_CONFIRM .form-btn a:hover{
	background: #BF242B;
	color: #FFF;
}
#RECRUIT_CONFIRM .input_btn{
	padding: 14px 64px;
    background: #FFF;
    color: #BF242B;
    border: 2px solid #BF242B;
    text-decoration: none;
    display: inline-block;
    -webkit-transition: .3s;
    transition: .3s;
	width: 180px;
	cursor: pointer;
	cursor: hand;
	text-align: center;
}
#RECRUIT_CONFIRM .input_btn:hover{
	background: #BF242B;
	color: #FFF;
}

/*--------------------------------------------------------------
# 1023-769
--------------------------------------------------------------*/
@media screen and (max-width: 1023px) {

	.header-inner .site-logo {
	padding: 16px 10px;
	}
	.header-inner .site-logo a {
		font-size: 1.5rem;
	}

	.page-header-nav-tel a {
		padding: 25px 0!important;
		font-size: 1.6rem;
	}

	#menu a {
	padding: 34px 30px;
	}
}


@media screen and (max-width: 769px) {
    /*--------------------------------------------------------------
# SP Typography
--------------------------------------------------------------*/
    html {
	font-size: 87.5%;
	-webkit-font-smoothing: antialiased;
	font-smoothing: antialiased;
    }
    body {
	-webkit-text-size-adjust: 100%;
    }
    /*--------------------------------------------------------------
# SP Elements
--------------------------------------------------------------*/
    .pc {
	display: none;
    }
    .sp {
	display: block;
    }
    .fl,
    .fr {
	float: none;
    }
	h2{
		font-size: 28px;
	}
	h3{
		font-size: 20px;
		line-height: 1.5em;
	}
	p{
		font-size:16px;
	}
	a{
		font-size:16px;
	}
	.pc-br{
		display: none;
	}
	.pc-txt{
	display:none;
	}
	
    /*--------------------------------------------------------------
# SP ham
--------------------------------------------------------------*/
    .hamburger {
	position: absolute;
	top: 0;
	right: 0;
	padding: 15px 15px;
	display: inline-block;
	cursor: pointer;
	transition-property: opacity, filter;
	transition-duration: 0.15s;
	transition-timing-function: linear;
	font: inherit;
	color: inherit;
	text-transform: none;
	background-color: transparent;
	border: 0;
	margin: 0;
	overflow: visible;
	width: 20%;
	height: 60px;
    }
    .hamburger-box {
	width: 30px;
	height: 24px;
	display: inline-block;
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	margin: auto;
    }
    .hamburger-inner {
	display: block;
	top: 50%;
	margin-top: -2px;
    }
    .hamburger-inner,
    .hamburger-inner::before,
    .hamburger-inner::after {
	width: 30px;
	height: 3px;
	background-color: #BF242B;
	border-radius: 4px;
	position: absolute;
	transition-property: transform;
	transition-duration: 0.15s;
	transition-timing-function: ease;
    }
    .hamburger-inner::before,
    .hamburger-inner::after {
	content: "";
	display: block;
    }
    .hamburger-inner::before {
	top: -10px;
    }
    .hamburger-inner::after {
	bottom: -10px;
    }
    /*
   * Spin
   */
    .hamburger--spin .hamburger-inner {
	transition-duration: 0.3s;
	transition-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    }
    .hamburger--spin .hamburger-inner::before {
	transition: top 0.1s 0.34s ease-in, opacity 0.1s ease-in;
    }
    .hamburger--spin .hamburger-inner::after {
	transition: bottom 0.1s 0.34s ease-in, transform 0.3s cubic-bezier(0.55, 0.055, 0.675, 0.19);
    }
    .is-active .hamburger--spin .hamburger-inner {
	transform: rotate(225deg);
	transition-delay: 0.14s;
	transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    }
    .is-active .hamburger--spin .hamburger-inner::before {
	top: 0;
	opacity: 0;
	transition: top 0.1s ease-out, opacity 0.1s 0.14s ease-out;
    }
    .is-active .hamburger--spin .hamburger-inner::after {
	bottom: 0;
	transform: rotate(-90deg);
	transition: bottom 0.1s ease-out, transform 0.3s 0.14s cubic-bezier(0.215, 0.61, 0.355, 1);
    }

/*--------------------------------------------------------------
# SP top btn
--------------------------------------------------------------*/
    #page-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
	font-size: 100%;
    }
    #page-top a {
	background: #BF242B;
	text-decoration: none;
	color: #fff;
	width: 44px;
	height: 44px;
	line-height: 44px;
	padding: 0;
	text-align: center;
	display: block;
	border-radius: 50%;
	font-size: 9px;
    }
    #page-top i {
	display: block;
	font-style: normal;
    }
    #page-top a:hover {
	text-decoration: none;
	background: #BF242B;
	color: #fff;
    }
	
/*--------------------------------------------------------------
# SP header
--------------------------------------------------------------*/
.site-header {
	position: fixed;
	top: 0;
	left: 0;
	height: 60px;
	width: 100%;
	z-index: 10020;
}
.header-inner {
	width: 100%;
	padding: 0;
}
.header-inner .site-logo {
/*width: 160px;*/
	position: absolute;
	top: -4px;
	left: 14px;
}
.header-inner .site-logo a {
	font-size: 1.5rem;
}
.header-inner .site-logo img{
	height: 40px;
}


/*--------------------------------------------------------------
# SP Content
--------------------------------------------------------------*/
html,
body {
	height: 100%;
}
    .inner {
	width: 95%;
	margin: auto;
    }

		.content-header-title,
		.content-header-white {
	margin-bottom: 30px;
	padding-bottom: 33px;
	text-align: center;
	font: normal 28px "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", "Hiragino Kaku Gothic ProN", "Hiragino Sans", sans-serif;
		}

.txtblock {
	width: 100%;
}

.box{
	display:block;
}

.img-box{
	width: 100%;
	padding: 0 ;
	margin-bottom: 16px;
}
.txt-box{
	width: 100%;
	padding: 0;
}
.jumbotron {
	margin-top: 60px;
	margin-bottom: 60px;
}
.sec-in{
	padding: 0 20px;
	margin:0 auto 80px;
}
.layout-type-1 .img-area, .layout-type-1 .txt-area{
    width: 100%;
}
.link-btn {
    display: table;
    margin: 30px auto;
    text-align: center;
}
.link-btn a {
    padding: 7px 64px;
    background: #BF242B;
	color: #FFF;
	border: 2px solid #BF242B;
	text-decoration: none;
    display: block;
	-webkit-transition: .3s;
    transition: .3s;
}
.link-btn a:hover {
	background: #BF242B;
	color: #FFF;
}
/*------------------------------------------------------
# SP Greeting
  ------------------------------------------------------*/

.top-greeting {
	margin-bottom: 75px;
}

    /*--------------------------------------------------------------
# SP footer
--------------------------------------------------------------*/
.page-footer {
	width: 100%;
	padding: 40px 0;
}

.page-footer .inner {
	display: block;
}

.page-footer-logo {
	width: 100%;
	font-size: 1.6rem;
	margin-bottom: 40px;
	padding: 0 20px;
}

.page-footer-info {
	padding: 0 20px;
	width: 100%;
}
	
.page-footer-info p{
	font-size: 16px;
	line-height: 1.5em;
}

.footer-inner {
	width: 100%;
	padding: 0;
}

.page-footer .copy {
	text-align: center;
	font-size: 12px;
	padding: 15px 0;
}
	
    /*--------------------------------------------------------------
# SP main-navigation
--------------------------------------------------------------*/
    .main-navigation {
	position: fixed;
	top: 0;
		left: 0;
	width: 100%;
	height: 100%;
	margin: 60px auto 0;
	background: #fff;
	visibility: hidden;
	opacity: 0;
	z-index: -1;
	-webkit-transition: .3s;
	transition: .3s;
    }
    .is-active .main-navigation {
	visibility: visible;
	opacity: 1;
	z-index: 10010;
    }
    .main-navigation li {
	float: none;
	width: 100%;
	background: #fff;
	border-bottom: 1px solid #ccc;
	text-align: center;
	margin: 0 auto;
    }
    .main-navigation li:last-child {
	margin-right: 0;
    }


.main-navigation .page-header-nav-tel {
	width: 100%;
	border-left: none;
}

    #menu a {
	display: block;
	padding: 8px 0;
	font-size: 22px;
	-webkit-transition: .3s;
	transition: .3s;
    }
    #menu a span {
	display: block;
	font-size: 12px;
	line-height: .8;
	text-align: center;
	-webkit-transition: .3s;
	transition: .3s;
    }

/*------------------------------------------------------
SP TOP以外
------------------------------------------------------*/
.jumbotron {
	background: url(../img/jumbotron_sp.jpg) no-repeat top center;
    height: auto;
    background-size: cover;
	margin-top: 60px;
	margin-bottom: 60px;
	height: 300px;
	position: relative;
}
.jumbotron h1{
	position: absolute;
    top: 50%;
	left: 50%;
	margin-top: -1em;
	text-align: center;
	font-size: 30px;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
}
/*------------------------------------------------------
SP Top
------------------------------------------------------*/
#HOME .jumbotron {
	background: url(../img/jumbotron_sp.jpg) no-repeat top center;
    height: auto;
    background-size: cover;
	margin-top: 60px;
	margin-bottom: 60px;
	height: 300px;
	position: relative;
}
#HOME .jumbotron h1{
	position: absolute;
    top: 32%;
	left: 74%;
}
#HOME .jumbotron h1 img{
	max-width:999%;
}

#HOME .box{
	display: inline-block;
}
#HOME .img-box,#HOME .txt-box{
	width: 100%;
}

#HOME .top-business {
	margin-bottom: 60px;
}
	
#HOME .top-business ul {
	margin: 0 auto;	
}
#HOME .top-business li {
	width: 100%;
	float: none;
	margin-bottom: 30px;
}
#HOME .top-business li p{
	margin-top: 16px;
	font-size: 20px;
	text-align: center;
}
#HOME .top-greeting{
	margin-bottom: 60px;
}
#HOME .top-greeting h3{
	font-size: 24px;
}
#HOME .top-greeting .img-box img{
	width: 100%;
}
#HOME .top-greeting .txt-box h3,#HOME .top-greeting .txt-box .txtblock{
	text-align: center;
}
	/*------------------------------------------------------
SP BUSINESS
------------------------------------------------------*/
#BUSINESS .jumbotron h1{
	margin-top: -2em;
    font-size: 26px;
}
	#BUSINESS .sec01 .layout-type-1{
		margin-bottom: 30px;
	}
	#BUSINESS .sec01 .message{
		position: static;
		font-size: 24px;
		line-height: 1.5em;
		margin: 0;
		text-align: center;
		margin-top: 20px;
	}
	#BUSINESS .sec02 .txt-area{
		margin-bottom: 40px;
	}
	#BUSINESS .sec02 .txt-area:last-child{
		margin-bottom: 0px;
	}
	#BUSINESS .sec02 .layout-type-1{
		border: none;
		margin-bottom: 60px;
	}
	#BUSINESS .sec02 .layout-type-1 .txt-area{
		width:100%;
		border: none;
		padding:0;
	}
	#BUSINESS .sec02 .layout-type-1 .txt-area:first-child{
		border: none;
	}
	#BUSINESS .sec03 .layout-type-1 .txt-area:first-child{
		margin-bottom: 60px;
	}
	#BUSINESS .sec04 .about-type-1 dl dt{
		width: 100%;
		font-weight: bold;
		font-size: 16px;
	}
	#BUSINESS .sec04 .about-type-1 dl dd{
		width: 100%;
		font-size: 16px;
	}
	#BUSINESS .sec04 .img-area{
		margin-bottom: 30px;
	}
	#BUSINESS .sec03 .layout-type-1 .txt-area:first-child{
		border: none;
		width: 100%;
		padding: 0;
	}
	#BUSINESS .sec03 .layout-type-1 .txt-area{
		border: none;
		width: 100%;
		padding: 0;
	}
/*------------------------------------------------------
SP ABOUT
------------------------------------------------------*/
	#ABOUT .bussiness-type-1 dl{
    padding-top: 0px;
	}
	#ABOUT .sec01 .top-company-info-table{
		margin-bottom:0;
	}
	#ABOUT .sec01 .top-company-info th,#BUSINESS .sec01 .top-company-info td{
		font-size: 16px;
	}
	#ABOUT .top-company-info-table tr th:nth-of-type(1){
		width:125px;
	}
	#ABOUT .sec02 .bussiness-type-1 dl dt{
		width: 100%;
		background: #BF242B;
		padding-left: 20px;
	}
	#ABOUT .sec02 .bussiness-type-1 dl dt span{
		padding:0;
		margin: 0;
	}
	#ABOUT .sec02 .bussiness-type-1 dl dd{
		padding: 6px 0 6px 20px;
	}
	#ABOUT .bussiness-type-1 dd li{
		 float:none;
		margin:0;
		margin-top: 16px;
	}
	#ABOUT .sec03 .bussiness-type-1 dl dt{
		width: 100%;
		background: #BF242B;
		padding-left: 20px;
	}
	#ABOUT .sec03 .bussiness-type-1 dl dt span{
		padding:0;
		margin: 0;
	}
	#ABOUT .sec03 .bussiness-type-1 dl dd{
		padding: 20px 0 6px 20px;
	}
	#ABOUT .top-company-info-table td{
		word-break: break-all;
	}

	
/*------------------------------------------------------
SP RECRUIT
------------------------------------------------------*/
	#RECRUIT h2{
		font-size: 24px;
	}
	#RECRUIT .sec01 .occupation {
		width: 100%;
		padding: 10px;
	}
	#RECRUIT .sec01 .occupation td{
		font-size: 16px;
	}
	#RECRUIT .link-btn a {
		padding: 7px 40px;
	}
	#RECRUIT .sec02 .txt-area p {
    margin-top: 0px;
}
/*------------------------------------------------------
SP FORM
----------------------------------------------------*/
	#FORM .jumbotron h1{
		margin-top: -2em;
	}
#FORM .contact {
	margin-bottom: 80px;
	}
#FORM .contact .txtblock {
	font-size: 0.8em;
}
#FORM .contact-detail {
	width: 100%;
	padding: 10px;
}
#FORM .contact .table {
	width: 100%;
}
#FORM .contact .table tr th {
	font-size: 18px;
	line-height: 1em;
	padding-top: 10px;
}
#FORM .contact span{
		font-size:14px;
}
#FORM .contact .table tr td {
	padding: 6px;
}
#FORM .contact input[type="text"],
#FORM .contact textarea {
	border: 1px solid #CCC;
	width: 100%;
	padding: 4px;
}
#FORM .contact .form-btn {
	margin: 0 auto 20px;
}
	#FORM .contact .form-btn a{
		font-size: 18px;
		width: 140px;
		padding: 7px 19px;
		background: #BF242B;
		color: #FFF;
	}
	#FORM .contact input[type="submit"]{
		font-size: 18px;
		font-weight: bold;
		width: 140px;
		padding: 14px 32px;
		background: #BF242B;
		color: #FFF;
	}
#FORM .contact .contact-detail p{
	font-size: 14px;
	}
#FORM .contact .table tr th.contact-txt{
	font-size: 16px;
	}	

/*------------------------------------------------------
SP RECRUIT_COMP
----------------------------------------------------*/
	#RECRUIT_COMP .jumbotron h1{
		top: 50%;
		line-height: 1.5em;
		margin: 0;
		margin-top: -2em;
	}
	#RECRUIT_COMP h2.content-header-blue{
		text-align: center;
		margin-bottom: 30px;
	}
	#RECRUIT_COMP .txtblock{
		text-align: center;
		margin-bottom: 100px;
	}
/*--------------------------------------------------------------
SP 応募確認
--------------------------------------------------------------*/
	#RECRUIT_CONFIRM .jumbotron h1{
		margin-top: -2em;
	}
	#RECRUIT_CONFIRM th,#RECRUIT_CONFIRM td{
		font-size: 16px;
	}
	#RECRUIT_CONFIRM .form-btn{
		width: 310px;
	}
	#RECRUIT_CONFIRM .form-btn li{
		width: 140px;
		margin-bottom: 20px
	}
	#RECRUIT_CONFIRM .form-btn a{
		background: #BF242B;
		color: #FFF;
		width: 140px;
		padding: 7px 50px;
		font-size: 18px;
	}
	#RECRUIT_CONFIRM .input_btn{
		background: #BF242B;
		color: #FFF;
		font-weight: bold;
		width: 140px;
		font-size: 18px;
		padding: 15px 50px;
	}
/*--------------------------------------------------------------
SP 応募エラー
--------------------------------------------------------------*/
#RECRUIT_ERROR .jumbotron h1{
		margin-top: -2em;
	}
#RECRUIT_ERROR .form-btn a{
    background: #BF242B;
    color: #FFF;
}
	

	
	
}
/*--------------------------------------------------------------
# 1023-769
--------------------------------------------------------------*/
@media screen and (max-width: 640px) {
		#HOME .jumbotron h1{
	position: absolute;
    top: 32%;
	left: 55%;
	}
}