@charset "UTF-8";

.fwl {
	font-weight: lighter;
}

.fwel,
.fwl,
.fwr,
caption,
td,
th {
	font-weight: 500
}

.bold,
.foot_list i,
.fwb,
.head_contact {
	font-weight: 700
}

.tal,
caption,
td,
th {
	text-align: left
}

a img,
button {
	border: none
}

.btn,
button,
textarea {
	-webkit-appearance: none
}

.head_contact,
html {
	line-height: 1
}

.foot_list_tit,
.l-header_menu,
input[type=reset],
input[type=submit] {
	cursor: pointer
}


.section_content,
.section_inner {
	-webkit-font-smoothing: antialiased
}

a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
sub,
summary,
sup,
table,
tbody,
td,
tfoot,
th,
thead,
time,
tr,
tt,
u,
ul,
var,
video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	vertical-align: baseline;
}

li,
a {
	-webkit-transition: all .3s;
	-o-transition: all .3s;
	transition: all .3s;
}

ol,
ul {
	list-style: none
}

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

caption,
td,
th {
	vertical-align: middle
}

.foot_banner img,
.gnav_cont_box,
.tac {
	text-align: center
}

blockquote,
q {
	quotes: none
}

blockquote:after,
blockquote:before,
q:after,
q:before {
	content: "";
	content: none
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
	display: block
}

button:focus {
	outline: 0
}

button {
	margin: 0;
	padding: 0;
	border-radius: 0
}

input[type=reset],
input[type=search],
input[type=submit],
input[type=text] {
	-moz-border-radius: 0;
	-webkit-border-radius: 0;
	margin: 0;
	padding: 0;
	border: none;
	border-radius: 0;
	-webkit-appearance: none;
	outline: 0;
	-webkit-box-shadow: none;
	box-shadow: none
}

textarea {
	-webkit-box-shadow: none;
	box-shadow: none
}


/*メンバー一覧でSPだけ名字と名前を改行でわける*/
.sp_br {
	display: none;
}
@media screen and (max-width: 768px) {
	.sp_br {
		display: block;
	}
}
@media screen and (max-width: 768px) {
	.sns_area {
		font-size:95%;
	}
}

.white_contact {
	padding-left: 20px;
	position: relative
}

.white_contact:before {
	content: "";
	display: block;
	height: 15px;
	width: 15px;
	position: absolute;
	top: 2px;
	left: 0;
	background: url(../img/common/white_mail.svg) no-repeat
}

.black_contact:before,
.fb_icon:after {
	height: 18px;
	content: ""
}

.black_contact {
	position: relative;
	z-index: 1
}

.black_contact:before {
	display: block;
	margin-right: 10px;
	margin-top: 3px;
	position: absolute;
	left: 0;
	width: 18px;
	z-index: 2;
	background: url(../img/common/black_mail.svg) no-repeat
}

.l-header_pc,
.l-header_sp {
	width: 100%
}

.l-header_sp_inner,
.l-header_wrap {
	z-index: 99999999;
}

.l-header_above ul {
	float: right;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	width: 30%;
	font-size: .8rem;
}

.gnav_cont_list li,
.head_btn_group,
.head_btn_group > li,
.head_contact,
.l-header_above li {
	vertical-align: middle
}

.l-header_above li {
	display: table-cell;
	margin: 2px 0px;
}

.l-header_above li i {
	font-size: .8rem;
}

.l-header_sp_inner {
	position: fixed;
	display: block;
	width: 96%;
	background: #fff;
	margin: 2%;
	border-radius: 5px;
	line-height: 50px;
	-webkit-box-shadow: 0 0 20px -5px rgb(212, 3, 50);
	box-shadow: 0 0 20px -5px rgb(212, 3, 50);
}

.l-header_sp_inner .header_logo {
	margin-top: 0px;
}

.fb_icon:after {
	display: block;
	width: 18px;
	border-radius: 2px;
	background: url(../img/common/fb_icon.svg) right center no-repeat #4267B2;
	background-size: 15px
}

.header_logo {
	float: left;
	width: 150px;
	margin-left: 10px;
	margin-top: 3px;
}

@media screen and (min-width:860px) {
	.l-header_wrap {
		position: absolute;
		margin: 10px auto 0;
		width: 100%;
	}

	.header_logo {
		width: 200px;
		margin-top: 0;
		line-height: 65px;
	}
}

.header_mbtn {
	float: right
}

.head_contact {
	width: 17px;
	display: table-cell;
	padding-left: 15px;
	color: #fff;
	font-size: 13px
}

.head_btn_group > li > a,
.head_contact a {
	background: 0 0;
	border-radius: 0;
	width: auto;
	text-indent: 0
}

.head_contact_text {
	display: none
}

.head_contact a {
	display: inline;
	height: auto;
	padding: 0
}

.head_btn_group {
	display: table-cell;
	float: right;
	white-space: nowrap;
	height: 1px
}

.head_btn_group ul {
	display: table
}

.head_btn_group > li {
	padding-left: 15px;
	display: table-cell;
	line-height: 1;
	font-weight: 700;
	color: #fff
}

.head_btn_group > li > a {
	color: #000;
	display: inline;
	height: auto;
	padding: 0
}

.l-header_menu {
	-webkit-transition: -webkit-transform .3s ease;
	transition: -webkit-transform .3s ease;
	-o-transition: transform .3s ease;
	transition: transform .3s ease;
	transition: transform .3s ease, -webkit-transform .3s ease;
	float: right;
	position: relative;
	width: 53px;
	height: 39px;
	padding: 10px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.l-header_menu:after {
	content: 'MENU';
	position: absolute;
	bottom: -25px;
	font-size: .7rem;
}

.l-header_menu span {
	display: block;
	margin-bottom: 8px;
	height: 1px;
	background: #444;
	-webkit-transition: opacity .4s ease, background .4s ease, -webkit-transform .4s ease;
	transition: opacity .4s ease, background .4s ease, -webkit-transform .4s ease;
	-o-transition: transform .4s ease, opacity .4s ease, background .4s ease;
	transition: transform .4s ease, opacity .4s ease, background .4s ease;
	transition: transform .4s ease, opacity .4s ease, background .4s ease, -webkit-transform .4s ease;
	-webkit-transform-origin: 0 0;
	-ms-transform-origin: 0 0;
	transform-origin: 0 0;
}

.l-header_wrap.is-fixed .l-header_above,
.m-gnav {
	display: none
}

.l-header_wrap.is-fixed .l-header_sp_inner {}

.m-gnav {
	position: fixed;
	left: 0;
	top: 65px;
	width: 96%;
	z-index: 99999;
	margin: 0 2%;
	right: 0;
	bottom: 0;
	overflow-y: auto;
}

.m-gnav > ul {
	background: #f9f9f9;
	border-radius: 5px;
}

@media screen and (min-width:860px) {
	.m-gnav {
		position: static;
		display: block;
		float: right;
		width: auto
	}

	.m-gnav > ul {
		background: 0 0
	}
}

.l-header_menu.is-open span.one {
	-webkit-transform: translate(5px, -3px) rotate(45deg);
	-ms-transform: translate(5px, -3px) rotate(45deg);
	transform: translate(5px, -3px) rotate(45deg)
}

.l-header_menu.is-open span.two {
	-webkit-transform: translate(10px, 0);
	-ms-transform: translate(10px, 0);
	transform: translate(10px, 0);
	opacity: 0
}

.l-header_menu.is-open span.three {
	-webkit-transform: translate(5px, 3px) rotate(-45deg);
	-ms-transform: translate(5px, 3px) rotate(-45deg);
	transform: translate(5px, 3px) rotate(-45deg);
}

.m-gnav > ul > .m-gnav_item > a,
.m-gnav > ul > .m-gnav_item > span,
header.l-header_sp.cb.sp > nav > ul > li:nth-child(1) > div > ul > span {
	position: relative;
	padding: 15px 40px 15px 15px;
	display: block;
	border-bottom: 1px solid #ddd;
	-webkit-transition: .2s;
	-o-transition: .2s;
	transition: .2s
}

@media screen and (min-width:860px) {

	.m-gnav > ul > .m-gnav_item > a,
	.m-gnav > ul > .m-gnav_item > span {
		height: 65px;
		font-weight: 700;
		font-size: .9rem;
		text-align: center;
		border: none;
		padding: 0 6px;
		display: table-cell;
		vertical-align: middle
	}

	.m-gnav > ul > .m-gnav_item.contact {
		display: none
	}
}

.m-gnav > ul > .m-gnav_item > a:hover,
.m-gnav > ul > .m-gnav_item > span:hover {
	color: #ce002c;
}

.m-gnav > ul > .m-gnav_item.contact:before {
	top: 30%;
	left: 15px
}

.menu_arrow:after,
.menu_plus:after,
.menu_plus:before {
	position: absolute;
	top: 50%;
	content: ""
}

.m-gnav > ul > .m-gnav_item.contact > a {
	padding-left: 40px
}

.menu_plus:after,
.menu_plus:before {
	display: block;
	background-color: #ce002c;
	right: 15px;
	-webkit-transition: .35s;
	-o-transition: .35s;
	transition: .35s;
	width: 13px;
	height: 2px
}

.menu_plus.active:before {
	-webkit-transform: translatey(-50%) rotate(-90deg);
	-ms-transform: translatey(-50%) rotate(-90deg);
	transform: translatey(-50%) rotate(-90deg);
	opacity: 0
}

.menu_plus.active:after {
	-webkit-transform: translatey(-50%) rotate(0);
	-ms-transform: translatey(-50%) rotate(0);
	transform: translatey(-50%) rotate(0)
}

.menu_plus:before {
	-webkit-transform: translatey(-50%);
	-ms-transform: translatey(-50%);
	transform: translatey(-50%)
}

.menu_plus:after {
	-webkit-transform: translatey(-50%) rotate(90deg);
	-ms-transform: translatey(-50%) rotate(90deg);
	transform: translatey(-50%) rotate(90deg)
}

.menu_arrow:after {
	display: inline-block;
	width: 7px;
	height: 7px;
	margin-top: -5px;
	right: 20px;
	background-color: inherit;
	border-top: 2px solid #ce002c;
	border-right: 2px solid #ce002c;
	-webkit-transform: rotate(45deg);
	-ms-transform: rotate(45deg);
	transform: rotate(45deg)
}


@media screen and (min-width:860px) {

	.m-gnav_content {
		display: none;
		position: absolute;
		left: 0;
		right: 0;
		top: 100%;
		margin: 0 auto;
		padding: 10px 0;
		width: 100%;
		z-index: 1;
		-webkit-box-shadow: 0 10px 20px -16px rgb(212, 3, 50);
		box-shadow: 0 10px 20px -16px rgb(212, 3, 50);
	}

	.m-gnav_content2 {
		display: none;
		position: absolute;
		left: 0;
		right: 0;
		top: 100%;
		margin: 0 auto;
		padding: 10px 0;
		width: 100%;
		z-index: 1;
		text-align: left;
		margin-top: -5px;
		background: #fff;
		padding-bottom: 20px;
		border-radius: 0 0 5px 5px;
		-webkit-box-shadow: 0 10px 20px -16px rgb(212, 3, 50);
		box-shadow: 0 10px 20px -16px rgb(212, 3, 50);
	}
}

.m-gnav_content {
	padding: 25px 15px 20px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	margin-top: -5px;
	width: 98%;
	border-radius: 0 0 5px 5px;
	z-index: 2;
	-webkit-box-shadow: 0 10px 20px -16px rgb(212, 3, 50);
	box-shadow: 0 10px 20px -16px rgb(212, 3, 50);

}

.m-gnav_content p.thin {
	font-weight: 700;
	font-size: .9rem;
	color: #333;
	margin: 35px 0 10px;
	text-align: center;
}


.gnav_cont_box {
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.1em;
}

.gnav_cont_box._service .inner:before {
	background: url(../img/service/bg01_sp.png) no-repeat center center;
	background-size: cover;
}

.gnav_cont_box._ad .inner:before {
	background: url(../img/top/top_ad.jpg) no-repeat center center;
	background-size: cover;
}

.gnav_cont_box._ec .inner:before {
	background: url(../img/service/bg03_sp.png) no-repeat center center;
	background-size: cover;
}

.gnav_cont_box._media .inner:before {
	background: url(../img/service/bg02_sp.png) no-repeat center center;
	background-size: cover;
}

.gnav_cont_box._dm .inner:before {
	background: url(../img/service/bg04_sp.png) no-repeat center center;
	background-size: cover;
}

.gnav_cont_box._recnew .inner:before {
	background: url(<?php echo SYS_SITE_URL; ?>common/img/common/btn-recruit-02.jpg) no-repeat center center;
	background-size: cover;
}

.gnav_cont_box._recnormal .inner:before {
	background: url(<?php echo SYS_SITE_URL; ?>common/img/common/btn-recruit-01.jpg) no-repeat center center;
	background-size: cover;
}

/*画像を追加*/
.gnav_cont_box .image {
	position: absolute;
	width: 100%;
	height: 100%;
	z-index: -1;

}

.gnav_cont_box .inner {
	padding: 0%;
	display: block;
}

.gnav_cont_box .inner:before {
	content: "";
	display: block;
	height: 150px;
	margin-bottom: 15px;
	border-radius: 0px;
}

@media screen and (min-width:860px) {
	.gnav_cont_box .inner:before {
		background-size: 35%
	}

	.gnav_cont_list li {}
}

@media screen and (min-width:1200px) {
	.gnav_cont_box .inner:before {
		background-size: 25%
	}
}


.gnav_cont_box.service a {
	padding: 50px 0 10px
}

.gnav_cont_list {
	padding: 0;
}

.gnav_cont_list li {
	font-size: 1.1rem;
	font-weight: bold;
	border-bottom: 1px solid #ddd
}

.gnav_cont_list_item {
	padding-top: 10px;
	padding-bottom: 10px
}

.dm_icon {
	padding-top: 5px;
	padding-bottom: 5px;
	padding-left: 40px;
	margin-left: 5px;
	background-image: url(../img/top/dm_icon.png);
	background-repeat: no-repeat;
	background-size: contain
}

@media screen and (min-width:860px) {
	.gnav_cont_list_item {
		font-size: 14px
	}

	.dm_icon {
		font-size: 20px;
		padding-left: 50px
	}

	.l-header_sp .container {
		padding: 0;
		display: table;
		-webkit-box-sizing: border-box;
		box-sizing: border-box
	}

	.l-header_pc_inner {
		margin-right: auto;
		margin-left: auto;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		border: none;
		padding: 0;
		background: #fff;
		z-index: 901;
		border-radius: 5px;
		-webkit-box-shadow: 0 0 15px -10px rgb(212, 3, 50);
		box-shadow: 0 0 15px -10px rgb(212, 3, 50);
		width: 98%;
	}

	.l-header_logo_wrap {
		float: none
	}

	.l-header_logo_wrap,
	.m-gnav,
	.m-gnav > ul > .m-gnav_item {
		display: inline-block;
		padding: 0;
		vertical-align: middle;
		padding: 0 15px;
	}

	.menu_arrow:after,
	.menu_plus:after,
	.menu_plus:before {
		display: none
	}

	.l-header_wrap.is-fixed {
		width: 100%;
		position: fixed;
		z-index: 99999999;
	}

	.l-header_wrap.is-fixed .m-gnav > ul > .m-gnav_item > a,
	.l-header_wrap.is-fixed .m-gnav > ul > .m-gnav_item > span {
		height: 65px
	}

	.l-header_wrap.is-fixed .m-gnav_item.contact {
		display: table-cell
	}

	.l-header_wrap.is-fixed .l-header_pc_inner {
		position: static;
		padding: 0
	}

	.l-header_wrap.is-fixed .m-gnav {
		position: static;
		display: block;
		float: right;
		width: auto
	}
}

.btn,
.career_fvtxt {
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}

.section_wrap {
	display: block;
	width: 100%;
	overflow: hidden
}

.section_content {
	margin: 0 auto;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	overflow: hidden
}

.blog_list li a,
.section_inner {
	-webkit-backface-visibility: hidden
}

.section_inner {
	margin: 0 -70px;
	-webkit-transform-origin: left center;
	-ms-transform-origin: left center;
	transform-origin: left center
}

.section_inner.right {
	background: #f9f9f9;
	-webkit-transform: rotate(3deg) translate3d(0, 0, 0);
	-ms-transform: rotate(3deg) translate3d(0, 0, 0);
	transform: rotate(3deg) translate3d(0, 0, 0)
}

.section_inner.left,
.section_inner.right .section_content {
	-webkit-transform: rotate(-3deg) translate3d(0, 0, 0);
	-ms-transform: rotate(-3deg) translate3d(0, 0, 0);
	transform: rotate(-3deg) translate3d(0, 0, 0)
}

.section_inner.left .section_content {
	-webkit-transform: rotate(3deg) translate3d(0, 0, 0);
	-ms-transform: rotate(3deg) translate3d(0, 0, 0);
	transform: rotate(3deg) translate3d(0, 0, 0);
	padding: 150px 90px 250px
}

.section_inner.fv_img .section_content {
	padding: 180px 0 200px;
	margin-top: -10%;
	background-color: #ce002c;
}

@media screen and (min-width:640px) {
	.section_wrap .section_wrap {
		display: block;
		width: 100%;
		overflow: hidden
	}

	.section_inner.fv_img .section_content {
		margin-top: -120px;
		padding: 280px 0
	}
}

@media screen and (min-width:860px) {
	.section_inner.fv_img .section_content {
		background-attachment: fixed;
	}
}

.section_inner.fv_img video {
	position: absolute;
	right: 0;
	bottom: 0;
	min-width: 100%;
	min-height: 100%;
	width: auto;
	height: auto
}

.section_inner.aboutus_img .section_content {
	background-attachment: scroll;
	padding: 140px 70px 70px;
	margin-top: -100px;
	background-color: #f9f9f9;
	background-image: url(../img/top/aboutus_bg.jpg);
	background-position: 50% center;
	background-size: cover
}

@media screen and (min-width:640px) {
	.section_inner.aboutus_img .section_content {
		margin-top: -120px;
		padding: 200px 100px;
		background-position: center center
	}
}

@media screen and (min-width:860px) {
	.section_inner.aboutus_img .section_content {
		background-attachment: fixed
	}
}

.section_inner.wkl_img .section_content {
	background-attachment: scroll;
	padding: 120px 70px 50px;
	margin-top: -100px;
	background-color: #f9f9f9;
	background-image: url(../img/top/02.png);
	background-position: 10% center;
	background-size: cover;
}

@media screen and (min-width:640px) {
	.section_inner.wkl_img .section_content {
		padding: 200px 100px 150px;
		background-position: center center
	}
}

@media screen and (min-width:860px) {
	.section_inner.wkl_img .section_content {
		margin-top: -100px;
		background-attachment: fixed;
		background-image: url(../img/top/02.png);
	}

	.wkl_wrap {
		display: table;
		table-layout: fixed;
		width: 100%
	}
}

.bg_base,
body {
	background: #f9f9f9
}

.section_inner.top_service {
	-webkit-box-shadow: 0 -5px 10px -1px rgba(0, 0, 0, .2);
	box-shadow: 0 -5px 10px -1px rgba(0, 0, 0, .2)
}

.section_inner.top_service .section_content {
	padding: 10px 90px 0px;
}

.section_inner.foot_section {
	margin-top: 0px;
	-webkit-box-shadow: none;
	box-shadow: none;
}

.section_inner.foot_section .section_content {
	padding: 50px 70px 30px;
}

@media screen and (min-width:640px) {
	.section_inner.foot_section .section_content {
		padding: 15px 90px;
	}
}

.section_inner.top_news {
	-webkit-box-shadow: 0 -5px 10px -1px rgba(0, 0, 0, .2);
	box-shadow: 0 -5px 10px -1px rgba(0, 0, 0, .2);
}

.section_inner.top_news .section_content {
	padding: 10px 70px 100px;
}

@media screen and (min-width:640px) {
	.foot_section {
		margin-top: -100px
	}
}

.l-service_container {
	position: relative;
	margin-top: 30px;
	padding-top: 30px;
	width: 100%;
}

@media screen and (min-width:640px) {
	.l-service_container {
		width: 49%;
	}
}

@media screen and (min-width:860px) {
	.l-service_container {
		width: 48%;
	}
}

.l-service_container .service_num_wrap {
	position: absolute;
	top: -.8em;
	left: 10px
}

.l-service_container .l-svitem {
	display: block;
	margin-top: 30px
}

.l-svimg {
	min-height: 60vw
}

@media screen and (min-width:640px) {
	.l-service_container .service_num_wrap {
		left: 0
	}

	.l-service_container .l-svitem {
		margin-top: 0;
		width: 100%;
		padding-left: 20px;
	}

	.l-service_container.left,
	.l-service_container.right {
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: start;
		-ms-flex-align: start;
		align-items: flex-start;
	}


	.l-svimg {
		min-height: 200px;
		width: calc(50% - 35px);
	}
}

.l-svimg.veve img {
	width: 80%;
	padding-left: 10%;
	padding-right: 10%
}

.l-service_info {
	width: 90%;
	padding: 0 5%
}

@media screen and (min-width:640px) {
	.l-service_info {
		width: 90%;
		padding: 0 0 0 10%;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center
	}


	.l-service_info .l-service_info_item {
		width: 95%;
		line-height: 2em;
		text-align: center;
	}
}

.l-service_info .right {
	width: 50%;
	float: right
}

.l-service_info .right.dm {
	width: 30%
}

.l-service_copy {
	margin-top: 10%;
	margin-bottom: 20%
}

@media screen and (min-width:640px) {
	.l-service_info .right {
		width: 50%;
		float: none
	}

	.l-service_copy {
		margin-top: 100px;
		margin-bottom: 150px
	}
}

.l-blog_wrap,
.l-news_wrap {
	width: 100%
}

@media screen and (min-width:640px) {

	.l-blog_wrap,
	.l-news_wrap {
		float: left;
		width: 69%;
		margin-left: 1%
	}
}

@media screen and (min-width:860px) {

	.l-blog_wrap,
	.l-news_wrap {
		width: 75%;
	}
}

.foot_banner {
	padding-top: 20px;
	padding-left: 10px;
	padding-bottom: 20px;
	border-top: 1px solid #bfbfbf;
	-ms-overflow-x: scroll;
	overflow-x: scroll;
	-ms-overflow-style: none
}

.foot_banner::-webkit-scrollbar {
	display: none
}

.foot_banner ul {
	width: 1050px
}

.foot_banner li {
	float: left;
	min-width: 150px;
	max-width: 350px
}

.foot_banner img {
	height: 80px
}

.foot_list_wrap {
	color: #aaa
}

.foot_list {
	width: 94%;
	margin-right: 3%;
	margin-left: 3%
}

@media screen and (min-width:640px) {
	.foot_list {
		width: 22%;
		vertical-align: top;
		display: inline-block;
		margin-right: 0;
		margin-left: 0
	}
}

.foot_list a,
.foot_list_tit.handler.active + .foot_inner {
	display: block
}

.foot_list i {
	float: right;
	margin-top: 5px;
	-webkit-transition: .4s;
	-o-transition: .4s;
	transition: .4s
}

.foot_list_tit {
	display: block;
	position: relative;
	z-index: 1;
	padding-top: 10px;
	padding-bottom: 10px;
	padding-right: 25px;
	margin: 2px 0;
}

@media screen and (min-width:640px) {
	.foot_list_tit {
		cursor: normal;
		padding-bottom: 0
	}
}

#GrayMask,
.ad_msc_ttl,
.btn,
.pointer,
.rcr_tab_btn li {
	cursor: pointer
}

.foot_list_tit.handler.active i {
	-webkit-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
	transform: rotate(90deg)
}

.foot_inner {
	border-top: 1px solid #eee;
	padding-top: 10px;
	padding-bottom: 10px;
	padding-left: 10px
}

@media screen and (min-width:640px) {
	.foot_inner {
		border-top: none;
		padding-left: 20px;
		list-style-type: disc;
	}
}

.foot_list_item a {
	padding: 5px 1%
}

.copyright {
	margin-top: 50px
}

@media screen and (min-width:640px) {
	.foot_banner ul {
		width: 800px;
		margin: 0 auto;
		-ms-overflow-x: hidden;
		overflow-x: hidden
	}

	.copyright {
		margin-top: 80px
	}
}

@font-face {
	font-family: WFonts;
	font-weight: 400;
	src: url(../fonts/axisel.eot);
	src: url(../fonts/axisl.otf) format("opentype"), url(../fonts/axisl.woff) format("woff")
}

@font-face {
	font-family: WFonts;
	font-weight: 700;
	src: url(../fonts/axism.eot);
	src: url(../fonts/axism.otf) format("opentype"), url(../fonts/axism.woff) format("woff")
}

body {
	/* font-family: WFonts, 'メイリオ', 'ヒラギノ角ゴシック', 'ＭＳ ゴシック', 'ＭＳ Ｐゴシック', 'MS PGothic', YuGothic, 'Yu Gothic', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif;
	font-size: 14px;
	color:#333; */
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Noto Sans Japanese", "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, Meiryo, sans-serif;
	font-size: 15px;
	color: #1a1a1a;
	line-height: 1.5;
	margin: 0;
	padding: 0
}

.fwb,
.fwel,
.fwl,
.fwr {
	/* font-family: WFonts, 'メイリオ', 'ＭＳ ゴシック', 'ＭＳ Ｐゴシック', 'MS PGothic', YuGothic, 'Yu Gothic', 'ヒラギノ角ゴシック', 'Hiragino Sans', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif */
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Noto Sans Japanese", "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, Meiryo, sans-serif;
}

.fa,
.far,
.fas {
	font-size: 15px
}

.font_min {
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif
}

.widthmax {
	width: 100%
}

.ver_top {
	vertical-align: top
}

.career_fvtxt,
.ver_mid {
	vertical-align: middle
}

.ovh {
	overflow: hidden
}

.ovy_scl {
	overflow-y: scroll
}

.c_red {
	color: #ce002c;
}

.c_red_important {
	color: #ce002c !important;
	margin-bottom: 0 !important;
}

.c_red_important:before {
	background: #ce002c !important;
}

.c_gray {
	color: #888
}

.c_gold {
	color: #9f8244
}

.c_white {
	color: #fff;
}

.c_pink {
	color: #ff4067
}

.c_black {
	color: #222 !important;
}

.c_blue {
	color: #2e78cc;
}

.bg_white {
	background: #fff
}

.bg_rgba_white {
	background: rgba(255, 255, 255, .8)
}

.bg_gray {
	background: #888
}

.bg_lightgray {
	background: #f1f1f1
}

.bg_black {
	background: #222
}

.bg_red,
.must {
	color: #fff;
	background: #ce002c
}

a.underline {
	text-decoration: underline
}

.blog_list li a,
.new_box p,
a {
	text-decoration: none
}

.must {
	font-size: 9px;
	border-radius: 2px;
	padding: 0 4px 1px;
	margin: 0 5px;
	display: inline-block;
	font-weight: 400
}

.red_btn,
.trns_btn {
	color: #fff;
	font-weight: 500;
}

.dn {
	display: none
}

.db {
	display: block
}

.dinb {
	display: inline-block
}

.din {
	display: inline
}

.dt {
	display: table
}

.dtce {
	display: table-cell
}

.top_border {
	border-top: 1px solid #888
}

.bottom_border {
	border-bottom: 1px solid #888
}

.top_dot_border {
	border-top: 1px dotted #888
}

.tar {
	text-align: right
}

.btn,
.rcr_dt {
	text-align: center
}

.word_wrap {
	word-wrap: break-word;
	overflow-wrap: break-word
}

.blog_data,
.blog_img,
.blog_list,
.blog_stfimg,
.eisu_brock,
.map_inner,
.page-top-visual,
.rcr_sys_img,
.sv_box {
	overflow: hidden
}

.flr {
	float: right
}

.fl-l,
.fll {
	float: left
}

.cb {
	clear: both
}

.btn {
	font-size: 1rem;
	font-weight: 700;
	display: inline-block;
	min-width: 100%;
	background: #ccc;
	padding: 10px 15px;
	-moz-appearance: none;
	-webkit-appearance: none;
	appearance: none;
	-webkit-transition: .3s;
	-o-transition: .3s;
	transition: .3s;
	/* -webkit-box-shadow: 2px 4px 10px rgba(0, 0, 0, .4);
	box-shadow: 2px 4px 10px rgba(0, 0, 0, .4) */
}

@media screen and (min-width:640px) {
	.btn {
		font-size: 100%;
		min-width: 200px;
	}
}

.mini_btn {
	padding: 5px 10px
}

.red_btn {
	background: #ce002c;
	letter-spacing: 2px;
	border-radius: 5px;
	-webkit-box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2);
	box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2);
}

.white_btn {
	background: #fff;
	color: #ce002c;
	letter-spacing: 2px;
	border-radius: 5px;
	-webkit-box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2);
	box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2);
	position: relative;
	z-index: 2;
}

a.btn:hover,
a.red_btn:hover {
	-webkit-box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .5);
	box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .5);
}

.trns_btn {
	background: none;
	border: 1px solid #fff;
	width: 60%;
	font-weight: normal;
	letter-spacing: 0.1em;
	display: block;
	margin: auto;
}


.trns_btn:hover {
	background: #ce002c;
	border-color: #ce002c;
	border-radius: 5px;
}


.fs10 {
	font-size: 10px
}

.fs12 {
	font-size: 12px
}

.fs14 {
	font-size: 14px
}

.fs16 {
	font-size: 16px
}

.fs18 {
	font-size: 18px
}

.fs20 {
	font-size: 20px
}

.fs22 {
	font-size: 22px
}

.fs28 {
	font-size: 28px
}

.pad5 {
	padding: 5px
}

.pad10 {
	padding: 10px
}

.pad15 {
	padding: 15px
}

.pad20 {
	padding: 20px
}

.padt10 {
	padding-top: 10px
}

.padt20 {
	padding-top: 20px
}

.padt30 {
	padding-top: 30px
}

.padt40 {
	padding-top: 40px
}

.padt50 {
	padding-top: 50px
}

.padt60 {
	padding-top: 60px
}

.padt70 {
	padding-top: 70px
}

.padt80 {
	padding-top: 80px
}

.padl0 {
	padding-left: 0px;
}

.padl10 {
	padding-left: 10px
}

.padl20 {
	padding-left: 20px
}

.padl30 {
	padding-left: 30px
}

.padl40 {
	padding-left: 40px
}

.padl50 {
	padding-left: 50px
}

.padl60 {
	padding-left: 60px
}

.padl70 {
	padding-left: 70px
}

.padl80 {
	padding-left: 80px
}

.padr5 {
	padding-right: 5px
}

.padr10 {
	padding-right: 10px
}

.padr20 {
	padding-right: 20px
}

.padr30 {
	padding-right: 30px
}

.padr40 {
	padding-right: 40px
}

.padr50 {
	padding-right: 50px
}

.padr60 {
	padding-right: 60px
}

.padr70 {
	padding-right: 70px
}

.padr80 {
	padding-right: 80px
}

.padb5 {
	padding-bottom: 5px
}

.padb10 {
	padding-bottom: 10px
}

.padb20 {
	padding-bottom: 20px
}

.padb30 {
	padding-bottom: 30px
}

.padb40 {
	padding-bottom: 40px
}

.padb50 {
	padding-bottom: 50px
}

.padb60 {
	padding-bottom: 60px
}

.padb70 {
	padding-bottom: 70px
}

.padb80 {
	padding-bottom: 80px
}

.padb90 {
	padding-bottom: 90px
}

.padb100 {
	padding-bottom: 100px !important;
}

.dpib {
	display: inline-block;
}

.mt5 {
	margin-top: 5px
}

.mt10 {
	margin-top: 10px
}

.mt15 {
	margin-top: 15px
}

.mt20 {
	margin-top: 20px
}

.mt30 {
	margin-top: 30px
}

.mt40 {
	margin-top: 40px
}

.mt50 {
	margin-top: 50px
}

.mt70 {
	margin-top: 70px
}

.mt80 {
	margin-top: 80px
}

.mt100 {
	margin-top: 100px
}

.mt200 {
	margin-top: 200px
}

.mr5 {
	margin-right: 5px
}

.mr10 {
	margin-right: 10px
}

.mr20 {
	margin-right: 20px
}

.mr30 {
	margin-right: 30px
}

.mr40 {
	margin-right: 40px
}

.mr50 {
	margin-right: 50px
}

.ml5 {
	margin-left: 5px
}

.ml10 {
	margin-left: 10px
}

.ml20 {
	margin-left: 20px
}

.ml30 {
	margin-left: 30px
}

.ml40 {
	margin-left: 40px
}

.ml50 {
	margin-left: 50px
}

.ml60 {
	margin-left: 60px
}

.ml70 {
	margin-left: 70px
}

.ml80 {
	margin-left: 80px
}

.ml90 {
	margin-left: 90px
}

.mb5 {
	margin-bottom: 5px
}

.mb10 {
	margin-bottom: 10px
}

.mb20 {
	margin-bottom: 20px
}

.mb30 {
	margin-bottom: 30px
}

.mb40 {
	margin-bottom: 40px
}

.mb50 {
	margin-bottom: 50px
}

.w10p {
	width: 10px
}

.w15p {
	width: 15px
}

.w20p {
	width: 20px
}

.w25p {
	width: 25px
}

.w30p {
	width: 30px
}

.w50p {
	width: 50px
}

.w60p {
	width: 60px
}

.w70p {
	width: 70px
}

.w80p {
	width: 80px
}

.w100p {
	width: 100px
}

.w120p {
	width: 120px
}

.w150p {
	width: 150px
}

.w160p {
	width: 160px
}

.w200p {
	width: 200px
}

.w220p {
	width: 220px
}

.w250p {
	width: 250px
}

.w300p {
	width: 300px
}

.w350p {
	width: 350px
}

.w400p {
	width: 400px
}

.w450p {
	width: 450px
}

.w500p {
	width: 500px
}

.w28 {
	width: 28%;
}

.w70 {
	width: 70%;
}

.udline_red {
	border-bottom: 2px solid #ce002c
}

.focus {
	background: #fff
}

.def_img {
	max-width: 100%
}

.def_link,
.def_link:hover {
	color: #222
}

.bor_orange {
	border: 1px solid #ff8100
}

.bor_yellow {
	border: 1px solid #FFB400
}

.bor_green {
	border: 1px solid #69BF00
}

.bor_skyblue {
	border: 1px solid #30BCED
}

.bor_blue {
	border: 1px solid #067BC2
}

.eisu_brock {
	word-break: break-all;
	-o-text-overflow: ellipsis;
	text-overflow: ellipsis
}

.good_btn {
	margin: 20px 0 10px 0;
	display: inline-block;
	font-weight: bold;
	padding: 3px 7px 3px 5px;
	cursor: pointer;
	color: #d40332;
	border: 2px solid #d40332;
	-webkit-border-radius: 3px;
	border-radius: 3px;
	-webkit-transition: .2s;
	-moz-transition: .2s;
	-ms-transition: .2s;
	-o-transition: .2s;
	transition: .2s;
}

.good_btn._checked {
	background: #FFF;
	cursor: default;
	color: #fff;
	background: #d40332;
}

.hov_opa {
	-webkit-transition: .2s;
	-o-transition: .2s;
	transition: .2s
}

.hov_opa:hover {
	opacity: .7
}

.sp {
	display: block
}

.pc {
	display: none
}

.txt_shadow {
	text-shadow: 0px 1px 5px rgba(0, 0, 0, .2)
}

.white_arrow {
	padding-left: 8px;
	background: url(../img/common/white_arrow.png) left center no-repeat;
	background-size: 3px
}

.red_arrow {
	padding-left: 0px;
	background: url(../img/common/red_arrow.png) right center no-repeat;
	background-size: 5px;
	padding-right: 10px;
}

.black_arrow {
	padding-left: 10px;
	background: url(../img/common/black_arrow.png) left center no-repeat;
	background-size: 5px
}

@media only screen and (max-width:640px) {
	.fl-l {
		float: none
	}
}

.fl-r {
	float: right
}

@media only screen and (max-width:640px) {
	.fl-r {
		float: none
	}
}

.pc-mode-01,
.pc-mode-02,
.pc-mode-03 {
	display: none !important
}

.sp-mode-01 {
	display: block !important
}

.sp-mode-02 {
	display: inline !important
}

.sp-mode-03 {
	display: inline-block !important
}

@font-face {
	font-family: icomoon;
	src: url(../fonts/wendlessicon.eot?7o772p);
	src: url(../fonts/wendlessicon.eot?7o772p#iefix) format("embedded-opentype"), url(../fonts/wendlessicon.ttf?7o772p) format("truetype"), url(../fonts/wendlessicon.woff?7o772p) format("woff"), url(../fonts/wendlessicon.svg?7o772p#icomoon) format("svg");
	font-weight: 400;
	font-style: normal
}

[class*=" cpicon-"],
[class^=cpicon-] {
	font-family: icomoon !important;
	speak: none;
	font-style: normal;
	font-weight: 400;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale
}

.cpicon-link_icon:before {
	content: "\e903"
}

.cpicon-double_arrow_right:before {
	content: "\e900"
}

.cpicon-double_arrow_left:before {
	content: "\e901"
}

.cpicon-home_icon:before {
	content: "\e902"
}

.cpicon-arrow_icon_right:before {
	content: "\e904"
}

.cpicon-arrow_icon_bottom:before {
	content: "\e905"
}

.cpicon-calendar:before {
	content: "\e906"
}

.dttl:before,
.msvc-line:after,
.privacy_list-01 li:before,
.seo_msg_txt_box:before {
	content: ""
}

.ptv_ttl_recruit {
	font-size: 16px;
	font-family: serif;
	font-weight: 700
}

@media screen and (min-width:640px) {
	.pc-mode-01 {
		display: block !important
	}

	.pc-mode-02 {
		display: inline !important
	}

	.pc-mode-03 {
		display: inline-block !important
	}

	.sp-mode-01,
	.sp-mode-02,
	.sp-mode-03 {
		display: none !important
	}

	.ptv_ttl_recruit {
		font-size: 22px
	}
}

.career_fvtxt {
	text-shadow: 0 0 10px #000;
	padding: 0 6%;
	display: table-cell
}

.rcr_dd,
.rcr_dt,
.rcr_sys_list li {
	vertical-align: top
}

.recruit_fvtxt {
	position: absolute;
	z-index: 2
}

.rcr_dt {
	width: calc(100% + 20px);
	padding: 10px;
	margin-bottom: 10px;
	line-height: 2;
	background: -o-linear-gradient(315deg, #d00026 10%, #ff5151 71%, #f1eaca 100%);
	background: linear-gradient(135deg, #d00026 10%, #ff5151 71%, #f1eaca 100%);
	color: #fff;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	margin: 0 -10px;
}

@media screen and (min-width:640px) {
	.rcr_dt {
		background: transparent;
		color: #7c7c7c;
		text-align: left;
		display: table-cell;
		width: 250px;
		padding: 0;
		line-height: 2.15
	}
}

.rcr_dd {
	width: 100%;
	line-height: 2
}

@media screen and (min-width:640px) {
	.rcr_dd {
		display: table-cell;
		line-height: 2.15
	}
}

.boxcont,
.interview_wrap {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-bottom: 20px
}

.box_interview {
	width: 100%;
	min-width: auto;
	min-height: 140px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	font-size: 1.5em;
	background: #fff;
	-webkit-box-flex: 1;
	-ms-flex: 1 1 auto;
	flex: 1 1 auto;
	margin: 0;
	padding: 0;
	line-height: 1;
	color: #4b4b4b;
	font-weight: 700;
	position: relative
}

@media screen and (min-width:640px) {
	.box_interview {
		font-size: 18px;
		min-width: 190px;
		width: 50%
	}
}

.box_interview h3 {
	margin: 1em .3em;
	font-size: .8em
}

@media screen and (min-width:640px) {
	.box_interview h3 {
		margin: 20px 0 10px;
		padding: 0 20px
	}
}

.box_interview p {
	font-size: .7em;
	padding: 0 20px;
	color: #4b4b4b
}

.box_interview .link {
	position: absolute;
	bottom: 20px;
	left: 0
}

.box_interview .link a {
	background-color: #cd002c;
	padding: 10px 15px;
	color: #fff;
	font-size: 13px
}

.box_interview img {
	opacity: 0;
	-webkit-transition: all ease 1s;
	-o-transition: all ease 1s;
	transition: all ease 1s;
	-webkit-transform: translateX(-100px);
	-ms-transform: translateX(-100px);
	transform: translateX(-100px)
}

.box_interview:nth-child(2n) {
	background: #fff
}

.anime .box_interview img {
	opacity: 1;
	-webkit-transform: translateX(0);
	-ms-transform: translateX(0);
	transform: translateX(0)
}

.box_data {
	width: calc(100%/3);
	-webkit-box-flex: 1;
	-ms-flex: 1 1 auto;
	flex: 1 1 auto;
	display: inherit;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	text-align: center;
	padding: 20px;
	min-height: 200px;
	background: #bc2734;
	color: #fff;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	font-size: 13px;
	opacity: 0;
	-webkit-transition: all ease 1s;
	-o-transition: all ease 1s;
	transition: all ease 1s;
	-webkit-transform: translateY(100px);
	-ms-transform: translateY(100px);
	transform: translateY(100px)
}

.box_data:nth-child(2n) {
	background: #dcdcdc;
	color: #000
}

.wid_three {
	width: calc(100% /3)
}

.new_box p {
	display: block;
	margin: 0;
	padding: 20px;
	color: #fff
}

.anime .box_data {
	opacity: 1;
	-webkit-transform: translateY(0);
	-ms-transform: translateY(0);
	transform: translateY(0)
}

.anime .box_data:nth-child(2) {
	-webkit-transition-delay: .5s;
	-o-transition-delay: .5s;
	transition-delay: .5s
}

.anime .box_data:nth-child(3) {
	-webkit-transition-delay: 1s;
	-o-transition-delay: 1s;
	transition-delay: 1s
}

.anime .box_data:nth-child(4) {
	-webkit-transition-delay: 1.5s;
	-o-transition-delay: 1.5s;
	transition-delay: 1.5s
}

.anime .box_data:nth-child(5) {
	-webkit-transition-delay: 2s;
	-o-transition-delay: 2s;
	transition-delay: 2s
}

.anime .box_data:nth-child(6) {
	-webkit-transition-delay: 2.5s;
	-o-transition-delay: 2.5s;
	transition-delay: 2.5s
}

@media screen and (max-width:640px) {
	.box_data {
		width: 100%
	}
}

.rcr_sys_list {
	width: auto;
	margin: 40px 0 0
}

.rcr_sys_list li {
	display: block;
	width: auto;
	margin-bottom: 30px;
	font-size: 14px
}

@media screen and (min-width:640px) {
	.rcr_sys_list {
		margin-top: 50px
	}

	.rcr_sys_list li {
		display: inline-block;
		width: calc(100% / 3);
	}
}

.rcr_sys_list li:nth-child(even) {
	margin-right: 0
}

.rcr_sys_inner {
	position: relative;
	padding: 16px 0 0
}

@media screen and (min-width:640px) {
	.rcr_sys_inner {
		padding: 16px 0 0 20px
	}
}

.rcr_sys_ttl {
	top: 0;
	left: 5px;
	position: absolute;
	z-index: 1;
	padding: 13px 18px 11px;
	background: #cd002c;
	color: #fff;
	font-weight: 700;
	line-height: 1.4
}

.rcr_sys_img {}

.rcr_sys_img img {
	width: 100%
}

.rcr_sys_txt {
	padding: 10px 15px;
	line-height: 1.75;
}

.rcr_msg_ttl {
	margin: 0 0 15px;
	padding: 0 0 15px;
	font-size: 20px;
	letter-spacing: .1em;
	line-height: 1.4;
	border-bottom: 1px solid #a40000
}

@media screen and (min-width:640px) {
	.rcr_msg_ttl {
		margin: 0 0 18px;
		padding: 0 0 23px;
		font-size: 30px
	}
}

.rcr_msg_txt {
	position: relative;
	z-index: 9;
	font-size: 14px;
	line-height: 2
}

.rcr_msg_sign {
	position: static;
	margin-top: 5px;
	text-align: right;
	z-index: 1
}

@media screen and (min-width:640px) {
	.rcr_msg_txt {
		font-size: 14px
	}

	.rcr_msg_sign {
		position: absolute;
		bottom: 10px;
		right: 10px
	}
}

.rcr_msg_col2 {
	margin: 40px auto 0;
	max-width: 1400px;
	position: relative;
	padding: 32px 0 84px
}

.rcr_msg_box {
	width: auto;
	position: relative;
	z-index: 9
}

.rcr_msg_inner {
	padding: 0 0 20px
}

@media screen and (min-width:640px) {
	.rcr_msg_col2 {
		margin: 50px auto 0
	}

	.rcr_msg_box {
		filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#CCffffff, endColorstr=#CCffffff);
		background: rgba(255, 255, 255, .8);
		width: 60.41667%
	}

	.rcr_msg_inner {
		padding: 30px
	}
}

.rcr_msg_img {
	position: static;
	width: auto
}

@media screen and (min-width:640px) {
	.rcr_msg_img {
		position: absolute;
		top: 0;
		left: 0;
		z-index: 1;
		width: 50%
	}
}

.rcr_tab_btn,
.rcr_table_wrap {
	width: 100%;
	table-layout: fixed
}

.mr-recruit {
	padding: 0 4% 70px
}

.rcr_tab_btn {
	margin: 40px 0 70px;
	display: table
}

@media screen and (min-width:640px) {
	.mr-recruit {
		padding-bottom: 123px
	}

	.rcr_tab_btn {
		margin: 59px 0 82px
	}
}

.rcr_tab_btn li {
	line-height: 1.5;
	font-size: 14px;
	color: #ce002c;
	font-weight: 700;
	display: table-cell;
	border: 1px solid #ce002c;
	padding: 12px 10px 11px;
	border-radius: 10px 10px 0 0;
	text-align: center
}

.cmp_dl:first-child,
.history_list li:first-child {}

.rcr_tab_btn li.current {
	color: #fff;
	background: #ce002c
}

.rcr_table_wrap {
	padding: 0 0 18px;
	display: table;
	border-bottom: 1px dotted #888
}

.cmp_dl,
.history_list li {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border-bottom: 1px solid #ddd;
}

.dttl,
.msa-ttl-01,
.privacy_ttl {
	border-bottom: 1px solid #ddd;
}

@media screen and (min-width:640px) {
	.rcr_tab_btn li {
		line-height: 1;
		font-size: 18px
	}

	.rcr_table_wrap {
		padding: 30px;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}
}

.rcr_table_wrap + .rcr_table_wrap {
	padding-top: 18px
}

.rcr_table_wrap ul.flow {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.rcr_table_wrap ul.flow li {
	display: table-cell;
	width: 25%;
	text-align: center;
	position: relative;
}

.rcr_table_wrap ul.flow li:after {
	position: absolute;
	content: "\00ab";
	font-size: 30px;
	top: 0;
	bottom: 0;
	margin: auto;
	-webkit-transform: rotate(180deg);
	-ms-transform: rotate(180deg);
	transform: rotate(180deg);
	right: 0;
	line-height: 3;
}

.rcr_table_wrap ul.flow li:last-child::after {
	position: absolute;
	content: "";
}

.flow li:last-child:after {
	position: absolute;
	content: "";
}

.rcr_table_wrap ul.flow li img {
	max-width: 100%;
	width: initial;
}

@media screen and (min-width:640px) {
	.rcr_table_wra {
		width: calc(100% - 40px);
		padding-top: 24px;
		margin: 0 -10px;
	}
}

.rcr_btn_wrap {
	margin: 30px 0 0;
	text-align: center
}

.rcr_btn {
	display: inline-block
}

.rcr_btn a {
	display: block;
	background: #cd002c;
	padding: 21px 45px 18px;
	letter-spacing: .19em;
	border-radius: 9px;
	color: #fff;
	font-weight: 700;
	line-height: 1.5;
	text-align: center
}

.company_logo_wrap {
	width: 117px;
	margin: 0 auto 40px
}

.company_top_txt {
	text-align: justify;
	line-height: 2.2;
	padding: 0 3%;
	font-size: 12px;
	font-size: 1.5;
	font-weight: 700;
	color: #000;
	margin: 0 0 2.2em
}

@media screen and (min-width:860px) {
	.company_top_txt {
		font-size: 14px;
		text-align: center;
		line-height: 2.2
	}
}

.mcpycply_txt {
	font-size: 24px;
	font-weight: 700;
	color: #fff;
	text-align: center;
	margin: 1.5% 0 0;
	letter-spacing: -1.5px
}

.mcpy-cont-cpd {
	padding-top: 6.8%;
	padding-bottom: 9%
}

.cmp_list_inner {
	width: auto;
}

.cmp_dl {
	padding: 20px 1%;
	display: table;
	table-layout: fixed;
	width: 100%
}

.cmp_dl dd,
.cmp_dl dt {
	display: table-cell;
	vertical-align: middle
}

.cmp_dl dt {
	width: 29%;
	color: #333;
}

.cmp_dl dd {
	color: #333;
}

.cmp_his_head {
	font-size: 12px;
	padding: 0 3%;
	line-height: 2;
	margin-top: 3%
}

.history_list {}

.history_list li {
	font-size: 12px;
	color: #4b4b4b;
	padding: 4.5% 2% 5%
}

.cmp_his_inner {
	display: inline-block;
	table-layout: auto;
	width: auto
}

.csl_msf_ctbox,
.ctl_msf_ttl,
.mcs-wrap,
.mri-col2,
.msvc-head {
	table-layout: fixed
}

@media screen and (min-width:640px) {
	.history_list {
		margin: 3% 0;
	}

	.history_list li {
		padding: 1% 0%;
	}

	.cmp_his_inner {
		display: table;
		table-layout: fixed
	}
}

.cmp_his_img {
	width: 32%;
	padding: 0 5% 0 0
}

@media screen and (min-width:640px) {
	.cmp_his_img {
		width: 70px;
		padding: 0 10px 0 0
	}
}

.cmp_his_img,
.cmp_his_txt {
	display: table-cell;
	vertical-align: middle;
	text-align: center;
}

.cmp_his_date {
	display: block;
	width: auto;
	text-align: left;
	padding: 0;
	margin: 0 0 2%
}

@media screen and (min-width:640px) {
	.cmp_his_date {
		width: 150px;
		padding: 0 20px 0 0
	}
}

.cmp_his_txt {
	padding: 0;
	text-align: justify;
	vertical-align: top
}

@media screen and (min-width:860px) {
	.mcpycply_txt {
		font-size: 40px
	}


	.cmp_list_inner {
		display: inline-block;
		vertical-align: top;
		letter-spacing: normal;
	}

	.cmp_dl {
		padding: 20px 5px 20px 45px
	}

	.cmp_dl dt {
		width: 150px
	}

	.mcpy-cont-aes {
		padding-top: 3%;
		padding-bottom: 3%
	}

	.mcpy-cont-hty {
		padding-top: 5%;
		padding-bottom: 5%
	}

	.cmp_his_head {
		font-size: 14px;
		text-align: center
	}
}

.seo_mswa_bg01 {
	background: url(../img/service/dm/mswa-bg01.png) top left;
	background-size: 8px 8px
}

.seo_mswa_bg02 {
	background: url(../img/service/dm/mswa-bg02.png) top left;
	background-size: 8px 8px
}

.seo_mswa_bg03 {
	background: url(../img/service/dm/mswa-bg03.png) top left;
	background-size: 8px 8px
}

.seo_ms_message {
	padding: 40px 0 100px
}

@media screen and (min-width:640px) {
	.seo_ms_message {
		padding-top: 117px;
		padding-bottom: 135px
	}
}

.ms-voice {
	padding-top: 37px;
	padding-bottom: 63px
}

.msv-ct-box {
	margin: 90px 0 0
}

.msv-ct-box + .msv-ct-box {
	margin-top: 53px
}

.msvc-head {
	display: table;
	width: 100%;
	margin: 0 0 10px
}

.msvc-line,
.msvc-ttl {
	display: table-cell;
	vertical-align: middle
}

.msvc-ttl {
	width: 360px
}

.msvc-line {
	padding: 0 0 0 14px
}

.msvc-line:after {
	display: block;
	height: 2px;
	width: 100%;
	background: #e41111
}

.msvc-txt {
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.75
}

.seo_msg_txt_box {
	width: auto;
	position: relative
}

@media screen and (min-width:640px) {
	.seo_msg_txt_box {
		width: 50%
	}
}

.seo_msg_txt_box:before {
	top: -12px;
	left: 4px;
	position: absolute;
	height: 40px;
	width: 40px;
	z-index: 1;
	background: #eb4d4d
}

.seo_msst_ttl,
.seo_msst_txt {
	z-index: 9;
	position: relative
}

@media screen and (min-width:640px) {
	.seo_msg_txt_box:before {
		height: 60px;
		width: 60px
	}
}

.seo_msst_ttl {
	padding: 35px 0 56px;
	font-size: 30px;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.2;
	text-align: center;
	letter-spacing: .1em
}

.seo_msst_txt {
	padding: 0 17px;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.75
}

.seo_msst_txt + .seo_msst_txt {
	margin-top: 29px
}

.seo_msst_img {
	width: 50%;
	text-align: right
}

.blog_list {
	padding: 10px 2.5% 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: flex-start;
    margin:0px 2%;
}

@media screen and (max-width:414px) {
	.blog_list {
		padding: 10px 1% 0;
	}
}

.blog_list li {
	background: #fff;
	vertical-align: top;
	width: 49%;
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	margin-bottom: 30px;
	border-radius: 5px;
	-webkit-box-shadow: 0 2px 2px rgba(0, 0, 0, .2);
	box-shadow: 0 2px 2px rgba(0, 0, 0, .2)
}

@media screen and (min-width:1200px) {
	.blog_list li {
        width: 30%;
        margin: 0px 1%;
	}
}

@media (max-width: 767px) {
	.blog_list li {
		width: 100%;
	}

	.rcr_table_wrap ul.flow {
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	.rcr_table_wrap ul.flow li {
		display: table-cell;
		width: 100%;
		text-align: center;
		position: relative;
		font-size: .7rem;
		line-height: 1.3em;
		height: 90px;
	}

	.rcr_table_wrap ul.flow li:after {
		font-size: 10px;
		bottom: 20px;
		right: -5px;
		display: none;
	}
}

@media screen and (max-width: 640px) {
	.blog_list {
		padding: 10px 0% 0 0;
	}
}

.blog_list li a {
	display: block;
	position: relative;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	width: 100%;
	-webkit-transition: all .3s;
	-o-transition: all .3s;
	transition: all .3s;
	border-radius: 5px;
}

.flip-in-x,
.flip-in-x-nr,
.flip-out-x {
	-webkit-backface-visibility: visible !important;
	backface-visibility: visible !important
}

.article_stf,
.dttl:before,
.privacy_list-01 li:before {
	display: inline-block;
	vertical-align: top
}

.pager-01 li,
.ptv_ttl,
.sv_tit,
.wkl_cont_inner {
	vertical-align: middle
}

.breadcrumb li,
.msa-list li,
.msa-ttl-01:before,
.msa-ttl-02:before,
.msal-txt,
.msd-list li,
.sv_box,
.sv_txt {
	vertical-align: top
}

.blog_img {
	height: 150px;
}

@media screen and (min-width:640px) {
	.blog_img {
		height: 200px
	}
}

.blog_img .width100 {
	width: 100%;
	height: auto
}

.blog_img .height100 {
	width: auto;
	height: 100%
}

.blog_img img {
	max-width: none
}

.blog_txt_wrap {
	margin: 5px;
	min-height: 130px;
	position: relative
}

@media screen and (max-width:640px) {
	.blog_txt_wrap {
		margin: 10px;
		min-height: auto;
	}
}

.blog_stfimg {
	border-radius: 50%;
	float: left;
	width: 50px;
	height: 50px;
	margin-right: 5px
}

@media screen and (min-width:640px) {
	.blog_stfimg {
		width: 50px;
		height: 50px;
	}
}

.blog_stfimg .img {
	height: 100%
}

.blog_date {
	position: relative;
	bottom: 0;
	right: 0;
	width: 100%;
	border-top: 1px solid #f1f1f1;
	padding: 5px 10px;
	background: #f9f9f9;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	border-radius: 0 0 5px 5px;
}

.blog_data {
	position: relative;
	margin-top: -36px;
	margin-bottom: 10px;
}

.blog_data .name {
	margin-top: 3px
}

@media screen and (min-width:640px) {
	.blog_data .name {
		margin-top: 5px
	}
}

.blog_data span + span {
	border-left: 1px solid #fff;
	padding-left: 5px;
	margin-left: 5px
}

.article_single_post {
	background: #fff;
	padding: 10px;
	-webkit-box-shadow: 0 2px 2px rgba(0, 0, 0, .2);
	box-shadow: 0 2px 2px rgba(0, 0, 0, .2);
	margin-right: 5%;
}

.article_entry_meta {
	text-align: left;
	color: #888;
	font-size: 12px;
	border-bottom: 1px solid #ddd;
	padding: 10px;
	margin: 0 -10px 20px;
}

.msa-list li,
.pager-01 li,
.ptvtw-ttl-box,
.top_fvtxt {
	text-align: center
}

.article_writer {
	border-top: 1px solid #ddd;
	padding: 20px 5%;
	margin: 0 -10px -10px;
	background: #f9f9f9;
}

.article_stf {}

.article_stf.photo {
	width: 10%
}

.article_stf.info {
	padding-left: 1%;
	width: 88%;
}

.dttl,
.privacy_ttl {
	padding: 0 0 5px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}

.article_stf .img {
	margin: 0 auto;
	width: 50px;
	height: 50px;
	border-radius: 50%
}

.article_stf_nickname {
	font-weight: 700;
	font-size: 18px;
	letter-spacing: 0.2em;
}

.article_stf_caption {
	max-width: 500px;
	font-size: 12px
}

.main-cmn-inner {
	margin: 8.5% 0 25%
}

.dttl {
	font-size: 22px;
	color: #000;
	margin: 0 0 30px
}

.dttl:before {
	width: 5px;
	height: 30px;
	margin: 4px 10px 0 0;
	background: #ce002c
}

.privacy_cont {
	font-size: 14px;
	color: #333;
	padding: 0 0 7%;
}

.privacy_cont-01 {
	margin: 0 0 5.4%
}

.privacy_ttl {
	font-size: 18px;
	color: #333;
	margin-bottom: 10px;
}

.privacy_list-01,
.privacy_list-02 {
	margin: 2.5% 0 3%;
	line-height: 1.8
}

.privacy_list-01 li:before {
	width: 11px;
	height: 11px;
	margin: 8px 10px 0 0;
	background: #bcbcbc
}

.privacy_date {
	margin: 3% 0 0
}

@media only screen and (max-width:640px) {
	.dttl {
		margin: 0 0 6%
	}

	.privacy_cont {
		margin: 0 0 8%
	}
}

.member_main {
	padding-top: 90px;
	position: relative
}

.main-cmn-inner {
	margin-top: 45px
}

.top-visual-wrap {
	background: #f6f6f6
}

.page-top-visual {
	height: 510px
}

.ptv-ttl-wrap {
	width: 100%;
	position: absolute;
	top: -50px
}

.ptvtw-ttl-bg {
	float: left;
	width: 250px;
	background: #ce002c;
	margin: 0 0 0 7px
}

.ptvtw-ttl-box {
	width: 250px;
	background: #fff;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding: 20px;
	color: #000;
	position: relative;
	z-index: 1;
	top: -7px;
	left: -7px
}

.ptvtw-ttl-box:before {
	content: " ";
	width: 51px;
	height: 24px;
	background: url(../img/staff/icon-ptvtw-ttl-box.png) center center no-repeat;
	background-size: 100%;
	position: absolute;
	z-index: 2;
	left: 6px;
	top: -11px
}

.about_list li:after,
.ec_img_wrap:before,
.ptv_ttl.sub:before,
.udline_tit:before,
.wkl_tit:before {
	content: ""
}

.ptvtw-name {
	float: right;
	font-size: 65px;
	line-height: 1.5;
	color: #cd002c;
	font-family: 'DIN Next', HelveticaNeue, sans-serif;
	margin-left: 20px;
	margin-right: 20px
}

.ptvtwtb-position {
	font-size: 14px
}

.mssctc-ttl,
.ptvtwtb-name {
	font-size: 24px
}

.mss-cont {
	position: relative;
	z-index: 1;
	padding: 0;
	margin: 0 0 83px
}

.mss-cont-01 {
	min-height: 417px;
	padding-bottom: 47px
}

.mss-cont-02 {
	min-height: 492px
}

.mss-cont-03 {
	min-height: 483px
}

.mssc-img-cont {
	position: absolute;
	z-index: -1
}

.msa-list li,
.msal-name {
	position: relative;
	z-index: 1
}

.mssc-img-cont-01 {
	left: -218px;
	top: 47px;
	width: 587px
}

.mssc-img-cont-02 {
	right: -219px;
	top: 0;
	width: 658px
}

.mssc-img-cont-03 {
	left: -142px;
	top: 0;
	width: 412px
}

.mssc-txt-cont {
	background: #fff;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding: 32px
}

.mssc-txt-cont-01 {
	float: right;
	width: 560px
}

.mssc-txt-cont-02 {
	float: left;
	width: 490px;
	margin-top: 57px
}

.mssc-txt-cont-03 {
	float: right;
	width: 660px;
	margin-top: 44px
}

.mssctc-ttl {
	color: #cd002c;
	line-height: 1.3;
	margin: 0 0 24px
}

.mssctc-txt {
	font-size: 14px
}

.pager-01-wrap {
	margin: 125px 0 120px
}

.pager-01 {
	display: table;
	margin: 0 auto
}

.pager-01 li {
	display: table-cell;
	font-size: 17px;
	font-weight: 700;
	color: #626262
}

.msa-list li,
.msa-ttl-01:before,
.msa-ttl-02:before,
.msal-txt {
	display: inline-block
}

.pager-01 li a {
	margin: 0 30px
}

.pager-01 li a.mouse-over:hover {
	opacity: 1;
	color: #313131
}

.pager-01 li .fa {
	color: #acacac
}

.pager-01 li a.mouse-over:hover .fa {
	color: #7b7b7b
}

.msa-ttl-01,
.msa-ttl-02 {
	color: #000;
	padding: 0 0 5px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}

.pager-01 li.pager-01-prv .fa {
	margin: 0 30px 0 0
}

.pager-01 li.pager-01-nxt .fa {
	margin: 0 0 0 30px
}

.pager-01 li.pager-01-ahv {
	width: 26px
}

.pager-01 li.pager-01-ahv a {
	margin: 0
}

.pager-01 li.pager-01-ahv a.mouse-over:hover {
	opacity: .7
}

.page-top-visual {
	background: url(../img/staff-archive/top-visual-staff-00.png) center center no-repeat;
	background-size: cover
}



.msa-cont {
	margin: 0 0 8.5%
}

.mb8per {
	margin-bottom: 8%
}

.msa-ttl-01 {
	font-weight: 700;
	font-size: 25px;
	text-align: left;
	border: none;
	margin-bottom: 40px;
	letter-spacing: 0.1em;
}

.msa-ttl-01 span {
	display: block;
	font-size: 60%;
	letter-spacing: 0.2em;
	color: #cd002c;
}

.msa-ttl-01:before {
	width: 5px;
	height: 30px;
	margin: 2px 10px 0 0
}

.msa-ttl-02 {
	font-size: 16px
}

.msa-ttl-02:before {
	width: 10px;
	height: 10px;
	margin: 8px 5px 0 0
}

.msa-list {
	letter-spacing: -.5em;
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	width: 100%;
}

.msa-list {
	letter-spacing: -.5em;
}

.msa-list li {
	letter-spacing: normal;
	font-size: 14px;
	color: #333;
	width: 20%;
	margin: 0;
}

.msa-list li:hover {
	background: #d00026;
	color: #fff;
	-webkit-box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .5);
	box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .5);
	-webkit-transition: .4s;
	-o-transition: .4s;
	transition: .4s;
	border-radius: 5px;
	-webkit-transform: scale(1.05);
	-ms-transform: scale(1.05);
	transform: scale(1.05);
	position: relative;
	z-index: 3;
}

.msa-list li:hover img {
	border-radius: 5px 5px 0 0;
}

.msa-list li:hover p {
	color: #fff;
}

.ptv_ttl,
.top_fvtxt {
	letter-spacing: .2em;
	font-weight: 700
}

.msal-img img {
	border-radius: 0;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border: none;
	width: 100%;
	height: auto;
}

.msal-txt > a {
	display: block
}

.msal-name {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding: 0;
	/*margin: 7px 0 0;*/
}


.msal-name-01 {
	font-size: 20px;
	font-weight: bold;
	letter-spacing: 0.1em;
	margin-top: 0px;
}

.msal-name-02 {
	font-size: 12px;
	color: #d00026;
	letter-spacing: 0.1em;
	text-transform: capitalize;
}

.msalnw-position {
	font-size: 12px;
	color: #767676;
	/*letter-spacing: 0.1em;*/
	height: 40px;
}

.lh12em {
	line-height: 1.2em;
}

@media only screen and (max-width:640px) {
	.member_main {
		padding-top: 150px
	}

	.page-top-visual {
		height: 300px
	}

	.ptv-ttl-wrap {
		top: -10px
	}

	.ptvtw-ttl-bg {
		float: none;
		margin: 0 auto
	}

	.ptvtw-name {
		float: none;
		font-size: 28px;
		text-align: center
	}

	.mss-cont {
		margin: 0 0 10%
	}

	.mss-cont-01,
	.mss-cont-02,
	.mss-cont-03 {
		min-height: 0;
		padding-bottom: 0
	}

	.mssc-img-cont {
		position: relative;
		z-index: 1
	}

	.mssc-img-cont-01,
	.mssc-img-cont-02,
	.mssc-img-cont-03 {
		left: 0;
		top: 0;
		width: auto;
		margin: 0 auto
	}

	.mssc-img-cont-03 {
		width: 70%
	}

	.mssc-txt-cont {
		padding: 6%
	}

	.mssc-txt-cont-01,
	.mssc-txt-cont-02,
	.mssc-txt-cont-03 {
		float: none;
		width: auto;
		margin-top: 4%
	}

	.mssctc-ttl {
		font-size: 20px;
		line-height: 1.4;
		margin: 0 0 5%
	}

	.pager-01-wrap {
		margin: 12% 0
	}

	.main-cmn-inner {
		margin: 30px 0 0
	}

	.msa-list-wrap {
		margin: 5% 0
	}

	.msa-list li {
		width: calc(100%/3);
		margin-top: 0;
		margin-bottom: 0;
	}

	.msal-name {
		margin: 10px 0;
		padding: 0;
	}
}

a {
	color: inherit
}

a.mouse-over:hover {
	-webkit-transition: all .3s;
	-o-transition: all .3s;
	transition: all .3s;
	filter: alpha(opacity=70);
	opacity: .7
}

#GrayMask {
	display: none;
	background: rgba(0, 0, 0, .5);
	width: 100%;
	height: 100%;
	z-index: 501;
	position: fixed;
	top: 0;
	left: 0
}

.top_fvtxt {
	font-size: 50px;
	text-align: center;
	line-height: 1.2;
}

.sec_tit_wrap {
	font-size: 24px;
	margin: 15px auto 30px;
}

.topsv_right_box {
	margin-bottom: 30px
}

.topsv_left_box,
.topsv_right_box {
	width: 92%;
	padding: 4%
}

.sv_box_wrap {
	width: 100%
}

.sv_box_wrap.right {
	margin-right: 4%
}

@media screen and (min-width:640px) {
	.sv_box_wrap {
		width: 49%;
		float: left
	}

	.sv_box_wrap.left {
		margin-top: 5%
	}

	.sv_box_wrap.right {
		margin-right: 2%
	}
}

.sv_box {
	margin-bottom: 10px;
	min-height: 180px;
	padding: 1%;
	background: #eee;
	-webkit-box-shadow: 1px 2px 4px rgba(0, 0, 0, .5);
	box-shadow: 1px 2px 4px rgba(0, 0, 0, .5);
	color: #fff;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.sv_box.service {
	background: url(../img/service/bg01_sp.png) no-repeat center center;
	background-size: cover;
}

.sv_box.media {
	background: url(../img/service/bg02_sp.png) no-repeat center center;
	background-size: cover;
}

.sv_box.ec {
	background: url(../img/service/bg03_sp.png) no-repeat center center;
	background-size: cover;
}

.sv_box.digital {
	background: url(../img/service/bg04_sp.png) no-repeat center center;
	background-size: cover;
}

.sv_box .link {
	border: 1px solid #fff;
	padding: 5px;
	width: 80%;
	margin: 10px auto 10px;
	text-align: center;
	font-weight: 700;
}

.sv_box .link a {
	display: block;
}


.sv_box .img_wrap {
	width: 80%;
	margin: 0 10%;
	display: inline-block
}

.sv_box .img_wrap.icon {
	width: 30%;
	margin: 0 5%
}

.sv_tit {
	font-size: 18px;
	height: 2.5em;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center
}

.sv_txt {
	display: inline-block;
	font-size: 14px;
	width: 55%;
	text-align: justify;
	text-justify: inter-ideograph
}

.about_list {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap
}

.about_list li {
	border-bottom: 1px solid transparent;
	margin-right: 10px;
	position: relative
}

.about_list li:after {
	-webkit-transition: .2s;
	-o-transition: .2s;
	transition: .2s;
	position: absolute;
	left: calc(50% - 10px);
	height: 2px;
	width: 20px;
	display: block;
	background-color: transparent;
	text-align: center
}

.side_list .monthry:before,
.side_list .side_list_tit:before {
	content: " ";
	vertical-align: top;
	height: 10px;
	position: relative
}

.about_list li:hover:after {
	background-color: #ce002c
}

.about_list li.current:after {
	background-color: #ce002c;
	width: 20px
}

.about_list_item {
	display: block;
	padding: 10px
}

.aboutus_subtit {
	font-size: 1.2rem;
}

.aboutus_txt {
	font-size: 12px;
	max-width: 200px
}

@media (max-width: 767px) {
	.aboutus_txt {
		font-size: 15px;
		max-width: 100%;
		text-shadow: 0 0 10px #000;
	}
}

.side_wrap {
	width: 100%;
	margin: 0;
	font-size: 13px;
}

.news_list_inner,
.news_list_item {
	-webkit-box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2);
	box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2)
}

@media screen and (min-width:640px) {
	.side_wrap {
		float: right;
		width: 30%;
		margin: 0
	}

	.sv_box .link {
		margin: 30px auto 0;
	}
}

@media screen and (min-width:860px) {
	.sv_box_wrap.right {
		float: left
	}

	.side_wrap {
		width: 24%;
	}
}

.side_ttl {
	font-weight: normal;
	padding: 10px 10px;
	background: #ce002c;
	color: #fff;
	font-size: 20px;
	letter-spacing: 0.1em;
}

ul.side_list {
	background: #fff;
}

.side_ttl::before {
	content: "";
	width: 30px;
	height: 1px;
	background: #fff;
	display: inline-block;
	vertical-align: middle;
	margin-left: -25px;
	-webkit-box-shadow: 0 0px 10px #d00026;
	box-shadow: 0 0px 10px #d00026;
	margin-right: 10px;
}

.side_ttl span {
	font-size: 60%;
	margin-left: 10px;
}

.side_ttl i {
	font-size: 18px
}

.side_list .side_list_tit {
	cursor: pointer;
	display: block;
	position: relative;
	z-index: 1;
	padding: 10px 10px 10px 5px;
	margin: 2px 0
}

.side_list .side_list_tit:before {
	display: inline-block;
	width: 10px;
	background: #ce002c;
	top: 6px;
	margin: 0 8px 0 0
}

.side_list .monthry {
	display: block;
	position: relative;
	z-index: 1;
	padding: 5px 5px 5px 15px;
	margin: 2px 0
}

.new_label,
.new_label span {
	display: inline-block;
	color: #fff;
	-webkit-animation-duration: 1.5s;
	-webkit-animation-timing-function: ease-out;
	-webkit-animation-iteration-count: infinite
}

.side_list .monthry:before {
	display: inline-block;
	width: 6px;
	border-left: 1px solid #000;
	border-bottom: 1px solid #000;
	top: 0;
	margin: 0 8px 0 0
}

.new_label:after,
.new_label:before {
	content: ''
}

.side_list a {
	display: block
}

.side_list a.monthry {
	color: #ce002c;
	text-decoration: underline
}

.side_list i {
	font-weight: 700;
	float: right;
	margin-top: 5px;
	-webkit-transition: .4s;
	-o-transition: .4s;
	transition: .4s
}

.side_list_sub {
	display: none;
	border-top: 1px dashed #eee
}

.js-side_has_active .side_list_sub {
	display: block
}

.js-side_has_active i {
	-webkit-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
	transform: rotate(90deg)
}

.news_list_inner {
	margin-top: 10px;
	margin-bottom: 30px
}

.news_list_item {
	-webkit-box-shadow: 0 -1px 0 #CFD8DC inset;
	box-shadow: 0 -1px 0 #CFD8DC inset;
	-webkit-transition-duration: .3s;
	-o-transition-duration: .3s;
	transition-duration: .3s;
	background-color: #fff;
	font-size: 1.1rem;
}

.am_fadeInLeft,
.am_fadeInUp,
.am_slideInLeft {
	-webkit-transition: 1s;
	-o-transition: 1s;
	transition: 1s
}

.news_list_item:hover {
	-webkit-box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .2);
	box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .2);
	-webkit-transform: translateY(-5%);
	-ms-transform: translateY(-5%);
	transform: translateY(-5%);
	z-index: 800
}

.news_date {
	font-size: .8rem;
	font-weight: 500;
	color: #131313;
}

.news_list_link {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	display: block;
	line-height: 1.5em;
	font-weight: 500;
	padding: .5rem 1.6rem;
	width: 100%
}

.new_label {
	position: absolute;
	top: -6px;
	left: 10px;
	margin: 0;
	padding: 5px 1px 3px;
	z-index: 2;
	width: 30px;
	text-align: center;
	font-size: 10px;
	background: #ce002c;
	border-radius: 2px 0 0
}

.new_label:before {
	position: absolute;
	top: 0;
	left: -5px;
	border: none;
	border-bottom: solid 6px #680016;
	border-left: solid 5px transparent
}

.new_label:after {
	position: absolute;
	left: 0;
	top: 100%;
	height: 0;
	width: 0;
	border-left: 16px solid transparent;
	border-right: 15px solid transparent;
	border-top: 7px solid #ce002c
}

.new_label span,
.wkl_tit {
	position: relative
}

.new_label span {
	-webkit-transform-origin: middle center;
	-webkit-transform: scale(1);
	-webkit-animation-name: NewTxtAnime;
	font-weight: 700;
	bottom: 0
}

.new_label span:nth-child(1) {
	-webkit-animation-delay: .2s
}

.new_label span:nth-child(2) {
	-webkit-animation-delay: .4s
}

.new_label span:nth-child(3) {
	-webkit-animation-delay: .6s
}

@-webkit-keyframes NewTxtAnime {

	0%,
	100%,
	70% {
		bottom: 0
	}

	85% {
		bottom: 2px
	}
}

.wkl_cont {
	width: 100%
}

.wkl_cont_inner {
	display: table-cell;
	width: 50%
}

.wklbg_01 {
	display: none
}

.wkl_tit:before {
	height: 4px;
	width: 30px;
	background: #fff;
	position: absolute;
	z-index: 1;
	bottom: -10px;
	left: 0;
	margin: 0 auto;
	/* -webkit-box-shadow: 2px 3px 5px rgba(0, 0, 0, .6);
	box-shadow: 2px 3px 5px rgba(0, 0, 0, .6) */
}

.map_wrap {
	width: 100%;
	margin-bottom: 30px
}

.map_inner {
	position: relative;
	height: 200px
}

@media (max-width: 767px) {
	.map_inner {
		height: 400px;
		margin: 0 -500%;
		padding: 0 500%;
		width: 100%;
	}
}

.map_inner embed,
.map_inner iframe,
.map_inner object {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}

.dotbg,
.top_dotbg {
	background: url(../img/top/bg_dot.png);
	display: block;
	width: 200%;
	height: 200%;
	position: absolute
}

.map_txt {
	font-size: 12px;
	padding: 200px 0;
}

.top_dotbg {
	left: -50%;
	top: -50%
}

.dotbg {
	z-index: -1
}

.page_fv,
.page_fv.recruit video {
	width: 100%
}

.page_fv,
.udline_tit {
	position: relative;
	z-index: 1
}

.page_fv {
	height: 350px;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center
}

.page_fv.company {
	background-image: url(../img/company/fv.jpg);
}

.page_fv.news {
	background-image: url(../img/news/news_head.png);
}

.page_fv.privacy {
	background-image: url(../img/top-visual-static-privacy.png);
}


.page_fv.contact {
	background-image: url(../img/contact_head.jpg);
}

.page_fv.entry-contact {
	background-image: url(../img/entry_contact_head.png);
	background-position: top;
}



@media screen and (min-width:640px) {
	.page_fv.recruit {
		background-image: url(../img/recruit/top_visual.jpg);
		background-position: right 15%;
	}
}

.page_fv.service_top {
	background-image: url(../img/service/service_top_fv.jpg);
	background-size: cover
}

.page_fv.ec_top {
	background-image: url(../img/service/ec_top_fv.jpg)
}

.page_fv.media_top {
	background-image: url(../img/service/media_top_bg.jpg);
}

.page_fv.blog {
	background: -o-linear-gradient(315deg, #d00026 10%, #ff5151 71%, #f1eaca 100%);
	background: linear-gradient(135deg, #d00026 10%, #ff5151 71%, #f1eaca 100%);
}

.page_fv.member_blog {
	background-image: url(../img/blog/top-visual-blog-00.jpg);
	background-position: center top;
}

.page_fv.ceo_blog {
	background-image: url(../img/blog/ceoblog_top_fv.jpg);
}

.page_fv.ceo-m_top {
	background-image: url(../img/ceo/ceo-mv.jpg);
	background-position: top right;
}

.page_fv.service_list_top {
	background-image: url(../img/service/list_top_fv.gif);
	background-position: 30% 0
}

@media screen and (min-width:640px) {
	.page_fv.service_list_top {
		background-position: center
	}
}

.page_fv.dm_top {
	background: -o-linear-gradient(315deg, #d00026 10%, #ff5151 71%, #f1eaca 100%);
	background: linear-gradient(135deg, #d00026 10%, #ff5151 71%, #f1eaca 100%);
}

.page_fv.consulting {
	background-image: url(../img/service/dm/fv_con.jpg);
}

.page_fv.internet_advertising {
	background-image: url(../img/service/dm/fv_ad.jpg);
}

.page_fv.seo {
	background-image: url(../img/service/dm/fv_seo.jpg);
}

.page_fv.rumor {
	background-image: url(../img/service/dm/top-visual-service-04.png);
}

.page_fv.system {
	background-image: url(../img/service/dm/fv_system.jpg);
}

.page_fv.web_production {
	background-image: url(../img/service/dm/fv_wd.jpg);
}

.ptv_ttl {
	color: #fff;
	font-size: 36px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding-top: 160px;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	position: relative;
}

.ptv_ttl span {
	font-size: 40%;
	margin-left: 2%;
	font-weight: normal;
}


.ptv_ttl.sub {
	color: rgba(255, 255, 255, .7);
	padding-top: 0;
	font-size: 14px
}

.ptv_ttl.sub:before {
	background-color: #ce002c;
	height: 3px;
	width: 20px;
	margin: 10px 0;
	display: block
}

.ptv_ttl.sub.white:before {
	background-color: #fff
}

.udline_tit.c_red:before,
.udline_tit:before {
	background: #cd002c
}

.udline_tit {
	font-size: 28px;
	font-weight: 700;
	padding-top: 10px;
	padding-bottom: 15px;
	line-height: 1.2
}

.udline_tit:before {
	height: 4px;
	width: 31px;
	position: absolute;
	z-index: 1;
	bottom: 0;
	left: 0;
	right: 0;
	margin: 0 auto
}

.udline_tit.c_white:before {
	background: #fff
}

.sub_tit {
	font-size: 14px;
	margin: 14px 0
}

.inner_bg {
	margin: 150px 0 0;
	position: relative;
	background-color: #f9f9f9;
	z-index: 2
}

/*.main_bg.service {
	background: url(../img/service/service_bg.png);
	-webkit-background-size: 10px;
	-o-background-size: 10px;
	background-size: 10px
}*/

.bread_wrap {
	width: 94%;
	margin-right: 3%;
	margin-left: 3%
}

.breadcrumb {
	padding-top: 20px;
	padding-bottom: 20px;
	-ms-overflow-y: hidden;
	overflow-y: hidden;
	-ms-overflow-x: scroll;
	overflow-x: scroll;
	-ms-overflow-style: none
}

.breadcrumb ul li a,
.breadcrumb ul li {
	font-size: 12px;
	-webkit-transition: all 0s;
	-o-transition: all 0s;
	transition: all 0s;
}

@media screen and (min-width:860px) {
	.breadcrumb {
		margin: 0 auto;
		-ms-overflow-x: hidden;
		overflow-x: hidden
	}

	.breadcrumb ul li a,
	.breadcrumb ul li {
		font-size: 12px;
		-webkit-transition: all 0s;
		-o-transition: all 0s;
		transition: all 0s;
	}
}

.breadcrumb li {
	float: left;
	font-weight: normal;
	color: #fff;
	margin: 0 6px 0 0;
}

.breadcrumb ul li a,
.breadcrumb ul li {
	font-size: 12px;
	-webkit-transition: all 0s;
	-o-transition: all 0s;
	transition: all 0s;
}

.breadcrumb li .fa {
	color: #ce002c;
	margin: 0 6px 0 0;
	position: relative;
	top: 0;
	font-size: 16px;
}

.breadcrumb li a:hover {
	color: #ce002c;
}

.service_copy {
	font-size: 6vw;
	line-height: 9vw
}

@media screen and (min-width:640px) {
	.service_copy {
		font-size: 30px;
		line-height: 54px
	}

	.breadcrumb ul li a,
	.breadcrumb ul li {
		font-size: 12px;
		-webkit-transition: all 0s;
		-o-transition: all 0s;
		transition: all 0s;
	}
}

.service_copy .sub {
	padding-left: 5vw;
	padding-right: 5vw;
	font-size: 3vw;
	line-height: 7vw
}

@media screen and (min-width:640px) {
	.service_copy .sub {
		font-size: 15px;
		line-height: 30px
	}
}

.service_num {
	padding-right: 1em;
	font-size: 72px;
	opacity: .6;
	line-height: .8em;
	font-weight: 700;
}

.service_num_sub {
	font-size: 10px;
	letter-spacing: .15em
}

.service_item_bg {
	height: 0;
	background-repeat: no-repeat;
	background-position: 0 0;
	background-size: 100%;
	padding-top: 25%;
	padding-bottom: 40%
}

.service_item_bg.bg01 {
	background-image: url(../img/service/bg01_sp.png)
}

.service_item_bg.bg02 {
	background-image: url(../img/service/bg02_sp.png);
}

.service_item_bg.bg03 {
	background-image: url(../img/service/bg03_sp.png);
}

.service_item_bg.bg04 {
	background-image: url(../img/service/bg04_sp.png);
}

.service_item_bg.bg05 {
	background-image: url(../img/service/dm/fv_ad.jpg);
}

@media screen and (min-width:640px) {
	.service_item_bg {
		background-position: right 5% top 0;
		padding-top: 25%;
		padding-bottom: 25%;
		background-size: 95%
	}

	.service_item_bg.bg01 {
		background-image: url(../img/service/bg01_sp.png);
		padding-top: 25%;
		padding-bottom: 25%;
	}

	.service_item_bg.bg02 {
		background-image: url(../img/service/bg02_sp.png);
		padding-top: 25%;
		padding-bottom: 25%;
	}

	.service_item_bg.bg03 {
		background-image: url(../img/service/bg03_sp.png);
		padding-top: 25%;
		padding-bottom: 25%;
	}

	.service_item_bg.bg04 {
		background-image: url(../img/service/bg04_sp.png);
		padding-top: 25%;
		padding-bottom: 25%;
	}
}

.slideInLeft {
	-webkit-transform: translateX(100%);
	-ms-transform: translateX(100%);
	transform: translateX(100%)
}

.am_fadeInUp {
	opacity: 0;
	-ms-transform: translate(0, 60px);
	transform: translate(0, 60px);
	-webkit-transform: translate(0, 60px)
}

.am_fadeInUp .btnlink {
	margin: 0px auto;
	border: 1px solid #000;
	color: #000;
	padding: 5px;
	display: inline-block;
	width: 20%;
}

.fadeInUp {
	opacity: 1;
	-ms-transform: translate(0, 0);
	transform: translate(0, 0);
	-webkit-transform: translate(0, 0)
}

.am_fadeInLeft {
	opacity: 0;
	-ms-transform: translate(-60px, 0);
	transform: translate(-60px, 0);
	-webkit-transform: translate(-60px, 0)
}

.fadeInLeft {
	opacity: 1;
	-ms-transform: translate(0, 0);
	transform: translate(0, 0);
	-webkit-transform: translate(0, 0)
}

.am_fadeInRight {
	opacity: 0;
	-ms-transform: translate(60px, 0);
	transform: translate(60px, 0);
	-webkit-transform: translate(60px, 0);
	-webkit-transition: 1s;
	-o-transition: 1s;
	transition: 1s
}

.fadeInRight {
	opacity: 1;
	-ms-transform: translate(0, 0);
	transform: translate(0, 0);
	-webkit-transform: translate(0, 0)
}

.servce_list_img {
	background-color: #fff;
	position: relative;
	border: 1px solid #ddd;
	background-repeat: no-repeat;
	background-position: center;
	background-size: cover;
}

.servce_list_img:hover {
	border: 1px solid #ce002c;
}

.servce_list_img.ekichika {
	background-image: url(../img/service/list_ekichika.png)
}

.servce_list_img.karireru {
	background-image: url(../img/service/list_karireru.png)
}

.servce_list_img.bitty_logo {
	background-image: url(../img/service/media-logo/bitty_logo.png)
}

.servce_list_img.card_logo {
	background-image: url(../img/service/media-logo/card_logo.png)
}

.servce_list_img.horehada_logo {
	background-image: url(../img/service/media-logo/horehada_logo.jpg)
}

.servce_list_img.kyosyo_logo {
	background-image: url(../img/service/media-logo/kyosyo_logo.png)
}

.servce_list_img.bijyohada_logo {
	background-image: url(../img/service/media-logo/bijyohada_logo.png)
}

.servce_list_img.bgnone {
	background-color: transparent;
	border: none;
}

.servce_list_img.veve {
	background-image: url(../img/service/list_veve.png)
}

.servce_list_img.md_web_n {
	background-image: url(../img/service/md_web.png);
}

.servce_list_img.md_reviewty {
	background-image: url(../img/service/md_reviewty.png)
}

.servce_list_img.md_datsumomap {
	background-image: url(../img/service/md_datsumomap.png)
}

.servce_list_img.md_cardloan {
	background-image: url(../img/service/md_cardloan.png)
}

.servce_list_img.ec_consulting {
	background-image: url(../img/service/ec_consulting.jpg)
}

.servce_list_img.ec_memoto {
	background-image: url(../img/service/ec_memoto.png)
}

.servce_list_img.ec_kikimate {
	background-image: url(../img/service/ec_kikimate.png)
}

.servce_list_img.ec_oyasumi {
	background-image: url(../img/service/ec_oyasumi.png)
}

.servce_list_img.ec_kouji {
	background-image: url(../img/service/ec_kouji.png)
}

.servce_list_img.ec_biiki {
	background-image: url(../img/ec_list/ec_biiki.jpg)
}

.servce_list_img.ec_doraemon {
	background-image: url(../img/ec_list/ec_doraemon.png)
}

.servce_list_img.ec_skinny {
	background-image: url(../img/ec_list/ec_skinny.png)
}

.servce_list_img.ec_maria {
	background-image: url(../img/ec_list/ec_maria.png)
}

.servce_list_img.ec_coco {
	background-image: url(../img/ec_list/ec_coco.png)
}

.servce_list_img.ec_torso {
	background-image: url(../img/ec_list/ec_torso.png)
}

.servce_list_img.ec_perle {
	background-image: url(../img/ec_list/ec_perle.png)
}

.servce_list_img.ec_dia {
	background-image: url(../img/ec_list/ec_dia.png)
}

.servce_list_img.ec_clear {
	background-image: url(../img/ec_list/ec_clear.png)
}

.servce_list_img.ec_fitness {
	background-image: url(../img/ec_list/ec_fitness.png)
}

.servce_list_img.ec_down5 {
	background-image: url(../img/ec_list/ec_down5.png)
}


.ec_img_wrap {
	display: block;
	height: auto;
	position: relative;
	width: 80%;
	margin-right: 10%;
	margin-left: 10%
}

.ec_img_wrap:before {
	display: block;
	padding-top: 100%
}

@media screen and (min-width:640px) {
	.ec_img_wrap {
		width: 50%;
		min-height: 300px
	}
}

.ec_img_wrap img {
	position: absolute;
	height: 80%
}

.ec_img_wrap .gohoubi1 {
	left: 0;
	top: 20%;
	z-index: 2;
	-webkit-transition: 1s;
	-o-transition: 1s;
	transition: 1s
}

.ec_img_wrap .gohoubi2 {
	left: 30%;
	top: 0;
	z-index: 1;
	-webkit-transition: .3s;
	-o-transition: .3s;
	transition: .3s
}

.ec_img_wrap .kikimate {
	left: 60%;
	top: 40%;
	z-index: 0;
	-webkit-transition: 1.5s;
	-o-transition: 1.5s;
	transition: 1.5s
}

.ec_tit {
	letter-spacing: .5em
}

.ec_tit:after,
.ec_tit:before {
	content: "ー"
}

.msd-list {
	width: auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
}


@media screen and (min-width:640px) {
	.msd-list {
		width: 103.125%
	}
}

.msd-list li {
	-webkit-box-shadow: 0 3px 7px 0 #000;
	box-shadow: 0 3px 7px 0 #000;
	display: block;
	width: auto;
	margin: 0 0 20px
}

.pd_concept {
	padding: 40px 4% 100px
}

@media screen and (min-width:800px) {
	.msd-list li {
		display: inline-block;
		width: 31%;
		margin: 0 2% 20px 0
	}

	.pd_concept {
		padding-bottom: 175px
	}
}

.pd_msc_ctbox + .pd_msc_ctbox {
	margin-top: 40px
}

@media screen and (min-width:640px) {
	.pd_msc_ctbox + .pd_msc_ctbox {
		margin-top: 99px
	}
}

.random_list .img_area {
	width: 25%;
	float: left;
	line-height: 0
}

@media all and (max-width:640px) {
	.random_list .img_area {
		width: auto
	}
}

.random_list .img_area .company_site,
.random_list .img_area .date_category {
	position: absolute;
	z-index: 1111111;
	color: #fff;
	line-height: 1.5;
	padding: 15px
}

.random_list .img_area .company_site {
	top: 0;
	left: 0
}

.random_list .img_area .date_category {
	bottom: 0;
	right: 0
}

.random_list .img_area a {
	position: relative;
	overflow: hidden;
	display: inline-block;
	width: 100%;
	line-height: 0;
	background: #000
}

.random_list .img_area a:after,
.random_list .img_area a:before {
	content: "";
	display: block;
	z-index: 111111;
	position: absolute;
	left: 0;
	width: 100%;
	height: 100px
}

.random_list .img_area a:before {
	top: 0;
	background: url(../img/service/dm/bg_shadow01.png) repeat-x
}

.random_list .img_area a:after {
	bottom: 0;
	background: url(../img/service/dm/bg_shadow02.png) repeat-x
}

.random_list .img_area a img {
	-webkit-transition: .5s all ease-in-out;
	-o-transition: .5s all ease-in-out;
	transition: .5s all ease-in-out;
	max-width: 100%;
	width: 100%;
	height: auto;
	vertical-align: bottom
}

.random_list .img_area a:hover img {
	opacity: .7;
	-webkit-transform: scale(1.03);
	-ms-transform: scale(1.03);
	transform: scale(1.03)
}

.main_work a.mouse-over:hover,
.random_list .img_area a + .mouse-over:hover {
	opacity: 1
}

.credit {
	padding-bottom: 80px
}

.credit .credit_ttl {
	font-size: 22px;
	text-align: center;
	margin-bottom: 30px;
	position: relative;
	font-weight: 700
}

.credit .credit_ttl:after {
	content: "";
	position: absolute;
	bottom: -10px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 60px;
	height: 2px;
	background: #cd042c
}

.credit .credit_spec {
	text-align: center
}

.load_more {
	padding: 30px 0
}

.visit_site {
	position: relative;
	-webkit-perspective: 10000
}

.visit_site .cube {
	max-width: 300px;
	width: 100%;
	height: 60px;
	position: relative;
	margin: 0 auto;
	-webkit-transform-style: preserve-3d;
	-webkit-transition: all .3s;
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}

.visit_site .cube:hover {
	-webkit-transform: rotateX(90deg)
}

.visit_site .cube .front,
.visit_site .cube .rotate {
	max-width: 300px;
	width: 100%;
	text-align: center;
	position: absolute
}

.visit_site .cube .front a,
.visit_site .cube .rotate a {
	width: 100%;
	height: 60px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding-top: 18px;
	display: inline-block;
	font-weight: 700
}

.visit_site .cube .front {
	top: 0;
	left: 0;
	-webkit-transform: translateZ(30px);
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border: 1px solid #999
}

.visit_site .cube .front a {
	color: #666;
	background: #fff;
	font-size: 14px
}

.visit_site .cube .rotate {
	top: 30px;
	left: 0;
	-webkit-transform: rotateX(-90deg)
}

.visit_site .cube .rotate a {
	color: #fff;
	background: #cd042c;
	font-size: 14px
}

.site_detail,
.site_pager {
	border-top: 1px solid #eee;
	background: #fff
}

@media all and (-ms-high-contrast:none) {

	.visit_site .cube .rotate,
	::-ms-backdrop {
		display: none
	}
}

.site_pager {
	padding: 20px 10px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	font-weight: 700
}

.site_pager .fa:before {
	font-size: 17px
}

.site_pager .all .fa,
.site_pager .prev .fa {
	padding-right: 10px
}

.site_pager .next .fa {
	padding-left: 10px
}

.site_detail {
	border-bottom: 1px solid #eee;
	padding-bottom: 20px
}

.site_detail .company_name {
	font-size: 18px;
	text-align: center;
	margin-bottom: 17px;
	position: relative
}

.site_detail .company_name:after {
	content: "";
	position: absolute;
	bottom: -10px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%);
	width: 60px;
	height: 2px;
	background: #cd042c
}

.site_detail .classification {
	font-size: 36px;
	font-weight: 700;
	text-align: center
}

.site_detail .classification .category1 {
	margin-right: 20px
}

.site_detail .da_ca_cl {
	padding: 20px 20px 50px;
	text-align: center
}

.sp_block {
	display: inline;
	margin-right: 15px
}

.sp_block:last-child {
	margin-right: 0
}

@media all and (max-width:640px) {
	.sp_block {
		display: block;
		margin-right: 0
	}
}

.main_work .img_area .no_image .company_site,
.main_work .img_area .no_image .date_category,
.main_work .img_area .no_image a:after,
.main_work .img_area .no_image a:before {
	display: none
}

.main_work .main_size,
.main_work .sub_size {
	width: 50%
}

@media only screen and (max-width:640px) {

	.main_work .main_size,
	.main_work .sub_size {
		width: auto
	}
}

.main_work .main_size {
	-webkit-animation: alpha 1s 1 ease-in;
	animation: alpha 1s 1 ease-in
}

.main_work .sub_size .img_area:nth-child(1) {
	-webkit-animation: alpha2 1s 1 ease-in;
	animation: alpha2 1s 1 ease-in
}

.main_work .sub_size .img_area:nth-child(2) {
	-webkit-animation: alpha3 1s 1 ease-in;
	animation: alpha3 1s 1 ease-in
}

.main_work .sub_size .img_area:nth-child(3) {
	-webkit-animation: alpha4 1s 1 ease-in;
	animation: alpha4 1s 1 ease-in
}

.main_work .sub_size .img_area:nth-child(4) {
	-webkit-animation: alpha5 1s 1 ease-in;
	animation: alpha5 1s 1 ease-in
}

.main_work:nth-child(odd) .main_size {
	float: left
}

.main_work:nth-child(odd) .sub_size {
	float: right
}

.main_work:nth-child(odd) .sub_size .img_area {
	width: 50%;
	float: left
}

.main_work:nth-child(even) .main_size {
	float: right
}

.main_work:nth-child(even) .sub_size {
	float: left
}

.main_work:nth-child(even) .sub_size .img_area {
	width: 50%;
	float: left
}

.main_work .img_area {
	line-height: 0
}

.main_work .img_area .company_site,
.main_work .img_area .date_category {
	position: absolute;
	z-index: 1111111;
	color: #fff;
	line-height: 1.5;
	padding: 15px
}

.main_work .img_area .date_category {
	bottom: 0;
	right: 0
}

.main_work .img_area .company_site {
	top: 0;
	left: 0
}

.main_work .img_area .company_site .site_name {
	font-size: 18px;
	padding-top: 5px
}

@media only screen and (max-width:640px) {

	.main_work .img_area .no_image,
	.main_work:nth-child(2) .main_size {
		display: none
	}

	.main_work:nth-child(even) .sub_size .img_area,
	.main_work:nth-child(odd) .sub_size .img_area {
		width: auto;
		float: none
	}

	.main_work:nth-child(even) .main_size,
	.main_work:nth-child(even) .sub_size,
	.main_work:nth-child(odd) .main_size,
	.main_work:nth-child(odd) .sub_size {
		float: none
	}

	.main_work .img_area .date_category {
		left: 0
	}
}

.main_work .img_area .no_image a {
	background: #d31544;
	pointer-events: none
}

.main_work .img_area .no_image a img,
.main_work .img_area .no_image a:hover img {
	opacity: 0
}

.main_work .img_area a {
	position: relative;
	overflow: hidden;
	display: inline-block;
	width: 100%;
	line-height: 0;
	background: #000
}

.main_work .img_area a:before {
	top: 0;
	background: url(../img/service/dm/bg_shadow01.png) repeat-x
}

.main_work .img_area a:after {
	bottom: 0;
	background: url(../img/service/dm/bg_shadow02.png) repeat-x
}

.main_work .img_area a:after,
.main_work .img_area a:before {
	content: "";
	display: block;
	z-index: 111111;
	position: absolute;
	left: 0;
	width: 100%;
	height: 100px
}

.main_work .img_area a img {
	-webkit-transition: .5s all ease-in-out;
	-o-transition: .5s all ease-in-out;
	transition: .5s all ease-in-out;
	max-width: 100%;
	width: 100%;
	height: auto;
	vertical-align: bottom
}

.main_work .img_area a:hover img {
	opacity: .7;
	-webkit-transform: scale(1.03);
	-ms-transform: scale(1.03);
	transform: scale(1.03)
}

@-webkit-keyframes alpha {

	0%,
	10% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}

@keyframes alpha {

	0%,
	10% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}

@-webkit-keyframes alpha2 {

	0%,
	20% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}

@keyframes alpha2 {

	0%,
	20% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}

@-webkit-keyframes alpha3 {

	0%,
	30% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}

@keyframes alpha3 {

	0%,
	30% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}

@-webkit-keyframes alpha4 {

	0%,
	40% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}

@keyframes alpha4 {

	0%,
	40% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}

@-webkit-keyframes alpha5 {

	0%,
	50% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}

@keyframes alpha5 {

	0%,
	50% {
		opacity: 0
	}

	100% {
		opacity: 1
	}
}

.slide_wrap {
	margin-bottom: 70px
}

.slide_wrap .slider {
	padding: 5% 3% 0;
	max-width: 1088px;
	margin: 0 auto
}

@media screen and (min-width:640px) {
	.slide_wrap .slider {
		padding: 70px 0 0
	}
}

.slide_wrap .slider .frame {
	position: relative;
	overflow: hidden
}

.slide_wrap .slider .slide {
	position: absolute;
	top: 0;
	left: 0;
	padding-left: 0
}

.slide_wrap .slider .slide li {
	float: left
}

.slide_wrap .slider .slide li img {
	width: 100%
}

.slide_wrap .slider .next,
.slide_wrap .slider .prev {
	display: none;
	position: fixed;
	left: 50%;
	top: 50%
}

.slide_wrap .slider .next {
	margin-left: 570px
}

.slide_wrap .slider .prev {
	margin-left: -602px
}

.slide_wrap .slider .pager {
	display: none
}

.slide_wrap .slider .pointer {
	margin-top: 15px;
	letter-spacing: -.4em;
	text-align: center
}

@media screen and (min-width:640px) {
	.slide_wrap .slider .pointer {
		margin-top: 25px
	}
}

.slide_wrap .slider .pointer li {
	display: inline;
	letter-spacing: 0
}

.slide_wrap .slider .pointer a {
	display: inline-block;
	margin: 0 6px;
	width: 9px;
	height: 9px;
	border: 1px solid #fff;
	background: #acacac;
	border-radius: 100%
}

.slide_wrap .slider .pointer .active a,
.slide_wrap .slider .pointer a:hover {
	background: 0 0;
	border: 1px solid #acacac
}

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

	.slide_wrap .slider .next,
	.slide_wrap .slider .prev {
		left: auto
	}

	.slide_wrap .slider .next {
		margin-left: 0;
		right: 15px
	}

	.slide_wrap .slider .prev {
		margin-left: 0;
		left: 15px
	}
}

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

	.slide_wrap .slider .next,
	.slide_wrap .slider .prev {
		display: none !important
	}
}

@media all and (max-width:640px) {
	.slide_wrap .slider .pager {
		display: none
	}
}

.ad_msc_ctbox {
	float: none;
	width: auto
}

.ad_msc_ctbox.blue .ad_ctb_inner {
	border-color: #aecff3;
	background-color: #f0f7ff
}

.ad_msc_ctbox.blue .ad_ctb_ttl {
	color: #2e78cc
}

.ad_msc_ctbox.pink .ad_ctb_inner {
	border-color: #fcc3c3;
	background-color: #fff7f7
}

.ad_msc_ctbox.pink .ad_ctb_ttl {
	color: #cd002c
}

.ad_ctb_inner {
	padding: 34px 19px 21px;
	border: 1px solid #d8d8d8;
	background: #f7f7f7
}

.ad_msc_ctbox + .ad_msc_ctbox {
	margin-left: 0
}

@media screen and (min-width:640px) {
	.ad_msc_ctbox {
		float: left;
		position: relative;
		width: 29.16667%
	}

	.ad_msc_ctbox + .ad_msc_ctbox {
		margin-left: 6.25%
	}
}

.ad_msc_ctbox + .ad_msc_ctbox:before {
	content: "";
	position: static;
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 14px 30px 0;
	border-color: #dde0e3 transparent transparent;
	margin: 25px auto
}

@media screen and (min-width:640px) {
	.ad_msc_ctbox + .ad_msc_ctbox:before {
		position: absolute;
		top: 50%;
		left: -36px;
		z-index: 1;
		border-width: 30px 0 30px 15px;
		border-color: transparent transparent transparent #dde0e3;
		margin: -44px 0 0
	}
}

.ad_msc_ctbox + .ad_msc_ctbox.blue:before {
	border-color: #cae3ff transparent transparent
}

@media screen and (min-width:640px) {
	.ad_msc_ctbox + .ad_msc_ctbox.blue:before {
		border-color: transparent transparent transparent #cae3ff
	}
}

.ad_msc_ctbox + .ad_msc_ctbox.pink:before {
	border-color: #f0cdcd transparent transparent
}

@media screen and (min-width:640px) {
	.ad_msc_ctbox + .ad_msc_ctbox.pink:before {
		border-color: transparent transparent transparent #f0cdcd
	}
}

.ad_fvtxt {
	margin: 12px 0;
	font-weight: 700
}

.ad_msc_ttl {
	min-height: 33px;
	position: relative;
	border-bottom: 1px solid #cd002c;
	padding: 4px 20px 5px 80px
}

.ad_msc_ttl:after {
	content: "";
	right: 0;
	height: 18px;
	width: 20px;
	position: absolute;
	z-index: 1;
	margin: -4.5px 0 0;
	background-image: url(../img/service/dm/toggle-icon-off.png);
	background-repeat: no-repeat;
	background-size: 10px 9px
}

@media screen and (min-width:640px) {
	.ad_msc_ttl {
		min-height: 41px;
		padding: 4px 50px 9px 122px
	}

	.ad_msc_ttl:after {
		top: 50%;
		right: 10px;
		margin: -16px 0 0
	}
}

.ad_msc_ttl.on:after {
	background-repeat: no-repeat;
	background-image: url(../img/service/dm/toggle-icon-on.png)
}

.ad_msc_wrap {
	margin: 40px 0 0
}

@media screen and (min-width:640px) {
	.ad_msc_wrap {
		margin: 93px 0 0
	}
}

.ad_msc_wrap + .ad_msc_wrap {
	margin-top: 30px
}

.ad_case {
	padding-bottom: 90px;
	padding-left: 10px;
	padding-right: 10px;
	margin-right: auto;
	margin-left: auto
}

@media screen and (min-width:640px) {
	.ad_msc_wrap + .ad_msc_wrap {
		margin-top: 56px
	}

	.ad_case {
		padding: 40px 4%
	}
}

.ad_ms_message {
	padding: 40px 4% 100px
}

.ad_msg_wrap {
	float: none;
	width: auto
}

@media screen and (min-width:640px) {
	.ad_ms_message {
		padding-top: 35px
	}

	.ad_msg_wrap {
		float: right;
		width: 49.58333%
	}
}

.ad_mssb_inner {
	display: block;
	padding: 20px 10px
}

@media screen and (min-width:640px) {
	.ad_mssb_inner {
		display: table;
		width: 100%;
		table-layout: fixed;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		padding: 20px 2.08333%
	}
}

.ad_mssb_txtbox {
	display: block;
	padding: 0
}

.ad_mss_box {
	margin-top: 57px;
	background: #fff
}

@media screen and (min-width:640px) {
	.ad_mssb_txtbox {
		display: table-cell;
		padding: 0 45px 7px 0;
		vertical-align: middle;
		width: 100%
	}

	.ad_mss_box {
		margin-top: 40px
	}
}

.ad_mss_box + .ad_mss_box {
	margin-top: 20px
}

.ad_solution {
	padding: 40px 4%
}

.ad_mssb_img {
	display: table-cell;
	width: 34.23913%;
	vertical-align: middle;
	text-align: center;
	margin: 0
}

@media screen and (min-width:640px) {
	.ad_solution {
		padding-top: 50px;
		padding-bottom: 100px
	}

	.ad_mssb_img {
		display: block;
		width: auto
	}
}

.ad_mssb_ttl {
	margin: 0 0 20px;
	font-size: 20px;
	font-weight: 700
}

.ad_mssb_ttl .ad_mssb_ttl {
	font-size: 24px;
	line-height: 1.2
}

.ad_mssb_ttl .sub {
	padding: 0 0 0 5px;
	font-size: 10px;
	color: #bababa
}

.ad_mssb_ttl .sub .ad_mssb_ttl-sub {
	padding: 0 0 0 10px;
	font-size: 12px
}

.rmr_txtbox {
	padding: 70px 0 40px;
	max-width: inherit
}

@media screen and (min-width:640px) {
	.rmr_txtbox {
		max-width: 50%;
		padding: 148px 0 0
	}
}

.rmr_solution {
	padding: 40px 0
}

@media screen and (min-width:640px) {
	.rmr_solution {
		padding-top: 54px;
		padding-bottom: 88px
	}
}

.rmr_planinfo {
	padding: 40px 1% 140px
}

@media screen and (min-width:640px) {
	.rmr_planinfo {
		padding-top: 61px;
		padding-bottom: 208px
	}
}

.rmr_plan {
	padding-top: 77px;
	padding-bottom: 140px
}

.systm_txt01 {
	font-size: 14px;
	font-size: 1.4rem;
	margin: 14px 0
}

@media screen and (min-width:640px) {
	.rmr_plan {
		padding: 40px 4% 0
	}

	.systm_txt01 {
		font-size: 26px;
		font-size: 2.6rem;
		margin-top: 55px
	}
}

.systm_img_wrap {
	margin-top: 10px;
	width: 100%
}

@media screen and (min-width:640px) {
	.systm_img_wrap {
		margin-top: 50px;
		height: auto;
		width: 106.25%;
		padding: 0
	}
}

.systm_img_wrap .img_item {
	float: none;
	width: 90%;
	padding: 0;
	margin: 0 auto 22px;
	font-size: 18px;
	text-align: center;
	color: #e41111;
	font-weight: 600
}

@media screen and (min-width:640px) {
	.systm_img_wrap .img_item {
		float: left;
		width: 29.41176%;
		padding: 0 3% 0 0;
		margin-bottom: 162px;
		font-size: 20px
	}
}

.systm_img_wrap .img_item img {
	display: block;
	margin: 0 auto 6px
}

@media screen and (min-width:640px) {
	.systm_img_wrap .img_item img {
		margin-bottom: 18px
	}
}

.systm_arrow {
	margin-bottom: 20px;
	text-align: center
}

@media screen and (min-width:640px) {
	.systm_arrow {
		margin: 0 auto 73px
	}
}

.systm_arrow img {
	width: 10%
}

.systm_sub_wrap {
	width: 100%;
	height: auto;
	margin-bottom: 20px;
	background-color: #f8f8f8
}

.systm_sub_wrap h3 {
	font-size: 18px;
	line-height: 36px;
	padding: 14px 0;
	text-align: center
}

@media screen and (min-width:640px) {
	.systm_sub_wrap {
		width: 100%;
		height: 189px;
		margin-bottom: 79px
	}

	.systm_sub_wrap h3 {
		font-size: 24px;
		line-height: 48px;
		padding: 48px 0 34px
	}
}

.systm_img_wrap02 {
	width: auto;
	margin-bottom: 100px
}

@media screen and (min-width:640px) {
	.systm_img_wrap02 {
		margin-bottom: 296px
	}
}

.systm_img_wrap02 .text_img {
	float: none;
	margin-bottom: 30px;
	overflow: hidden;
	max-width: 300px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	vertical-align: top;
	position: relative;
	background: #e41111;
	padding: 0 10px 9px 0
}

@media screen and (min-width:640px) {
	.systm_img_wrap02 .text_img {
		width: 45%;
		float: left
	}

	.systm_img_wrap02 .text_img p {
		position: relative;
		z-index: 100
	}

	.systm_img_wrap02 .text_img:after,
	.systm_img_wrap02 .text_img:before {
		content: "";
		position: absolute;
		z-index: 1;
		height: 15px;
		background: #fff
	}

	.systm_img_wrap02 .text_img:before {
		bottom: 0;
		left: 0;
		width: 17px
	}

	.systm_img_wrap02 .text_img:after {
		top: 0;
		right: 0;
		width: 10px
	}
}

.systm_img_wrap02 .text_item {
	float: none;
	margin: 0 auto
}

.systm_img_wrap02 .text_item .text_item02 {
	color: #e41111;
	font-size: 16px;
	font-weight: 600;
	line-height: 1;
	margin-bottom: 12px
}

@media screen and (min-width:640px) {
	.systm_img_wrap02 .text_item {
		width: 50%;
		float: left;
		margin-top: 3px;
		margin-left: 5%
	}

	.systm_img_wrap02 .text_item .text_item02 {
		font-size: 24px
	}
}

.systm_img_wrap02 .text_item span {
	font-size: 12px;
	color: #bababa;
	padding-left: 12px;
	margin-bottom: 10px;
	vertical-align: middle
}

.systm_img_wrap02 .text_item .text_item03 {
	font-size: 14px;
	text-indent: 0;
	text-align: left
}

.systm_img_wrap02 .text_item .text_inner + .text_inner {
	margin-top: 20px
}

@media screen and (min-width:640px) {
	.systm_img_wrap02 .text_item .text_item03 {
		font-size: 16px;
		text-indent: 33px
	}

	.systm_img_wrap02 .text_item .text_inner + .text_inner {
		margin-top: 50px
	}
}

.systm_resource_wrap {
	width: auto;
	height: auto;
	margin: 0 auto 40px;
	position: relative;
	padding: 0 15px 50px;
	color: #4d4d4d;
	background-color: #f8f8f8
}

.systm_resource_wrap .rsc_img img {
	max-width: 100px;
	position: absolute;
	top: -50px;
	left: 0
}

@media screen and (min-width:640px) {
	.systm_resource_wrap {
		margin: 0 auto 142px
	}

	.systm_resource_wrap .rsc_img img {
		top: -71px;
		left: -71px
	}
}

.systm_resource_wrap h3 {
	font-size: 18px;
	font-weight: 600;
	line-height: 36px;
	padding: 64px 0 14px;
	margin: 0 auto;
	text-align: center;
	border-bottom: solid 1px #4d4d4d
}

@media screen and (min-width:640px) {
	.systm_resource_wrap h3 {
		font-size: 24px;
		line-height: 48px;
		padding: 76px 0 37px;
		margin: 0 97px
	}
}

.systm_resource_wrap .text_wrap {
	font-size: 14px;
	line-height: 24px;
	margin-top: 20px;
	text-align: left
}

.cmn-link a,
.msd-arrow,
.msd-lead {
	text-align: center
}

@media screen and (min-width:640px) {
	.systm_resource_wrap .text_wrap {
		text-align: center;
		font-size: 16px;
		line-height: 36px;
		margin-top: 38px
	}
}

.systm_resource_wrap .text_wrap p + p {
	margin-top: 12px
}

.tab_contents {
	display: none
}

.tab_contents.current {
	display: block
}

.form_textarea,
input[type=text].form_input {
	border-radius: 5px;
	border: 1px solid #aaa;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: block;
	width: 94%;
	padding: 5px;
	font-size: 16px;
	line-height: 1.42857143;
	background-color: #fff;
	background-image: none;
	-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
	box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
	-webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
	-o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
	transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;
	transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
	transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s, -webkit-box-shadow ease-in-out .15s
}

.form_textarea {
	max-width: 100%;
	min-height: 200px;
	border-radius: 5px;
	border: 1px solid #aaa
}
.privacy_window{
    background-color: #fff;
    padding:15px;
    border:1px solid #ccc;
    width: 80%;
    margin:0px auto 15px;;
    display: block;
    overflow: scroll;
    height: 200px;
    font-size: .9rem;
    line-height: 1.8rem;
    text-align: left;
}
.privacy_window a{
    color:#e42a42;
}
.privacy_window .biko{
    float: right;
    font-size: .7rem;
    border:1px solid #000;
    padding:8px;
    display: block;
    margin:10px 0px;
    line-height: 1.1em;
}

@media screen and (min-width:450px) {
	.sv_box {
		padding: 5%
	}
}

@media screen and (min-width:640px) {
	.systm_resource_wrap .text_wrap p + p {
		margin-top: 35px
	}

	.aboutus_btn,
	.service_btn {
		min-width: 350px
	}

	.sv_box {
		padding: 5%;
		min-height: 250px
	}

	.sv_box .img_wrap.icon {
		width: 46%;
		margin: 10px 27% 20px
	}

	.sv_txt {
		width: 100%
	}

	.topsv_left_box {
		width: 98%;
		padding: 1%
	}

	.aboutus_txt {
		font-size: .9rem;
		font-weight: 400;
		max-width: 55%;
	}

	.map_wrap {
		vertical-align: top;
		display: inline-block;
		width: 100%;
	}

	.map_wrap.left {}

	.map_inner {
		height: 400px;
	}

	.map_txt {
		font-size: 14px
	}
}

@media screen and (min-width:860px) {

	.mtw-ttl-01,
	.mtw-txt-01 {
		color: #4b4b4b;
		font-weight: 700
	}

	.sp {
		display: none
	}

	.pc {
		display: block
	}

	.top_fvtxt {
		width: 100%
	}

	.sec_tit_wrap {
		font-size: 1.5rem;
	}

	.topsv_right_box {
		margin-top: 10%;
		width: 44%;
		float: right;
		padding: 0
	}

	.topsv_right_box .title {
		color: #ce002c;
		font-weight: bold;
		display: inline-block;
		font-size: 1.2rem;
	}

	.topsv_left_box {
		margin-right: 2%;
		float: left;
		width: 52%
	}

	.wkl_txt {
		font-size: 14px
	}

	.wklbg_01 {
		width: 40%;
		display: table-cell
	}

	.wklbg_02 {
		width: 55%
	}

	.main {
		position: relative;
		z-index: 10
	}

	.mtw-ttl-01 {
		font-size: 36px;
		margin: 0 0 1.8%
	}

	.mtw-txt-01 {
		font-size: 20px
	}

	.main_inner {
		margin: 10px 0 0
	}

	.udline_tit {
		font-size: 37px
	}
}

@media screen and (min-width:1200px) {
	.sv_tit {
		font-size: 18px
	}

	.sv_txt {
		font-size: 13px
	}

	.topsv_right_box {
		width: 38%
	}

	.topsv_left_box {
		width: 54%;
		margin-right: 4%
	}
}

img {
	max-width: 100%
}

.clearfix:after {
	content: " ";
	display: block;
	clear: both
}

.font-jp-01 {
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif
}

.font-deco-01 {
	color: #cd002c !important
}

.cmntw-ttl-01 {
	color: #cd002c;
	font-size: 37px;
	font-weight: 700;
	position: relative;
	z-index: 1;
	padding-top: 10px;
	padding-bottom: 15px;
	line-height: 1.2
}

.cmntw-ttl-01:before {
	content: "";
	height: 4px;
	width: 31px;
	background: #cd002c;
	position: absolute;
	z-index: 1;
}

.cmntw-txt-01 {
	color: #4b4b4b;
	font-size: 14px;
	margin: 14px 0
}

.cmn-link a {
	display: block;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border: 1px solid #666;
	width: 141px;
	height: 41px;
	padding: 6px 0 0;
	font-size: 16px
}

.mswt-label,
.stm-img-wrap02 .text-img {
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box
}

.mr-system {
	padding-top: 55px
}

.mr-interview {
	padding-bottom: 64px;
}

.mri-col2 {
	display: table;
	width: 100%;
	margin-bottom: 10px
}

.mri-img,
.mri-txt {
	display: table-cell;
	vertical-align: middle
}

.mri-img {
	width: 582px
}

.mri-img a {
	display: block
}

.msl-txt {
	line-height: 2.15
}

.msl-txt02 {
	margin: -8px 0 -14px;
	font-size: 24px;
	font-size: 2.4rem;
	font-weight: 700;
	line-height: 2
}

.msl-txt03 {
	margin: -2px 0 0;
	line-height: 1.75
}

.msl-txt03 + .msl-txt03 {
	margin-top: 24px;
	margin-bottom: 0
}

.ms-demand {
	padding-top: 0px;
	padding-bottom: 150px
}

.msd-lead {
	margin: 38px 0 49px;
	font-weight: 700;
	color: #989898;
	font-size: 26px;
	font-size: 2.6rem;
	line-height: 1.5
}

.msd-arrow {
	padding: 22px 0 0
}

.stm-img-wrap02 {
	width: auto;
	margin-top: 40px;
	margin-bottom: 100px
}

@media screen and (min-width:640px) {
	.stm-img-wrap02 {
		padding-top: 12px;
		margin-top: 59px;
		margin-bottom: 174px
	}
}

.stm-img-wrap02 .text-img {
	float: none;
	margin: 0 auto 30px;
	overflow: hidden;
	max-width: 400px;
	background: #e41111;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	vertical-align: top
}

@media screen and (min-width:640px) {
	.stm-img-wrap02 .text-img {
		position: relative;
		float: left;
		margin-left: 38px;
		padding: 0 10px 9px 0
	}
}

.stm-img-wrap02 .text-img p {
	position: relative;
	z-index: 100
}

.stm-img-wrap02 .text-img:after,
.stm-img-wrap02 .text-img:before {
	content: "";
	position: absolute;
	z-index: 1;
	height: 15px;
	background: #fff
}

.stm-img-wrap02 .text-img:before {
	bottom: 0;
	left: 0;
	width: 17px
}

.stm-img-wrap02 .text-img:after {
	top: 0;
	right: 0;
	width: 10px
}

.stm-img-wrap02 .text-item {
	float: none;
	max-width: 400px;
	margin: 0 auto
}

@media screen and (min-width:640px) {
	.stm-img-wrap02 .text-item {
		float: left;
		margin: 3px 0 0 65px
	}
}

.stm-img-wrap02 .text-item .text-item02 {
	color: #e41111;
	font-size: 16px;
	font-weight: 600;
	line-height: 1;
	margin-bottom: 12px
}

@media screen and (min-width:640px) {
	.stm-img-wrap02 .text-item .text-item02 {
		font-size: 24px
	}
}

.stm-img-wrap02 .text-item span {
	font-size: 12px;
	color: #bababa;
	padding-left: 12px;
	margin-bottom: 10px;
	vertical-align: middle
}

.stm-img-wrap02 .text-item .text-item03 {
	font-size: 14px;
	text-indent: 0;
	text-align: left
}

.stm-img-wrap02 .text-item .text-inner + .text-inner {
	margin-top: 20px
}

@media screen and (min-width:640px) {
	.stm-img-wrap02 .text-item .text-item03 {
		font-size: 16px;
		text-indent: 33px
	}

	.stm-img-wrap02 .text-item .text-inner + .text-inner {
		margin-top: 50px
	}
}

.stm-resource-wrap {
	width: auto;
	height: auto;
	margin: 0 auto 40px;
	position: relative;
	padding: 0 15px 50px;
	color: #4d4d4d;
	background-color: #f8f8f8
}

.stm-resource-wrap .rsc-img img {
	max-width: 100px;
	position: absolute;
	top: -50px;
	left: 0
}

@media screen and (min-width:640px) {
	.stm-resource-wrap {
		height: 700px;
		margin: 0 auto 99px
	}

	.stm-resource-wrap .rsc-img img {
		top: -71px;
		left: -71px
	}
}

.stm-resource-wrap h3 {
	width: 100%;
	font-size: 18px;
	line-height: 36px;
	padding: 64px 0 14px;
	margin: 0 auto;
	font-weight: 600;
	border-bottom: solid 1px #4d4d4d;
	text-align: center
}

.csl_msfc_ttl,
.mnvlb-txt,
.msc-ctb-ttl,
.msc-ctb-txt02,
.msc-ctb-txt03,
.mscc-btn a,
.mscc-ttl,
.msct-label,
.msf-catch,
.msfct-ttl,
.msftl-ttl-txt,
.msfttb-ttl-sub,
.msm-label,
.msp-col3-btn a,
.msp-col3-ttl,
.msp-ttl,
.mspi-red-box,
.mspi-ttl,
.mspl-txt,
.mss-col3-txt,
.msw-ttl01,
.msw-ttl02,
.pd_msfc_ttl,
.txt_detail .concept_ttl {
	font-weight: 700
}

@media screen and (min-width:640px) {
	.stm-resource-wrap h3 {
		font-size: 24px;
		line-height: 48px;
		padding: 76px 0 37px
	}
}

.stm-resource-wrap .text-wrap {
	font-size: 14px;
	line-height: 24px;
	margin-top: 20px;
	text-align: left
}

.csl_msfc_ttl,
.ms-lead,
.msc-ctb-img,
.msc-ctb-ttl,
.msct-label,
.msf-catch,
.msf-img,
.msf-img01,
.msp-col4-list,
.msw-ttl01,
.msw-ttl02,
.msw-txt,
.msw-word-box,
.mswa-img,
.mswa-txt,
.mswt-label-text,
.pd_msfc_ttl {
	text-align: center
}

@media screen and (min-width:640px) {
	.stm-resource-wrap .text-wrap {
		text-align: center;
		font-size: 16px;
		line-height: 36px;
		margin-top: 38px
	}
}

.stm-resource-wrap .text-wrap p + p {
	margin-top: 12px
}

@media screen and (min-width:640px) {
	.stm-resource-wrap .text-wrap p + p {
		margin-top: 35px
	}
}


.ctl_msf_ttl {
	display: table;
	width: 100%;
	margin: 0 0 62px;
	padding: 0 0 10px;
	border-bottom: 1px solid #d3d3d3
}

.msft-icon,
.msft-txt-box {
	display: table-cell;
	vertical-align: top
}

.msft-icon {
	width: 59px
}

.msft-txt-box {
	padding: 10px 0 0 21px
}

.msfttb-ttl {
	font-size: 20px;
	line-height: 1.1
}

.msfttb-ttl-sub {
	margin: 4px 0 0 3px;
	font-size: 12px;
	letter-spacing: .02em;
	line-height: 1;
	color: #bababa
}

.csl_msf_ctbox {
	display: table;
	width: 100%;
	padding-top: 22px
}

.csl_msf_ctbox + .csl_msf_ctbox {
	margin-top: 79px
}

.csl_msf_ctbox + .ctl_msf_ttl {
	margin-top: 86px
}

.csl_msfc_img_box {
	display: block;
	width: auto;
	margin: 0 0 20px;
	vertical-align: top
}

@media screen and (min-width:640px) {
	.csl_msfc_img_box {
		display: table-cell
	}
}

@media screen and (min-width:860px) {
	.csl_msfc_img_box {
		width: 436px
	}
}

.csl_msfc_box_inner {
	position: relative;
	padding: 0 0 0 20px
}

.csl_msfc_ttl,
.msct-label {
	position: absolute;
	z-index: 1;
	left: 0
}

.csl_msfc_ttl {
	top: -22px;
	min-width: 239px;
	padding: 14px 10px 13px;
	background: #ce002c;
	line-height: 1.2;
	color: #fff
}

.csl_msfc_txt_box {
	display: table-cell;
	padding: 0 0 0 32px;
	line-height: 1.75;
	letter-spacing: .008em;
	vertical-align: middle
}

.mnv-list li,
.msftl-box,
.msftl-ttl-txt,
.msp-box,
.mswt-label,
.mswwb-txt {
	vertical-align: top
}

.ms-flow {
	padding-top: 47px;
	padding-bottom: 40px
}

.msf-img {
	margin: 38px 0 94px
}

.msf-list-box {
	overflow: hidden
}

.msf-txt-list {
	font-size: 0
}

.msftl-box {
	font-size: 14px
}

.msftl-ttl-txt {
	display: inline-block;
	color: #e42c11;
	line-height: 1
}

.msftl-ttl-txt01 {
	color: #f17012
}

.msftl-ttl-txt02 {
	color: #e44611
}

.msftl-txt {
	line-height: 1.5;
	letter-spacing: .01em
}

.js-toggle-contents {
	display: none
}

.msct-label {
	top: 0;
	background: #d2d2d2;
	line-height: 1;
	color: #fff
}

.msct-label:after,
.msct-label:before {
	content: "";
	position: absolute;
	z-index: 1;
	background: #fff;
	display: block
}

.msct-label:before {
	top: 0;
	right: 0
}

.msct-label:after {
	bottom: 0;
	left: 0
}

.msct-label p {
	position: relative;
	z-index: 9;
	background: #cd002c
}

.msc-ctb-ttl {
	padding: 0 0 10px;
	border-bottom: 1px solid #d9d9d9;
	font-size: 18px;
	line-height: 1.5
}

.msc-ctb-li,
.msc-ctb-txt03,
.mssb-list li {
	padding-left: 1em;
	text-indent: -1em
}

.msc-ctb-img {
	margin: 0 0 29px
}

.msc-ctb-li {
	font-size: 16px;
	line-height: 1.85
}

.msc-ctb-li:before {
	content: "・"
}

.msc-ctb-li.small {
	font-size: 14px
}

.msc-ctb-arrow:after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 14px 30px 0;
	border-color: #dde0e3 transparent transparent;
	margin: 21px auto 16px
}

.msc-ctb-txt02 {
	color: #2e78cc;
	line-height: 1.5
}

.msc-ctb-txt03 {
	margin: 0 0 20px;
	font-size: 16px;
	line-height: 1.85;
	line-height: 1.4
}

.msc-ctb-txt03:before {
	content: "→"
}

.mssb-list li {
	line-height: 1.75;
	color: #333
}

.mssb-list li:before {
	content: "・"
}

.mssb-txt {
	color: #333
}

.msm-label {
	color: #bababa;
	line-height: 1
}

.msm-ttl {
	line-height: 1.3
}

.ms-g-box {
	background: #f7f7f7;
}

.ms-g-box02 {
	background: #666
}

.ms-wcase {
	padding: 43px 0 0
}

.ms-wcase .ms-g-box02 {
	margin: 52px 0 0
}

.msw-bg-inner {
	max-width: 804px;
	margin: 0 auto;
	padding: 33px 0 29px
}

.msw-txt {
	margin: 0 0 43px;
	color: #fff;
	font-size: 16px;
	line-height: 1.9
}

.msw-ttl01,
.msw-ttl02 {
	line-height: 1.2
}

.msw-ttl01 {
	margin: 0 0 10px;
	font-size: 24px;
	color: #fff
}

.msw-ttl01:after {
	content: "・・・";
	display: block;
	color: #f17012;
	letter-spacing: .1em
}

.msp-box,
.mswwb-txt {
	display: inline-block
}

.msw-ttl02 {
	margin: 0 0 3px;
	font-size: 18px;
	color: #222;
}

.msw-word-box {
	padding: 18px 5px 19px;
	background: #fff;
	line-height: 1
}

.mswwb-txt {
	font-size: 16px;
	line-height: 2;
}

.flex .mswwb-txt {
	width: 33%;
}

.mswwb-txt:before {
	content: "・";
	padding: 0 4px
}

.main-nav-bg:before,
.mscc-list li:before,
.msp-btn a:before,
.msp-ttl:after,
.mswt-label:after,
.mswt-label:before,
.mswt-line:before {
	content: ""
}

.mswwb-col2-wrap {
	padding: 23px 0 0
}

.mswwb-col2-box {
	width: 48.13433%
}

.msw-after-box {
	position: relative;
	padding: 59px 0 0
}

.mswa-txt {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	margin: 0 auto;
	z-index: 9
}

.mswa-img {
	padding: 0 4%
}

.ms-point {
	overflow: hidden;
	padding-top: 69px;
	padding-bottom: 97px
}

.msp-col2-wrap {
	width: 104.6875%;
	padding: 61px 0 0 1.77083%;
	font-size: 0
}

.msp-box {
	width: 43.48259%;
	margin: 0 4.47761% 2.88557% 0
}

.msp-label {
	padding: 0 0 6px 8px;
	color: #bababa;
	font-size: 16px;
	line-height: 1
}

.msp-label span {
	font-size: 24px
}

.msp-ttl {
	position: relative;
	margin: 0 0 12px;
	padding: 0 0 4px 7px;
	border-bottom: 2px solid #cd002c;
	font-size: 20px;
	line-height: 1.5
}

.msp-ttl:after {
	position: absolute;
	bottom: -4px;
	right: -7px;
	z-index: 1;
	display: block;
	height: 6px;
	width: 8px;
	background: url(../img/service/dm/msp-ttl.png) no-repeat
}

.msp-txt {
	padding: 0 0 0 7px;
	color: #333;
	font-size: 1.456rem;
	line-height: 1.75
}

.ms-lead {
	margin-bottom: 59px;
	padding-top: 55px;
	padding-bottom: 60px
}

.msf-head {
	margin-bottom: 104px
}

.msf-catch {
	margin: 28px 0 0;
	color: #989898;
	font-size: 26px;
	line-height: 1.5
}

.msf-img01 {
	margin: 0 0 160px;
	padding: 0 2%
}

.msf-ct-box {
	position: relative;
	padding: 23px 0 0
}

.msf-ct-box + .msf-ct-box {
	margin-top: 91px
}

.msfc-txt-box {
	position: relative;
	float: left;
	width: 46.35417%;
	background: #faf5ef;
	margin: 0 0 0 3.75%
}

.msfc-txt-box.right {
	float: right;
	margin: 0
}

.msfct-inner {
	padding: 58px 21px 40px;
	line-height: 2.15
}

.pd_msfc_ttl {
	width: auto;
	position: absolute;
	top: -23px;
	left: -4.42177%;
	z-index: 9;
	padding: 11px 0 11px 9.52381%;
	padding-right: calc(4.2% + 15px);
	padding-left: calc(4.2% + 15px);
	background: #cd002c;
	color: #fff;
	line-height: 1;
	font-size: 18px
}

@media screen and (min-width:640px) {
	.pd_msfc_ttl {
		width: 140px;
		font-size: 22px;
		left: -8.08989%;
		min-width: 239px;
		padding: 15px 0 11px
	}
}

.pd_msfc_img {
	float: right;
	width: 44.89583%;
	margin: 0 2.60417% 0 0
}

.pd_msfc_img img {
	padding: 7px 0 0
}

.pd_msfc_img.left {
	float: left;
	width: 45.83333%;
	margin: 0 0 0 2.08333%
}

.msfct-txt {
	letter-spacing: .09em
}

.msfct-txt + .msfct-ttl {
	margin-top: 60px
}

.ms-works {
	padding-top: 54px
}

.msw-head {
	margin: 0 0 51px
}

.msw-ttl {
	margin: 0 0 45px
}

.msw-ttl.right .mswt-label {
	float: right
}

.msw-ttl.right .mswt-line {
	float: left
}

.mswt-label {
	position: relative;
	float: left;
	width: 50%;
	padding: 0 3px 5px 0;
	background: #d2d2d2;
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}

.mspi-txt-box,
.mswt-line {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box
}

.mswt-label:after,
.mswt-label:before {
	position: absolute;
	height: 5px;
	width: 3px;
	background: #f8f8f8;
	z-index: 1
}

.mswt-label:before {
	bottom: 0;
	left: 0
}

.mswt-label:after {
	top: 0;
	right: 0
}

.mswt-label-text {
	display: block;
	background: #cd002c;
	padding: 9px 10px;
	color: #fff;
	font-size: 16px;
	line-height: 1.5
}

.mswt-line {
	float: right;
	width: 50%;
	padding: 19px 15px 0;
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}

.load .btn_wrap a,
.main-contact-arrow,
.mnv-list li,
.mnvl-btn,
.mnvl-btn-on,
.mnvlbo-link a {
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}

.mswt-line:before {
	display: block;
	height: 2px;
	width: 100%;
	background: #cd002c
}

.msw-ct-box {
	margin: 0 0 80px
}

.mswc-txt-box {
	width: 100%;
	margin: 0;
}

.mswc-txt-box.right {
	float: right;
	margin: 0 1.66667% 0 0
}

.mswct-ttl {
	padding: 10px 20px;
	margin: 0;
	border-bottom: none;
	font-size: 14px;
	background: #cd002c;
	color: #fff;
	font-weight: 500;
	display: inline-block;
	margin-top: -28px;
	position: absolute;
	letter-spacing: 0.1em;
}

.dunrop {
	line-height: 1em;
}

.mswct-txt {
	padding: 28px 0 0;
}

.mswct-txt-ttl {
	margin: 0 0 2px;
	font-size: 15px;
	font-weight: 600;
}

.mswct-txt-lead {
	padding: 0;
	line-height: 1.8;
	font-size: 12px;
}

.mswct-txt-lead + .mswct-txt-ttl {
	margin-top: 27px
}

.mswc-img-box {
	float: right;
	width: 49.79167%;
	margin: 0 .3125% 0 0;
	-webkit-box-shadow: 0 0 10px 0 rgba(0, 0, 0, .2);
	box-shadow: 0 0 10px 0 rgba(0, 0, 0, .2)
}

.mswc-img-box.left {
	float: left;
	margin: 0 0 0 .52083%
}

.mswci-img {
	padding: 14px
}

.mswci-img a {
	display: block
}

.msp-col3-list li,
.msp-col4-list li {
	display: inline-block;
	vertical-align: top
}

.ms-professional {
	padding: 67px 0 0
}

.msp-head {
	margin-bottom: 0px;
}

.msp-col4-list {
	margin: 0 0 20px;
	font-size: 0;
	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;
}

.msp-col4-list li {
	width: 24%;
	margin: 0;
	text-align: left;
	font-size: 14px;
}

.msp-col4-img {
	margin: 0;
	-webkit-box-shadow: 0 0px 10px rgba(0, 0, 0, 0.2);
	box-shadow: 0 0px 10px rgba(0, 0, 0, 0.2);
}

.msp-col4-txt {
	padding: 0;
}

.msp-lead-box {
	padding: 59px 0 77px;
	border-top: 1px solid #c2c2c2;
	border-bottom: 1px solid #c2c2c2
}

.msp-lead {
	padding: 0 0 72px
}

.mspl-txt {
	color: #989898;
	text-align: center;
	line-height: 1.2;
	font-size: 36px
}

.msp-col3-list {
	font-size: 0
}

.msp-col3-list li {
	width: 33.33333333333%;
	text-align: center
}

.msp-col3-ttl {
	margin: 0 0 15px;
	font-size: 18px
}

.msp-col3-ttl img {
	margin-right: 5px
}

.msp-col3-txt {
	max-width: 260px;
	margin: 0 auto;
	padding: 0 20px;
	font-size: 12px;
	line-height: 2.15;
	text-align: left
}

.mscc-ttl,
.msp-col3-btn a {
	text-align: center
}

.msp-col3-btn {
	width: 115px;
	margin: 30px auto 0;
	-webkit-box-shadow: 0 3px 5px 0 #000;
	box-shadow: 0 3px 5px 0 #000
}

.msp-col3-btn a {
	display: block;
	background: #cd002c;
	padding: 12px 10px;
	border-radius: 2px;
	color: #fff;
	line-height: 1;
	font-size: 16px
}

.msc-head {
	padding: 65px 0 44px
}

.mscc-txt-box {
	float: left;
	width: 50%
}

.mscc-img,
.mscc-txt-box.right {
	float: right
}

.mscc-txt-box.mscc-txt-box02 {
	width: 32.29167%;
	margin: 0 0 0 4.6875%
}

.mscc-ttl {
	margin: 0 0 44px;
	padding: 0 20px;
	font-size: 24px;
	line-height: 1.5
}

.mscc-ttl.mscc-ttl02 {
	margin: 0 0 25px;
	padding: 87px 0 0 32px;
	text-align: left;
	font-size: 22px
}

.load .btn_wrap a,
.mnvl-btn,
.mnvlbo-link a,
.mscc-btn a,
.txt_detail .concept_ttl {
	text-align: center
}

.mscc-inner {
	width: 100%;
}

.mscc-txt {
	line-height: 2
}

.mscc-txt + .mscc-txt {
	margin-top: 28px
}

.mscc-img {
	width: 50%;
	margin: 30px 0 0
}

.mscc-img.left {
	float: left;
	margin: 23px 0 0
}

.mscc-img.mscc-img02 {
	width: 61.66667%;
	margin: -3px 0 0
}

.mscc-list {
	padding: 0 0 0 15px
}

.mscc-list li {
	position: relative;
	padding: 0 0 0 18px
}

.mscc-list li:before {
	position: absolute;
	top: 3px;
	left: 0;
	z-index: 1;
	height: 15px;
	width: 10px;
	background: url(../img/service/dm/mscc-list.png) no-repeat
}

.mscc-list li + li {
	margin-top: 10px
}

.mscc-btn {
	width: 250px;
	margin: 44px 0 0;
	-webkit-box-shadow: 0 3px 5px 0 #000;
	box-shadow: 0 3px 5px 0 #000
}

.mscc-btn a {
	display: block;
	background: #cd002c;
	padding: 23px 10px 22px;
	border-radius: 2px;
	color: #fff;
	line-height: 1
}

.load .btn_wrap {
	max-width: 300px;
	margin: 0 auto
}

.load .btn_wrap a {
	width: 100%;
	display: inline-block;
	padding: 15px;
	border: 1px solid #ccc;
	margin: 40px 10px
}

.txt_detail .concept_ttl {
	font-size: 24px;
	line-height: 1.6;
	padding: 70px 0 30px
}

.txt_detail .concept_spec {
	font-size: 15px;
	line-height: 1.8;
	margin-bottom: 30px;
	text-align: center
}

@media only screen and (max-width:640px) {

	.msp-box,
	.msvc-head,
	.msvc-ttl {
		display: block
	}

	.msd-arrow,
	.msf-img,
	.msm-img,
	.msst-img,
	.msw-word-box,
	.mswt-label-text {
		text-align: center
	}

	.ms-lead {
		margin-bottom: 40px;
		padding: 40px 4%
	}

	.ms-wcase {
		padding: 40px 0
	}

	.ms-wcase .ms-g-box02 {
		margin: 40px 0 0
	}

	.msw-bg-inner {
		padding: 33px 4% 29px
	}

	.msw-txt {
		margin: 0 0 40px;
		font-size: 14px
	}

	.msw-ttl01 {
		margin: 0 0 10px;
		font-size: 20px;
		font-size: 2rem
	}

	.msw-ttl02 {
		margin: 0 0 3px;
		font-size: 16px
	}

	.msw-word-box {
		padding: 18px 5px 14px;
		background: #fff;
		line-height: 1
	}

	.mswwb-txt {
		margin: 0 0 5px;
		font-size: 12px;
		vertical-align: top
	}

	.mswwb-col2-box {
		width: auto
	}

	.msw-after-box {
		padding: 36px 0 0
	}

	.mswa-txt img {
		width: 95.5px
	}

	.msfc-txt-box,
	.msp-box,
	.msst-img,
	.msvc-ttl {
		width: auto
	}

	.mswa-img {
		padding-top: 20px;
		padding-bottom: 20px
	}

	.ms-point {
		padding: 40px 4%
	}

	.msp-col2-wrap {
		width: auto;
		padding: 40px 0 0
	}

	.msp-box {
		margin: 0 0 40px
	}

	.msp-label {
		padding: 0 0 6px;
		font-size: 14px;
		font-size: 1.4rem
	}

	.msp-label span {
		font-size: 22px;
		font-size: 2.2rem
	}

	.msp-ttl {
		margin: 0 0 12px;
		padding: 0 0 4px;
		font-size: 18px
	}

	.msp-txt {
		padding: 0;
		font-size: 1.4rem
	}

	.ms-voice {
		padding: 40px 4%
	}

	.msv-ct-box {
		margin: 40px 0 0
	}

	.msv-ct-box + .msv-ct-box {
		margin-top: 40px
	}

	.msvc-head {
		margin: 0 0 10px
	}

	.msvc-line {
		display: none
	}

	.msvc-txt {
		font-size: 14px
	}

	.msst-ttl {
		padding: 19px 0 24px;
		font-size: 20px;
		letter-spacing: normal
	}

	.msst-txt {
		padding: 0;
		font-size: 14px
	}

	.msst-txt + .msst-txt {
		margin-top: 20px
	}

	.msst-img {
		margin: 30px 0 0
	}

	.ptv_ttl .mv-text02 {
		font-size: 14px;
		padding: 0 4%
	}

	.inner-01 {
		padding-right: 3%;
		padding-left: 3%
	}

	.ptv_ttl {
		font-size: 26px;
		display: block;
	}

	.ptv_ttl span {
		display: block;
	}

	.msf-head {
		margin-bottom: 40px
	}

	.msf-catch {
		margin: 28px 0 0;
		font-size: 16px
	}

	.msf-img01 {
		margin: 0 4% 50px;
		padding: 0
	}

	.msf-ct-box {
		padding: 23px 0 0
	}

	.msf-ct-box + .msf-ct-box {
		margin-top: 50px
	}

	.msfc-txt-box,
	.msfc-txt-box.right {
		float: none;
		margin: 0
	}

	.pd_msfc_img,
	.pd_msfc_img.left {
		margin: 30px 0 0;
		float: none;
		width: auto
	}

	.msfct-inner {
		padding: 40px 15px 30px;
		line-height: 2.15
	}

	.pd_msfc_img img {
		padding: 7px 0 0
	}

	.msfct-txt + .msfct-ttl {
		margin-top: 20px
	}

	.ms-works {
		padding: 40px 4%
	}

	.msw-head {
		margin: 0 0 51px
	}

	.msw-ttl {
		margin: 0 0 20px
	}

	.msw-ttl.right .mswt-label {
		float: none
	}

	.mswt-label {
		float: none;
		width: auto
	}

	.mswt-label-text {
		display: block;
		background: #cd002c;
		padding: 9px 10px;
		color: #fff;
		font-size: 16px;
		font-size: 1.6rem;
		line-height: 1.5
	}

	.mswt-line {
		display: none
	}

	.csl_msfc_txt_box,
	.mri-col2,
	.mri-img,
	.mri-txt,
	.msftl-box,
	.msp-col3-list li,
	.mswci-img a {
		display: block
	}

	.msw-ct-box {
		margin: 0 0 40px
	}

	.mswc-txt-box,
	.mswc-txt-box.right {
		float: none;
		width: auto;
		margin: 0
	}

	.mswct-ttl {
		margin-top: -60px;
		font-size: 16px;
	}

	.mswct-txt {
		padding: 0
	}

	.mswct-txt-ttl {
		font-size: 14px;
	}

	.mswct-txt-lead {}

	.mswct-txt-lead + .mswct-txt-ttl {
		margin-top: 20px
	}

	.mswc-img-box,
	.mswc-img-box.left {
		float: none;
		width: auto;
		margin: 25px 0 0
	}

	.mswci-img {
		padding: 14px
	}

	.ms-professional {
		padding: 40px 0 0
	}

	.ms-professional .inner-01 {
		padding: 0;
	}

	.msp-head {
		margin-bottom: 40px
	}

	.msp-col4-list {
		margin: 0 0 40px
	}

	.msp-col4-list li {
		display: block;
		width: auto;
		margin: 0;
	}

	.msp-col4-img {
		margin: 0;
	}

	.msp-col4-txt {
		padding: 0
	}

	.msp-lead-box {
		padding: 40px 0
	}

	.msp-lead {
		padding: 0 0 40px
	}

	.mspl-txt {
		line-height: 1.2;
		font-size: 24px;
		font-size: 2.4rem;
		font-weight: 700
	}

	.msp-col3-list li {
		width: auto
	}

	.msp-col3-list li + li {
		margin-top: 40px
	}

	.msp-col3-txt {
		max-width: 280px;
		padding: 0
	}

	.msp-col3-btn {
		margin: 20px auto 0
	}

	.msc-head {
		padding: 40px 0
	}

	.mscc-txt-box {
		float: none;
		width: auto
	}

	.mscc-txt-box.right {
		float: none
	}

	.mscc-txt-box.mscc-txt-box02 {
		width: auto;
		margin: 0
	}

	.mscc-ttl,
	.mscc-ttl.mscc-ttl02 {
		margin: 0 0 20px
	}

	.mscc-ttl {
		padding: 0;
		font-size: 2rem
	}

	.mscc-ttl.mscc-ttl02 {
		padding: 40px 0 0;
		font-size: 2rem
	}

	.mscc-img,
	.mscc-img.left,
	.mscc-img.mscc-img02 {
		margin: 20px 0 0;
		float: none
	}

	.mscc-list,
	.msf-list-box {
		padding: 0
	}

	.mscc-inner {
		max-width: inherit
	}

	.mscc-img,
	.mscc-img.mscc-img02 {
		width: auto
	}

	.mscc-btn {
		width: auto;
		margin: 30px 0 0
	}

	.ms-flow .cmn-ttl-wrap {
		margin-bottom: 40px;
	}

	.msf-txt-list {
		width: auto
	}

	.msftl-box {
		width: auto;
		margin: 0 0 40px
	}

	.msftl-ttl {
		margin: 0 0 22px
	}

	.msftl-ttl-txt {
		padding: 15px 0 0 9px;
		font-size: 20px;
		font-size: 2rem
	}

	.msct-label {
		width: 70px;
		padding: 0 2px 3px 0
	}

	.msct-label:after,
	.msct-label:before {
		height: 3px;
		width: 2px
	}

	.msct-label p {
		padding: 10px 0;
		letter-spacing: normal;
		font-size: 10px;
		font-size: 1rem
	}

	.msct-txt {
		font-size: 14px;
		font-size: 1.4rem
	}

	.msc-ct-wrap {
		padding: 0;
	}

	.mssb-list li {
		font-size: 14px;
		font-size: 1.4rem
	}

	.mssb-txt {
		margin: 9px 0 0
	}

	.msm-label {
		margin: 0 0 13px 2px;
		font-size: 12px;
		font-size: 1.2rem
	}

	.msm-ttl {
		margin: 0 0 14px;
		font-size: 20px;
		font-size: 2rem
	}

	.msm-txt {
		line-height: 1.75
	}

	.msm-img {
		float: none;
		width: auto;
		margin: 20px 0 0
	}

	.msl-txt02 {
		margin: 0;
		font-size: 20px;
		font-size: 2rem
	}

	.msl-txt03 {
		margin: 0
	}

	.msl-txt03 + .msl-txt03 {
		margin-top: 24px
	}

	.ms-demand {}

	.msd-lead {
		margin: 40px 0;
		font-size: 20px;
		font-size: 2rem
	}

	.msd-arrow {
		padding: 22px 0 0
	}

	.msd-arrow img {
		width: 30px
	}

	.ms-flow {
		padding: 40px 4%
	}

	.ctl_msf_ttl {
		margin: 0 0 30px;
		padding: 0 0 10px
	}

	.msft-txt-box {
		padding: 0 0 0 15px
	}

	.msfttb-ttl {
		font-size: 20px;
		font-size: 2rem
	}

	.csl_msf_ctbox {
		padding-top: 22px
	}

	.csl_msf_ctbox + .csl_msf_ctbox {
		margin-top: 40px
	}

	.csl_msf_ctbox + .ctl_msf_ttl {
		margin-top: 70px
	}

	.csl_msfc_box_inner,
	.csl_msfc_txt_box {
		padding: 0
	}

	.mr-system {
		padding: 40px 4%
	}

	.mr-message {
		padding: 40px 4% 70px
	}

	.mr-blog-wrap,
	.mr-interview {
		padding: 40px 4%
	}

	.mri-img {
		width: auto
	}
}

.main-nav-bg {
	position: relative;
	z-index: 0;
}

.main-nav-bg:before {
	height: 100%;
	width: 100%;
	background: url(../img/common/bg-main-02.png) bottom center no-repeat;
	background-size: 100%;
	position: absolute;
	z-index: 1;
	bottom: 0
}

.main-nav {
	position: relative;
	z-index: 10;
	margin-bottom: 4.5%
}

.mnv-list li,
.mnvlb-img {
	position: relative;
	z-index: 1
}

.mnv-list-wrap {
	overflow: hidden
}

.mnv-list {}

.mnv-list li {
	background: #fff;
	display: inline-block;
	letter-spacing: normal;
	width: 32%;
	margin: 0 0 2% 0;
	font-size: 14px;
	border: 1px solid #ddd;
	height: 350px;
	border-radius: 5px;
}

.mnvlb-img,
.mnvlb-img img,
.mnvlb-img-01 {
	margin: 0 auto
}

.mnvlb-img {
	height: 125px;
}

.mnvl-btn-on,
.mnvlb-img img {
	z-index: 2;
	bottom: 0;
	left: 0;
	right: 0;
	position: absolute
}

.mnvlb-img-01 {
	width: 148px
}

.mnvlb-img-02 {
	width: 182px
}

.mnvlb-img-03 {
	width: 106px
}

.mnvlb-img-04 {
	width: 125px
}

.mnvlb-img-05 {
	width: 101px
}

.mnvlb-img-06 {
	width: 115px
}

.mnvlb-txt {
	margin: 20px 0 0;
	color: #222;
	font-size: 16px;
	line-height: 1.4;
	letter-spacing: 0.1em;
}

.mnvl-btn-on {
	font-size: 13px;
	padding: 5%;
	margin: 0%;
	color: #fff;
	background: #cd002c;
	-webkit-transition: all .8s;
	-o-transition: all .8s;
	transition: all .8s;
	filter: alpha(opacity=0);
	opacity: 1;
	border-radius: 0 0 5px 5px;
	height: 200px;
}

.mnv-list li:hover .mnvl-btn-on {
	-webkit-transition: all .8s;
	-o-transition: all .8s;
	transition: all .8s;
	filter: alpha(opacity=100);
	opacity: 1
}

.mnvlbo-txt {
	max-height: 104px;
	overflow: auto
}

.mnvlbo-link {
	bottom: 12px;
	position: absolute;
	z-index: 3;
	width: 90%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	display: block;
}

.mnvlbo-link a {
	color: #fff;
	display: block;
	border: 1px solid #fff;
	width: 100%;
	height: 30px;
	padding: 4px 0 0;
	background: #cd002c;
	letter-spacing: 0.2em;
}

.mnvlbo-link a:hover {
	color: #cd002c;
	background: #fff;
	-webkit-box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .2);
	box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .2);
	opacity: 1;
	letter-spacing: 0.5em;
	border-radius: 5px;
}

.mcs-ttl-wrap {
	padding-top: 4.7%;
	padding-bottom: 3.5%
}

.mcs-wrap {
	display: table;
	width: 100%
}

.mcswctw-ttl-01 {
	color: #fff
}

.mcswctw-ttl-01:before {
	background: #fff
}

.mcswc-txt-wrap {
	color: #fff;
	margin: 6% auto;
	width: 70%;
	text-align: justify
}

.mcsw-cont {
	display: table-cell;
	height: 400px;
	vertical-align: middle
}

.mcsw-cont-txt {
	width: 50%;
	background: #cd002c;
	background-size: cover;
	color: #fff
}

.mcsw-cont-img-01 {
	background: url(../img/service/dm/bg-mcsw-cont-img-01.png) center center no-repeat;
	background-size: cover
}

.mcsw-cont-img-02 {
	background: url(../img/service/dm/bg-mcsw-cont-img-02.png) center center no-repeat;
	background-size: cover
}

.mcsw-cont-img-03 {
	background: url(../img/service/dm/bg-mcsw-cont-img-03.png) center center no-repeat;
	background-size: cover
}

.main-contact-arrow {
	width: 152px;
	margin: 0 auto;
	padding: 3.5% 0 2.5%
}

@media only screen and (max-width:640px) {
	.main-service-ahv {
		margin: 45px 0 0
	}

	.mnv-list {
		width: 102%
	}

	.mnv-list li {
		width: 100%;
		height: 200px;
		padding: 2%;
		margin: 0 2% 2% 0
	}

	.mnvlb-img {
		-ms-transform: scale(1);
		-webkit-transform: scale(1);
		transform: scale(1);
		height: 140px;
		max-width: 150px
	}

	.mnvlb-txt {
		font-size: 14px;
		margin: 5px 0 0;
		display: none;
	}

	.mnvl-btn-on {
		padding: 7%;
		opacity: 0.7;
	}

	.mnvlbo-txt {
		max-height: 84px;
		text-align: justify
	}

	.mcs-wrap {
		display: block;
		table-layout: auto
	}

	.mcsw-cont {
		height: auto;
		min-height: 300px;
		display: block;
		width: auto
	}

	.mcswc-ttl-wrap {
		padding-top: 15%
	}

	.mcswc-txt-wrap {
		width: 80%;
		margin: 0 auto;
		padding: 6% 0 10%
	}

	.main-contact-arrow {
		width: 124px;
		padding: 10% 0
	}
}

.msm-img,
.msp-btn a,
.msp-list,
.mspi-red-box,
.mspi-ttl,
.mspi-txt-sub,
.mss-col3-list li {
	text-align: center
}

.ms-about {
	height: auto;
	background: url(../img/service/dm/ms-about.png) center center no-repeat;
	background-size: cover
}

.ms-about .inner-02 {
	padding: 0 4%
}

@media screen and (min-width:640px) {
	.mnvlbo-link {
		bottom: 12px
	}

	.ms-about {
		background-position: right top;
		height: 611px
	}
}

.msatb-txt {
	margin: 44px 0 0;
	padding: 0 28px;
	font-size: 16px;
	line-height: 2.25
}

.msp-btn a,
.mss-col3-txt {
	line-height: 1;
	color: #fff
}

.msp-list {
	margin: 73px 0 0;
	font-size: 0
}

.msp-list li {
	display: inline-block;
	width: 31.25%;
	margin: 0 0 0 2.5%;
	font-size: 14px
}

.msp-list li:first-child {
	margin-left: 0
}

.msp-img {
	margin: 0 0 51px;
	border: 1px solid #e2e2e2
}

.msp-btn {
	width: 186px;
	margin: 0 auto
}

.msp-btn a {
	display: block;
	padding: 17px 5px 16px;
	background: #cd002c
}

.msp-btn a:before {
	display: inline-block;
	height: 14px;
	width: 9px;
	vertical-align: middle;
	background: url(../img/service/dm/msp-btn.png) no-repeat;
	margin: -2px 12px 0 2px
}

.mss-col3-list {
	display: table;
	table-layout: fixed;
	width: 100%;
	margin: 37px 0 0
}

.mss-col3-list li {
	display: table-cell;
	height: 344px;
	vertical-align: middle
}

.mss-col3-txt {
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr=#80000000, endColorstr=#80000000);
	background: rgba(0, 0, 0, .55);
	padding: 42px 10px;
	font-size: 24px;
	text-shadow: 1px 3px 5px #180101, 1px 3px 6px #180101
}

.mss-col3-bg01 {
	background: url(../img/service/dm/mss-col3-bg01.png) center center no-repeat;
	background-size: cover
}

.mss-col3-bg02 {
	background: url(../img/service/dm/mss-col3-bg02.png) center center no-repeat;
	background-size: cover
}

.mss-col3-bg03 {
	background: url(../img/service/dm/mss-col3-bg03.png) center center no-repeat;
	background-size: cover
}

.mspi-col2-box {
	margin: 30px 0 0;
	padding-top: 90px
}

.mspi-txt-box {
	width: 100%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	padding: 25px 15px 0;
}

.mspi-ttl {
	margin: 0 0 15px;
	padding: 0 0 9px;
	line-height: 1.2;
}

.mspi-ttl::before {
	content: "";
	height: 2px;
	width: 30px;
	background: #cd002c;
	position: absolute;
	margin: auto;
	bottom: 0;
	left: 0;
	right: 0;
}

.mspi-txt {
	max-width: 100%;
	margin: 0 auto;
	font-size: 15px;
	line-height: 1.75;
	min-height: 125px;
}

.mspi-img {
	width: auto;
	margin: 0
}

@media screen and (min-width:640px) {
	.mspi-img {
		width: 50%;
		margin: 3px 0 0
	}
}

.msf-txt-list,
.msftl-box {
	width: auto
}

.mspi-red-box {
	max-width: 100%;
	margin: 10px auto 0;
	padding: 20px 5px;
	background: #cd002c;
	color: #fff;
	font-size: 24px;
	line-height: 1
}

.mspi-txt-sub {
	max-width: 358px;
	margin: 11px auto 0;
	font-size: 16px;
	color: #4b4b4b
}

@media only screen and (max-width:640px) {

	.msp-list li,
	.mss-col3-list {
		display: block
	}

	.msatb-txt {
		margin: 30px 0 0;
		padding: 0 28px;
		font-size: 14px;
		line-height: 2.25
	}

	.msp-list {
		margin: 40px 0 0
	}

	.msp-list li {
		width: auto;
		margin: 0 0 60px
	}

	.msp-img {
		margin: 0 0 30px
	}

	.mspi-col2-box,
	.mss-col3-list {
		margin: 40px 0 0
	}

	.mss-col3-list li {
		display: block;
		padding: 70px 0;
		height: auto
	}

	.mss-col3-txt {
		padding: 42px 10px;
		font-size: 20px
	}

	.mspi-txt-box {
		width: auto;
		padding: 0
	}

	.mspi-ttl {
		margin: 0 0 30px;
		padding: 0 0 9px;
		font-size: 24px
	}

	.mspi-txt {
		max-width: inherit;
		font-size: 14px;
		line-height: 1.75
	}

	.mspi-red-box {
		margin: 30px auto 0;
		padding: 20px 5px;
		font-size: 20px
	}

	.mspi-txt-sub {
		max-width: inherit;
		font-size: 14px
	}
}

.ms-flow,
.ms-lead {
	padding: 40px 4%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.msf-list-box {
	padding: 0
}

.msftl-box {
	display: block;
	margin: 0 0 40px
}

.msftl-ttl {
	margin: 0 0 22px
}

.msftl-ttl-txt {
	padding: 15px 0 0 9px;
	font-size: 20px;
	font-size: 2rem
}

.msct-label {
	width: 70px;
	padding: 0 2px 3px 0
}

.msct-label:after,
.msct-label:before {
	height: 3px;
	width: 2px
}

.msct-label p {
	padding: 10px 0;
	letter-spacing: normal;
	font-size: 10px;
	font-size: 1rem
}

.msct-txt {
	font-size: 14px;
	font-size: 1.4rem
}

.msc-ct-wrap {
	padding: 42px 0 15px
}

.mssb-list li {
	font-size: 14px;
	font-size: 1.4rem
}

.mssb-txt {
	margin: 9px 0 0
}

.msm-label {
	margin: 0 0 13px 2px;
	font-size: 12px;
	font-size: 1.2rem
}

.msm-ttl {
	margin: 0 0 14px;
	font-size: 20px;
	font-size: 2rem
}

.msm-txt {
	line-height: 1.75
}

.msm-img {
	float: none;
	width: auto;
	margin: 20px 0 0
}

@media screen and (min-width:640px) {

	.msftl-box,
	.msftl-ttl-txt {
		display: inline-block;
		vertical-align: top
	}

	.ms-lead,
	.msc-ctb-img,
	.msc-ctb-ttl,
	.msct-label,
	.msf-img {
		text-align: center
	}

	.ms-lead {
		padding-top: 48px;
		padding-bottom: 35px
	}

	.msl-txt {
		line-height: 2.15
	}

	.ms-flow {
		padding-top: 47px;
		padding-bottom: 100px;
	}

	.msf-img {
		margin: 38px 0 94px
	}

	.msf-list-box {
		overflow: hidden;
		padding: 0 0 0 2.08333%
	}

	.msf-txt-list {
		width: 105.74468%;
		font-size: 0
	}

	.msftl-box {
		width: 43.56137%;
		margin: 0 5.4326% 6.94165% 0;
		font-size: 14px;
		font-size: 1.4rem
	}

	.msftl-ttl {
		margin: 0 0 22px
	}

	.msftl-ttl-txt {
		padding: 12px 0 0 16px;
		color: #e42c11;
		font-weight: 700;
		font-size: 24px;
		font-size: 2.4rem;
		line-height: 1
	}

	.msftl-ttl-txt01 {
		color: #f17012
	}

	.msftl-ttl-txt02 {
		color: #e44611
	}

	.msftl-txt {
		line-height: 1.5;
		letter-spacing: .01em
	}

	.js-toggle-contents {
		display: none
	}

	.msct-label {
		position: absolute;
		top: 0;
		left: 0;
		z-index: 1;
		width: 100px;
		padding: 0 4px 5px 0;
		background: #d2d2d2;
		font-weight: 700;
		line-height: 1;
		color: #fff
	}

	.msct-label:after,
	.msct-label:before {
		content: "";
		position: absolute;
		display: block;
		z-index: 1;
		height: 5px;
		width: 4px;
		background: #fff
	}

	.msct-label:before {
		top: 0;
		right: 0
	}

	.msct-label:after {
		bottom: 0;
		left: 0
	}

	.msc-ctb-li:before,
	.mssb-list li:before {
		content: "・"
	}

	.msct-label p {
		position: relative;
		z-index: 9;
		background: #cd002c;
		padding: 14px 5px 12px;
		letter-spacing: .09em
	}

	.msct-txt {
		font-size: 20px;
		font-size: 2rem
	}

	.msc-ct-wrap {
		padding: 0;
	}

	.msc-ctb-ttl {
		padding: 0 0 10px;
		border-bottom: 1px solid #d9d9d9;
		font-size: 18px;
		font-size: 1.8rem;
		line-height: 1.5;
		font-weight: 700
	}

	.msc-ctb-li,
	.mssb-list li {
		padding-left: 1em;
		text-indent: -1em
	}

	.msc-ctb-img {
		margin: 0 0 29px
	}

	.msc-ctb-li {
		font-size: 16px;
		font-size: 1.6rem;
		line-height: 1.85
	}

	.msc-ctb-li.small {
		font-size: 14px;
		font-size: 1.4rem
	}

	.msc-ctb-txt01 {
		font-size: 12px;
		line-height: 1.7
	}

	.mssb-list li {
		font-size: 16px;
		font-size: 1.6rem;
		line-height: 1.75;
		color: #333
	}

	.msm-label {
		margin: 1px 0 13px 2px;
		font-weight: 700;
		color: #bababa;
		line-height: 1
	}

	.msm-ttl {
		margin: 0 0 14px;
		font-size: 24px;
		font-size: 2.4rem;
		line-height: 1.3
	}

	.msm-txt {
		line-height: 1.75
	}

	.msm-img {
		float: left;
		width: 46.875%
	}
}

/*!
* animsition v4.0.2
* A simple and easy jQuery plugin for CSS animated page transitions.
* http://blivesta.github.io/animsition
* License : MIT
* Author : blivesta (http://blivesta.com/)
*/

.animsition,
.animsition-overlay {
	position: relative;
	opacity: 0;
	-webkit-animation-fill-mode: both;
	animation-fill-mode: both
}

.animsition-overlay-slide {
	position: fixed;
	z-index: 905;
	width: 100%;
	height: 100%;
	background-color: #fff
}

.animsition-loading,
.animsition-loading:after {
	width: 32px;
	height: 32px;
	position: fixed;
	top: 50%;
	left: 50%;
	margin-top: -16px;
	margin-left: -16px;
	border-radius: 50%;
	z-index: 999
}

.animsition-loading {
	background-color: transparent;
	border-top: 5px solid rgba(0, 0, 0, .2);
	border-right: 5px solid rgba(0, 0, 0, .2);
	border-bottom: 5px solid rgba(0, 0, 0, .2);
	border-left: 5px solid #eee;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-timing-function: linear;
	animation-timing-function: linear;
	-webkit-animation-duration: .8s;
	animation-duration: .8s;
	-webkit-animation-name: animsition-loading;
	animation-name: animsition-loading
}

@-webkit-keyframes animsition-loading {
	0% {
		-webkit-transform: rotate(0);
		transform: rotate(0)
	}

	to {
		-webkit-transform: rotate(1turn);
		transform: rotate(1turn)
	}
}

@keyframes animsition-loading {
	0% {
		-webkit-transform: rotate(0);
		transform: rotate(0)
	}

	to {
		-webkit-transform: rotate(1turn);
		transform: rotate(1turn)
	}
}

@-webkit-keyframes fade-in {
	0% {
		opacity: 0
	}

	to {
		opacity: 1
	}
}

@keyframes fade-in {
	0% {
		opacity: 0
	}

	to {
		opacity: 1
	}
}

.fade-in {
	-webkit-animation-name: fade-in;
	animation-name: fade-in
}

@-webkit-keyframes fade-out {
	0% {
		opacity: 1
	}

	to {
		opacity: 0
	}
}

@keyframes fade-out {
	0% {
		opacity: 1
	}

	to {
		opacity: 0
	}
}

.fade-out {
	-webkit-animation-name: fade-out;
	animation-name: fade-out
}

@-webkit-keyframes fade-in-up {
	0% {
		-webkit-transform: translateY(500px);
		transform: translateY(500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}
}

@keyframes fade-in-up {
	0% {
		-webkit-transform: translateY(500px);
		transform: translateY(500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}
}

.fade-in-up {
	-webkit-animation-name: fade-in-up;
	animation-name: fade-in-up
}

@-webkit-keyframes fade-out-up {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(-500px);
		transform: translateY(-500px);
		opacity: 0
	}
}

@keyframes fade-out-up {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(-500px);
		transform: translateY(-500px);
		opacity: 0
	}
}

.fade-out-up {
	-webkit-animation-name: fade-out-up;
	animation-name: fade-out-up
}

@-webkit-keyframes fade-in-up-sm {
	0% {
		-webkit-transform: translateY(100px);
		transform: translateY(100px);
		opacity: 0
	}

	to {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}
}

@keyframes fade-in-up-sm {
	0% {
		-webkit-transform: translateY(100px);
		transform: translateY(100px);
		opacity: 0
	}

	to {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}
}

.fade-in-up-sm {
	-webkit-animation-name: fade-in-up-sm;
	animation-name: fade-in-up-sm
}

@-webkit-keyframes fade-out-up-sm {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(-100px);
		transform: translateY(-100px);
		opacity: 0
	}
}

@keyframes fade-out-up-sm {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(-100px);
		transform: translateY(-100px);
		opacity: 0
	}
}

.fade-out-up-sm {
	-webkit-animation-name: fade-out-up-sm;
	animation-name: fade-out-up-sm
}

@-webkit-keyframes fade-in-up-lg {
	0% {
		-webkit-transform: translateY(1000px);
		transform: translateY(1000px);
		opacity: 0
	}

	to {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}
}

@keyframes fade-in-up-lg {
	0% {
		-webkit-transform: translateY(1000px);
		transform: translateY(1000px);
		opacity: 0
	}

	to {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}
}

.fade-in-up-lg {
	-webkit-animation-name: fade-in-up-lg;
	animation-name: fade-in-up-lg
}

@-webkit-keyframes fade-out-up-lg {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(-1000px);
		transform: translateY(-1000px);
		opacity: 0
	}
}

@keyframes fade-out-up-lg {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(-1000px);
		transform: translateY(-1000px);
		opacity: 0
	}
}

.fade-out-up-lg {
	-webkit-animation-name: fade-out-up-lg;
	animation-name: fade-out-up-lg
}

@-webkit-keyframes fade-in-down {
	0% {
		-webkit-transform: translateY(-500px);
		transform: translateY(-500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}
}

@keyframes fade-in-down {
	0% {
		-webkit-transform: translateY(-500px);
		transform: translateY(-500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}
}

.fade-in-down {
	-webkit-animation-name: fade-in-down;
	animation-name: fade-in-down
}

@-webkit-keyframes fade-out-down {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(500px);
		transform: translateY(500px);
		opacity: 0
	}
}

@keyframes fade-out-down {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(500px);
		transform: translateY(500px);
		opacity: 0
	}
}

.fade-out-down {
	-webkit-animation-name: fade-out-down;
	animation-name: fade-out-down
}

@-webkit-keyframes fade-in-down-sm {
	0% {
		-webkit-transform: translateY(-100px);
		transform: translateY(-100px);
		opacity: 0
	}

	to {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}
}

@keyframes fade-in-down-sm {
	0% {
		-webkit-transform: translateY(-100px);
		transform: translateY(-100px);
		opacity: 0
	}

	to {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}
}

.fade-in-down-sm {
	-webkit-animation-name: fade-in-down-sm;
	animation-name: fade-in-down-sm
}

@-webkit-keyframes fade-out-down-sm {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(100px);
		transform: translateY(100px);
		opacity: 0
	}
}

@keyframes fade-out-down-sm {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(100px);
		transform: translateY(100px);
		opacity: 0
	}
}

.fade-out-down-sm {
	-webkit-animation-name: fade-out-down-sm;
	animation-name: fade-out-down-sm
}

.fade-in-down-lg {
	-webkit-animation-name: fade-in-down;
	animation-name: fade-in-down
}

@-webkit-keyframes fade-out-down-lg {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(1000px);
		transform: translateY(1000px);
		opacity: 0
	}
}

@keyframes fade-out-down-lg {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateY(1000px);
		transform: translateY(1000px);
		opacity: 0
	}
}

.fade-out-down-lg {
	-webkit-animation-name: fade-out-down-lg;
	animation-name: fade-out-down-lg
}

@-webkit-keyframes fade-in-left {
	0% {
		-webkit-transform: translateX(-500px);
		transform: translateX(-500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

@keyframes fade-in-left {
	0% {
		-webkit-transform: translateX(-500px);
		transform: translateX(-500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

.fade-in-left {
	-webkit-animation-name: fade-in-left;
	animation-name: fade-in-left
}

@-webkit-keyframes fade-out-left {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(-500px);
		transform: translateX(-500px);
		opacity: 0
	}
}

@keyframes fade-out-left {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(-500px);
		transform: translateX(-500px);
		opacity: 0
	}
}

.fade-out-left {
	-webkit-animation-name: fade-out-left;
	animation-name: fade-out-left
}

@-webkit-keyframes fade-in-left-sm {
	0% {
		-webkit-transform: translateX(-100px);
		transform: translateX(-100px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

@keyframes fade-in-left-sm {
	0% {
		-webkit-transform: translateX(-100px);
		transform: translateX(-100px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

.fade-in-left-sm {
	-webkit-animation-name: fade-in-left-sm;
	animation-name: fade-in-left-sm
}

@-webkit-keyframes fade-out-left-sm {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(-100px);
		transform: translateX(-100px);
		opacity: 0
	}
}

@keyframes fade-out-left-sm {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(-100px);
		transform: translateX(-100px);
		opacity: 0
	}
}

.fade-out-left-sm {
	-webkit-animation-name: fade-out-left-sm;
	animation-name: fade-out-left-sm
}

@-webkit-keyframes fade-in-left-lg {
	0% {
		-webkit-transform: translateX(-1500px);
		transform: translateX(-1500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

@keyframes fade-in-left-lg {
	0% {
		-webkit-transform: translateX(-1500px);
		transform: translateX(-1500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

.fade-in-left-lg {
	-webkit-animation-name: fade-in-left-lg;
	animation-name: fade-in-left-lg
}

@-webkit-keyframes fade-out-left-lg {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(-1500px);
		transform: translateX(-1500px);
		opacity: 0
	}
}

@keyframes fade-out-left-lg {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(-1500px);
		transform: translateX(-1500px);
		opacity: 0
	}
}

.fade-out-left-lg {
	-webkit-animation-name: fade-out-left-lg;
	animation-name: fade-out-left-lg
}

@-webkit-keyframes fade-in-right {
	0% {
		-webkit-transform: translateX(500px);
		transform: translateX(500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

@keyframes fade-in-right {
	0% {
		-webkit-transform: translateX(500px);
		transform: translateX(500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

.fade-in-right {
	-webkit-animation-name: fade-in-right;
	animation-name: fade-in-right
}

@-webkit-keyframes fade-out-right {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(500px);
		transform: translateX(500px);
		opacity: 0
	}
}

@keyframes fade-out-right {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(500px);
		transform: translateX(500px);
		opacity: 0
	}
}

.fade-out-right {
	-webkit-animation-name: fade-out-right;
	animation-name: fade-out-right
}

@-webkit-keyframes fade-in-right-sm {
	0% {
		-webkit-transform: translateX(100px);
		transform: translateX(100px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

@keyframes fade-in-right-sm {
	0% {
		-webkit-transform: translateX(100px);
		transform: translateX(100px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

.fade-in-right-sm {
	-webkit-animation-name: fade-in-right-sm;
	animation-name: fade-in-right-sm
}

@-webkit-keyframes fade-out-right-sm {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(100px);
		transform: translateX(100px);
		opacity: 0
	}
}

@keyframes fade-out-right-sm {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(100px);
		transform: translateX(100px);
		opacity: 0
	}
}

.fade-out-right-sm {
	-webkit-animation-name: fade-out-right-sm;
	animation-name: fade-out-right-sm
}

@-webkit-keyframes fade-in-right-lg {
	0% {
		-webkit-transform: translateX(1500px);
		transform: translateX(1500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

@keyframes fade-in-right-lg {
	0% {
		-webkit-transform: translateX(1500px);
		transform: translateX(1500px);
		opacity: 0
	}

	to {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}
}

.fade-in-right-lg {
	-webkit-animation-name: fade-in-right-lg;
	animation-name: fade-in-right-lg
}

@-webkit-keyframes fade-out-right-lg {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(1500px);
		transform: translateX(1500px);
		opacity: 0
	}
}

@keyframes fade-out-right-lg {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: translateX(1500px);
		transform: translateX(1500px);
		opacity: 0
	}
}

.fade-out-right-lg {
	-webkit-animation-name: fade-out-right-lg;
	animation-name: fade-out-right-lg
}

@-webkit-keyframes rotate-in {
	0% {
		-webkit-transform: rotate(-90deg);
		transform: rotate(-90deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}
}

@keyframes rotate-in {
	0% {
		-webkit-transform: rotate(-90deg);
		transform: rotate(-90deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}
}

.rotate-in {
	-webkit-animation-name: rotate-in;
	animation-name: rotate-in
}

@-webkit-keyframes rotate-out {
	0% {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(90deg);
		transform: rotate(90deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}
}

@keyframes rotate-out {
	0% {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(90deg);
		transform: rotate(90deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}
}

.rotate-out {
	-webkit-animation-name: rotate-out;
	animation-name: rotate-out
}

@-webkit-keyframes rotate-in-sm {
	0% {
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}
}

@keyframes rotate-in-sm {
	0% {
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}
}

.rotate-in-sm {
	-webkit-animation-name: rotate-in-sm;
	animation-name: rotate-in-sm
}

@-webkit-keyframes rotate-out-sm {
	0% {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}
}

@keyframes rotate-out-sm {
	0% {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}
}

.rotate-out-sm {
	-webkit-animation-name: rotate-out-sm;
	animation-name: rotate-out-sm
}

@-webkit-keyframes rotate-in-lg {
	0% {
		-webkit-transform: rotate(-180deg);
		transform: rotate(-180deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}
}

@keyframes rotate-in-lg {
	0% {
		-webkit-transform: rotate(-180deg);
		transform: rotate(-180deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}
}

.rotate-in-lg {
	-webkit-animation-name: rotate-in-lg;
	animation-name: rotate-in-lg
}

@-webkit-keyframes rotate-out-lg {
	0% {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(180deg);
		transform: rotate(180deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}
}

@keyframes rotate-out-lg {
	0% {
		-webkit-transform: rotate(0);
		transform: rotate(0);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 1
	}

	0%,
	to {
		-webkit-transform-origin: center center
	}

	to {
		-webkit-transform: rotate(180deg);
		transform: rotate(180deg);
		-webkit-transform-origin: center center;
		transform-origin: center center;
		opacity: 0
	}
}

.rotate-out-lg {
	-webkit-animation-name: rotate-out-lg;
	animation-name: rotate-out-lg
}

@-webkit-keyframes flip-in-x {
	0% {
		-webkit-transform: perspective(550px) rotateX(90deg);
		transform: perspective(550px) rotateX(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(550px) rotateX(0);
		transform: perspective(550px) rotateX(0);
		opacity: 1
	}
}

@keyframes flip-in-x {
	0% {
		-webkit-transform: perspective(550px) rotateX(90deg);
		transform: perspective(550px) rotateX(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(550px) rotateX(0);
		transform: perspective(550px) rotateX(0);
		opacity: 1
	}
}

.flip-in-x {
	-webkit-animation-name: flip-in-x;
	animation-name: flip-in-x
}

@-webkit-keyframes flip-out-x {
	0% {
		-webkit-transform: perspective(550px) rotateX(0);
		transform: perspective(550px) rotateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(550px) rotateX(90deg);
		transform: perspective(550px) rotateX(90deg);
		opacity: 0
	}
}

@keyframes flip-out-x {
	0% {
		-webkit-transform: perspective(550px) rotateX(0);
		transform: perspective(550px) rotateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(550px) rotateX(90deg);
		transform: perspective(550px) rotateX(90deg);
		opacity: 0
	}
}

.flip-out-x {
	-webkit-animation-name: flip-out-x;
	animation-name: flip-out-x
}

@-webkit-keyframes flip-in-x-nr {
	0% {
		-webkit-transform: perspective(100px) rotateX(90deg);
		transform: perspective(100px) rotateX(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(100px) rotateX(0);
		transform: perspective(100px) rotateX(0);
		opacity: 1
	}
}

@keyframes flip-in-x-nr {
	0% {
		-webkit-transform: perspective(100px) rotateX(90deg);
		transform: perspective(100px) rotateX(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(100px) rotateX(0);
		transform: perspective(100px) rotateX(0);
		opacity: 1
	}
}

.flip-in-x-nr {
	-webkit-animation-name: flip-in-x-nr;
	animation-name: flip-in-x-nr
}

.flip-in-x-fr,
.flip-out-x-nr {
	-webkit-backface-visibility: visible !important;
	backface-visibility: visible !important
}

@-webkit-keyframes flip-out-x-nr {
	0% {
		-webkit-transform: perspective(100px) rotateX(0);
		transform: perspective(100px) rotateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(100px) rotateX(90deg);
		transform: perspective(100px) rotateX(90deg);
		opacity: 0
	}
}

@keyframes flip-out-x-nr {
	0% {
		-webkit-transform: perspective(100px) rotateX(0);
		transform: perspective(100px) rotateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(100px) rotateX(90deg);
		transform: perspective(100px) rotateX(90deg);
		opacity: 0
	}
}

.flip-out-x-nr {
	-webkit-animation-name: flip-out-x-nr;
	animation-name: flip-out-x-nr
}

@-webkit-keyframes flip-in-x-fr {
	0% {
		-webkit-transform: perspective(1000px) rotateX(90deg);
		transform: perspective(1000px) rotateX(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(1000px) rotateX(0);
		transform: perspective(1000px) rotateX(0);
		opacity: 1
	}
}

@keyframes flip-in-x-fr {
	0% {
		-webkit-transform: perspective(1000px) rotateX(90deg);
		transform: perspective(1000px) rotateX(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(1000px) rotateX(0);
		transform: perspective(1000px) rotateX(0);
		opacity: 1
	}
}

.flip-in-x-fr {
	-webkit-animation-name: flip-in-x-fr;
	animation-name: flip-in-x-fr
}

.flip-in-y,
.flip-out-x-fr {
	-webkit-backface-visibility: visible !important;
	backface-visibility: visible !important
}

@-webkit-keyframes flip-out-x-fr {
	0% {
		-webkit-transform: perspective(1000px) rotateX(0);
		transform: perspective(1000px) rotateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(1000px) rotateX(90deg);
		transform: perspective(1000px) rotateX(90deg);
		opacity: 0
	}
}

@keyframes flip-out-x-fr {
	0% {
		-webkit-transform: perspective(1000px) rotateX(0);
		transform: perspective(1000px) rotateX(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(1000px) rotateX(90deg);
		transform: perspective(1000px) rotateX(90deg);
		opacity: 0
	}
}

.flip-out-x-fr {
	-webkit-animation-name: flip-out-x-fr;
	animation-name: flip-out-x-fr
}

@-webkit-keyframes flip-in-y {
	0% {
		-webkit-transform: perspective(550px) rotateY(90deg);
		transform: perspective(550px) rotateY(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(550px) rotateY(0);
		transform: perspective(550px) rotateY(0);
		opacity: 1
	}
}

@keyframes flip-in-y {
	0% {
		-webkit-transform: perspective(550px) rotateY(90deg);
		transform: perspective(550px) rotateY(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(550px) rotateY(0);
		transform: perspective(550px) rotateY(0);
		opacity: 1
	}
}

.flip-in-y {
	-webkit-animation-name: flip-in-y;
	animation-name: flip-in-y
}

.flip-in-y-nr,
.flip-out-y {
	-webkit-backface-visibility: visible !important;
	backface-visibility: visible !important
}

@-webkit-keyframes flip-out-y {
	0% {
		-webkit-transform: perspective(550px) rotateY(0);
		transform: perspective(550px) rotateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(550px) rotateY(90deg);
		transform: perspective(550px) rotateY(90deg);
		opacity: 0
	}
}

@keyframes flip-out-y {
	0% {
		-webkit-transform: perspective(550px) rotateY(0);
		transform: perspective(550px) rotateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(550px) rotateY(90deg);
		transform: perspective(550px) rotateY(90deg);
		opacity: 0
	}
}

.flip-out-y {
	-webkit-animation-name: flip-out-y;
	animation-name: flip-out-y
}

@-webkit-keyframes flip-in-y-nr {
	0% {
		-webkit-transform: perspective(100px) rotateY(90deg);
		transform: perspective(100px) rotateY(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(100px) rotateY(0);
		transform: perspective(100px) rotateY(0);
		opacity: 1
	}
}

@keyframes flip-in-y-nr {
	0% {
		-webkit-transform: perspective(100px) rotateY(90deg);
		transform: perspective(100px) rotateY(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(100px) rotateY(0);
		transform: perspective(100px) rotateY(0);
		opacity: 1
	}
}

.flip-in-y-nr {
	-webkit-animation-name: flip-in-y-nr;
	animation-name: flip-in-y-nr
}

.flip-in-y-fr,
.flip-out-y-nr {
	-webkit-backface-visibility: visible !important;
	backface-visibility: visible !important
}

@-webkit-keyframes flip-out-y-nr {
	0% {
		-webkit-transform: perspective(100px) rotateY(0);
		transform: perspective(100px) rotateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(100px) rotateY(90deg);
		transform: perspective(100px) rotateY(90deg);
		opacity: 0
	}
}

@keyframes flip-out-y-nr {
	0% {
		-webkit-transform: perspective(100px) rotateY(0);
		transform: perspective(100px) rotateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(100px) rotateY(90deg);
		transform: perspective(100px) rotateY(90deg);
		opacity: 0
	}
}

.flip-out-y-nr {
	-webkit-animation-name: flip-out-y-nr;
	animation-name: flip-out-y-nr
}

@-webkit-keyframes flip-in-y-fr {
	0% {
		-webkit-transform: perspective(1000px) rotateY(90deg);
		transform: perspective(1000px) rotateY(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(1000px) rotateY(0);
		transform: perspective(1000px) rotateY(0);
		opacity: 1
	}
}

@keyframes flip-in-y-fr {
	0% {
		-webkit-transform: perspective(1000px) rotateY(90deg);
		transform: perspective(1000px) rotateY(90deg);
		opacity: 0
	}

	to {
		-webkit-transform: perspective(1000px) rotateY(0);
		transform: perspective(1000px) rotateY(0);
		opacity: 1
	}
}

.flip-in-y-fr {
	-webkit-animation-name: flip-in-y-fr;
	animation-name: flip-in-y-fr
}

@-webkit-keyframes flip-out-y-fr {
	0% {
		-webkit-transform: perspective(1000px) rotateY(0);
		transform: perspective(1000px) rotateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(1000px) rotateY(90deg);
		transform: perspective(1000px) rotateY(90deg);
		opacity: 0
	}
}

@keyframes flip-out-y-fr {
	0% {
		-webkit-transform: perspective(1000px) rotateY(0);
		transform: perspective(1000px) rotateY(0);
		opacity: 1
	}

	to {
		-webkit-transform: perspective(1000px) rotateY(90deg);
		transform: perspective(1000px) rotateY(90deg);
		opacity: 0
	}
}

.flip-out-y-fr {
	-webkit-animation-name: flip-out-y-fr;
	animation-name: flip-out-y-fr;
	-webkit-backface-visibility: visible !important;
	backface-visibility: visible !important
}

@-webkit-keyframes zoom-in {
	0% {
		-webkit-transform: scale(.7);
		transform: scale(.7);
		opacity: 0
	}

	to {
		opacity: 1
	}
}

@keyframes zoom-in {
	0% {
		-webkit-transform: scale(.7);
		transform: scale(.7);
		opacity: 0
	}

	to {
		opacity: 1
	}
}

.zoom-in {
	-webkit-animation-name: zoom-in;
	animation-name: zoom-in
}

@-webkit-keyframes zoom-out {
	0% {
		-webkit-transform: scale(1);
		transform: scale(1);
		opacity: 1
	}

	50% {
		-webkit-transform: scale(.7);
		transform: scale(.7)
	}

	50%,
	to {
		opacity: 0
	}
}

@keyframes zoom-out {
	0% {
		-webkit-transform: scale(1);
		transform: scale(1);
		opacity: 1
	}

	50% {
		-webkit-transform: scale(.7);
		transform: scale(.7)
	}

	50%,
	to {
		opacity: 0
	}
}

.zoom-out {
	-webkit-animation-name: zoom-out;
	animation-name: zoom-out
}

@-webkit-keyframes zoom-in-sm {
	0% {
		-webkit-transform: scale(.95);
		transform: scale(.95);
		opacity: 0
	}

	to {
		opacity: 1
	}
}

@keyframes zoom-in-sm {
	0% {
		-webkit-transform: scale(.95);
		transform: scale(.95);
		opacity: 0
	}

	to {
		opacity: 1
	}
}

.zoom-in-sm {
	-webkit-animation-name: zoom-in-sm;
	animation-name: zoom-in-sm
}

@-webkit-keyframes zoom-out-sm {
	0% {
		-webkit-transform: scale(1);
		transform: scale(1);
		opacity: 1
	}

	50% {
		-webkit-transform: scale(.95);
		transform: scale(.95)
	}

	50%,
	to {
		opacity: 0
	}
}

@keyframes zoom-out-sm {
	0% {
		-webkit-transform: scale(1);
		transform: scale(1);
		opacity: 1
	}

	50% {
		-webkit-transform: scale(.95);
		transform: scale(.95)
	}

	50%,
	to {
		opacity: 0
	}
}

.zoom-out-sm {
	-webkit-animation-name: zoom-out-sm;
	animation-name: zoom-out-sm
}

@-webkit-keyframes zoom-in-lg {
	0% {
		-webkit-transform: scale(.4);
		transform: scale(.4);
		opacity: 0
	}

	to {
		opacity: 1
	}
}

@keyframes zoom-in-lg {
	0% {
		-webkit-transform: scale(.4);
		transform: scale(.4);
		opacity: 0
	}

	to {
		opacity: 1
	}
}

.zoom-in-lg {
	-webkit-animation-name: zoom-in-lg;
	animation-name: zoom-in-lg
}

@-webkit-keyframes zoom-out-lg {
	0% {
		-webkit-transform: scale(1);
		transform: scale(1);
		opacity: 1
	}

	50% {
		-webkit-transform: scale(.4);
		transform: scale(.4)
	}

	50%,
	to {
		opacity: 0
	}
}

@keyframes zoom-out-lg {
	0% {
		-webkit-transform: scale(1);
		transform: scale(1);
		opacity: 1
	}

	50% {
		-webkit-transform: scale(.4);
		transform: scale(.4)
	}

	50%,
	to {
		opacity: 0
	}
}

.zoom-out-lg {
	-webkit-animation-name: zoom-out-lg;
	animation-name: zoom-out-lg
}

@-webkit-keyframes overlay-slide-in-top {
	0% {
		height: 100%
	}

	to {
		height: 0
	}
}

@keyframes overlay-slide-in-top {
	0% {
		height: 100%
	}

	to {
		height: 0
	}
}

.overlay-slide-in-top {
	top: 0;
	height: 0;
	-webkit-animation-name: overlay-slide-in-top;
	animation-name: overlay-slide-in-top
}

@-webkit-keyframes overlay-slide-out-top {
	0% {
		height: 0
	}

	to {
		height: 100%
	}
}

@keyframes overlay-slide-out-top {
	0% {
		height: 0
	}

	to {
		height: 100%
	}
}

.overlay-slide-out-top {
	top: 0;
	height: 100%;
	-webkit-animation-name: overlay-slide-out-top;
	animation-name: overlay-slide-out-top
}

@-webkit-keyframes overlay-slide-in-bottom {
	0% {
		height: 100%
	}

	to {
		height: 0
	}
}

@keyframes overlay-slide-in-bottom {
	0% {
		height: 100%
	}

	to {
		height: 0
	}
}

.overlay-slide-in-bottom {
	bottom: 0;
	height: 0;
	-webkit-animation-name: overlay-slide-in-bottom;
	animation-name: overlay-slide-in-bottom
}

@-webkit-keyframes overlay-slide-out-bottom {
	0% {
		height: 0
	}

	to {
		height: 100%
	}
}

@keyframes overlay-slide-out-bottom {
	0% {
		height: 0
	}

	to {
		height: 100%
	}
}

.overlay-slide-out-bottom {
	bottom: 0;
	height: 100%;
	-webkit-animation-name: overlay-slide-out-bottom;
	animation-name: overlay-slide-out-bottom
}

@-webkit-keyframes overlay-slide-in-left {
	0% {
		width: 100%
	}

	to {
		width: 0
	}
}

@keyframes overlay-slide-in-left {
	0% {
		width: 100%
	}

	to {
		width: 0
	}
}

.overlay-slide-in-left {
	width: 0;
	-webkit-animation-name: overlay-slide-in-left;
	animation-name: overlay-slide-in-left
}

@-webkit-keyframes overlay-slide-out-left {
	0% {
		width: 0
	}

	to {
		width: 100%
	}
}

@keyframes overlay-slide-out-left {
	0% {
		width: 0
	}

	to {
		width: 100%
	}
}

.overlay-slide-out-left {
	left: 0;
	width: 100%;
	-webkit-animation-name: overlay-slide-out-left;
	animation-name: overlay-slide-out-left
}

@-webkit-keyframes overlay-slide-in-right {
	0% {
		width: 100%
	}

	to {
		width: 0
	}
}

@keyframes overlay-slide-in-right {
	0% {
		width: 100%
	}

	to {
		width: 0
	}
}

.overlay-slide-in-right {
	right: 0;
	width: 0;
	-webkit-animation-name: overlay-slide-in-right;
	animation-name: overlay-slide-in-right
}

@-webkit-keyframes overlay-slide-out-right {
	0% {
		width: 0
	}

	to {
		width: 100%
	}
}

@keyframes overlay-slide-out-right {
	0% {
		width: 0
	}

	to {
		width: 100%
	}
}

.overlay-slide-out-right {
	right: 0;
	width: 100%;
	-webkit-animation-name: overlay-slide-out-right;
	animation-name: overlay-slide-out-right
}

@media screen and (min-width:640px) {
	.container {
		width: 98%;
		margin: auto;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}
}

@media screen and (min-width:860px) {
	.container {
		width: 98%;
		margin: auto;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}
}

@media screen and (min-width:1200px) {
	.container {
		width: 1200px;
		margin: auto;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}
}

.content_inner {
	width: 100%;
}



/*----------------------------------------
追加CSS
------------------------------------------*/
#loader-bg {
	display: none;
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background: #ce002c;
	z-index: 999999;
}

#loader {
	display: none;
	position: fixed;
	top: 40vh;
	width: 100%;
	height: auto;
	text-align: center;
	color: #fff;
	z-index: 1000000;
}

.ml4 {
	position: relative;
	font-weight: 900;
	font-size: 5.5em;
}

.ml4 .letters {
	position: absolute;
	margin: auto;
	left: 0;
	top: 0.3em;
	right: 0;
	opacity: 0;
}

i.fas.fa-angle-down {
	padding-left: 10px;
}

.large_txt {
	font-size: 1.4em;
	letter-spacing: 3px;
}

@media (max-width: 767px) {
	.large_txt {
		font-size: 1.1em;
		line-height: 1.2em;
		letter-spacing: -1px;
	}

}

span.corp_color {
	color: #ce002c;
}

.breadcrumb100w {
	background: #333;
	width: 50%;
	margin-top: -27px;
	position: relative;
	z-index: 10;
}

ruby > rt {
	display: block;
	font-size: 25%;
	text-align: start;
}

@media (max-width: 1100px) {
	.breadcrumb100w {
		width: 70%;
	}
}

i.cpicon-home_icon.c_red {
	padding-right: 6px;
}

i.fas.fa-angle-right {
	padding: 0 10px;
	vertical-align: text-bottom;
	color: #ddd;
}

.flex {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.flex3 {
	width: 31%;
}

.flex4 {
	width: 24%;
}

.flex5 {
	width: 19%;
}

.mtb_7p {
	margin-top: 7%;
	margin-bottom: 7%;
}

.ptb_7p {
	padding-top: 7%;
	padding-bottom: 7%;
}

.anchor {
	display: block;
	padding-top: 100px;
	margin-top: -100px;
}

.bg_main_white {
	background: #fff;
	margin-bottom: -27px;
	padding-bottom: 27px;
}

canvas.particles-js-canvas-el {
	margin-top: -214px;
	background: rgb(0, 0, 0, 0.2);
}

span.y_border {
	font-weight: bold;
	background: -o-linear-gradient(transparent 60%, #ffff66 60%);
	background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, #ffff66));
	background: linear-gradient(transparent 60%, #ffff66 60%);
}

@media (max-width: 767px) {
	.container {
		padding: 0 5%;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}

	.breadcrumb100w {
		width: 100%;
	}

	.bread_wrap {
		width: 100%;
		margin: 0;
	}

	.rec_button {
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	.rec_button > div {
		width: 100%;
	}

	.rec_button > div a {
		text-align: center;
		margin-bottom: 6px;
	}


}

/*----------------------------------------
NAVI
------------------------------------------*/
@media screen and (min-width: 860px) {
	nav.m-gnav {
		margin-left: auto;
		margin-right: 0;
	}

	.m-gnav_content {
		background: #fff;
		display: none;
	}
}

@media screen and (max-width: 860px) {
	.m-gnav_content {
		padding: 0;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
		margin-top: 0;
		width: 100%;
		border-radius: 0;
		z-index: 2;
		background: none;
		display: none;
	}

	.sp_under_navi {
		padding: 0;
	}

	.sp_under_navi li {}

	.sp_under_navi li a {
		padding: 3% 15px;
		border-bottom: 1px solid #ddd;
		background: #fff;
	}

	header.l-header_sp.cb.sp > nav > ul > li:nth-child(1) > div > ul > span {
		background: #fff;
		padding: 3% 15px;
	}

	header.l-header_sp.cb.sp > nav > ul > li:nth-child(1) > div > ul > div > ul > li > a {
		background: #f1f1f1;
		padding: 3% 25px;
	}
}

.m-gnav_content a {
	-webkit-transition: all .3s;
	-o-transition: all .3s;
	transition: all .3s;
}

.m-gnav_content a:hover {
	color: #cd002c;
}

.main_menu {
	text-align: center;
	font-size: 30px;
	letter-spacing: 0.1em;
}

.main_menu a {
	display: block;
	margin: 10px 0 25px;
	font-weight: bold;
}

.main_menu a span {
	font-size: 50%;
	display: block;
	font-weight: normal;
}

.gnav_cont_list a {
	padding: 15px;
}

.gnav_cont_list a:hover {
	background: #cd002c;
	color: #fff;
	opacity: 1;
}

.gnav_cont_list a:hover i.fas.fa-angle-right,
.gnav_cont_list a:hover i.fas.fa-external-link-square-alt {
	color: #fff;
	opacity: 1;
}

.gnav_cont_list i.fas.fa-angle-right,
.gnav_cont_list i.fas.fa-external-link-square-alt,
.gnav_cont_list_item i.fas.fa-angle-right,
.gnav_cont_list_item i.fas.fa-external-link-square-alt {
	padding: 3px 0px;
	color: #cd002c;
	float: right;
}

.m-gnav_content2 {
	display: none;
	text-align: left;
	padding: 0 20px 20px;
	box-sizing: border-box;
}

a.left_icon {
	padding-left: 70px;
}

a.left_icon:hover,
a.left_icon:active,
a.left_icon:focus {
	padding-left: 15px;
}

.__wc {
	background: url(../img/common/icon_01.png) no-repeat center center;
	background-size: 50px;
	background-position: left center;
}

.__ad {
	background: url(../img/common/icon_02.png) no-repeat center center;
	background-size: 50px;
	background-position: left center;
}

.__seo {
	background: url(../img/common/icon_03.png) no-repeat center center;
	background-size: 50px;
	background-position: left center;
}

.__higai {
	background: url(../img/common/icon_04.png) no-repeat center center;
	background-size: 50px;
	background-position: left center;
}

.__system {
	background: url(../img/common/icon_05.png) no-repeat center center;
	background-size: 50px;
	background-position: left center;
}

.__hp {
	background: url(../img/common/icon_06.png) no-repeat center center;
	background-size: 50px;
	background-position: left center;
}

/*----------------------------------------
MV
------------------------------------------*/
#top-mv {
	height: 700px;
	background: #cd002c;
}

.mv-inner {
	display: -webkit-inline-box;
	display: -ms-inline-flexbox;
	display: inline-flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: 100vw;
	height: 700px;
}

.mv-left {
	width: 50%;
}

.mv-right {
	width: 50%;
	position: relative;
	z-index: 1500;
}

.right-text {
	position: absolute;
	z-index: 10;
	display: grid;
	height: 700px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	background: rgb(211, 3, 50, 0.4);
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	width: 51%;
	top: 0;
}

.right-text p {
	font-weight: bold;
	font-size: 5vw;
	color: #fff;
	text-align: center;
	line-height: 1.5em;
}

.right-text p span {
	font-size: 10vw;
	color: #fff;
	display: block;
}

top_fvtxt h3 {
	font-size: 5vw;
	text-align: center;
	padding-left: 0;
	line-height: 1.5;
	font-weight: 900;
	letter-spacing: 0;
}

@media (max-width: 767px) {
	.mv-inner {
		display: block;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
	}

	.mv-left {
		width: 100%;
		height: 60vh;
	}

	.mv-right {
		width: 100%;
		height: 30vh;
		-webkit-box-align: center;
		-ms-flex-align: center;
		align-items: center;
		display: -webkit-box;
		display: -ms-flexbox;
		display: flex;
		padding: 0px 30px;
	}

	.right-text {
		z-index: 10;
		display: grid;
		height: 60vh;
		width: 100%;
		padding-top: 50px;
	}

	.right-text p {
		font-size: 9vw;
	}

	.right-text p span {
		font-size: 18.5vw;
	}

	.top_fvtxt h3 {
		font-size: 10vw;
		text-align: left;
		width: 100%;
		padding-left: 0%;
	}
}

/*----------------------------------------
MV スライダー
------------------------------------------*/



/*#slide_wrapp .slide_item {
	opacity: 0;
	-webkit-transform: scale(1);
	-ms-transform: scale(1);
	transform: scale(1);
	-webkit-transition: opacity 2s ease-in-out, -webkit-transform 5s ease-in-out;
	transition: opacity 2s ease-in-out, -webkit-transform 5s ease-in-out;
	-o-transition: opacity 2s ease-in-out, transform 5s ease-in-out;
	transition: opacity 2s ease-in-out, transform 5s ease-in-out;
	transition: opacity 2s ease-in-out, transform 5s ease-in-out, -webkit-transform 5s ease-in-out;
	position: relative;
	z-index: 1;
	height: 700px;
	width: 100%;
}

#slide_wrapp .slide_item:not(:first-child) {
	position: absolute;
	top: 0;
	left: 0;
}

#slide_wrapp .slide_item.show_ {
	opacity: 1;
}

#slide_wrapp .slide_item.zoom_ {
	-webkit-transform: scale(1.15);
	-ms-transform: scale(1.15);
	transform: scale(1.15);
}
*/
#slide_wrapp .slide_item img {
	display: block;
	height: 700px;
	width: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

@media (max-width: 767px) {
	#slide_wrapp {
		height: 60vh;
	}

	#slide_wrapp .slide_item {
		height: 60vh;
	}

	#slide_wrapp .slide_item img {
		height: 60vh;
		width: 100%;
	}
}

/*----------------------------------------
TOP追加CSS
------------------------------------------*/
/*--会社概要CSS--*/
span.h2-border {
	width: 40px;
	height: 3px;
	background: #ce002c;
	display: block;
	margin: 10px 0;
}

span.sec_tit_wrap_en {
	font-size: 40%;
	letter-spacing: 5px;
	color: #555;
	display: block;
	line-height: 2;
}

.bg-txt {
	position: absolute;
	font-size: 123px;
	font-weight: bold;
	opacity: 0.5;
	text-align: justify;
	text-justify: inter-ideograph;
	line-height: 1.2;
}

.bg-txt {
	position: absolute;
	font-size: 140px;
	font-weight: bold;
	opacity: 0.3;
	line-height: 1.2;
}

.bg-txt span {
	font-size: 120px;
	display: block;
}

@media (max-width: 767px) {
	.bg-txt {
		font-size: 4vw;
		opacity: 1;
		position: relative;
		text-align: center;
		background: #f12711;
		/* fallback for old browsers */
		/* Chrome 10-25, Safari 5.1-6 */
		background: -o-linear-gradient(left, #f5af19, #f12711);
		background: -webkit-gradient(linear, left top, right top, from(#f5af19), to(#f12711));
		background: linear-gradient(to right, #f5af19, #f12711);
		/* W3C, IE 10+/ Edge, Firefox 16+, Chrome 26+, Opera 12+, Safari 7+ */

		display: inline-block;
		padding: 5px;
	}

	.bg-txt span {
		font-size: 4vw;
		display: inline;
	}
}

/*--事業・サービスCSS--*/
.container.sec_service {
	padding: 50px 0 25px;
}

.w100_border {
	width: 100%;
	height: 1px;
	background: #cd002c;
	-webkit-transform: rotate(3deg) translate3d(0, 0, 0);
	-ms-transform: rotate(3deg) translate3d(0, 0, 0);
	transform: rotate(3deg) translate3d(0, 0, 0);
	position: absolute;
	bottom: 174px;
}

.slide-box {
	margin: 0 10px;
}

.slide-box a {
	background-color: #fff;
	display: block;
	text-decoration: none;
	border-radius: 5px;
}

.slide-box a:hover {
	background-color: #cd002c;
	color: #fff;
	-webkit-box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .5);
	box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .5);
	-webkit-transform: translateY(-5%);
	-ms-transform: translateY(-5%);
	transform: translateY(-5%);
}

.slide-box .over_txt {
	color: #fff;
	position: absolute;
	letter-spacing: 0.3em;
	font-weight: normal;
	text-align: center;
	padding: 10px;
}

.slide-box img {
	display: block;
	height: auto;
	width: 100%;
	border-radius: 5px 5px 0 0;
	border-bottom: 1px solid #f5f5f5;
}

.slide-box a:hover img {
	border-bottom: 1px solid #cd002c;
}

.slide-box h3 {
	font-weight: bold;
	padding: 10px;
}

.slide-box p {
	padding: 0 10px 10px;
	font-size: 80%;
}

#main > section > div.section_inner.left.bg_base.top_service > div.section_content > div > div.fade-down {
	margin: auto;
	text-align: center;
}

@media screen and (max-width: 479px) {}

/*--リクルートCSS--*/
.wklbg_02 .bg-txt {
	font-size: 90px;
	text-align: right;
	opacity: 1;
	position: relative;
	z-index: 0;
	margin-bottom: -280px;
}

.wklbg_02 .bg-txt span {
	font-size: 90px;
	text-align: right;
}

.wklbg_02 .aboutus_txt {
	max-width: 100%;
	position: relative;
}

.top_recruit {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.top_recruit div {
	width: 100%;
}

.top_recruit a {
	width: 98%;
}

@media (max-width: 767px) {
	.wklbg_02 .bg-txt {
		font-size: 4vw;
		opacity: 1;
		position: inherit;
		z-index: 0;
		text-align: left;
		display: inline-block;
		padding: 5px;
		margin-bottom: 90px;
		text-shadow: none;
	}

	.wklbg_02 .bg-txt span {
		font-size: 4vw;
		display: inline-block;
		text-align: left;
	}

	.wkl_cont_inner {
		color: #fff;
		text-shadow: 0 0 10px #000 !important;
	}

	.top_recruit {
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
	}

	.top_recruit div {
		width: 48%;
	}

	.top_recruit a {
		text-shadow: none;
	}
}

/*--フッターmap css--*/
.foot_map {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	clear: both;
}

.map_wrap_osaka,
.map_wrap_tokyo {
	width: 50%;
}

.map_wrap_osaka {
	background-image: url(../img/top/aboutus_bg.jpg);
	background-position: 50% center;
	background-size: cover;
}

.map_wrap_tokyo {
	background-image: url(../img/top/aboutus_bg_tokyo.jpg);
	background-position: 50% center;
	background-size: cover;
}

.map_wrap_okinawa {
	margin: 10px 0px 30px;
	line-height: 2em;
}

.foot_map_name {
	font-size: 150%;
	display: block;
	font-weight: bold;
	margin: 10px 0;
}

.foot_map p {
	background: rgba(211, 3, 50, 0.2);
	-webkit-transition: all .3s;
	-o-transition: all .3s;
	transition: all .3s;
}

.foot_map a:hover p {
	background: rgba(211, 3, 50, 0.7);
}

@media (max-width: 767px) {
	.foot_map {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
	}

	.map_wrap_osaka,
	.map_wrap_tokyo {
		width: 100%;
	}

	.map_wrap_osaka {
		border-bottom: 1px solid #f9f9f9;
	}

	.map_txt {
		font-size: 15px;
		padding: 70px 0;
	}
}

/*--フッターコンタクト css--*/
.flex_50 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.flex_50_inner {
	width: 50%;
}

.joint {
	text-align: left;
}

.joint h2 {
	font-size: 150%;
}

.joint p {
	font-size: 90%;
	font-weight: normal;
}

.flex_50.flex_50_inner a {
	width: 98%;
	letter-spacing: 2px;
	font-size: 100%;
	line-height: 1em;
	height: 51px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
}

.flex_50.flex_50_inner a .hours {
	font-size: .7rem;

}

@media (max-width: 767px) {
	.flex_50 {
		-webkit-box-orient: vertical;
		-webkit-box-direction: normal;
		-ms-flex-direction: column;
		flex-direction: column;
	}

	.flex_50_inner {
		width: 100%;
		margin-bottom: 10px;
	}

	.flex_50.flex_50_inner > div:nth-child(2) {
		margin-bottom: 0px;
	}
}

/*--フッター css--*/
footer a {
	-webkit-transition: all .3s;
	-o-transition: all .3s;
	transition: all .3s;
	position: relative;
	z-index: 1;
}

img.footer_logo_img {
	width: 80%;
}

.fa-facebook-square,
.fa-instagram {
	float: left !important;
	margin-top: 2px !important;
	padding-right: 10px;
	font-weight: normal !important;
	font-size: 120%;
}

p.foot_list_tit.banner {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	max-width: 160px;
	-webkit-box-align: start;
	-ms-flex-align: start;
	align-items: flex-start;
}

.banner a {
	margin-right: 5px;
}

p.copyright.fs10.tac {
	text-align: right;
}

footer > div:nth-child(1) {
	width: 30%;
}

footer > div:nth-child(2) {
	margin-left: 2%;
}

footer a:hover {
	color: #fff;
}

p.footer_bg_txt {
	position: absolute;
	font-size: 110px;
	font-weight: bold;
	left: 0;
	opacity: 0.1;
	z-index: 0;
	line-height: 1;
	overflow: hidden;
}

@media (max-width: 767px) {
	.foot_list_tit {
		padding-right: 0;
		font-size: 16px;
	}

	li.foot_list_item.fs12 {
		font-size: 16px;
	}

	footer > div:nth-child(1) {
		width: 94%;
		margin-right: 3%;
		margin-left: 3%;
	}

	footer > div:nth-child(2) {
		width: 94%;
		margin-right: 3%;
		margin-left: 3%;
	}

	img.footer_logo_img {
		width: 60%;
		margin: 0 20%;
	}

	p.footer_bg_txt {
		font-size: 10vw;
		left: 2%;
	}
}

/*----------------------------------------
ABOUT CSS
------------------------------------------*/

.flex-37 {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}

.flex-3 {
	width: 25%;
	text-align: left;
	font-size: 1.4rem;
	font-weight: bold;
}

.flex-3_img {}

.flex-7 {
	width: 75%;
	text-align: left;
}

h2.subh2 {
	text-align: left;
	font-size: 30px;
}

.flex-7 h3 {
	font-size: 35px;
	letter-spacing: 2px;
	margin-bottom: 20px;
}

.flex-7 p {
	line-height: 2;
}

.policy {
	padding: 100px 0 50px;
}

.policy span.h2-border {
	background: #fff;
}

.policy span.sec_tit_wrap_en {
	color: #fff;
}


.access-cap {
	background: #ce002c;
	width: 80%;
	position: relative;
	margin: -100px auto 30px;
	text-align: center;
	padding: 20px;
	color: #fff;
	border-radius: 5px;
	-webkit-box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2);
	box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2);
}

.access-cap .content_inner {
	max-width: 60%;
	margin: 0px auto 10px;
	text-align: left;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}

.access-cap .content_inner i {
	float: left;
}

.access-cap h4 {
	font-size: 30px;
	margin-bottom: 10px;
}

.access-cap div {
	font-size: 13px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	text-align: left;
}

.access-cap div ul {}

.access-cap div ul li {}

.access-cap i {
	font-size: 25px;
	margin: 10px;
}

@media (max-width: 767px) {
	.flex-37 {
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	.flex-3 {
		width: 100%;
		margin-bottom: 25px;
	}

	.flex-7 {
		width: 100%;
	}

	.access-cap {
		width: 100%;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}

	.access-cap div {
		-webkit-box-pack: start;
		-ms-flex-pack: start;
		justify-content: start;
	}
}

/*----------------------------------------
STAFF CSS
------------------------------------------*/

.msal-txt {
	width: 100%;
	text-align: left;
	padding: 10px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

li.staff-cat {
	background: #d00026;
	color: #fff;
	display: inline-grid;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	text-align: center;
	font-size: 16px;
	letter-spacing: 0.1em;
	font-weight: bold;
}

.stuff_content {
	margin-top: -60px;
	display: inline-block;
	padding: 0;
}

.stuff_intarview {
	-webkit-box-flex: 1;
	-ms-flex: 1 0 auto;
	flex: 1 0 auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	height: auto;
	background: #fff;
	width: 60%;
	float: right;
	padding: 50px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.stuff_img {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: flex-end;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	top: 0px;
	width: 40%;
	height: 100vh;
	color: #fff;
	background-image: url(../img/member/sugawara/01.jpg);
	background-size: cover;
	background-position: center;
	float: left;
}

.stuff_img p {
	font-size: 1vw;
	letter-spacing: 1em;
	color: #fff;
	background: #d00026;
	text-align: center;
	padding: 10px;
	border-radius: 5px;
	padding-left: calc(1em + 10px);
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	margin-bottom: 50px;
}

.sec {
	width: 100%;
	margin-bottom: 10%;
}

@media screen and (min-width:1400px) {
	.sec {
		width: 80%;
	}
}

.sec_img {
	width: 100%;
	height: 375px;
	background-size: cover;
	background-position: center;
}

.sec_img.sugawara01 {
	background-image: url(../img/member/sugawara/sugahara_1.jpg);
}

.sec_img.sugawara02 {
	background-image: url(../img/member/sugawara/sugahara_2.jpg);
}

.sec_img.sugawara03 {
	background-image: url(../img/member/sugawara/sugahara_3.jpg);
}

.txt_area {
	margin: 10px 0 0 10px;
}

.txt_anime h3 {
	font-size: 25px;
	background: #fff;
	padding: 10px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	display: inline-block;
	opacity: 0;
}

.block_anime {
	display: inline-block;
	overflow: hidden;
	position: relative;
	-webkit-animation: fadeIn 0.1s 0.5s;
	animation: fadeIn 0.1s 0.5s;
	-webkit-animation-fill-mode: both;
	animation-fill-mode: both;

}

.txt_anime.block_anime h3 {
	opacity: 1;
}

.block_anime:after {
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	background: #f12711;
	background: -o-linear-gradient(left, #f5af19, #f12711);
	background: -webkit-gradient(linear, left top, right top, from(#f5af19), to(#f12711));
	background: linear-gradient(to right, #f5af19, #f12711);
	/*アニメーションの設定*/
	-webkit-animation: secondaryImageOverlayIn 0.6s 0s cubic-bezier(.77, 0, .175, 1),
		secondaryImageOverlayOut 0.6s 0.6s cubic-bezier(.77, 0, .175, 1);
	animation: secondaryImageOverlayIn 0.6s 0s cubic-bezier(.77, 0, .175, 1),
		secondaryImageOverlayOut 0.6s 0.6s cubic-bezier(.77, 0, .175, 1);
	-webkit-animation-fill-mode: both;
	animation-fill-mode: both;
}


/*keyframesの設定*/
/*文字が消えている状態から現れるアニメーション*/
@-webkit-keyframes fadeIn {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

@keyframes fadeIn {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

/*はじめにブロックを伸ばすアニメーション*/
@-webkit-keyframes secondaryImageOverlayIn {
	0% {
		width: 0;
	}

	100% {
		width: 100%;
	}
}

@keyframes secondaryImageOverlayIn {
	0% {
		width: 0;
	}

	100% {
		width: 100%;
	}
}

/*のび太ブロックを横に追いやるアニメーション*/
@-webkit-keyframes secondaryImageOverlayOut {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
	}

	100% {
		-webkit-transform: translateX(102%);
		transform: translateX(102%);
	}
}

@keyframes secondaryImageOverlayOut {
	0% {
		-webkit-transform: translateX(0);
		transform: translateX(0);
	}

	100% {
		-webkit-transform: translateX(102%);
		transform: translateX(102%);
	}
}

.txt_area p {
	line-height: 1.8;
}

.sec.sns {
	font-size: 30px;
}

.sec.sns a {
	display: block;
}

.sec.sns .fa-facebook-square,
.sec.sns .fa-instagram,
.sec.sns .fa-twitter {
	line-height: 1;
	margin: 0 !important;
	font-size: 30px;
	display: inline-block;
	padding-right: 20px;
	float: left;
	overflow: hidden;
	-webkit-transition: all .3s;
	-o-transition: all .3s;
	transition: all .3s;
}

.sec.sns .fa-facebook-square:hover,
.sec.sns .fa-instagram:hover,
.sec.sns .fa-twitter:hover {
	color: #d00026;

}

@media (max-width: 767px) {
	.stuff_img {
		width: 100%;
	}

	.stuff_intarview {
		width: 100%;
		padding: 0px 5% 50px;
		z-index: 5;
		position: relative;
		margin-top: 100vh;
	}

	.sec_img {
		width: 112%;
		height: 250px;
		margin: 0 -6%;
	}

	.stuff_img p {
		font-size: 3vw;
	}
}


/*----------------------------------------
MEMBER CSS
------------------------------------------*/
.filter {
	/*margin: 50px 0 0px;*/
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}

.filter a {
	display: inline-block;
	padding: 10px;
	border: 1px solid #ddd;
	position: relative;
	margin-right: 10px;
	margin-bottom: 10px;
	width: calc(100%/5 - 10px);
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	text-align: center;
	border-radius: 5px;
	font-size: 13px;
}

.boxes {}



.filter a:hover {
	border-color: #d00026;
	color: #d00026;
}

.filter a.active {
	background: #d00026;
	color: #fff;
	border-color: #d00026;
	-webkit-box-shadow: 0 2px 4px 0 rgba(0, 0, 0, .2);
	box-shadow: 0 2px 4px 0 rgba(0, 0, 0, .2);
}


.is-animated {
	-webkit-animation: .6s zoom-in;
	animation: .6s zoom-in;
}

@keyframes zoom-in {
	0% {
		-webkit-transform: scale(.1);
		transform: scale(.1);
	}

	100% {
		-webkit-transform: none;
		transform: none;
	}
}

/*----------------------------------------
BLOG CSS
------------------------------------------*/
.blog_eyecatch,
.blog_prof {
	background-size: cover;
	background-position: center;
	width: 100%;
	height: 100%;
}

.blog_prof {}

.blog_eyecatch {
	border-radius: 5px 5px 0 0;
}

.blog_date p {
	width: 50%;
	font-weight: bold;
}

.page_nav {
	width: 95%;
	display: block;
	overflow: hidden;
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	margin: auto;
	/* left: 0; */
	/* right: 0; */
}

.page_nav ul {}

.page_nav ul li {
	width: 50%;
	float: left;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.prev {
	border-right: 1px solid #ddd;
}

.next {
	text-align: right;
}

.page_nav ul li a {
	display: block;
	padding: 30px;
	-webkit-transition: all .3s;
	-o-transition: all .3s;
	transition: all .3s;
}

.page_nav ul li a:hover {
	background-color: #cd002c;
	color: #fff;
	-webkit-box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .5);
	box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .5);
}

.fa-arrow-alt-circle-left {
	padding-right: 20px;
}

.fa-arrow-alt-circle-right {
	padding-left: 20px;
}

@media (max-width: 767px) {
	.page_nav {
		width: 100%;
		margin-bottom: 50px;
	}
}

.blog_list li a:hover {
	-webkit-box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .5);
	box-shadow: 0 5px 16px 0 rgba(0, 0, 0, .5);
}

/*----------------------------------------
BLOG SIDE CSS
------------------------------------------*/
.widget {
	margin-bottom: 50px;
	background: #fff;
}

.widget .blog_img {
	width: 30%;
	height: 75px;
	float: left;
	display: inline-block;
}

.widget .blog_eyecatch {
	border-radius: 0;
}

.new_post ul {}

.new_post ul li {
	clear: both;
	margin: 10px 0;
	border-bottom: 1px dashed #ccc;
	padding: 0 10px 0 0;
}



.new_post ul li a {
	display: block;
	height: 75px;
	-webkit-transition: all .3s;
	-o-transition: all .3s;
	transition: all .3s;
}

.new_post h3 {
	padding-left: 10px;
	display: inline-block;
	float: right;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 70%;
}

.new_post.side_news_new h3 {
	padding-left: 10px;
	display: inline-block;
	float: none;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 100%;
}

.new_post ul li a:hover {
	color: #cd002c;
}

/*----------------------------------------
BLOG Single CSS
------------------------------------------*/
article .blog_img {
	margin: -10px -10px 0;
	height: 400px;
}

article .blog_eyecatch {
	border-radius: 0 0;
}

h1.article_entry_ttl {
	font-size: 25px;
	padding: 20px 10px;
	border-bottom: 1px solid #ddd;
	margin: 0 -10px;
}

.article_entry_content a {
	color: #d00026;
	text-decoration: underline;

}

.article_entry_content h2 {
	padding: 10px;
	font-size: 20px;
	background: #d2001d;
	color: #fff;
	margin: 15px -10px;
}

.article_entry_content h3 {
	padding: 10px;
	font-size: 18px;
	margin: 10px -10px;
	border-left: 5px solid #d4000f;
}

.article_entry_content h4 {
	padding: 10px;
	font-size: 16px;
	margin: 10px -10px;
	color: #d4000f;
}

.article_entry_content p {
	font-size: 15px;
	line-height: 1.6;
}

@media (max-width: 767px) {
	.article_single_post {
		margin-right: 0%;
	}

	.container.sp_wmax {
		margin: 0 -5%;
	}

	.article_writer {
		text-align: center;
	}

	.container.sp_wmax .side_wrap {
		padding: 5%;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}

	article .blog_img {
		height: 250px;
	}
}

/*----------------------------------------
BUSSINES TOP CSS
------------------------------------------*/
.service_num_wrap {
	color: #fff;
	background: #d40332;
	border-radius: 5px;
	-webkit-box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2);
	box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2);
}

.service_num {
	padding: 10px 10px 0;
	opacity: 1;
}

.service_num_sub {
	padding: 0 10px 10px;
}

.l-service_info .l-service_info_item h3 {
	letter-spacing: 0.1em;
}

span.bussines_title {
	text-align: right;
	display: block;
	font-size: 4vw;
	margin-top: -5.5vw;
	color: #fff;
	opacity: 0.5;
	font-weight: 100;
	padding-right: 3%;
}

/*----------------------------------------
BUSSINES content CSS
------------------------------------------*/
.main_bg.service {
	background: #fff;
}

.main_bg.service h3 {
	font-size: 28px;
	display: block;
	position: relative;
}

.main_bg.service .steps h3 {
	font-size: 20px;
	margin-bottom: 6px;
}

.l-service_container > div > h3 {
	font-size: 22px !important;
	color: #d00026;
	background: #fff;
	background: -o-linear-gradient(315deg, #d00026 10%, #ff5151 50%, #f1eaca 100%);
	background: linear-gradient(135deg, #d00026 10%, #ff5151 50%, #f1eaca 100%);
	-webkit-background-clip: text !important;
	-webkit-text-fill-color: transparent;
	margin: 0;
}

.list_name {
	text-align: center;
}

.list_name p {
	position: relative;
	display: block;
	letter-spacing: 1em;
	font-size: 20px;
	margin-right: -1em;
	margin-left: -1em;
	background: #d5032b;
	color: #fff;
	padding: 10px 0;
}

.list_name p:before {
	content: '';
	position: absolute;
	top: 50%;
	display: inline-block;
	width: 30%;
	height: 1px;
	background: -o-linear-gradient(-315deg, #d00026 10%, #ff5151 50%, #f1eaca 100%);
	background: -o-linear-gradient(225deg, #d00026 10%, #ff5151 50%, #f1eaca 100%);
	background: linear-gradient(-135deg, #d00026 10%, #ff5151 50%, #f1eaca 100%);
}

.list_name p:after {
	content: '';
	position: absolute;
	top: 50%;
	display: inline-block;
	width: 30%;
	height: 1px;
	background: -o-linear-gradient(315deg, #d00026 10%, #ff5151 50%, #f1eaca 100%);
	background: linear-gradient(135deg, #d00026 10%, #ff5151 50%, #f1eaca 100%);
}

.list_name p:before {
	left: 0;
}

.list_name p:after {
	right: 0;
}

.ec_cta {
	background-image: url(../img/service/ec_cta.jpg);
	background-size: cover;
	background-position: center 50%;
}

.ec_cta h3 {
	font-size: 25px;
}

.ec_cta .b_inner {
	color: rgb(255, 255, 255);
	background: rgba(0, 0, 0, 0.6);
	padding: 50px 0px;
}

.ec_cta .am_fadeInUp {
	width: 80%;
	line-height: 2;
}

.ec_cta .fs20 {
	letter-spacing: 0.3em;
}

.ec_cta .hov_opa {
	margin: 0;
	width: 300px;
}

.ec_cta a:hover {
	opacity: 1;
}

.sss {}

.sss .container {}

.sss .flex3 {
	background: #fff;
	border-radius: 5px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	width: 32%;
	-webkit-box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2);
	box-shadow: 0 2.5px 8px 0 rgba(0, 0, 0, .2);
}

.sss h2 {
	background: #f9f9f9;
	color: #d5032b;
	padding: 4%;
	border-radius: 4px 4px 0 0;
	font-size: 20px;
	letter-spacing: 0.2em;
	border-bottom: 1px solid #d5032b;
}

.sss span {
	display: block;
	font-size: 60%;
	letter-spacing: 0.2em;
	font-weight: 100;
}

.sss {
	margin-bottom: 15%;
}

.sss p {
	padding: 4%;
	text-align: left;
}

.sss_bg {
	background: -o-linear-gradient(left, rgba(221, 24, 24, 0.7), rgba(221, 24, 24, 0.9)), url(../img/service/sss_bg.jpg);
	background: -webkit-gradient(linear, left top, right top, from(rgba(221, 24, 24, 0.7)), to(rgba(221, 24, 24, 0.9))), url(../img/service/sss_bg.jpg);
	background: linear-gradient(to right, rgba(221, 24, 24, 0.7), rgba(221, 24, 24, 0.9)), url(../img/service/sss_bg.jpg);
	background-size: cover;
	position: absolute;
	right: 0;
	bottom: 0;
	width: 75%;
	height: 400px;
	z-index: -6;
	background-position: center;
	margin-bottom: -12%;
}

@media (max-width: 766px) {
	.sss .flex3 {
		margin-bottom: 5%;
		width: 100%;
	}
}

/*----------------------------------------
WEBコンサルティング content CSS
------------------------------------------*/

.ms-demand .container,
.ms-demand2 .container {
	position: relative;
	z-index: 1;
}

.ms-demand .bg {
	background: -o-linear-gradient(left, rgba(221, 24, 24, 0.7), rgba(221, 24, 24, 0.9)), url(../img/service/dm/wc/demand_bg.jpg);
	background: -webkit-gradient(linear, left top, right top, from(rgba(221, 24, 24, 0.7)), to(rgba(221, 24, 24, 0.9))), url(../img/service/dm/wc/demand_bg.jpg);
	background: linear-gradient(to right, rgba(221, 24, 24, 0.7), rgba(221, 24, 24, 0.9)), url(../img/service/dm/wc/demand_bg.jpg);
	background-size: cover;
	position: relative;
	left: 0;
	top: 0;
	width: 75%;
	height: 420px;
	z-index: 0;
	background-position: center;
	margin-bottom: -420px;
}

.ms-demand2 .bg {
	background: url(../img/service/dm/sol_wc.jpg);
	background-size: cover;
	position: relative;
	right: 0;
	top: 0;
	width: 75%;
	height: 420px;
	z-index: 0;
	background-position: center;
	margin-bottom: -420px;
	margin-left: 25%;
}

.ms-demand2.ad_demand2 .bg {
	background: url(../img/service/dm/sol_ad.jpg);
	background-size: cover;
}

.ms-demand2.seo_demand2 .bg {
	background: url(../img/service/dm/sol_seo.jpg);
	background-size: cover;
	background-position: bottom;
}

.ms-demand2.rumor_demand2 .bg {
	background: url(../img/service/dm/sol_rumor.jpg);
	background-size: cover;
}

.ms-demand2.ms_system .bg {
	background: url(../img/service/dm/sol_system.jpg);
	background-size: cover;
	background-position: bottom;
}

.ms-demand2.web_demand2 .bg {
	background: url(../img/service/dm/sol_hp.jpg);
	background-size: cover;
}

.cmntw-ttl-01 {
	color: #fff;
	font-size: 37px;
	font-weight: 500;
	position: relative;
	z-index: 1;
	padding-top: 50px;
	padding-bottom: 15px;
	line-height: 1.2;
	text-align: left;
	letter-spacing: 0.2em;
	margin-bottom: 50px;
}

.cmntw-ttl-01:before {
	content: "";
	height: 1px;
	width: 40px;
	background: #fff;
	position: absolute;
	z-index: 1;
	margin-left: -60px;
	margin-top: 22px;
}

.cmntw-ttl-01 span {
	font-size: 40%;
	font-weight: 500;
	letter-spacing: 0.2em;
}

.msd-list li {
	background: #fff;
	border-radius: 5px;
	-webkit-box-shadow: 0 0px 10px rgba(0, 0, 0, 0.2);
	box-shadow: 0 0px 10px rgba(0, 0, 0, 0.2);
	padding: 15px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	min-height: 170px;
}

.main_bg.service .ms-demand p {
	font-size: 24px;
	letter-spacing: 0.1em;
	margin-bottom: 20px;
	color: #da0331;
}

.main_bg.service .ms-demand p::before {
	content: "";
	height: 2px;
	width: 30px;
	background: #d5032b;
	position: absolute;
	z-index: 1;
	margin-top: 45px;
}

.main_bg.service .ms-demand h3 {
	font-size: 18px;
}

.ms-demand2 .ms-lead.container {
	margin: 0;
	text-align: left;
	padding: 50px 0;
}

.ms-demand2 .ms-lead.container p {
	font-size: 30px;
	color: #da3539;
	background: #fff;
	display: inline;
	line-height: 2em;
	margin: 0;
	padding: 5px;
}

.solution {
	font-size: 100px;
	position: absolute;
	color: #da3539;
	margin-top: 0;
	line-height: 0;
	margin-top: -10px;
}

p.text-item02 {
	text-align: center;
	font-size: 24px;
	letter-spacing: 0.1em;
	background: #da3539;
	color: #fff;
	border-radius: 5px 5px 0 0;
	padding: 15px;
	margin: -15px -15px 10px;
}

p.text-item02 span {
	display: block;
	font-size: 70%;
	letter-spacing: 0.2em;
	font-weight: 100;
}

p.text-item03 {
	text-align: center;
}

p.text-item03.tal {
	text-align: left;
}

.ms-demand2 .msd-list li {
	min-height: auto;
}

.steps {
	padding: 0;
}

.steps .cols {
	margin: 0 -30px;
}

.steps .cols .col {
	float: left;
	width: 48%;
	padding: 0 0.5%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.steps .cols .col li {
	display: table;
	width: 100%;
	margin: 0 0 40px 0;
}

.steps .cols .col li .step {
	vertical-align: middle;
	width: 90px;
	background-color: #F3F3F3;
	text-align: center;
	font-size: 20px;
	line-height: 30px;
	font-weight: bold;
	position: relative;
}

.steps .cols .col li .step:after {
	content: "";
	position: absolute;
	left: 0;
	bottom: -25px;
	border-top: 25px solid #f3f3f3;
	border-left: 45px solid transparent;
	border-right: 45px solid transparent;
}

.steps .cols .col li .content {
	vertical-align: top;
	padding: 0 0 20px 30px;
}

.steps .cols .col li .step,
.steps .cols .col li .content {
	display: table-cell;
}

.ms-flow .cmntw-ttl-01 {
	color: #d40332;
}

.ms-flow .cmntw-ttl-01:before {
	background: #d40332;
}

.cn_cta {
	background-image: url(../img/service/dm/fv_con.jpg);
}



/*----------------------------------------
インターネット広告  CSS
------------------------------------------*/

.ad_demand2 p.text-item03 {
	text-align: left;
}

.ad_demand2 .msd-list li {
	min-height: 220px;
}

.ad01,
.ad02,
.ad03,
.ad04 {
	color: #fff !important;
}

.ad01 {
	background-color: #f37a0f !important;
}

.ad01:after {
	border-top-color: #f37a0f !important;
}

.ad02 {
	background-color: #e7500e !important;
}

.ad02:after {
	border-top-color: #e7500e !important;
}

.ad03 {
	background-color: #e8320e !important;
}

.ad03:after {
	border-top-color: #e8320e !important;
}

.ad04 {
	background-color: #e80f0e !important;
}

.ad04:after {
	border-top-color: #e80f0e !important;
}

.ad_case .cmntw-ttl-01,
.seo_case .cmntw-ttl-01 {
	color: #d40332;
}

.ad_case .cmntw-ttl-01:before,
.seo_case .cmntw-ttl-01:before {
	background: #d40332;
}

.cov {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	margin-bottom: 20px;
	-webkit-box-shadow: 0 0px 10px rgba(0, 0, 0, 0.2);
	box-shadow: 0 0px 10px rgba(0, 0, 0, 0.2);
}

.cov .bg_inner {
	width: 100%;
}

.cov .bg01 {
	background: -o-linear-gradient(left, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.9)), url(../img/service/dm/ad/case01.jpg);
	background: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0.7)), to(rgba(0, 0, 0, 0.9))), url(../img/service/dm/ad/case01.jpg);
	background: linear-gradient(to right, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.9)), url(../img/service/dm/ad/case01.jpg);
	color: #fff;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	background-size: cover;
}

.cov .bg02 {
	background: -o-linear-gradient(left, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.9)), url(../img/service/dm/ad/case02.jpg);
	background: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0.7)), to(rgba(0, 0, 0, 0.9))), url(../img/service/dm/ad/case02.jpg);
	background: linear-gradient(to right, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.9)), url(../img/service/dm/ad/case02.jpg);
}

.cov .bg03 {
	background: -o-linear-gradient(left, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.9)), url(../img/service/dm/ad/case03.jpg);
	background: -webkit-gradient(linear, left top, right top, from(rgba(0, 0, 0, 0.7)), to(rgba(0, 0, 0, 0.9))), url(../img/service/dm/ad/case03.jpg);
	background: linear-gradient(to right, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.9)), url(../img/service/dm/ad/case03.jpg);
}

.cov .ec-bg01 {
	background: url(../img/top/christian_img.jpg);
	color: #fff;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	background-size: cover;
	background-position: center;
}

.ec-bg01 > div > div > p > img {
	max-width: 100px;
}

.cov .cov_left,
.cov .cov_right {
	width: 50%;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.cov .cov_left.cov .cov_label {
	text-align: center;
}

.cov .cov_label p {
	text-align: center;
}

.cov .cov_h3 {
	text-align: center;
}

.cov h4 {
	font-size: 26px;
	padding: 0 0 10px;
	letter-spacing: 0.1em;
	font-weight: 200;
}

.cov h4 .fas,
.cov h4 .far,
.cov h4 .fa {
	font-size: 24px;
}

.cov ul {}

.cov ul li {
	list-style-type: initial;
	list-style-position: inside;
	font-weight: bold;
}

.cov .far,
.cov .fas {
	padding-right: 10px;
}



.cov_sec_01,
.cov_sec_02,
.cov_sec_03 {
	padding: 25px;
}

.cov_sec_02 {
	background: #fff;
}

.cov_sec_03 {
	background: #d40332;
	color: #fff;
}

p.p_01 {
	margin-bottom: 10px;
}

p.p_02 {
	margin-bottom: 20px;
}

.chosa {
	background: #333;
	color: #fff;
	padding: 0 10px;
	margin-right: 10px;
	border-radius: 5px;
	display: inline-block;
}

.kaizen {
	background: #2e78cc;
	color: #fff;
	padding: 0 10px;
	margin-right: 10px;
	border-radius: 5px;
	display: inline-block;
}

.row-reverse {
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	-ms-flex-direction: row-reverse;
	flex-direction: row-reverse;
}

.cov_left {
	padding: 25px;
}

.cov_right {
	background: #f9f9f9;
}

.ad_cta {
	background-image: url(../img/service/dm/fv_ad.jpg);
}

.authority {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	margin: 15px 0px;
}

.authority > div {
	border: 1px solid #eee;
	padding: 5px;
	max-width: calc(100% / 3.6);
	min-height: 140px;
	padding: 10px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-orient: vertical;
	-webkit-box-direction: normal;
	-ms-flex-direction: column;
	flex-direction: column;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}

.authority > div p {
	line-height: 1.3em;
}


/*----------------------------------------
SEO CSS
------------------------------------------*/
.seo_case .cov_left .cov_h3 {
	text-align: left;
	font-size: 120%;
	padding-top: 15px;
}

.cov_seo_inner {
	padding: 25px;
}

.cov_seo_inner h3 {
	text-align: center;
	margin-bottom: 15px;
	color: #d40332;
}

.ms-wcase.seo_case.container {
	margin-bottom: 100px;
}

.main_bg.service .ms-demand p.seo_voice_txt {
	font-size: 100%;
	color: #111;
	margin-bottom: 0;
	letter-spacing: 0;
}

.main_bg.service .ms-demand p.seo_voice_txt::before {
	content: none;
}

.ms-demand.seo_voice > div.container > ul > li > h3 {
	position: relative;
	width: calc(100% + 30px);
	display: block;
	margin: -15px -15px 0;
	border-radius: 5px 5px 0 0;
}

.ms-demand.seo_voice > div.container > ul > li > h3 > img {
	width: 90%;
	text-align: center;
	padding: 5%;
	background: #f7f6f6;
	border-radius: 5px 5px 0 0;
}

.seo_voice .bg {
	background: -o-linear-gradient(left, rgba(221, 24, 24, 0.5), rgba(221, 24, 24, 0.1)), url(../img/service/voice_bg.jpg);
	background: -webkit-gradient(linear, left top, right top, from(rgba(221, 24, 24, 0.5)), to(rgba(221, 24, 24, 0.1))), url(../img/service/voice_bg.jpg);
	background: linear-gradient(to right, rgba(221, 24, 24, 0.5), rgba(221, 24, 24, 0.1)), url(../img/service/voice_bg.jpg);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}

.main_bg.bg_white.main-service-04 > div.rmr_planinfo.container.ad_case > ul > li > div > h3 {
	font-size: 22px;
}

.seo_cta {
	background-image: url(../img/service/dm/fv_seo.jpg);
}



/*----------------------------------------
風評被害  CSS
------------------------------------------*/

.cov .bg_inner img {
	width: 100%;
}


.rmr_planinfo .msd-list li {
	background: #f9f9f9;
	padding: 15px 0;
}

.rmr_planinfo p.text-item02 {
	background: #fff;
	margin: -15px 0px 0px;
}

.rmr_planinfo p.text-item02 img {
	height: 250px;
	widows: auto;

}

.rumor_cta {
	background-image: url(../img/service/dm/top-visual-service-04.png);
}

/*----------------------------------------
システム  CSS
------------------------------------------*/

.system_cta {
	margin-top: 100px;
	background-image: url(../img/service/dm/fv_system.jpg);
}

/*----------------------------------------
Web制作  CSS
------------------------------------------*/
p.msp_cap {
	font-weight: bold;
	font-size: 18px;
	letter-spacing: 0.1em;
	margin: 10px 0;
	color: #d00026;
	display: inline-block;
}

.ms-professional.ms-flow {
	padding-bottom: 0;
}

.ms-demand.web_voice.seo_voice {
	padding-bottom: 50px;
}

.hp_cta {
	margin-top: 100px;
	background-image: url(../img/service/dm/fv_wd.jpg);
}

/*----------------------------------------
リクルート CSS
------------------------------------------*/
#main > section > div.main_bg.recruit.bg_white > div.main-service-06 > div.container.tac.mtb_7p.flex-37 > div.flex-7 > h3 {
	margin-top: -10px;
}

.recruit_ms .solution {
	color: #111;
	margin-bottom: 50px;
}

.recruit_ms .ms-lead.container {
	padding: 100px 0 50px;
}

.recruit_ms .bg {
	background: url(../img/recruit/mrm-img.png);
	background-size: cover;
	height: 600px;
	margin-bottom: -300px;
}

.rcr_msg_inner {
	padding: 25px;
	width: 75%;
	background: #fff;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.rcr_msg_sign {
	position: static;
	text-align: left;
	padding-top: 20px;
}

.rec_button {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-ms-flex-pack: distribute;
	justify-content: space-around;
	width: 100%;
	margin: 20px 0px 60px;
}

.rec_button > div {
	display: inline-block;
	width: 45%;
	text-align: center;
}

.rec_button > div a {
	display: block;
	background-color: #e42a42;
	font-size: 1.1rem;
	font-weight: bold;
	color: #fff;
	padding: 20px 65px;
	border-radius: 8px;
}

.tabs {
	margin-top: 50px;
	padding-bottom: 40px;
	background-color: #fff;
	-webkit-box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
	box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
	width: 100%;
	margin: 0 auto 50px;
	padding: 0 10px 30px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}


.tab_item {
	width: calc(100%/3);
	height: 50px;
	border-bottom: 3px solid #cd002c;
	background-color: #d9d9d9;
	line-height: 50px;
	font-size: 16px;
	text-align: center;
	color: #565656;
	display: block;
	float: left;
	text-align: center;
	font-weight: bold;
	-webkit-transition: all 0.2s ease;
	-o-transition: all 0.2s ease;
	transition: all 0.2s ease;
}

.tab_item:hover {
	opacity: 1;
}



input[name="tab_item"] {
	display: none;
}


.tab_content {
	display: none;
	padding: 40px 40px 0;
	clear: both;
	overflow: hidden;
}




#shinsotsu:checked ~ #shinsotsu_content,
#chuto:checked ~ #chuto_content,
#gijyutsu:checked ~ #gijyutsu_content {
	display: block;
}

.tabs input:checked + .tab_item {
	background-color: #cd002c;
	color: #fff;
}

.tab_recruit{
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    border-bottom: 3px solid #cd002c;
}
.tab_recruit > div{
    width:calc(100% / 5.3);
    line-height: 1.1em;
    margin: 0px;
}
.tab_recruit > div a{
    background-color: #cd002c;
    border-radius: 10px 10px 0 0;
    padding:18px 0px;
    color:#fff;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
}
.tab_recruit > div a.select{
    padding:25px 0px;
    background-color: #cd002c;margin-top: -14px;
}
.tab_recruit > div a:hover{
    background-color: #d9d9d9;
    color:#1b1b1b;
}

.rcr_sys_list.flex {
	-ms-flex-pack: distribute;
	justify-content: start;
}

.page_fv.recruit {
	background: -o-linear-gradient(315deg, #d00026 10%, #ff5151 71%, #f1eaca 100%);
	background: linear-gradient(135deg, #d00026 10%, #ff5151 71%, #f1eaca 100%);
	display: block;
}

span.dd_sec {
	font-weight: bold;
	padding-right: 25px;
}

span.dd_sec::after {
	content: "：";

}

span.dd_cap {
	color: #cd002c;
	line-height: 1.2em;
	display: block;
	/* border: 1px solid #cd002c; */
	padding: 5px;
	border-radius: 8px;
	max-width: 70%;
}

span.dd_cap .book {
	display: block;

}

span.dd_cap .book label {
	background-color: #cd002c;
	color: #fff;
	padding: 8px;
	border-radius: 8px;
	margin: 5px 0px;
	font-size: .9rem;
	display: inline-block;
}

span.dd_sec .fsb {}

.rulebook {
	margin: 30px 0px;
	padding: 20px;
	display: block;
	border: 1px solid #ccc;
	border-radius: 8px;
	width: 90%;
	margin: 30px auto;
}

.modal_content {
	max-width: initial;
}

.rulebook .career_table {
	font-size: .9rem !important;
	width: 100%;
}

.rulebook table tr {
	/* border:1px solid #ccc; */
}

.rulebook table tr.ghead th {
	background-color: #bd1838;
	color: #fff;
}

.rulebook table tr.mhead th {
	background-color: #ffcc99;
	color: #fff;
	margin-top: 10px;
}

.rulebook table tr.shead th {
	background-color: #99cccc;
	color: #fff;
}

.rulebook table tr.phead th {
	background-color: #99cc99;
	color: #fff;
}

.rulebook table tr.ehead th {
	background-color: #9cbfe0;
	color: #fff;
}

.rulebook table tr.ghead td,
.rulebook table tr.mhead td,
.rulebook table tr.shead td,
.rulebook table tr.phead td,
.rulebook table tr.ehead td {
	border-bottom: 1px solid #cd002c;
	border-top: 1px solid #cd002c;
	padding: 0px !important;
	font-weight: bold;
	color: #cd002c;

}

.rulebook table tr.ghead td,
.rulebook table tr.mhead td,
.rulebook table tr.shead td,
.rulebook table tr.shead td,
.rulebook table tr.phead td,
.rulebook table tr.ehead td {
	padding: 25px 10px;
}

.rulebook table tr.total {
	background-color: #eee;
	font-weight: bold;
	padding: 15px;
}

.rulebook table tr th,
.rulebook table tr td {
	text-align: center;
	padding: 10px;
}

.rulebook table tr th {
	min-width: 100px;
}

.rulebook table tr span.how {
	background-color: #fff;
	color: #1b1b1b;
	margin: 10px auto;
	font-size: .8rem;
	font-weight: 300;
	padding: 3px;
	border-radius: 8px;
	display: block;
	max-width: 60%;
	line-height: 1.4em;
}

.rulebook_cap {
	margin: 0px;
	font-size: .9rem;
	border: 0px;
	padding: 0;
	border-radius: 8px;
	line-height: 1.5em;
}

.rulebook_cap h4 {
	margin-top: 30px;
	font-size: 1.3em;
}

.rulebook_cap p {
	padding: 5px;
	margin: 20px 0px 5px;
	background-color: #cc0000;
	color: #fff;

}

.rulebook_cap .image {
	margin: 50px auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	border: 1px solid #ccc;
	padding: 5%;
	border-radius: 8px;
}

.rulebook_cap .image img {
	width: 50%;
	margin: 0px auto;
}


/*----------------------------------------
キャリア採用 CSS
------------------------------------------*/
.flex33_card {
	width: 32.5%;
	margin-bottom: 1%;
}


.card h3,
.card p,
.card a,
.card span {
	color: #fff;
	letter-spacing: 0.02em;
	font-weight: 500;
}

.card h3,
.card p {
	padding-left: 15px;
}

.card h3 {
	font-size: 20px;
	letter-spacing: 0.2em;
}

.card p {
	font-size: 15px;
	line-height: 25px;
}

.card button {
	border: 0;
	border-radius: 26px;
	padding-bottom: 2px;
}

.card span {
	font-size: 1.6em;
}

.card,
.card .flip-box,
.card .front,
.card .back {
	width: 100%;
	height: 350px;
}

.card,
.card .flip_box {
	position: relative;
}

.card .front,
.card .back {
	position: absolute;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}

/*.card {
	-moz-transform: perspective(1200px);
	-webkit-perspective: 1200px;
	perspective: 1200px;
}*/

.card .flip_box {
	-webkit-transition: all 0.5s ease-out;
	-o-transition: all 0.5s ease-out;
	transition: all 0.5s ease-out;
	-webkit-transform-style: preserve-3d;
	transform-style: preserve-3d;
}

.card .front {
	background-size: cover;
	background-position: center;
	border-radius: 5px;
}

.card .front.list-01 {
	background-image: url('../img/recruit/ad_shigeji.jpg');
}

.card .front.list-02 {
	background-image: url('../img/recruit/seo_sugiyama.jpg');
	background-position: left;
}

.card .front.list-03 {
	background-image: url('../img/recruit/sales_okubo.jpg');
	background-color: #ccc;
}

.card .front.list-04 {
	/* background-image: url('../img/recruit/seo_sugiyama.jpg'); */
	background-position: left;
}

.card .front.list-05 {
	/* background-image: url('../img/recruit/ad_shigeji.jpg'); */
}

.card .front.list-06 {
	/* background-image: url('../img/recruit/seo_sugiyama.jpg'); */
	background-position: left;
}

.card .f_title {
	padding-top: 30px;
}

.card .f_subline {
	padding-top: 255px;
	color: #fff;
	margin-bottom: 5px;
	text-shadow: 0 0 5px #000;
}

.card .f_headline {
	line-height: 23px;
	text-shadow: 0 0 5px #000;
}

.card .back {
	background-color: #cd002c;
	-webkit-transform: rotateY(180deg);
	-ms-transform: rotateY(180deg);
	transform: rotateY(180deg);
	border-radius: 5px;
	padding: 15px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.card .b_headline {
	padding: 0;
}

.card .b_text {
	font-size: 15px;
	line-height: 28px;
	padding-top: 10px;
	padding-left: 0px;
	opacity: 0.85;
}

/*
.card .b_button {
	position: absolute;
	left: 15px;
	bottom: 38px;
	width: 150px;
	height: 52px;
	background-color: #80001b;
	-webkit-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
}

.card .b_button:hover {
	background-color: #fff;
}

.card .b_button:hover a span {
	color: #cd002c;
}
*/
.card .flipped {
	-webkit-transform: rotateY(-180deg);
	-ms-transform: rotateY(-180deg);
	transform: rotateY(-180deg);
}

.card .r_wrap {
	position: absolute;
	right: 40px;
	bottom: 38px;
}

.card .b_round,
.card .s_round {
	position: absolute;
	right: 0px;
	bottom: 0px;
	width: 52px;
	height: 52px;
	border-radius: 50%;
	background-color: #cd002c;
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear;
}

.card .b_round {
	opacity: 0;
	background-color: #80001b;
}

.card .b_round_hover {
	-webkit-transform: scale(1.37);
	-ms-transform: scale(1.37);
	transform: scale(1.37);
	opacity: 0.4;
}

.card .b_round_back_hover {
	background-color: #cd002c;
}

.card .s_round_click {
	-webkit-transform: scale(1.7);
	-ms-transform: scale(1.7);
	transform: scale(1.7);
}

.card .s_round_back {
	background-color: #cd002c;
}

.card .s_arrow {
	width: 52px;
	height: 52px;
	background-image: url('https://img-fotki.yandex.ru/get/194549/29644339.5/0_d6c60_1d7815f0_orig');
	background-color: transparent;
	-webkit-transition: all 0.35s linear;
	-o-transition: all 0.35s linear;
	transition: all 0.35s linear;
}

.card .s_arrow_rotate {
	-webkit-transform: rotate(-180deg);
	-ms-transform: rotate(-180deg);
	transform: rotate(-180deg);
}

.carrier_rec {
	width: calc(100%/2);
}

.flex50 {
	width: 48%;
	margin-bottom: 50px;
}

.flex50 .data_content {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.flex50 .data_content_inner {
	width: 100%;
}

.flex50 h3 {
	text-align: center;
	font-size: 25px;
	margin-bottom: 10px;
	vertical-align: middle;
}

.flex50 p {}

.flex50 .data {
	text-align: center;
	font-size: 200%;
	color: #d30332;
	padding-left: 10px;
}

.flex50 .chart-container {
	position: relative;
	height: 300px;
}

.flex50 #m_and_f {}

@media (max-width: 767px) {
	.cmntw-ttl-01 {
		margin-bottom: 15px;
	}

	.cmntw-ttl-01 span {
		padding-left: 0;
		display: block;
	}

	.msd-list li {
		width: 48%;
		margin: 1%;
	}

	.rmr_planinfo .msd-list li {
		width: 100%;
		margin: 1% 1% 5%;
		padding-bottom: 0;
	}

	.ms-demand .bg {
		width: 100%;
		height: 600px;
		margin-bottom: -600px;
		margin-left: 0;
		background-position: left;
	}

	.ms-demand2 .bg {
		width: 100%;
		height: 200px;
		margin-bottom: 0px;
		margin-left: 0;
		margin-top: -100px;
	}

	.solution {
		font-size: 75px;
	}

	.ms-demand2 .ms-lead.container p {
		font-size: 20px;
	}

	.ms-demand2 .msd-list li {
		min-height: auto;
		width: 100%;
	}

	p.text-item02 {
		font-size: 17px;
	}

	.cov .cov_left,
	.cov .cov_right {
		width: 100%;
	}

	.flex .mswwb-txt {
		width: 50%;
	}

	.ms-demand.seo_voice > div.container > ul > li {
		width: 100%;
	}

	.ec_cta .am_fadeInUp {
		width: 100%;
	}

	.steps {
		padding: 0;
		overflow-x: initial;
		width: 100%;
	}

	.steps .cols .col {
		width: 100%;
		padding: 0 0px;
	}

	.steps {
		padding: 0;
		overflow-x: initial;
		width: 100%;
	}

	.steps .cols .col li .content {
		padding: 0 10px 0px 20px;
	}

	.main_bg.service h3 {
		font-size: 6vw;
	}

	.main_bg.service .ms-demand h3 {
		font-size: 15px;
	}

	.cmntw-ttl-01 {
		font-size: 28px;

	}

	.msp-col4-list li {
		width: 49%;
		margin-bottom: 15px;
	}

	.mscc-inner {
		width: 100%;
		margin-top: -30px;
	}

	.cmntw-ttl-01:before {
		margin-left: -50px;
	}

	.ms-demand2.recruit_ms > div.container {
		margin-top: 300px;
	}

	.recruit_ms .ms-lead.container {
		padding: 45px 0 10px;
	}

	.rcr_msg_inner {
		padding: 20px;
		width: 100%;
	}

	.recruit_ms .rcr_msg_inner {
		padding: 0px;
	}


	.tab_content {
		padding: 15px 15px 0;
	}

	.careaar_table {}

	.rulebook table {
		width: 100%;

	}

	.rulebook {}

	.rulebook .rule_container {
		overflow: scroll;
		padding: 0px;
	}

	.rulebook table {
		min-width: 100%;
	}

	.rulebook table tr.ghead {}

	.rulebook table tr th,
	.rulebook table tr td {
		/* word-break: break-all; */
	}

	span.dd_sec {
		font-weight: bold;
		padding-right: 25px;
		display: block;
		padding-top: 20px;
	}

	span.dd_sec::after {
		content: "";

	}

	.rcr_table_wrap {
		padding: 0 0 5px;
		display: table;
		border-bottom: none;
	}

	.msa-ttl-01 {
		margin-bottom: 10px;
	}

	.msal-name-01 {
		font-size: 4vw;
	}

	.main_bg.bg_white.main-service-04 > div.rmr_planinfo.container.ad_case > ul > li > div > h3 {
		padding-top: 20px;
		margin: 15px;
		padding-bottom: 15px;
	}

	.main_bg.bg_white.main-service-04 > div.rmr_planinfo.container.ad_case > ul > li > div > .mspi-txt {
		padding: 0 10px;
	}

	.recruit_ms .bg {
		margin-top: 0;
		margin-bottom: -305px;
	}

	.flex-7 h3 {
		font-size: 6vw;
	}

	.flex33_card {
		width: 100%;
		margin-bottom: 1%;
		height: 250px;
	}

	.card,
	.card .flip-box,
	.card .front,
	.card .back {
		width: 100%;
		height: 250px;
	}

	.card .b_round,
	.card .s_round {
		right: -20px;
		bottom: -20px;
	}

	.card .b_button {
		left: 15px;
		bottom: 15px;
	}

	.card .f_subline {
		padding-top: 180px;
	}

	.card h3 {
		font-size: 18px;
	}

	.card .b_text {
		font-size: 12px;
	}

	.filter a {
		width: auto;
		font-size: 11px;
	}

	.flex50 .chart-container {
		position: relative;
		width: 100%;
		height: 200px;
	}

	.flex50 {
		width: 100%;
		margin-bottom: 50px;
	}
    .tab_recruit{
        flex-wrap: wrap;
        justify-content: space-between;

    }
    .tab_recruit > div{
        margin: 0px 0px 5px;
        width:calc(100% / 2.5);
    }
    .tab_recruit > div a{
        border-radius: 10px;
    }
    .tab_recruit > div a.select{
        padding: 18px 0px;
        margin: 0px;
        background: #c9525c;
    }



}

@media (min-width: 1300px) {
	.recruit_ms .bg {
		width: 50%;
		margin-left: 39%;
	}
}

/* モーダル コンテンツエリア */
#modal-main {
	display: none;
	width: 80%;
	height: 80%;
	margin: 0;
	padding: 3%;
	background-color: #ffffff;
	color: #222;
	position: fixed;
	z-index: 999999999;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-box-shadow: 0 0 20px -5px rgb(212, 3, 50);
	box-shadow: 0 0 20px -5px rgb(212, 3, 50);
}

/* モーダル 背景エリア */
#modal-bg {
	display: none;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.5);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 99999999;
}

.modal_wrap input {
	display: none;
}

.modal_overlay {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	overflow: auto;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.7);
	opacity: 0;
	-webkit-transition: opacity 0.5s, -webkit-transform 0s 0.5s;
	transition: opacity 0.5s, -webkit-transform 0s 0.5s;
	-o-transition: opacity 0.5s, transform 0s 0.5s;
	transition: opacity 0.5s, transform 0s 0.5s;
	transition: opacity 0.5s, transform 0s 0.5s, -webkit-transform 0s 0.5s;
	-webkit-transform: scale(0);
	-ms-transform: scale(0);
	transform: scale(0);
}

.modal_trigger {
	position: absolute;
	width: 100%;
	height: 100%;
}

.modal_content {
	height: 80%;
	-ms-flex-item-align: center;
	align-self: center;
	width: 90%;
	max-width: 1280px;
	padding: 30px 30px 15px;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	background: #fff;
	font-size: 1.2rem;
	line-height: 2.6em;
	-webkit-transform: scale(1.2);
	-ms-transform: scale(1.2);
	transform: scale(1.2);
	-webkit-transition: 0.5s;
	-o-transition: 0.5s;
	transition: 0.5s;
	-webkit-box-shadow: 0 0 20px -5px rgb(212, 3, 50);
	box-shadow: 0 0 20px -5px rgb(212, 3, 50);
	border-radius: 8px;
	overflow: scroll;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
	-webkit-overflow-scrolling: touch;
}

.close_button {
	position: absolute;
	top: 14px;
	right: 16px;
	font-size: 24px;
	cursor: pointer;
}

.modal_wrap input:checked ~ .modal_overlay {
	-webkit-transform: scale(1);
	-ms-transform: scale(1);
	transform: scale(1);
	-webkit-transition: opacity 0.5s;
	-o-transition: opacity 0.5s;
	transition: opacity 0.5s;
	opacity: 1;
}


.modal_wrap input:checked ~ .modal_overlay .modal_content {
	-webkit-transform: scale(1);
	-ms-transform: scale(1);
	transform: scale(1);
}

.card button {
	border: 0;
	border-radius: 26px;
	padding-bottom: 2px;
}

.card .open_button {
	position: absolute;
	left: 15px;
	bottom: 38px;
	width: 150px;
	height: 52px;
	background-color: #80001b;
	-webkit-transition: all 0.3s;
	-o-transition: all 0.3s;
	transition: all 0.3s;
	border-radius: 25px;
	color: #fff;
	line-height: 52px;
	font-size: 1rem;
	cursor: pointer;
}

.card .open_button:hover {
	background-color: #fff;
	color: #cd002c;
}

.page_fv_carrier {
	height: 100%;
}

.page_fv_carrier canvas.particles-js-canvas-el {
	background: rgb(0, 0, 0, 0);
	top: 0;
	position: absolute;
	margin: 0;
}

.carrier_style {
	position: absolute;
	z-index: 5;
	width: 100%;
	height: 100%;
	text-align: center;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

.carrier_style h2 {
	color: #fff;
	text-align: center;
	width: 100%;
	display: block;
	padding: 0;
}

.carrier_style span {
	display: block;
	margin: 0;
}

#page-top {
	position: fixed;
	bottom: 20px;
	right: 20px;
	font-size: 77%;
	z-index: 99999999;
}

#page-top a {
	background: #d40332;
	text-decoration: none;
	color: #fff;
	width: 50px;
	padding: 0;
	text-align: center;
	display: block;
	border-radius: 50px;
	line-height: 50px;
}

#page-top a:hover {
	text-decoration: none;
	margin-bottom: 10px;
}

.m-gnav_content2 ul {
	display: block;
	width: 100%;
	max-width: 1200px;
	margin: auto;
}

.m-gnav_content2 ul li {
	float: left;
	width: calc(100% / 3 - 15px);
	margin-right: 20px;
}

.m-gnav_content2 ul li:nth-child(3),
.m-gnav_content2 ul li:nth-child(6) {
	margin-right: 0px;
}

@media screen and (max-width:1000px) {

	.breadcrumb ul li a,
	.breadcrumb ul li {
		font-size: 12px;
		-webkit-transition: all 0s;
		-o-transition: all 0s;
		transition: all 0s;
	}
}

@media (max-width: 460px) {
	.slick-list {
		overflow: visible !important;
	}

	.slick-prev,
	.slick-next {
		z-index: 2;
	}

	.slick-prev {
		left: -5px !important;
	}

	.slick-next {
		right: -5px !important;
	}

	.media-slide .slide-box a {
		background-color: #d40332;
		color: #fff;
	}

	.breadcrumb100w > div > div > ul {
		overflow-x: auto;
	}

	.breadcrumb ul li a,
		{
		font-size: 12px !important;
	}

	.breadcrumb li .fa,
	.breadcrumb ul li {
		font-size: 80% !important;
	}
}

.member-page {
	margin-bottom: 50px;
}

.profile_area {
	background: #fff;
	padding: 15px;
}

.profile_area h4 {
	font-size: 120%;
	text-align: center;
	padding: 10px 0;
	margin: 10px 0;
	background: #d40032;
	color: #fff;
	letter-spacing: .1em;
}

.profile_area .yakusyoku {}

.profile_area .name {}

.profile_area img {
	width: 100%;
}

.profile_area p {
	line-height: 1.8;
}

.profile_img {
	width: 100%;
	height: 400px;
	background-size: cover;
}

.txt_area h3 {
	color: #cd002c;
	font-size: 25px;
	padding: 20px 0;
	margin-bottom: 10px;
	letter-spacing: .1em;
	font-weight: bold;
}

.txt_area h3.cmntw-ttl-01:before {
	content: "";
	height: 1px;
	width: 20px;
	background: #cd002c;
	position: relative;
	z-index: 1;
	margin-left: -30px;
	display: inline-block;
	margin-right: 10px;
	top: 0;
	vertical-align: middle;
	margin-top: 0;
}

.txt_area p {}

.member-page .w70 {
	background: #fff;
}

.txt_area {
	margin: 15px;
}

.ceo-me {
	clear: both;
	position: relative;
	margin-bottom: 125px;
}

.ceo-me .profile_img {
	width: 40%;
	float: right;
	position: relative;
	top: 50px;
	right: 0;
	background-position: center;
	z-index: 1;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-box-shadow: 0 5px 50px -7px rgba(25, 25, 25, .7);
	box-shadow: 0 5px 50px -7px rgba(25, 25, 25, .7);
	min-height: 450px;
}

.ceo-me .txt_area {
	width: 70%;
	min-height: 300px;
	background: #fff;
	color: #181818;
	padding: 65px 195px 80px 100px;
	position: relative;
	top: 0;
	left: 0;
	z-index: 0;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}

.ceo-me.ceo-me-rev .profile_img {
	float: left;
	left: 0;
	right: auto;
}

.ceo-me.ceo-me-rev .txt_area {
	padding: 65px 105px 80px 195px;
	margin: 0 0 0 auto;
}

.ceo-h1 {
	text-align: center;
	margin: 50px 0;
}

.ceo-h1 h1 {
	font-size: 2.5em;
	position: relative;
	z-index: 1;
	padding-top: 50px;
}

.ceo-h1 .inner-txt {
	position: absolute;
	margin: auto;
	font-size: 9em;
	left: 0;
	right: 0;
	margin-top: -150px;
	color: #cd002c;
	z-index: 0;
	font-weight: bold;
	opacity: .1;
}

.ceo-h1 h2 {
	margin-top: 30px;
	font-size: 1.5em;
	letter-spacing: .2em;
}

.sign {
	position: relative;
	margin-top: -60px;
	margin-right: 100px;
	text-align: right;
}

span.red {
	color: #cd002c;
}

div.red {
	color: #cd002c;
}

@media (max-width: 768px) {
	.ceo-me .txt_area {
		padding: 35px 150px 50px 50px;
	}

	.ceo-me.ceo-me-rev .txt_area {
		padding: 35px 50px 50px 150px;
	}
}

@media (max-width: 460px) {
	.ceo-h1 h1 {
		font-size: 2em;
		position: relative;
		z-index: 1;
		padding-top: 0;
	}


	.ceo-h1 .inner-txt {
		position: absolute;
		margin: auto;
		font-size: 3em;
		left: 0;
		right: 0;
		margin-top: 0;
		color: #cd002c;
		z-index: 0;
		font-weight: bold;
		opacity: .1;
	}

	.ceo-me .profile_img,
	.ceo-me.ceo-me-rev .profile_img {
		width: 100%;
		float: none;
		min-height: 400px;
	}

	.profile_img {
		height: 200px;
	}

	.ceo-me .txt_area,
	.ceo-me.ceo-me-rev .txt_area {
		width: 100%;
		margin: 40px 0 0;
		padding: 15px;
	}

	.ceo-me {
		margin-bottom: 0px;
	}

	.w28 {
		width: 100%;
	}

	.w70 {
		width: 100% !important;
	}

	.sign {
		position: relative;
		margin-top: 30px;
		margin-right: 0;
		text-align: center;
	}

	.rcr_dd {
		width: 100%;
		line-height: 2;
		margin-top: 15px;
	}

}

span.required.contact_poinnt {
	background: #eb3f43;
}

span.contact_poinnt {
	background: #4e7ab9;
	color: #fff;
	padding: 5px 10px;
	border-radius: 5px;
	margin-left: 10px;
}

.cp_ipselect {
	overflow: hidden;
	width: 95%;
	text-align: center;
}

.cp_ipselect select {
	width: 100%;
	padding-right: 1em;
	cursor: pointer;
	text-indent: 0.01px;
	-o-text-overflow: ellipsis;
	text-overflow: ellipsis;
	border: none;
	outline: none;
	background: transparent;
	background-image: none;
	-webkit-box-shadow: none;
	box-shadow: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.cp_ipselect select::-ms-expand {
	display: none;
}

.cp_ipselect.cp_sl01 {
	position: relative;
	border: 1px solid #bbbbbb;
	border-radius: 2px;
	background: #ffffff;
}

.cp_ipselect.cp_sl01::before {
	position: absolute;
	top: 0.8em;
	right: 0.9em;
	width: 0;
	height: 0;
	padding: 0;
	content: '';
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid #666666;
	pointer-events: none;
}

.cp_ipselect.cp_sl01 select {
	padding: 0px 38px 8px 8px;
	color: #333;
	font-size: 16px;
}

@media (max-width: 460px) {
	span.required.contact_poinnt {
		background: #fff;
		color: #eb3f43;
	}
}


.tbl-r03 th {
	background: #CE002C;
	border: solid 1px #ddd;
	color: #fff;
	padding: 10px;
}

.tbl-r03 td {
	border: solid 1px #ddd;
	padding: 10px;
}

@media screen and (max-width: 640px) {
	.tbl-r03 {
		width: 100% !important;
	}

	.tbl-r03 tr {
		display: block !important;
		float: left !important;
	}

	.tbl-r03 tr td,
	.tbl-r03 tr th {
		border-left: none;
		display: block;
		font-size: 12px;
	}

	.tbl-r03 thead {
		display: block;
		float: left;
		width: 50%;
	}

	.tbl-r03 thead tr {
		width: 100% !important;
	}

	.tbl-r03 tbody {
		display: block !important;
		float: left !important;
		width: 50% !important;
	}

	.tbl-r03 tbody tr {
		width: 100% !important;
	}

	.tbl-r03 tr td + td {
		border-left: none !important;
	}

	.tbl-r03 tbody td:last-child {
		border-bottom: solid 1px #ccc !important;
	}

	.rulebook .tbl-r03 tr th {
		min-width: 50%;
	}
}

span.chusyaku {
	display: block;
	font-size: 85%;
	/* color: red; */
    color: #222;
}

.book {
	background: #d40032;
	color: #fff;
	width: 24%;
	text-align: center;
	border-radius: 5px;
	margin-top: 30px;
}

@media screen and (max-width: 640px) {
	.book {
		width: 100%;
		padding: 5px 0;
		margin-top: 10px;
	}

	.modal_content {
		padding: 10px;
	}
}

.mr-50 {
	margin-right: 50px;
}

span.gakkou {
	width: 31%;
	display: inline-block;
}

span.job {
	margin-right: 20px;
}

@media screen and (max-width: 640px) {
	span.gakkou {
		width: 100%;
		display: block;
		margin-bottom: 10px;
	}

	span.job {
		margin-right: 0px;
		width: 100%;
		display: block;
		margin-bottom: 10px;
	}

	#main > section > div.main_bg > div.main_inner > div > div.flex-7.am_fadeInUp.fadeInUp > div > div > a.btn.red_btn.dinb.am_fadeInUp.mr-50.fadeInUp {
		margin-bottom: 10px;
	}
}

.meta-data {
	text-align: right;
	color: #999;
}

.sns_area {
	position: absolute;
	margin-top: 20px;
}

span.sns_area_sns {
	background: #ce002c;
	color: #fff;
	z-index: 9999;
	position: relative;
	padding: 5px 10px;
	border-radius: 5px;
	margin-right: 10px;
}

span.sns_area_sns .fab,
span.sns_area_sns .fas {
	float: none !important;
	margin-top: 2px !important;
	padding-right: 10px;
	font-size: 100%;
}

br.sp-only {
	display: none;
}

.am_fadeInUp > #slide_wrapp > div {
	position: absolute;
	overflow: hidden;
	height: 700px;
	width: 100%;
	top: -350px;
	padding: 0;
}

#slide_wrapp img {
	transform-origin: center top;
	transform: scale(1.1);
	transition: 6s ease-out;
	overflow: hidden;
}

#slide_wrapp .slick-active img {
	transform: scale(1.0);
}



#slide_wrapp img {
	transform-origin: center top;
	transform: scale(1.1);
	transition: 6s ease-out;
	overflow: hidden;
}

#slide_wrapp .slick-active img {
	transform: scale(1.0);
}

@media screen and (max-width: 768px) {
	section > div.section_inner.foot_section.ovh > div > div > div.flex_50 {
		-ms-flex-wrap: wrap;
		flex-wrap: wrap;
	}

	section > div.section_inner.foot_section.ovh > div > div > div.flex_50 > .flex_50_inner {
		width: 100%;
	}

	section > div.section_inner.foot_section.ovh > div > div > div.flex_50 > div.flex_50.flex_50_inner > div {
		width: 100%;
	}

	section > div.section_inner.foot_section.ovh > div > div > div.flex_50 > div.flex_50.flex_50_inner > div > .btn {
		font-size: 100%;
		min-width: 100%;
	}

	section > div.section_inner.foot_section.ovh > div > div > div.flex_50 > div.flex_50.flex_50_inner > div {
		width: 100%;
	}

	.joint p {
		font-size: 90%;
		font-weight: normal;
		margin-bottom: 20px;
	}

	.msd-list li {
		width: 48%;
	}
}

@media screen and (max-width: 640px) {
	.access-cap h4 {
		font-size: 20px;
		margin-bottom: 10px;
	}

	.access-cap .content_inner {
		max-width: 100%;
	}

	br.sp-only {
		display: block;
	}

	.msd-list li {
		width: 100%;
	}

	.am_fadeInUp .btnlink {
		width: 80%;
	}

	.rec_button > div {
		width: 100%;
	}

	.modal_content {
		width: 90%;
		padding: 30px 15px 15px;
		font-size: 1rem;
	}

	.rec_button > div a {
		font-size: 3vw;
	}

	.am_fadeInUp > #slide_wrapp > div {
		width: 100%;
		top: 0;
		overflow: hidden !important;
		z-index: 0;
		position: relative;
		height: auto;
	}

	#top-mv {
		height: 90vh;
	}

	.mv-inner {
		height: 90vh;
	}
}

@media screen and (max-width: 320px) {

	.tbl-r03 tr td,
	.tbl-r03 tr th {
		height: 60px;
	}
}


@media all and (-ms-high-contrast: none) {
	.ptv_ttl {
		display: inline-block;
	}

	ruby > rt {
		display: ruby-text;
		letter-spacing: -.2em;
		ruby-position: over;
		ruby-overhang：none;
		ruby-align: space-around;
	}

	.right-text {
		padding-top: 250px;
	}

	#slide_wrapp img {
		transform-origin: center top;
		transform: scale(1.0);
		transition: 8s ease-out;
		overflow: hidden;
	}

	#slide_wrapp .slick-active img {
		transform: scale(1.0);
	}
}

@supports (-ms-ime-align: auto) {
	ruby > rt {
		display: ruby-text;
		letter-spacing: -.2em;
		ruby-position: over;
		ruby-overhang：none;
		ruby-align: space-around;
	}
}

#main > section > div > div > div > ul > div {
	padding: 30px 0;
}

.privacy_cont {
	line-height: 1.8;
	max-width: 900px;
	margin: auto;
}

.privacy_cont h2 {
	margin-bottom: 20px;
	font-size: 1.7em;
	letter-spacing: .2em;
}

.privacy_cont h3 {
	margin-bottom: 15px;
	font-size: 1.3em;
	margin-top: 25px;
	background: #ececec;
	padding-left: 15px;
}
.privacy_cont p a{
    text-decoration: underline;
    color: #0084b2;
}

.privacy_cont ul {
	margin: 10px;
}

.privacy_cont ul li {
	margin-left: 15px;
	list-style-type: disc;
	margin-bottom: 10px;
}

div.privacy_cont > ul > ul {
	margin-left: 15px;
}

.privacy_cont > ul > ul > li {
	margin-left: 15px;
	list-style-type: circle;
}

p.text-right {
	text-align: right;
}

/*---------------------------------------
0829 追加分
---------------------------------------*/
.float-left {
	float: left;
	width: 50%;
	margin-top: 20px;
}

.float-left a {
	width: 70% !important;
}

@media screen and (max-width: 640px) {
	.float-left {
		width: 100%;
	}

	.rulebook_cap .image img {
		width: 100%;
		margin: 0px auto;
	}

	span.sp-none {
		display: none;
	}
}

#lb figure {
	margin: 0;
	display: none;
}

#lb figure:target {
	display: block;
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	z-index: 9999;
}

#lb figure:target #overlay {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background: rgba(0, 0, 0, 0.7);
	text-decoration: none;
	color: inherit;
}
#lb figure:target #overlay picture{
    text-align: center;
    margin:0px auto;
}

#lb figure:target img {
	animation: fadein .3s;
}

@keyframes fadein {
	0% {
		transform: scale(0.2);
		opacity: 0.2;
	}

	100% {
		transform: scale(1);
		opacity: 1;
	}
}

.business-area .slide-box p {
	min-height: 55px;
}

.product-area .slide-box h3 {
	font-size: 90%;
}

.filter .child-area a {
	background: #f7f6f6;
	width: auto;
	min-width: 150px;
}

.filter .child-area a.active {
	background: #d00025;
}

.filter .child-area a[data-filter="sub"] {
	background: #dcdada;
}

.filter .child-area a.active[data-filter="sub"] {
	background: #d00025;
}
