@charset "UTF-8";
*{
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	color:#000;
	font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
a{
	transition: all 0.3s ease 0s;
	text-decoration:none;
}
a:hover{
	filter: alpha(opacity=60);
	-moz-opacity:0.6;
	opacity:0.6;
}
a.cover{
	position:absolute;
	display:block;
	height:100%;
	width:100%;
	top:0;
	left:0;
	z-index:2;
}
a.cover:hover{
	background:rgba(256,256,256,0.4);
}

.mar_t_10{
	margin-top:10px;
}
.mar_t_20{
	margin-top:20px;
}
.mar_t_30{
	margin-top:30px;
}
.mar_t_40{
	margin-top:40px;
}
.mar_b_0{
	margin-bottom:0px;
}
.mar_b_10{
	margin-bottom:10px;
}
.mar_b_20{
	margin-bottom:20px;
}
.mar_b_30{
	margin-bottom:30px;
}
.mar_b_40{
	margin-bottom:40px;
}
.mar_b_50{
	margin-bottom:50px;
}
.mar_b_60{
	margin-bottom:60px;
}
.mar_b_70{
	margin-bottom:70px;
}
.mar_b_80{
	margin-bottom:80px;
}
.mar_b_100{
	margin-bottom:100px;
}
.f_l{
	float:left;
}
.f_r{
	float:right;
}
.basic_text{
	font-size:15px;
	line-height:2;
	color:#666;
}
.text-center{
	text-align:center;
}
.text-right{
	text-align:right;
}
.text-left{
	text-align:left;
}
.pc_on{
	display:block;
}
.sp_on{
	display:none;
}


/* ---------------------------------------- */
body{
}
.inner{
	max-width:1000px;
	width:100%;
	margin:auto;
	padding:100px 10px 120px;
}
h2{
	text-align:center;
}
h3{
	text-align:center;
}


/* ---------------------------------------- */
/* ヘッダー */

header#common-header {
	position:fixed;
	top:0;
	left:0;
	width:100%;
	z-index:100;
	background-image:url(./images/common/head_bg.jpg);
	background-position:center center;
	background-size:cover;
}
header#common-header .inner{
	max-width:1420px;
	width:100%;
	margin:auto;
	padding:0px;
	background:#f6891f;
}
header#common-header h1{
    position: relative;
    z-index: 5;
	display:inline-block;
	float:left;
}
header#common-header h1 a{
	display:inline-block;
	padding:17px 30px 50px 20px;
	background:#FFF;
}
header#common-header h1 a img {
    position: relative;
    top: 20px;
}
@media screen and (max-width:767px) {
    header#common-header h1 a img {
       
        top: 0px;
    }
}
header#common-header ul{
    position: relative;
    z-index: 2;
	display:table;
	float:right;
	table-layout:fixed;
    background-color: #f6891f;
}
header#common-header ul li{
	display:table-cell;
	padding:40px 20px 35px;
}
/*
header#common-header ul li:last-child{
	padding:40px 0 35px 20px;
}
*/
header#common-header ul li a{
	display:block;
	color:#FFF;
}



header#common-header button#common-header-toggle {
  /* メニュー表示ボタン */
  /* PCでは非表示 */
    position: relative;
    z-index: 4;
  float: right;
    margin: 15px 10px;
  display: none;
  /* 幅高さの基準を変更 */
  box-sizing: border-box;
  width: 40px;
  max-width: 15%;
  padding: 0;
  border: 2px solid #f6891f;
  border-radius: 5px;
  background-color: transparent;
  color: #f6891f;
  cursor: pointer;
  /* ※ 本要素のbeforeで縦横比を固定 */
}
header#common-header button#common-header-toggle::before {
  /* paddingが横幅基準であることを利用して高さを確保 */
  display: block;
  position: static;
  width: 100%;
  height: 0;
  margin: 0;
  padding: 100% 0 0;
  overflow: hidden;
  content: "";
}
header#common-header button#common-header-toggle span {
  /* メニュー表示ボタンバー */
  display: block;
  position: absolute;
  width: 80%;
  height: 2px;
  background-color: #f6891f;
  /* アニメーション変化 */
  -moz-transition: all 0.6s ease 0s;
  -o-transition: all 0.6s ease 0s;
  -webkit-transition: all 0.6s ease 0s;
  transition: all 0.6s ease 0s;
}
header#common-header button#common-header-toggle span:nth-child(1) {
  top: 24%;
  left: 10%;
}
header#common-header button#common-header-toggle span:nth-child(2) {
  top: 49%;
  left: 10%;
}
header#common-header button#common-header-toggle span:nth-child(3) {
  top: 74%;
  left: 10%;
}




/* ---------------------------------------- */
/* 表示領域 */

.wrapper {
    padding-top: 90px;
}





/* ---------------------------------------- */
/* 共通パーツ */

.white_orange{
	display:inline-block;
	background:#FFF;
	text-align:center;
	color:#f6891f;
	padding:20px 40px;
	border-radius: 40px;        /* CSS3草案 */  
	-webkit-border-radius: 40px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 40px;   /* Firefox用 */  
	font-size:14px;
}
.orange_white{
	display:inline-block;
	background:#f6891f;
	text-align:center;
	color:#FFF;
	padding:20px 40px;
	border-radius: 40px;        /* CSS3草案 */  
	-webkit-border-radius: 40px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 40px;   /* Firefox用 */  
	font-size:14px;
}
.replace-call-link {
    color: inherit;
}
.replace-call-link a {
    color: inherit;
    text-decoration: underline;
}



/* ---------------------------------------- */
/* トップページ */

.wrapper .main{
	width:100%;
	background-image:url(./images/top/main_bg.jpg);
	background-position:center center;
	background-size:cover;
	overflow:hidden;
}
.wrapper .main ul.slider li img {
	width:100%;
    height: auto;
}
.concept_area{
	background:#fbf4ea;
}
.concept_area .inner{
	text-align:center;
}
.concept_area h2{
	font-size:44px;
	margin-bottom:40px;
	color:#666;
}
.concept_area .concept_comment{
	text-align:center;
	font-size:18px;
	line-height:1.8;
	margin-bottom:40px;
}
.area_1{
	background-image:url(./images/top/top_img_1.jpg);
	background-repeat:no-repeat;
	background-position:calc(50% + 365px) top;
	margin-bottom:50px;
}
.area_1 .inner{
	max-width:1400px;
	width:100%;
	margin:auto;
	padding:20px 10px 22px;
}
.area_1 .left_text{
	float:left;
	width:470px;
	padding:70px 0 100px;
	height:710px;
}
.area_1 .left_text h3{
	display:block;
	padding-bottom:5px;
	padding-right:35px;
	margin-bottom:20px;
	font-size:44px;
	color:#666;
	border-bottom:2px solid #f6891f;
	text-align:left;
}
.area_1 .left_text .basic_text{
	margin-bottom:20px;
	padding-right:35px;
}
.area_2{
	background-image:url(./images/top/top_img_2.jpg);
	background-repeat:no-repeat;
	background-position:calc(50% - 365px) top;
}
.area_2 .inner{
	max-width:1400px;
	width:100%;
	margin:auto;
	padding:20px 10px 0px;
}
.area_2 .right_text{
	float:right;
	width:470px;
	padding:100px 0 100px;
	height:709px;
}
.area_2 .right_text h3{
	display:block;
	padding-bottom:5px;
	padding-left:35px;
	margin-bottom:20px;
	font-size:44px;
	color:#666;
	border-bottom:2px solid #f6891f;
	text-align:left;
}
.area_2 .right_text .basic_text{
	margin-bottom:20px;
	padding-left:35px;
}
.area_2 .right_text .orange_white{
	margin-left:35px;
}
.area_3 .company_area{
	width:50%;
	float:left;
	height:370px;
	background-image:url(./images/top/top_img_3.jpg);
	background-repeat:no-repeat;
	background-size:cover;
	background-position:right top;
	padding:100px 0;
}
.area_3 .company_area .inner{
	max-width:424px;
	width:80%;
	margin:auto;
	padding:0;
}
.area_3 .company_area .inner h3{
	font-size:32px;
	color:#FFF;
	margin-bottom:30px;
}
.area_3 .company_area .inner p{
	color:#FFF;
}
.area_3 .company_area .inner .btn{
	display:inline-block;
	border:3px solid #f6891f;
	text-align:center;
	color:#f6891f;
	padding:20px 40px;
	border-radius: 40px;        /* CSS3草案 */  
	-webkit-border-radius: 40px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 40px;   /* Firefox用 */  
	font-size:14px;
}
.area_3 .news_area{
	width:50%;
	float:left;
	height:370px;
	background:#fbf4ea;
	padding:70px 0;
}
.area_3 .news_area .inner{
	max-width:588px;
	width:80%;
	margin:auto;
	padding:0;
}
.area_3 .news_area .inner h3{
	font-size:32px;
	color:#666;
	margin-bottom:30px;
}
.area_3 .news_area .inner p{
	color:#FFF;
}
.area_3 .news_area .inner li{
	margin-bottom:15px;
}
.area_3 .news_area .inner li span{
    float: left;
    display: block;
/*    width: 6em;*/
}
.area_3 .news_area .inner li a{
    display: block;
    margin-left: 9em;
	color:#f6891f;
}
.area_3 .news_area .inner ul{
	margin-bottom:40px;
}
.area_3 .news_area .inner .btn{
	display:inline-block;
	border:3px solid #f6891f;
	text-align:center;
	color:#f6891f;
	padding:20px 40px;
	border-radius: 40px;        /* CSS3草案 */  
	-webkit-border-radius: 40px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 40px;   /* Firefox用 */  
	font-size:14px;
}

@media all and (max-width:1400px) {

    .area_1 .left_text{
        background: rgba(255,255,255,0.75);
    }
    .area_2 .right_text{
        background: rgba(255,255,255,0.75);
    }
}




/* ---------------------------------------- */
/* サブページ共通 */
.subpage_header {
    padding: 0 0 0;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    background-color: #f6891f;
}
.subpage_header .inner {
    max-width: 1400px;
}
.subpage_header .inner h2 {
    width: 45%;
    margin: 0 0 0 auto;
    color: #fff;
    text-align: right;
    font-size: 44px;
}
.subpage_header .inner p {
    width: 45%;
    margin: 10px 0 0 auto;
    color: #fff;
    text-align: left;
    font-size: 14px;
    line-height: 2;
}
.subpage_heading {
    position: relative;
    z-index: 1;
    color: #666;
    text-align: center;
    font-size: 40px;
}
.subpage_heading::before {
    position: absolute;
    z-index: -1;
    bottom: 0;
    left: 0;
    right: 0;
    display: block;
    width: 200px;
    height: 10px;
    margin: 0 auto;
    background-color: #f6891f;
    content: "";
}
.mini_column {
    background-color: #fbf4ea;
}
.mini_column .inner {
    padding-top: 70px;
    padding-bottom: 70px;
}
.mini_column h4 {
    position: relative;
    z-index: 1;
    padding-bottom: 10px;
    margin-bottom: 30px;
    color: #666;
    text-align: center;
    font-size: 18px;
}
.mini_column h4::before {
    position: absolute;
    z-index: -1;
    bottom: 0;
    left: 0;
    right: 0;
    display: block;
    width: 100px;
    height: 3px;
    margin: 0 auto;
    background-color: #666;
    content: "";
}
.mini_column .table_wrap {
    overflow-x: auto;
}
.mini_column .table_wrap table {
    width: 100%;
    border-collapse: collapse;
    border-top: 1px solid #666;
    border-left: 1px solid #666;
}
.mini_column .table_wrap table tr th,
.mini_column .table_wrap table tr td {
    padding: 10px 30px;
    border-right: 1px dotted #666;
    border-bottom: 1px dashed #666;
    text-align: center;
    vertical-align: top;
    font-size: 14px;
    line-height: 1.6;
}
.mini_column .table_wrap table tr.heading_row th {
    border-bottom: 1px solid #666;
}
.mini_column .table_wrap table tr th:last-child,
.mini_column .table_wrap table tr td:last-child {
    border-right: 1px solid #666;
}
.mini_column .table_wrap table tr:last-child th,
.mini_column .table_wrap table tr:last-child td {
    border-bottom: 1px solid #666;
}
.column_heading {
    position: relative;
    z-index: 1;
    padding-bottom: 10px;
    margin-bottom: 30px;
    color: #666;
    text-align: center;
    font-size: 18px;
}
.column_heading::before {
    position: absolute;
    z-index: -1;
    bottom: 0;
    left: 0;
    right: 0;
    display: block;
    width: 100px;
    height: 3px;
    margin: 0 auto;
    background-color: #666;
    content: "";
}
.image_band {
    width: 100%;
}
.image_band img {
    display: block;
    width: 100%;
    height: auto;
}
.image_box {
    width: 100%;
}
.image_box img {
    display: block;
    width: 100%;
    height: auto;
}
.map_band {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
}
.map_band .image {
    width: 50%;
}
.map_band .image img {
    display: block;
    width: 100%;
    height: auto;
}
.map_band .map {
    width: 50%;
}
.map_band .map iframe {
    width: 100%;
    height: 100%;
}
p.message-text {
    font-size: 14px;
    line-height: 1.8;
    text-align: left;
}
p.message-text a {
    color: #f6891f;
    text-decoration: underline;
}




/* ---------------------------------------- */
/* 事業内容 */

.subpage_header.about_header {
    background-image: url(images/about/about_heading.jpg);
}
.about_area_1 {
    
}
.about_area_1 .inner {
    
}
.about_area_1 .inner .article_list {
    
}
.about_area_1 .inner .article_list article {
    margin-top: 70px;
}
.about_area_1 .inner .article_list article::after {
    display: block;
    clear: both;
    width: 100%;
    height: 0;
    content: "";
}
.about_area_1 .inner .article_list article .text {
    width: 48%;
}
.about_area_1 .inner .article_list article .text h4 {
    padding-top: 30px;
    padding-bottom: 30px;
    border-bottom: 2px solid #f6891f;
    color: #666;
    text-align: left;
    font-size: 30px;
}
.about_area_1 .inner .article_list article .text p {
    padding-top: 10px;
    text-align: left;
    font-size: 14px;
    line-height: 2;
}
.about_area_1 .inner .article_list article:nth-child(2n+1) .text {
    float: left;
    padding-right: 30px;
}
.about_area_1 .inner .article_list article:nth-child(2n+1) .text h4 {
}
.about_area_1 .inner .article_list article:nth-child(2n+1) .text p {
}
.about_area_1 .inner .article_list article:nth-child(2n) .text {
    float: right;
    padding-left: 30px;
}
.about_area_1 .inner .article_list article:nth-child(2n) .text h4 {
}
.about_area_1 .inner .article_list article:nth-child(2n) .text p {
}
.about_area_1 .inner .article_list article .image {
    width: 52%;
}
.about_area_1 .inner .article_list article .image img {
    display: block;
    width: 100%;
    height: auto;
}
.about_area_1 .inner .article_list article:nth-child(2n+1) .image {
    float: right;
}
.about_area_1 .inner .article_list article:nth-child(2n) .image {
    float: left;
}
.about_area_2 {
    
}
.about_area_2 .inner {
    
}
.about_area_2 .inner .article_list {
    
}
.about_area_2 .inner .article_list article {
    margin-top: 70px;
}
.about_area_2 .inner .article_list article .heading_box {
    position: relative;
}
.about_area_2 .inner .article_list article .heading_box img {
    display: block;
    width: 100%;
    height: auto;
}
.about_area_2 .inner .article_list article .heading_box h4 {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 90%;
    margin-left: 0.25em;
    color: #fff;
    text-align: center;
    font-size: 30px;
    letter-spacing: 0.5em;
    transform: translate(-50%,-50%);
    text-shadow: 0 0 20px #000;
}
.about_area_2 .inner .article_list article p {
    padding-top: 10px;
    text-align: center;
    font-size: 14px;
    line-height: 2;
}
.about_area_2 .inner .article_list article p em {
    font-weight: bold;
    font-style: normal;
}
.about_area_3 {
    
}
.about_area_3 .inner {
    
}
.about_area_3 .inner .article_list {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
}
.about_area_3 .inner .article_list article {
    margin-top: 70px;
    margin-right: 5%;
    width: 30%;
}
.about_area_3 .inner .article_list article:nth-child(3n) {
    margin-right: 0;
}
.about_area_3 .inner .article_list article .image {
}
.about_area_3 .inner .article_list article .image img {
    display: block;
    width: 100%;
    height: auto;
}
.about_area_3 .inner .article_list article .text p {
    padding-top: 10px;
    text-align: left;
    font-size: 14px;
    line-height: 2;
}
.about_facility_nav {
    padding: 0 0 0;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    background-image: url(images/about/about_facility_nav.jpg);
}
.about_facility_nav .inner {
    text-align: center;
}
.about_facility_nav .inner a {
    position: relative;
    display: inline-block;
    padding: 50px 80px 50px 50px;
    background-color: #fff;
    text-align: center;
    font-size: 26px;
    color: #666;
}
.about_facility_nav .inner a + a {
    margin-left: 50px;
}
.about_facility_nav .inner a::before {
    position: absolute;
    right: 35px;
    bottom: 50%;
    display: block;
    width: 0;
    height: 40px;
    border-right: 2px solid #666;
    transform: matrix(1,0,0.75,1,0,0);
    content: "";
}
.about_facility_nav .inner a::after {
    position: absolute;
    right: 35px;
    top: 50%;
    display: block;
    width: 0;
    height: 40px;
    border-right: 2px solid #666;
    transform: matrix(1,0,-0.75,1,0,0);
    content: "";
}




/* ---------------------------------------- */
/* 設備紹介 */

.subpage_header.facility_header {
    background-image: url(images/facility/facility_heading.jpg);
}
.facility_area_1 {
    
}
.facility_area_1 .inner {
    
}
.facility_area_1 .inner .article_list {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
}
.facility_area_1 .inner .article_list article {
    margin-top: 70px;
    margin-right: 5%;
    width: 30%;
}
.facility_area_1 .inner .article_list article:nth-child(3n) {
    margin-right: 0;
}
.facility_area_1 .inner .article_list article .image {
}
.facility_area_1 .inner .article_list article .image img {
    display: block;
    width: 100%;
    height: auto;
}
.facility_area_1 .inner .article_list article .text h4 {
    padding-top: 10px;
    text-align: center;
    font-size: 14px;
    line-height: 2;
}
.facility_area_1 .inner .article_list article .text p {
    text-align: center;
    font-size: 11px;
    line-height: 2;
}
.facility_area_2 {
    
}
.facility_area_2 .inner {
    
}
.facility_area_2 .inner .article_list {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
}
.facility_area_2 .inner .article_list article {
    margin-top: 70px;
    margin-right: 5%;
    width: 30%;
}
.facility_area_2 .inner .article_list article:nth-child(3n) {
    margin-right: 0;
}
.facility_area_2 .inner .article_list article .image {
}
.facility_area_2 .inner .article_list article .image img {
    display: block;
    width: 100%;
    height: auto;
}
.facility_area_2 .inner .article_list article .text h4 {
    padding-top: 10px;
    text-align: center;
    font-size: 14px;
    line-height: 2;
}
.facility_area_2 .inner .article_list article .text p {
    text-align: center;
    font-size: 11px;
    line-height: 2;
}






/* ---------------------------------------- */
/* 採用情報 */

.subpage_header.recruit_header {
    background-image: url(images/recruit/recruit_heading.jpg);
}
.recruit_area_1 {
    
}
.recruit_area_1 .inner {
    
}
.recruit_area_1 .inner .article_list {
    
}
.recruit_area_1 .inner .article_list article {
    margin-top: 70px;
}
.recruit_area_1 .inner .article_list article::after {
    display: block;
    clear: both;
    width: 100%;
    height: 0;
    content: "";
}
.recruit_area_1 .inner .article_list article .text {
}
.recruit_area_1 .inner .article_list article .text h4 {
    padding-top: 30px;
    padding-bottom: 30px;
    border-bottom: 2px solid #f6891f;
    color: #666;
    text-align: left;
    font-size: 30px;
}
.recruit_area_1 .inner .article_list article .text p {
    padding-top: 10px;
    text-align: left;
    font-size: 14px;
    line-height: 2;
}
.recruit_area_1 .inner .article_list article .image {
    width: 52%;
    margin-bottom: 30px;
}
.recruit_area_1 .inner .article_list article .image img {
    display: block;
    width: 100%;
    height: auto;
}
.recruit_area_1 .inner .article_list article:nth-child(2n+1) .image {
    float: left;
    margin-right: 30px;
}
.recruit_area_1 .inner .article_list article:nth-child(2n) .image {
    float: right;
    margin-left: 30px;
}
.recruit_area_2 {
    
}
.recruit_area_2 .inner {
    
}
.recruit_area_2 .inner:first-child {
    padding-bottom: 50px;
}
.recruit_area_2 .image_band + .inner {
    padding-top: 10px;
}
.recruit_area_2 .inner .article_list {
    margin-bottom: 140px;
}
.recruit_area_2 .inner .article_list article {
    margin-top: 70px;
    padding-bottom: 50px;
    border-bottom: 1px solid #ccc;
}
.recruit_area_2 .inner .article_list article:last-child {
    padding-bottom: 0;
    border-bottom: 0px none;
}
.recruit_area_2 .inner .article_list article::after {
    display: block;
    clear: both;
    width: 100%;
    height: 0;
    content: "";
}
.recruit_area_2 .inner .article_list article .text {
}
.recruit_area_2 .inner .article_list article .text h4 {
    text-align: left;
    font-size: 18px;
    margin-bottom: 10px;
}
.recruit_area_2 .inner .article_list article .text p {
    padding-top: 10px;
    text-align: left;
    font-size: 14px;
    line-height: 2;
}
.recruit_area_2 .inner .article_list article .image {
    width: 52%;
    margin-bottom: 30px;
}
.recruit_area_2 .inner .article_list article .image img {
    display: block;
    width: 100%;
    height: auto;
}
.recruit_area_2 .inner .article_list article:nth-child(2n+1) .image {
    float: left;
    margin-right: 30px;
}
.recruit_area_2 .inner .article_list article:nth-child(2n) .image {
    float: right;
    margin-left: 30px;
}
.recruit_area_3 {
/*    margin-bottom: 70px;*/
}
.recruit_area_3 .mini_column {
    padding-bottom: 70px;
}
.recruit_area_3 .mini_column .table_wrap table tr th {
  text-align: justify;
  -moz-text-align-last: justify;
  text-align-last: justify;
}
.recruit_area_3 .mini_column .table_wrap table tr td {
  text-align: left;
}



/* ---------------------------------------- */
/* 会社概要 */

.subpage_header.company_header {
    background-image: url(images/company/company_heading.jpg);
}
.company_area_1 {
    
}
.company_area_1 .inner {
    
}
.company_area_1 .inner .article_list {
    
}
.company_area_1 .inner .article_list article {
    margin-top: 70px;
}
.company_area_1 .inner .article_list article::after {
    display: block;
    clear: both;
    width: 100%;
    height: 0;
    content: "";
}
.company_area_1 .inner .article_list article .text {
}
.company_area_1 .inner .article_list article .text h4 {
    padding-top: 30px;
    padding-bottom: 30px;
    border-bottom: 2px solid #f6891f;
    color: #666;
    text-align: left;
    font-size: 30px;
}
.company_area_1 .inner .article_list article .text p {
    padding-top: 10px;
    text-align: left;
    font-size: 14px;
    line-height: 2;
}
.company_area_1 .inner .article_list article .image {
    width: 52%;
    margin-bottom: 30px;
}
.company_area_1 .inner .article_list article .image img {
    display: block;
    width: 100%;
    height: auto;
}
.company_area_1 .inner .article_list article:nth-child(2n+1) .image {
    float: left;
    margin-right: 30px;
}
.company_area_1 .inner .article_list article:nth-child(2n) .image {
    float: right;
    margin-left: 30px;
}
.company_area_2 {
    
}
.company_area_2 .mini_column {
    background-color: transparent;
}
.company_area_2 .mini_column .table_wrap table tr th {
  text-align: justify;
  -moz-text-align-last: justify;
  text-align-last: justify;
}
.company_area_2 .mini_column .table_wrap table tr td {
  text-align: left;
}
.company_area_4 {
    
}
.company_area_4 .inner {
    padding-bottom: 0;    
}
.company_area_4 .inner ul.images {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
}
.company_area_4 .inner ul.images li {
    margin-top: 20px;
    margin-right: 2%;
    width: 49%;
}
.company_area_4 .inner ul.images li:nth-child(2n) {
    margin-right: 0;
}
.company_area_4 .inner ul.images li img {
    display: block;
    width: 100%;
    height: auto;
}
.company_area_5 {
    
}
.company_area_5 .inner .article_list {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
}
.company_area_5 .inner .article_list article {
    margin-top: 50px;
    margin-right: 4%;
    width: 48%;
}
.company_area_5 .inner .article_list article:nth-child(2n) {
    margin-right: 0;
}
.company_area_5 .inner .article_list article .image {
}
.company_area_5 .inner .article_list article .image img {
    display: block;
    width: 100%;
    height: auto;
}
.company_area_5 .inner .article_list article .text h4 {
    padding-top: 10px;
    text-align: center;
    font-size: 12px;
    line-height: 2;
}
.company_area_5 .inner .article_list article .text p {
    text-align: center;
    font-size: 12px;
    line-height: 2;
}
.company_area_6 {
    
}
.company_area_6 .mini_column {
    padding-bottom: 70px;
}
.company_area_6 .mini_column .table_wrap table tr th {
  text-align: justify;
  -moz-text-align-last: justify;
  text-align-last: justify;
}
.company_area_6 .mini_column .table_wrap table tr td {
  text-align: left;
}
/*
.company_area_7 {
    margin-bottom: 70px;
}
.company_area_7 .mini_column {
    background-color: transparent;
}
.company_area_7 .mini_column .table_wrap table tr th {
  text-align: justify;
  -moz-text-align-last: justify;
  text-align-last: justify;
}
.company_area_7 .mini_column .table_wrap table tr td {
  text-align: left;
}
*/






/* ---------------------------------------- */
/* お問い合わせ */

.subpage_header.contact_header {
    background-image: url(images/contact/contact_heading.jpg);
}
.contact_form {
    
}
.contact_form em.required {
    display: inline-block;
    padding: 3px 7px;
    background-color: #f6891f;
    border-radius: 10px;
    color: #fff;
    font-weight: bold;
    font-size: 12px;
    font-style: normal;
}
.contact_form .inner {
    
}
.contact_form .inner dl.form_table {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    flex-wrap: wrap;
    font-size: 14px;
    line-height: 1.6;
    overflow: hidden;
}
.contact_form .inner dl.form_table:not(:first-child) {
    margin-top: 50px;
}
.contact_form .inner dl.form_table dt {
    position: relative;
    width: 13em;   
    padding: 7px 0;
    margin-bottom: 50px;
}
.contact_form .inner dl.form_table dt.new_section::before {
    position: absolute;
    top: -25px;
    left: 0;
    display: block;
    width: 100vw;
    height: 1px;
    background-color: #ccc;
    content: "";
}
.contact_form .inner dl.form_table dt span.name {
    float: left;
    display: block;
    width: 9em;
  text-align: justify;
  -moz-text-align-last: justify;
  text-align-last: justify;
    
}
.contact_form .inner dl.form_table dt span.name.long {
    width: 13em;
}
.contact_form .inner dl.form_table dt span.name .sub {
    display: block;
}
.contact_form .inner dl.form_table dt span.name em.sub {
    color: #f6891f;
    font-style: normal;
    font-size: 11px;
}
.contact_form .inner dl.form_table dt em.required {
    float: right;
}
.contact_form .inner dl.form_table dd {
    width: calc(100% - 13em);
    padding-left: 2em;
    margin-bottom: 50px;
}
.contact_form .inner dl.form_table.confirm dd {
    padding-top: 7px;
    padding-bottom: 7px;
}
.contact_form .inner dl.form_table dd label {
    display: inline-block;
    padding: 6px 0;
    max-width: 100%;
    font-size: 14px;
}
.contact_form .inner dl.form_table dd label:not(:last-child) {
    margin-right: 2em;
}
.contact_form .inner dl.form_table dd input[type="text"] {
    border: 1px solid #ccc;
    padding: 5px 10px;
    max-width: 100%;
    font-size: 14px;
    line-height: 1.6;
}
.contact_form .inner dl.form_table dd input[type="text"].long {
    width: 100%;
}
.contact_form .inner dl.form_table dd input[type="text"].middle {
    width: 600px;
}
.contact_form .inner dl.form_table dd input[type="text"].short {
    width: 300px;
}
.contact_form .inner dl.form_table dd textarea {
    border: 1px solid #ccc;
    padding: 5px 10px;
    width: 100%;
    height: 320px;
    font-size: 14px;
    line-height: 1.6;
}
.contact_form .inner dl.form_table dd p.hint {
    font-size: 13px;
    color: #999;
}
.contact_form .inner .form_button {
    text-align: center;
    margin-top: 50px;
}
.contact_form .inner .form_button > input[type="submit"],
.contact_form .inner .form_button > input[type="button"],
.contact_form .inner .form_button > button,
.contact_form .inner .form_button > a {
    display: inline-block;
    padding: 10px 30px;
    margin: 10px;
    border: 2px solid #f6891f;
    font-size: 16px;
    font-style: normal;
    font-weight: bold;
	transition: all 0.3s ease 0s;
	text-decoration:none;
}
.contact_form .inner .form_button > input[type="submit"]:hover,
.contact_form .inner .form_button > input[type="button"]:hover,
.contact_form .inner .form_button > button:hover,
.contact_form .inner .form_button > a:hover{
	filter: alpha(opacity=60);
	-moz-opacity:0.6;
	opacity:0.6;
}
.contact_form .inner .form_button > input[type="submit"].forward,
.contact_form .inner .form_button > input[type="button"].forward,
.contact_form .inner .form_button > button.forward,
.contact_form .inner .form_button > a.forward {
    background-color: #f6891f;
    color: #fff;
}
.contact_form .inner .form_button > input[type="submit"].back,
.contact_form .inner .form_button > input[type="button"].back,
.contact_form .inner .form_button > button.back,
.contact_form .inner .form_button > a.back {
    background-color: #fff;
    color: #f6891f;
}




/* ---------------------------------------- */
/* ニュース */

.subpage_header.news_header {
    background-image: url(images/news/news_heading.jpg);
}
.news_detail {
    
}
.news_detail .inner {
    
}
.news_detail .inner .news_title {
    position: relative;
    z-index: 1;
    color: #666;
    text-align: center;
    font-size: 24px;
    line-height: 1.4;
}
.news_detail .inner .news_title::before {
    position: absolute;
    z-index: -1;
    bottom: 0;
    left: 0;
    right: 0;
    display: block;
    width: 400px;
    height: 5px;
    margin: 0 auto;
    background-color: #f6891f;
    content: "";
}
.news_detail .inner .news_content {
    margin-top: 50px;
    margin-bottom: 50px;
    text-align: left;
    font-size: 16px;
    line-height: 1.8;
}
.news_list .inner ul.news_articles{
	margin-bottom:40px;
}
.news_list .inner ul.news_articles li{
	margin-bottom:15px;
}
.news_list .inner ul.news_articles li span{
    float: left;
    display: block;
/*    width: 6em;*/
}
.news_list .inner ul.news_articles li a{
    display: block;
    margin-left: 6em;
	color:#f6891f;
}
.news_list .inner ul.news_pager{
	margin-bottom:40px;
    text-align: center;
}
.news_list .inner ul.news_pager li{
    display: inline-block;
	margin: 3px;
}
.news_list .inner ul.news_pager li a{
	display:inline-block;
	background:#f6891f;
	border: 1px solid #f6891f;
	text-align:center;
	color:#FFF;
    min-width: 34px;
	padding:10px;
	border-radius: 20px;        /* CSS3草案 */  
	-webkit-border-radius: 20px;    /* Safari,Google Chrome用 */  
	-moz-border-radius: 20px;   /* Firefox用 */  
	font-size:12px;
}
.news_list .inner ul.news_pager li a.current{
	background:#fff;
	color:#f6891f;
}



/* ---------------------------------------- */
/* 個人情報保護方針 */

.subpage_header.policy_header {
    background-image: url(images/contact/contact_heading.jpg);
}
.privacy_policy {
    
}
.privacy_policy .inner {
    font-size: 14px;
    line-height: 1.8;
    text-align: left;
}
.privacy_policy .inner dl.policy:not(:first-child) {
  margin-top: 50px;
}
.privacy_policy .inner dl.policy dt {
  text-align: left;
  font-weight: bold;
  font-size: 22px;
}
.privacy_policy .inner dl.policy dt:not(:first-child) {
  margin-top: 50px;
}
.privacy_policy .inner dl.policy dd {
  margin-top: 20px;
  text-align: left;
}
.privacy_policy .inner dl.policy dd p:not(:first-child) {
  margin-top: 20px;
}
.privacy_policy .inner dl.policy dd ul:not(:first-child) {
  margin-top: 20px;
}
.privacy_policy .inner dl.policy dd ul li {
  padding-left: 1em;
}
.privacy_policy .inner dl.policy dd ul li::before {
  display: inline-block;
  margin-left: -1em;
  width: 1em;
  text-align: center;
  content: "・";
}
.privacy_policy .inner .policy-credit {
  margin-top: 50px;
  text-align: right;
  margin-bottom: 70px;
}


/* ---------------------------------------- */
/* フッター */

footer .black{
	background:#444;
}
footer .black .inner{
	padding:70px 0 100px;
	text-align:center;
}
footer .black .inner h1{
	margin-bottom:20px;
}
footer .black .inner .name{
	color:#FFF;
	font-size:32px;
	margin-bottom:20px;
}
footer .black .inner .address{
	color:#FFF;
	font-size:14px;
	line-height:1.7;
}
footer .white .inner{
	padding:30px 0 40px;
	text-align:center;
}
footer .white .inner .copy{
	font-size:12px;
}