@charset "utf-8";
/************************************************************************************************************************************
	TOP
************************************************************************************************************************************/
#index .index_sec_ttl {
	text-align: center;
}
#index .index_sec_ttl .ttl {
	display: inline-block;
	text-align: center;
}
#index .index_sec_ttl .ttl span {
	display: block;
	font-weight: 700;
	line-height: 1;
}
#index .index_sec_ttl .ttl .en {
	color: #059ce9;
	font-size: 18px;
	letter-spacing: 2px;
	margin-bottom: 9px;
	text-transform: uppercase;
}
#index .index_sec_ttl .ttl .ja {
	color: #222222;
	font-size: 50px;
}

#index #section_02 .index_sec_ttl .ttl .en {	color: #FFF;	}
#index #section_02 .index_sec_ttl .ttl .ja {	color: #FFF;	}
#index #section_04 .index_sec_ttl .ttl .en {	color: #FFF;	}
#index #section_04 .index_sec_ttl .ttl .ja {	color: #FFF;	}
#index #section_05 .index_sec_ttl .ttl .en {	color: #FFF;	}
#index #section_05 .index_sec_ttl .ttl .ja {	color: #FFF;	}

#index #section_01 .index_sec_ttl {	margin-bottom: 20px;	}
#index #section_02 .index_sec_ttl {	margin-bottom: 60px;	}
#index #section_03 .index_sec_ttl {	margin-bottom: 80px;	}
#index #section_04 .index_sec_ttl {	margin-bottom: 50px;	}
#index #section_05 .index_sec_ttl {	margin-bottom: 85px;	}


@media print, screen and (min-width: 768px) {
	#index #section_01 .index_sec_ttl {	text-align: left;	}
	#index #section_01 .index_sec_ttl .ttl .en {	font-size: 14px;	margin-bottom: 4px;	}
	#index #section_01 .index_sec_ttl .ttl .ja {	font-size: 40px;	}

	#index #section_02 .content_01 .index_sec_ttl { width: 200px;	text-align: right; margin-left: auto;	}
	#index #section_02 .content_02 .index_sec_ttl { width: 200px;	text-align: left; margin-right: auto;	}
}
@media screen and (max-width: 767px) {
	#index .index_sec_ttl .ttl .en {
		font-size: 20px;
	}
	#index .index_sec_ttl .ttl .ja {
		font-size: 30px;
	}
}




#index .button_more {
	text-align: center;
}
#index .button_more a {
	display: inline-block;
	color: #FFF;
	font-size: 14px;
	font-weight: 700;
	line-height: 41px;
	text-align: center;
	max-width: 200px;
	width: 100%;
	height: 41px;
	background-color: rgb(48, 48, 48);
	background-image: url('../img/button_01_arrow.png');
	background-size: 6px 9px;
	background-position: right 10px center;
	background-repeat: no-repeat;
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}




/** #section_00 *****************************************************************/
#index #section_00 #mv {
	position: relative;
}

#index #section_00 #mv .pc-text {
	position: absolute;
	left: 0; top: 0;
	max-width: 797px;
}

#index #section_00 #mv .bg {
	width: 100%;
}


@media print, screen and (min-width: 768px) {
	#index #section_00 #mv .sp-text {
		display: none;
	}
	#index #section_00 #mv .bg img:last-child {
		display: none;
	}

	#index #section_00 #mv .pc-text {
		width: 56.928571428571428571428571428571%;	/* 797/1400*100 */
		margin-left: 34px;
		margin-top: 19.571428571428571428571428571429%;	/* 274/1400*100 */
	}
}
@media print, screen and (min-width: 1380px) {
	#index #section_00 #mv .pc-text {
		bottom: 0;
		height: 316px;
		margin-top: auto; margin-bottom: auto;
		padding-top: 4.5%;	/* 目算 */
	}
}
@media screen and (max-width: 767px) {
	#index #section_00 #mv .bg img:first-child {
		display: none;
	}
	#index #section_00 #mv .pc-text {
		display: none;
	}

	#index #section_00 #mv .sp-text {
		position: absolute;
		left: 10px; top: 0px;
		margin-top: 20%;
	}
	#index #section_00 #mv .sp-text .ttl {
		color: #FFF;
		font-size: 18px;
		font-weight: 700;
		line-height: 1;
		margin-bottom: 35px;
		text-shadow: 0px 0px 4.55px rgba(0, 0, 0, 0.59);
	}
	#index #section_00 #mv .sp-text .ttl::first-letter {
		color: #00c6ff;
	}
	#index #section_00 #mv .sp-text .ttl span {
		position: relative;
		display: inline-block;
		font-size: 50px;
		padding-bottom: 23px;
		margin-bottom: 23px;
		text-shadow: 0px 0px 13.28px rgba(0, 0, 0, 0.6);
	}
	#index #section_00 #mv .sp-text .ttl span::after {
		content: " ";
		display: block;
		position: absolute;
		z-index: 10;
		left: 0;
		bottom: -3px;
		width: 100%;
		height: 3px;
		background-color: #FFF;
		background-image: -moz-linear-gradient( 0deg, rgb(0,198,255) 9%, rgb(255,255,255) 21%);
	  background-image: -webkit-linear-gradient( 0deg, rgb(0,198,255) 9%, rgb(255,255,255) 21%);
	  background-image: -ms-linear-gradient( 0deg, rgb(0,198,255) 9%, rgb(255,255,255) 21%);
	}
	#index #section_00 #mv .sp-text .desc {
		color: #FFF;
		font-size: 14px;
		line-height: 2;
		text-shadow: 0px 0px 9.3px rgba(0, 0, 0, 0.46);
	}
}
@media screen and (max-width: 330px) {
	#index #section_00 #mv .sp-text {
		position: absolute;
		left: 5px;
	}
	#index #section_00 #mv .sp-text .ttl {
		font-size: 16px;
	}
}






/** #section_01 *****************************************************************/
#index #section_01 {
	padding: 60px 0 30px;
}

#index #section_01 .info {
	overflow: hidden;
	position: relative;
	margin: 0 auto;
}
#index #section_01 .info li {
	color: #222222;
	font-size: 16px;
	padding: 25px 0;
	border-bottom: solid 1px #dde2e4;
}

#index #section_01 .info li .date {
	font-size: 16px;
	font-weight: 500;
	vertical-align: middle;
}
#index #section_01 .info li .description {
	font-size: 16px;
	font-weight: 400;
}
#index #section_01 .info li .cate {
	display: inline-block;
	color: #FFF;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 1px;
	line-height: 21px;
	text-align: center;
	text-indent: 0;
	width: 62px;
	height: 21px;
	background-color: rgb(51, 51, 51);
}
#index #section_01 .info li .cate.c1 { background-color: #059ce9; }
#index #section_01 .info li .cate.c2 { background-color: #062146; }


@media print, screen and (min-width: 768px) {
	#index #section_01 .info li {
		padding-left: 205px;
		text-indent: -205px;
	}
	#index #section_01 .info li .date {
	}
	#index #section_01 .info li .cate {
		margin-left: 30px;
		margin-right: 30px;
	}

	#index #section_01 .content_01 {
		position: relative;
	}
	#index #section_01 .button_more {
		position: absolute;
		top: 15px;
		left: 215px;
		width: 144px;
	}
}
@media screen and (max-width: 767px) {
	#index #section_01 .info {
	}
	#index #section_01 .info li {
		font-size: 14px;
	}
	#index #section_01 .info li .date {
		font-size: 14px;
		margin-right: 10px;
		margin-bottom: 10px;
	}
	#index #section_01 .info li .description {
		font-size: 14px;
		display: block;
		margin-top: 7px;
	}

	#index #section_01 .button_more {
		margin-top: 30px;
	}
}






/** #section_02 *****************************************************************/
#index #section_02 {
	position: relative;
}


@media print, screen and (min-width: 768px) {
	#index #section_02 {
		padding: 21.428571428571428571428571428571% 0 24.285714285714285714285714285714%;
		background-image: url('../img/index/sec_02_bg_01.png');
		background-size: 100% auto;
		background-position: right center;
		background-repeat: no-repeat;
	}

	#index #section_02::after {
		content: " ";
		position: absolute;
		right: 0;
		bottom: 0;
		max-width: 443px;
		width: 31.642857142857142857142857142857%;	/* 443/1400*100 */
		padding-bottom: 25.142857142857142857142857142857%;	/* 352/1400*100 */
		background-image: url('../img/index/sec_02_img_01.png');
		background-size: contain;
		background-position: center top;
		background-repeat: no-repeat;
		margin-right: 2.2857142857142857142857142857143%;	/* 32/1400*100 */
		margin-bottom: -6.5714285714285714285714285714286%;	/* 92/1400*100 */
	}

	#index #section_02 .content_02 {
		order: 1;
		-moz-box-sizing:border-box;-webkit-box-sizing:border-box;-o-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;
		width: 64.270833333333333333333333333333%;	/* 617/960*100 */
		max-width: 617px;
		padding-top: 80px;
		padding-left: 30px;
	}
	#index #section_02 .content_01 {
		order: 2;
		-moz-box-sizing:border-box;-webkit-box-sizing:border-box;-o-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;
		width: 35.729166666666666666666666666667%;	/* 343/960*100 */
		max-width: 343px;
		padding-right: 30px;
	}

	#index #section_02 .content_02 .button_more {
		text-align: left;
	}
	#index #section_02 .content_01 .button_more {
		text-align: right;
	}

	#index #section_02 .content_01 .button_more a {
		color: #FFF;
		border: solid 1px #FFF;
		background-color: transparent;
	}
}
@media print, screen and (min-width: 2500px) {
	#index #section_02 .content_02 {
		max-width: none;
		padding-left: 17.785714285714285714285714285714%;	/* 249/1400*100 */

	}
	#index #section_02 .content_01 {
		max-width: none;
		padding-right: 17.785714285714285714285714285714%;	/* 249/1400*100 */
	}
}
@media screen and (max-width: 767px) {
	#index #section_02 .content_01 {
		background-image: url('../img/index/sec_02_bg_02_sp.png');
		background-size: 100% auto;
		background-position: center bottom;
		background-repeat: no-repeat;
	}
	#index #section_02 .content_02 {
		position: relative;
		top: -80px;
		background-image: url('../img/index/sec_02_bg_01_sp.png');
		background-size: 100% auto;
		background-position: center top;
		background-repeat: no-repeat;
	}
}






/** #section_03 *****************************************************************/
#index #section_03 {
}

#index #section_03 .gmaps {
	margin-bottom: 40px;
}

#index #section_03 .text {
	margin-bottom: 35px;
}

#index #section_03 .text .mg {
	display: inline-block;
	padding: 0 13px;
	vertical-align: middle;
	margin-bottom: 6px;
}
#index #section_03 .text .space {
	padding: 0 15px;
}
#index #section_03 .text .bold {
	font-weight: 700;
	letter-spacing: 1px;
}
#index #section_03 .text .color.italic {
	color: #059ce9;
	font-size: 22px;
	font-weight: 400;
	font-style: italic;
}


@media print, screen and (min-width: 768px) {
	#index #section_03 .gmaps li {
		width: 470px;
	}
	#index #section_03 .text {
		font-size: 18px;
		text-align: center;
	}

	#index #section_03 .gmaps li:nth-child(1) {
		order: 2;
	}
}
@media screen and (max-width: 767px) {
	#index #section_03 .text {
		font-size: 16px;
	}
	#index #section_03 .text .bold {
		display: block;
		font-size: 18px;
		padding-top: 10px;
	}
}






/** #section_04 *****************************************************************/
#index #section_04 {
	position: relative;
	z-index: 11;
	padding: 0px 0 0px;
}

#index #section_04 .text {
	color: #FFF;
	font-size: 18px;
	line-height: 2;
	text-align: center;
	margin-bottom: 30px;
}


@media print, screen and (min-width: 768px) {
	#index #section_04 {
		padding: 16.785714285714285714285714285714% 0 25.714285714285714285714285714286%;
		margin-bottom: -19.785714%;
		background-image: url('../img/index/sec_04_bg_01.png');
		background-size: 100% auto;
		background-position: center bottom;
		background-repeat: no-repeat;
	}
	#index #section_04 .content_01 {
		width: 50%;
		margin-left: auto;
	}

	#index #section_04::before {
		-moz-box-sizing:border-box;-webkit-box-sizing:border-box;-o-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;
		content: " ";
		position: absolute;
		top: 0;
		left: 0;
		max-width: 401px;
		width: 28.642857142857142857142857142857%;	/* 401/1400*100 */
		min-height: 254px;
		padding-bottom: 18.142857142857142857142857142857%;	/* 254/1400*100 */
		background-image: url('../img/index/sec_04_img_01.png');
		background-size: contain;
		background-position: center bottom;
		background-repeat: no-repeat;
		margin-top: -2.5714285714285714285714285714286%;	/* 36/1400*100 */
		margin-left: 3.5714285714285714285714285714286%;	/* 50/1400*100 */
	}
}
@media screen and (max-width: 767px) {
	#index #section_04 {
		padding: 200px 0 100px;
		margin-bottom: -100px;
		background-image: url('../img/index/sec_04_bg_01_sp.png');
		background-size: 100% auto;
		background-position: center bottom;
		background-repeat: no-repeat;
	}

	#index #section_04 .text {
		font-size: 16px;
	}
}
@media screen and (max-width: 330px) {
	#index #section_04 {
		padding: 100px 0 80px;
		margin-bottom: -100px;
	}
}






/** #section_05 *****************************************************************/
#index #section_05 {
	position: relative;
	z-index: 10;
	padding: 0px 0 0px;
}

#index #section_05 .unique_button {
	text-align: center;
	margin-top: 40px;
}
#index #section_05 .unique_button a {
	position: relative;
	display: inline-block;
	color: #FFF;
	font-size: 14px;
	font-weight: 500;
	text-align: center;
	line-height: 81px;
	max-width: 308px;
	height: 83px;
	width: 100%;
	background-color: rgba(48, 48, 48, 0.8);
	background-image: url('../img/button_01_arrow.png');
	background-size: 6px 9px;
	background-position: right 17px center;
	background-repeat: no-repeat;
}
#index #section_05 .unique_button a::before {
	content: " ";
	display: inline-block;
	vertical-align: middle;
	width: 13px;
	height: 9px;
	margin-right: 8px;
	margin-bottom: 2px;
	background-image: url('../img/button_01_icon.png');
	background-size: contain;
	background-position: center center;
	background-repeat: no-repeat;
}
#index #section_05 .unique_button a::after {
	-moz-box-sizing:border-box;-webkit-box-sizing:border-box;-o-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;
	content: " ";
	top:0; bottom:0; left:0; right:0;
	position: absolute;
	display: block;
	width: 298px;
	width: calc(100% - 10px);
	height: 73px;
	margin: auto;
	border: solid 1px #737373;
}

@media print, screen and (min-width: 768px) {
	#index #section_05 {
		padding: 20.714285714285714285714285714286% 0 9.2857142857142857142857142857143%;
		background-image: url('../img/index/sec_05_bg_01.png');
		background-size: cover;
		background-position: center bottom;
		background-repeat: no-repeat;
	}
}
@media screen and (max-width: 767px) {
	#index #section_05 {
		padding: 100px 0 100px;
		background-image: url('../img/index/sec_05_bg_01_sp.png');
		background-size: cover;
		background-position: center bottom;
		background-repeat: no-repeat;
	}
}








/************************************************************************************************************************************
	お知らせ
************************************************************************************************************************************/
#news {
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}


/** #section_01 *****************************************************************/
#news #section_01 {
}
#news #section_01 .info {
	overflow: hidden;
	position: relative;
	margin: 0 auto;
}
#news #section_01 .info li {
	color: #222222;
	font-size: 16px;
	padding: 25px 0;
	border-bottom: solid 1px #dde2e4;
}

#news #section_01 .info li .date {
	font-size: 16px;
	font-weight: 500;
	vertical-align: middle;
}
#news #section_01 .info li .description {
	font-size: 16px;
	font-weight: 400;
}
#news #section_01 .info li .cate {
	display: inline-block;
	color: #FFF;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 1px;
	line-height: 21px;
	text-align: center;
	text-indent: 0;
	width: 62px;
	height: 21px;
	background-color: rgb(51, 51, 51);
}
#news #section_01 .info li .cate.c1 { background-color: #059ce9; }
#news #section_01 .info li .cate.c2 { background-color: #062146; }


@media print, screen and (min-width: 768px) {
	#news #section_01 .info li {
		padding-left: 205px;
		text-indent: -205px;
	}
	#news #section_01 .info li .date {
	}
	#news #section_01 .info li .cate {
		margin-left: 30px;
		margin-right: 30px;
	}
}
@media screen and (max-width: 767px) {
	#news #section_01 .info {
	}
	#news #section_01 .info li {
		font-size: 14px;
	}
	#news #section_01 .info li .date {
		font-size: 14px;
		margin-right: 10px;
		margin-bottom: 10px;
	}
	#news #section_01 .info li .description {
		font-size: 14px;
		display: block;
		margin-top: 7px;
	}
}








/************************************************************************************************************************************
	会社案内
************************************************************************************************************************************/
#company {
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}




/** #section_00 *****************************************************************/
#company #section_00 {
}

#company #section_00 .glaybox {
	padding: 40px 45px 45px;
	background-color: #f8fafa;
}
#company #section_00 .glaybox .text {
	line-height: 1.8;
	margin-bottom: 40px;
}

#company #section_00 .img {
	max-width: 214px;
	text-align: right;
	margin-left: auto;
}

@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
	#company #section_00 .glaybox {
		padding: 40px 15px 45px;
	}
}




/** #section_01 *****************************************************************/
#company #section_01 {
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}




/** #section_02 *****************************************************************/
#company #section_02 {
}

#company #section_02 table.common_table tbody th .date {
	color: #3877bd;
	padding-left: 20px;
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}








/************************************************************************************************************************************
	アクセス
************************************************************************************************************************************/
#access {
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}




/** #section_01 *****************************************************************/
#access #section_01 {
}

#access #section_01 .gmaps {
	margin-bottom: 40px;
}

#access #section_01 .text .mg {
	display: inline-block;
	padding: 0 13px;
	vertical-align: middle;
	margin-bottom: 6px;
}
#access #section_01 .text .space {
	padding: 0 10px;
}
#access #section_01 .text .color.italic {
	font-size: 22px;
}


@media print, screen and (min-width: 768px) {
	#access #section_01 .gmaps li {
		width: 470px;
	}
	#access #section_01 .text {
		font-size: 18px;
		text-align: center;
	}

	#access #section_01 .gmaps li:nth-child(1) {
		order: 2;
	}
}
@media screen and (max-width: 767px) {
	#access #section_01 .text {
		font-size: 16px;
	}
	#access #section_01 .text .bold {
		display: block;
		font-size: 18px;
		padding-top: 10px;
	}
}








/************************************************************************************************************************************
	事業案内
************************************************************************************************************************************/
#business {
}

#business .common_table {
	margin-bottom: 20px;
}

#business .img {
	max-width: 470px;
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
	#business .img {
		margin: 0 auto 20px;
	}
}




/** #section_01 *****************************************************************/
#business #section_01 {
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}








/************************************************************************************************************************************
	採用情報
************************************************************************************************************************************/
#recruit {
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}




/** #section_01 *****************************************************************/
#recruit #section_01 {
}

#recruit #section_01 table.common_table {
	margin-top: 40px;
	margin-bottom: 50px;
}
#recruit #section_01 .text .bold {
	font-size: 18px;
}
#recruit #section_01 .text .mg {
	display: inline-block;
	padding: 0 13px;
	vertical-align: middle;
	margin-bottom: 6px;
}
#recruit #section_01 .text .color.italic {
	font-size: 22px;
}

#recruit #section_01 .unique_button {
	text-align: center;
	margin-top: 40px;
}
#recruit #section_01 .unique_button a {
	position: relative;
	display: inline-block;
	color: #FFF;
	font-size: 16px;
	font-weight: 500;
	text-align: center;
	line-height: 81px;
	max-width: 308px;
	height: 83px;
	width: 100%;
	background-color: #303030;
	background-image: url('../img/button_01_arrow.png');
	background-size: 6px 9px;
	background-position: right 17px center;
	background-repeat: no-repeat;
}
#recruit #section_01 .unique_button a::before {
	content: " ";
	display: inline-block;
	vertical-align: middle;
	width: 13px;
	height: 9px;
	margin-right: 8px;
	margin-bottom: 2px;
	background-image: url('../img/button_01_icon.png');
	background-size: contain;
	background-position: center center;
	background-repeat: no-repeat;
}
#recruit #section_01 .unique_button a::after {
	-moz-box-sizing:border-box;-webkit-box-sizing:border-box;-o-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box;
	content: " ";
	top:0; bottom:0; left:0; right:0;
	position: absolute;
	display: block;
	width: 298px;
	width: calc(100% - 10px);
	height: 73px;
	margin: auto;
	border: solid 1px #737373;
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
	#recruit #section_01 table.common_table {
		margin-top: 30px;
	}
}








/************************************************************************************************************************************
	お問い合わせ
************************************************************************************************************************************/
#contact {
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}




/** #section_01 *****************************************************************/
#contact #section_01 {
}

#contact #section_01 .text {
	line-height: 2;
}

#contact #section_01 .text .required {
	color: #d43131;
}
#contact #section_01 .text a {
	border-bottom: solid 2px #999999;
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
}




/** #section_02 *****************************************************************/
#contact #section_02 .text {
	line-height: 1.8;
	margin-bottom: 40px;
}
#contact #section_02 .text.read {
	margin-bottom: 45px;
}
#contact #section_02 .ttl {
	position: relative;
	font-size: 18px;
	font-weight: 700;
	padding-left: 32px;
	padding-bottom: 10px;
	margin-bottom: 15px;
	border-bottom: solid 1px #cccccc;
}
#contact #section_02 .ttl .num {
	position: absolute;
	left: 0; top: 3px;
	color: #FFF;
	font-size: 18px;
	text-align: center;
	line-height: 23px;
	width: 23px;
	height: 23px;
	background-image: url('../img/icon_num_bg.png');
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
}

#contact #section_02 .text .indent {
	display: block;
}
#contact #section_02 .text .indent.size1 {
	padding-left: 24px;
	text-indent: -24px;
}


@media print, screen and (min-width: 768px) {
}
@media screen and (max-width: 767px) {
	#contact #section_02 .ttl {
		font-size: 16px;
	}
	#contact #section_02 .text .indent.size1 {
		padding-left: 21px;
		text-indent: -21px;
	}
}






