@charset "UTF-8";
/* CSS Document */

/************************
 BASE
*************************/
html {
	font-size: 62.5%;
	overflow-x: hidden;
}

body {
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif, メイリオ, Meiryo, ＭＳ Ｐゴシック, MS P Gothic, Verdana, sans-serif;
	font-family: a-otf-futo-go-b101-pr6n, sans-serif;
	font-weight: 400;
	font-style: normal;
	font-kerning: auto;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 2.0;
	color: #333;
	background: #f3f2f4;
	overflow-x: hidden;
	letter-spacing: .5px;
	-webkit-font-smoothing: antialiased;
}

.eng {
	font-family: 'Noto Sans', sans-serif;
}

body * {
	box-sizing: border-box;
}

a {
	transition: .5s;
	color: #000;
	cursor: pointer;
}

a:hover {
	opacity: 0.8;
}

ul,
li,
ol {
	list-style: none;
}

img {
	/* display: block; */
	height: auto;
	max-width: 100%;
}

.prepare {
	text-align: center;
	font-weight: bold;
	padding: 100px 0;
}

h1,
h2,
h3,
h4,
h5 {
	font-family: a-otf-futo-go-b101-pr6n, sans-serif;
	font-weight: 500;
}

*:last-child {
	margin-bottom: 0 !important;
}

@media screen and (max-width: 768px) {
	.sp-none {
		display: none !important;
	}

	.no-top #mainvisual {
		padding-top: 0;
	}
}

@media screen and (min-width: 768px) {
	.sp-only {
		display: none !important;
	}
}

@media screen and (max-width: 768px) {
	.tab-only {
		display: none !important;
	}

	.sp-none {
		display: none !important;
	}

	body {
		font-kerning: auto;
		font-size: 14px;
		font-size: 1.4rem;
		line-height: 1.6;
	}
}

a[href^="tel:"] {
	text-decoration: underline;
}

@media screen and (min-width: 769px) {
	a[href^="tel:"] {
		pointer-events: none;
		text-decoration: none;
	}

	.u-tab-only {
		display: none !important;
	}

	.sp-only {
		display: none !important;
	}
}

/************************
 .sc-fade
*************************/

.sc-fade {
	opacity: 0;
	transform: translate(0, 50px);
	transition: all 0.8s;
}

.sc-fade.sc-fadein {
	opacity: 1;
	transform: translate(0, 0);
}



/************************
 material
*************************/
.button {
	max-width: 350px;
	width: 20%;
	font-size: 1.8rem;
	font-weight: normal;
	margin: auto;
	font-size: 2.0rem;
	padding: 0.5rem 1.6rem;
	color: #333;
	border: 1px solid #333;
}

.button-normal {
	background-color: transparent;
	color: #FFF;
	/* border: 1px solid #fff; */
}

.btn_corp .button-normal {
	background-color: #333;
	color: #FFF;
}

.button-primary {
	background-color: #0071bc;
	color: #FFF;
}

.button-caution {
	background-color: transparent;
	color: #FFF;
	/* border: 1px solid #fff; */
}

.button-caution:hover,
.button-primary:hover {
	color: rgba(255, 255, 255, 0.8);
}

span.ul {
	position: relative;
	display: inline-block;
}

span.ul:after {
	display: inline-block;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 0;
	background: #ffe200;
	height: 4px;
	width: 100%;
	content: "";
}


/************************
 layout
*************************/

.d-flex {
	display: flex;
	justify-content: center;
}

.d-block {
	display: block;
}

.text-right {
	text-align: right;
}

.text-center {
	text-align: center;
}

/**header**/

header {
	top: 0;
	left: 0;
	z-index: 1000;
	width: 100%;
	position: fixed;
	background: #fff;
}

.header::before {
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	width: 100%;
	height: 0%;
	content: "";
	background: #1e489d;
	background: -webkit-gradient(linear, left top, right top, from(#315399), to(#162560));
	background: -o-linear-gradient(left, #315399 0%, #162560 100%);
	background: linear-gradient(90deg, #315399 0%, #162560 100%);
	-webkit-transition: height 0.3s ease-in-out;
	-o-transition: height 0.3s ease-in-out;
	transition: height 0.3s ease-in-out;
}

.header.is-fixed {
	box-shadow: 0px 7px 13px 0px rgba(39, 39, 39, 0.3);
}

.header.is-fixed::before {
	height: 100%;
}

header .container {
	width: 100%;
	max-width: 100%;
	padding: 0 20px;
	background: transparent;
}

header .container .d-flex {
	width: 100%;
	height: 64px;
	flex-flow: row;
	justify-content: space-between;
	align-items: center;
}

header .container h1 {
	margin-bottom: 0;
}

header .container h1 img {
	max-width: 300px;
}

header .container h1 a {
	display: flex;
	align-items: center;
	font-size: 1.8rem;
	font-weight: normal;
	color: #666666;
	text-decoration: none;
}

header .container h1 a span {
	display: inline-block;
	margin-left: 1em;
	display: none;
}

.nav_btn {
	display: flex;
	max-width: 1000px;
	margin: 0 auto;
}

.nav_btn li {
	max-width: 140px;
	margin: 0 auto;
	padding: 0 15px;
}

.nav_btn li a {
	color: #fff;
	font-size: 15px;
	text-decoration: none;
	position: relative;
	display: inline-block;
	text-decoration: none;
}

.nav_btn li a::after {
	position: absolute;
	bottom: -4px;
	left: 0;
	content: '';
	width: 100%;
	height: 1px;
	background: #fff;
	transform: scale(0, 1);
	transform-origin: right top;
	transition: transform .3s;
}

.nav_btn li a:hover::after {
	transform-origin: left top;
	transform: scale(1, 1);
}

header .container nav * {
	margin-bottom: 0;
}

header .container nav ul {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	gap: 3rem;
}

header .container nav ul li {
	margin-right: 1rem;
}

header .container nav ul>li:last-child {
	margin-right: 72px;
}

header .container nav ul li a.button {
	font-size: 0.7em;
	padding: 10px;
}

header .container nav ul li a.button img {
	margin-bottom: 0.5em;
}

/**sp用**/

.sp-gnav {
	top: 0em;
	left: 0;
	z-index: 1000;
	width: 100%;
	position: fixed;
}

.sp-only-header nav ul {
	display: block;
}

.sp-only-header nav ul li a {
	display: block;
	color: #fff;
	padding: 10px 15px;
	text-decoration: none;
	font-weight: 400;
}

.sp-only-header nav ul li a span {
	color: #0000B3;
	font-size: 12px;
	padding: 2px 10px;
	line-height: 35px;
}

.sp-only-header nav ul li {
	border-bottom: 1px dotted #fff;
	margin-bottom: 0;
}

.sp-only-header {
	top: 0em;
	left: 0;
	z-index: 1000;
	width: 100%;
	position: fixed;
}

nav {
	display: block;
	width: 300px;
	transition: all .5s;
	z-index: 3;
	opacity: 1;
}

.open nav {
	left: 0;
	opacity: 1;
}

nav .inner {
	padding: 25px 10px;
}

nav .inner ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

nav .inner ul li {
	position: relative;
	margin: 0;
	border-bottom: 0.5px solid #333;
}

nav .inner ul li a {
	display: block;
	color: #333;
	font-weight: 400;
	font-size: 14px;
	padding: 1em 10px;
	text-decoration: none;
	transition-duration: 0.2s;
}

nav .inner ul li a:hover {
	background: rgba(0, 0, 179, 0.1);
}

nav .inner ul li a span {
	color: #333;
	border-bottom: 0.5px solid #333;
	font-size: 10px;
	padding: 3px 0;
}

@media screen and (max-width: 767px) {
	nav {
		left: -220px;
		width: 260px;
	}

	nav {
		display: block;
		position: fixed;
		top: 0;
		bottom: 0;
		background: #ffffff;
		overflow-x: hidden;
		overflow-y: auto;
		-webkit-overflow-scrolling: touch;
		transition: all .5s;
		z-index: 3;
		opacity: 0;
	}
}

/*============
.toggle_btn
=============*/
.toggle_btn {
	display: block;
	position: fixed;
	top: 13px;
	right: 30px;
	width: 30px;
	height: 30px;
	transition: all .5s;
	cursor: pointer;
	z-index: 3;
}

.toggle_btn span {
	display: block;
	position: absolute;
	left: 0;
	width: 30px;
	height: 2px;
	background-color: #333;
	border-radius: 4px;
	transition: all .5s;
}

.toggle_btn span:nth-child(1) {
	top: 4px;
}

.toggle_btn span:nth-child(2) {
	top: 14px;
}

.toggle_btn span:nth-child(3) {
	bottom: 4px;
}

.open .toggle_btn span {
	background-color: #fff;
}

.open .toggle_btn span:nth-child(1) {
	-webkit-transform: translateY(10px) rotate(-315deg);
	transform: translateY(10px) rotate(-315deg);
}

.open .toggle_btn span:nth-child(2) {
	opacity: 0;
}

.open .toggle_btn span:nth-child(3) {
	-webkit-transform: translateY(-10px) rotate(315deg);
	transform: translateY(-10px) rotate(315deg);
}

/*============
#mask
=============*/
#mask {
	display: none;
	transition: all .5s;
}

.open #mask {
	display: block;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: #000;
	opacity: .8;
	z-index: 2;
	cursor: pointer;
}

.drawer-overlay {
	z-index: 10;
}

.sp-only ul.d-flex {
	/* background: #0000B3; */
	background: #0A015A;
	margin-top: 4.55em;
	text-align: center;
	display: flex;
	justify-content: space-between;
	z-index: 900;
	width: 100%;
	position: fixed;
}

.sp-only ul.d-flex li {
	padding: 2px 7px;
	margin-bottom: 0;
	border-right: 1px solid #fff;
	width: 100px;
}

.sp-only ul.d-flex li:nth-child(5) {
	border: none;
}

.sp-only ul.d-flex li a {
	color: #fff;
	font-size: 2vw;
	padding: 10px 3px;
}

header .container nav ul>li:last-child {
	margin-right: 52px;
}

@media screen and (min-width: 769px) {
	header .container .d-flex {
		height: 80px;
		align-items: center;
	}

	header .container h1 img {
		max-width: 400px;
		width: 100%;
		margin: 0 auto;
	}

	header .container h1 a {
		font-size: 2.5rem;
	}

	header .container h1 a span {
		display: inline-block;
		margin-left: 1em;
		font-size: 15px;
	}

	header .container {
		padding: 30px 40px;
		background: transparent;
	}

	header .container nav ul li a.button {
		font-size: 0.9em;
		padding: 15px 35px;
		position: relative;
		background: #333;
	}

	header .container nav ul li a.button:hover {
		color: rgba(255, 255, 255, 0.8);
	}

	/* header .container nav ul li .button:before {
	content: "\f105";
	position:absolute;
	left:8px;
	font-family: 'FontAwesome';
} */

	header .container nav ul li a.button img {
		margin-bottom: 0;
	}

	header .container nav ul>li:last-child {
		margin-right: 0;
	}
}

/**footer**/

footer {
	text-align: center;
	border-top: 1px solid #333;
	padding-top: 3em;
	background: #0A015A;
}

footer h1 {
	margin-bottom: 10px;
}

footer h1 a {
	color: #fff;
}

footer h1 img {
	max-width: 40rem;
	width: 100%;
}

footer .footer_top {
	background: #0A015A;
	padding: 0 2.0rem 0;
}

footer .footer_top h1 {
	margin-bottom: 0;
}

footer .footer_top img {
	margin: 0 auto;
	width: 350px;
}

footer .footer_top p,
footer .footer_top a {
	color: #fff !important;
	font-size: 1.2rem;
	/*text-decoration: none;*/
	/*pointer-events: auto;*/
}

footer .footer_top p {
	margin-top: 8px;
	margin-bottom: 2em !important;
}

footer .footer_btm p {
	font-size: 1.1rem;
	padding: 1.6rem;
	color: #fff;
}

footer .footer_table {
	width: 100%;
	max-width: 1000px;
	margin: 20px auto;
	display: flex;
	justify-content: center;
}

footer table {
	width: 100%;
	margin: 0 20px;
}

footer table th {
	width: 25%;
	font-weight: 600;
	font-size: 1.2rem;
}

footer table th::before {
	display: none;
}

footer table td {
	font-weight: 300;
}

footer table th,
footer table td {
	padding: 8px 15px;
	font-size: 1.2rem;
	color: #fff;
	border-bottom: 1px dotted #E1E1E1;
}

/***追従するトップへ戻るボタン***/
#page-top {
	position: fixed;
	right: -35px;
	bottom: 55px;
	height: 50px;
	text-decoration: none;
	font-weight: 600;
	transform: rotate(90deg);
	font-size: 1.2em;
	line-height: 3.5rem;
	color: #0088C0;
	padding: 0 0 0 35px;
	border-top: solid 1px;
	letter-spacing: 2px;
	/* font-family: 'Playfair Display', serif; */
}

#page-top::before {
	content: "";
	display: block;
	position: absolute;
	top: -1px;
	left: 0px;
	width: 15px;
	border-top: solid 1px;
	transform: rotate(35deg);
	transform-origin: left top;
}

.no-top #mainvisual .img-wrapper .d-flex .copy-box {
	display: block;
	padding-top: 40px;
	padding-bottom: 40px;
	text-align: center;
	background: rgba(0, 0, 0, 0.5);
	padding: 3%;
	height:500px;
	margin-top: 11em;
}

/***トップへ戻るボタンここまで***/
@media screen and (min-width: 769px) {
	footer .footer_top p {
		font-size: 1.2rem;
		margin-bottom: 2em !important;
	}

	footer .footer_btm p {
		font-size: 1.2rem;
		margin-top: 1em;
	}
}


/** index #mainvisual **/

#mainvisual {
	width: 100%;
	position: relative;
}

body:not(.no-top) #mainvisual .img-wrapper {
	padding-top: 64px;
	width: 88%;
	max-width: 1664px;
	margin: auto;
}

.txt-wrapper {
	text-align: center;
	background-size: cover;
	color: #4e4e4e;
	position: relative;
}

.txt-wrapper:before {
	content: "";
	width: 100%;
	height: 120px;
	position: absolute;
	top: -120px;
	left: 0;
	z-index: -1;
}

.txt-wrapper h2 strong {
	font-family: 'Playfair Display', serif;
	font-weight: 700;
	display: inline-block;
	text-align: center;
	position: relative;
	z-index: 1;
}

.txt-wrapper h2 {
	font-size: 4.8rem;
	line-height: 1.2;
	margin-bottom: 25px;
	color: #4e4e4e;
	text-align: center;
	position: relative;
	text-shadow: 0 0 2px white;
}

.txt-wrapper h2 span {
	font-size: 2.0rem;
	text-align: center;
	display: block;
}

@media screen and (min-width: 769px) {
	body:not(.no-top) #mainvisual .img-wrapper {
		padding-top: 80px;
	}

	.txt-wrapper h2 {
		font-size: 5.6rem;
	}

}

/** detail #mainvisual **/
.no-top #mainvisual {
	padding-bottom: 0;
	position: relative;
	height: auto;
}

@keyframes fadein {
	from {
		opacity: 0;
		transform: translateY(20px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.no-top #mainvisual .img-wrapper img {
	width: 100%;
	height: 700px;
	object-fit: cover;
	animation-name: fadein;
	animation-duration: 2s;
	visibility: visible;
    /*animation-name: fadeInUp;*/
    /*display: none;*/
}

.fade-reset {
	animation-name: fadeInUp;
    display: none;
}

.no-top #mainvisual .img-wrapper .d-flex {
	height: 100%;
	flex-flow: column;
	justify-content: space-between;
}

.no-top #mainvisual {
	padding-top: 4em;
	position: relative;
}

.no-top #mainvisual .img-wrapper {
	background: url("../img/recruit-1.jpg") no-repeat center;
	background-size: cover;
	height: 700px;
}

.no-top #mainvisual .img-wrapper.detail2 {
	/* background: url("../img/mainImg_rec02.jpg") no-repeat right; */
	background: url("../img/recruit-2.jpg") no-repeat center top;
	background-size: cover;
	height: 700px;
}

.no-top #mainvisual .img-wrapper.detail3 {
	background: url("../img/recruit-3.jpg") no-repeat center top;
	background-size: cover;
}

.no-top #mainvisual .img-wrapper.detail4 {
	background: url("../img/recruit-3.jpg") no-repeat center top;
	background-size: cover;
}

.no-top #mainvisual .img-wrapper.detail5 {
	/*background: url("../img/222007779.jpg") no-repeat center top;*/
	background-size: cover;
}

.no-top #mainvisual .img-wrapper.detail6 {
	/*background: url("../img/215339349.jpg") no-repeat center top;*/
	background-size: cover;
}

.no-top #mainvisual .img-wrapper .container {
	max-width: 1728px;
	position: relative;
	height: 100%;
	width: 90%;
}

.no-top #mainvisual .img-wrapper .icon {
	width: 60%;
	margin: 20px auto 0;
}

.no-top #mainvisual .img-wrapper .d-flex {
	height: 100%;
	flex-flow: row;
	justify-content: center;
}

.no-top #mainvisual .img-wrapper .d-flex .maiTit h1 strong {
	font-size: 4rem;
	margin-bottom: 0.25em;
	text-align: center;
	color: #fff;
	font-weight: 600;
	/* font-family: 'Oswald', '游ゴシック' ,'YuGothic' ,'メイリオ' ,'Meiryo' ,'ＭＳ Ｐゴシック' ,sans-serif; */
	letter-spacing: 2px;
}

.no-top #mainvisual .img-wrapper .d-flex .maiTit h1 {
	font-size: 4rem;
	margin-bottom: 0.25em;
	text-align: center;
	visibility: visible;
    animation-delay: 0.3s;
    animation-name: fadeInRight;
}

.no-top #mainvisual .img-wrapper .d-flex .maiTit p strong {
	font-size: 5.5rem;
	font-weight: 600;
	letter-spacing: 6px;
	color: #fff;
	text-shadow: 0 0 10px #000;
}

.point_box1 {
	display: flex;
	justify-content: space-between;
	width: 420px;
}

.point_box2 {
	display: flex;
	justify-content: space-between;
	width: 420px;
}

@media screen and (max-width: 767px) {
	header {
		background: #fff;
	}

	.no-top #mainvisual .img-wrapper .container {
		width: 100%;
	}

	.no-top #mainvisual .inner {
		position: relative;
		z-index: 4;
		top: 38%;
	}

	.no-top #mainvisual {
		padding-top: 4.7em;
		margin-bottom: 3em;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit h1 {
		/* font-family: "游教科書体"; */
		font-size: 1.4rem;
		color: #fff;
		margin-bottom: 0.25em;
		text-align: center;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit h1 strong {
		text-align: center;
		color: #fff;
		text-shadow: 1px 1px 20px #000;
		font-size: 4rem;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit p {
		font-size: 1.8rem;
		font-family: 'Oswald', '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', sans-serif;
		letter-spacing: 2px;
		font-weight: 400;
		text-align: center;
		color: #fff;
		padding: 10px 0 10px 10px;
		text-shadow: 1px 1px 20px #000;
		border-top: 1px solid #FFF;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit .kv_koyo {
		padding: 5px 0;
		margin: 0 auto 1em;
		max-width: 250px;
		background: #fff;
		/* color: #0000B3; */
		color: #0A015A;
		text-shadow: none;
		border: none;

	}

	.kv_koyo_comment {
		visibility: visible;
		animation-delay: 1.0s;
		animation-name: fadeInRight;
	}

	.no-top #mainvisual .img-wrapper .d-flex .copy-box span {
		font-size: 2rem;
	}

	.no-top #mainvisual .img-wrapper .d-flex .pointWrap {
		display: flex;
		justify-content: center;
		padding-bottom: 20px;
		padding-top: 20px;
	}

	.no-top #mainvisual .img-wrapper .d-flex .pointWrap li {
		width: 90px;
		height: 90px;
		color: #fff;
		background-color: #ff375400;
		border: 1px solid #fff;
		text-align: center;
		font-size: 1.5rem;
		line-height: 1.2;
		display: flex;
		justify-content: center;
		align-items: center;
		font-weight: 400;
		margin: 0 1.5%;
	}
}


@media screen and (max-width:460px) {
	.no-top #welfare .container .fBox .text-box h3 {
		font-size: 1.7rem;
	}

	.no-top #welfare .container .fBox .text-box {
		padding: 25px 10px;
	}
}

@media screen and (min-width: 769px) {
	.no-top #mainvisual {
		position: relative;
	}

	.no-top #mainvisual .img-wrapper .icon {
		position: absolute;
		right: 40px;
		top: 90px;
		width: 18%;
		margin: 0;
	}

	.no-top #mainvisual .img-wrapper .d-flex .pointWrap {
		display: flex;
		justify-content: center;
		padding-bottom: 20px;
		padding-top: 20px;
	}

	.no-top #mainvisual .img-wrapper .d-flex .pointWrap li {
		width: 160px;
		height: 160px;
		text-align: center;
		font-size: 1.6rem;
		line-height: 1.4;
		justify-content: center;
		align-items: center;
		font-weight: 600;
		margin: 0 1.5%;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit h1 {
		font-size: 4.8rem;
		margin-bottom: 1.25em;
		text-align: center;
	}

	.no-top #mainvisual .img-wrapper .d-flex .copy-box {
		display: inline-block;
		max-width: 800px;
		width: 100%;
		margin: 0 auto;
		padding-top: 40px;
		padding-bottom: 40px;
		text-align: center;
		background: rgba(0, 0, 0, 0.5);
		padding: 4%;
		height: 590px;
		margin-top: 5em;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit p {
		/* font-family: "游教科書体"; */
		color: #fff;
		text-shadow: 0 0 8px #000;
		font-size: 2.4rem;
		font-weight: 400;
		max-width: 800px;
		text-align: center;
		padding: 10px 0;
		line-height: 1.8;
		font-size: 2rem;
		border-top: 1px solid #FFF;
		font-family: 'Oswald', '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', sans-serif;
		letter-spacing: 2px;
	}

	.no-top #mainvisual .img-wrapper .d-flex .copy-box span {
		font-size: 2rem;
	}
}

.maiTit {
	/* text-shadow: 1px 1px 1px #fff, -1px 1px 1px #fff, 1px -1px 1px #fff, -1px -1px 1px #fff; */
}

.wrap {
	width: 768px;
	margin: 0 auto;
}

.kv_txt {
	position: relative;
}

.eachTextAnime {
	position: absolute;
	top: 50%;
	left: 5%;
	width: 62vw;
	color: #fff;
	font-size: 2em;
	-webkit-font-smoothing: auto;
	/* font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",sans-serif; */
	font-size: 2.5vw;
	letter-spacing: .2em;
	padding: 0 30px;
	background-color: rgba(0, 0, 0, .4);
	/* text-shadow: 0 0 10px #000; */
}

.eachTextAnime span:nth-of-type(16) {
	display: block;
	height: 0;
}
.eachTextAnime span:nth-of-type(32) {
	display: block;
	height: 0;
}
.eachTextAnime span:nth-of-type(52) {
	display: block;
	height: 0;
}

/*
@media screen and (max-width: 767px) {
	.eachTextAnime span:nth-of-type(17) {
		display: block;
		height: 0;
	}
}*/

.kv_subtxt {
	position: absolute;
	top: 70%;
	left: 5%;
	color: #fff;
	font-size: 1em;
	-webkit-font-smoothing: auto;
	/* font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",sans-serif; */
	font-size: 1.5vw;
	margin-top: 65px;
	text-align: left;
	letter-spacing: .2em;
	/* text-shadow: 0 0 10px #000; */
}

.eachTextAnime span {
	opacity: 0;
}

.eachTextAnime.appeartext span {

	animation: text_anime_on 1s ease-out forwards;
}


@keyframes text_anime_on {
	0% {
		opacity: 0;
	}

	50% {
		opacity: 0;
	}


	100% {
		opacity: 1;
	}
}

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

	.text-move {
		font-size: 30px;
	}
}

/** detail pankuzu **/
.no-top .pankuzu {
	/*
	position:absolute;
	top:780px;
*/
	position: relative;
	width: 100%;
	z-index: 1;
	font-size: 10px;
}

.no-top .pankuzu .inner {
	padding: 0 20px;
}

.no-top .pankuzu * {
	color: #4e4e4e;
}

.no-top .pankuzu li {
	display: inline-block;
	margin-right: 0.8rem;
}

.no-top .pankuzu li:after {
	content: ">";
	padding-left: 0.8rem;
}

.no-top .pankuzu li:last-child:after {
	content: "";
}

@media screen and (min-width: 769px) {
	.no-top .pankuzu {
		padding: 20px 0 0;
	}
}

/** #contents **/
#contents {
	margin-bottom: 10px;
}

#contents section {
	padding: 56px 0 100px;
}

#contents section h2 {
	text-align: center;
	color: #333;
	font-size: 4.8rem;
}

#contents section h2 strong {
	font-size: 10rem;
	line-height: 1.2;
	margin-bottom: 40px;
	color: #0A015A;
	text-align: center;
	position: relative;
	text-shadow: 0 0 2px white;
	z-index: 1;
	font-family: 'Oswald', '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', sans-serif;
	letter-spacing: 4px;
}

#contents section .about_ttl h2 {
	text-align: left;
	display: flex;
	align-items: center;
	animation-duration: 1.5s;
	visibility: visible;
    animation-name: fadeInRight;
    margin-top: 0px;

}

#contents section .about_ttl h2:after {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
	margin-left: .4em;
}

#contents section .about_ttl h2 strong {
	padding-left: 0.5em;
}


#contents section .privacy_ttl h2 {
	text-align: left;
	display: flex;
	align-items: center;
	margin-bottom: 2em !important;
}

#contents section .privacy_ttl h2:after,
#contents section .privacy_ttl h2:before {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
	margin: 0 0.4em;
}

#contents section .privacy_ttl h2 strong {
	padding-left: 0.5em;
	font-size: 7rem;
	margin-bottom: 0;
}


#contents section .thanx_ttl h2 {
	text-align: left;
	display: flex;
	align-items: center;
	margin-bottom: 4em !important;
	margin-top: 5em;
}

#contents section .thanx_ttl h2:after,
#contents section .thanx_ttl h2:before {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
	margin: 0 0.4em;
}

#contents section .thanx_ttl h2 strong {
	padding-left: 0.5em;
	font-size: 7rem;
	margin-bottom: 0;
}


#contents section .recruit_ttl h2 strong {
	padding-right: 0.5em;
}

#contents section .recruit_ttl h2 {
	text-align: right;
	display: flex;
	align-items: center;
	animation-duration: 1.5s;
	visibility: visible;
    animation-name: fadeInLeft;
}

#contents section .recruit_ttl h2:before {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
	margin-right: .4em;
}

.slideshow {
	position: absolute;
	width: 100vw;
	height: 700px;
	overflow: hidden;
}

.slideshow-image {
	position: absolute;
	width: 100%;
	height: 100%;
	background: no-repeat 50% 50%;
	background-size: cover;
	-webkit-animation-name: kenburns;
	animation-name: kenburns;
	-webkit-animation-timing-function: linear;
	animation-timing-function: linear;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
	-webkit-animation-duration: 16s;
	animation-duration: 16s;
	opacity: 1;
	transform: scale(1.2);
}

.slideshow-image:nth-child(1) {
	-webkit-animation-name: kenburns-1;
	animation-name: kenburns-1;
	z-index: 3;
}

.slideshow-image:nth-child(2) {
	-webkit-animation-name: kenburns-2;
	animation-name: kenburns-2;
	z-index: 2;
}

.slideshow-image:nth-child(3) {
	-webkit-animation-name: kenburns-3;
	animation-name: kenburns-3;
	z-index: 1;
}

.slideshow-image:nth-child(4) {
	-webkit-animation-name: kenburns-4;
	animation-name: kenburns-4;
	z-index: 0;
}

@-webkit-keyframes kenburns-1 {
	0% {
		opacity: 1;
		transform: scale(1.2);
	}

	1.5625% {
		opacity: 1;
	}

	23.4375% {
		opacity: 1;
	}

	26.5625% {
		opacity: 0;
		transform: scale(1);
	}

	100% {
		opacity: 0;
		transform: scale(1.2);
	}

	98.4375% {
		opacity: 0;
		transform: scale(1.2117647059);
	}

	100% {
		opacity: 1;
	}
}

@keyframes kenburns-1 {
	0% {
		opacity: 1;
		transform: scale(1.2);
	}

	1.5625% {
		opacity: 1;
	}

	23.4375% {
		opacity: 1;
	}

	26.5625% {
		opacity: 0;
		transform: scale(1);
	}

	100% {
		opacity: 0;
		transform: scale(1.2);
	}

	98.4375% {
		opacity: 0;
		transform: scale(1.2117647059);
	}

	100% {
		opacity: 1;
	}
}

@-webkit-keyframes kenburns-2 {
	23.4375% {
		opacity: 1;
		transform: scale(1.2);
	}

	26.5625% {
		opacity: 1;
	}

	48.4375% {
		opacity: 1;
	}

	51.5625% {
		opacity: 0;
		transform: scale(1);
	}

	100% {
		opacity: 0;
		transform: scale(1.2);
	}
}

@keyframes kenburns-2 {
	23.4375% {
		opacity: 1;
		transform: scale(1.2);
	}

	26.5625% {
		opacity: 1;
	}

	48.4375% {
		opacity: 1;
	}

	51.5625% {
		opacity: 0;
		transform: scale(1);
	}

	100% {
		opacity: 0;
		transform: scale(1.2);
	}
}

@-webkit-keyframes kenburns-3 {
	48.4375% {
		opacity: 1;
		transform: scale(1.2);
	}

	51.5625% {
		opacity: 1;
	}

	73.4375% {
		opacity: 1;
	}

	76.5625% {
		opacity: 0;
		transform: scale(1);
	}

	100% {
		opacity: 0;
		transform: scale(1.2);
	}
}

@keyframes kenburns-3 {
	48.4375% {
		opacity: 1;
		transform: scale(1.2);
	}

	51.5625% {
		opacity: 1;
	}

	73.4375% {
		opacity: 1;
	}

	76.5625% {
		opacity: 0;
		transform: scale(1);
	}

	100% {
		opacity: 0;
		transform: scale(1.2);
	}
}

@-webkit-keyframes kenburns-4 {
	73.4375% {
		opacity: 1;
		transform: scale(1.2);
	}

	76.5625% {
		opacity: 1;
	}

	98.4375% {
		opacity: 1;
	}

	100% {
		opacity: 0;
		transform: scale(1);
	}
}

@keyframes kenburns-4 {
	73.4375% {
		opacity: 1;
		transform: scale(1.2);
	}

	76.5625% {
		opacity: 1;
	}

	98.4375% {
		opacity: 1;
	}

	100% {
		opacity: 0;
		transform: scale(1);
	}
}

#mainvisual .index_top h1 {
	position: absolute;
	max-width: 800px;
	width: 100%;
	top: 65%;
	left: 50%;
	transform: translate3d(-50%, -50%, 0);
	z-index: 99;
	text-align: center;
	/* font-family: Raleway, sans-serif; */
	font-weight: 600;
	text-transform: uppercase;
	/* background-color: rgba(255, 255, 255, 0.75); */
	box-shadow: 0 1em 2em -1em rgba(0, 0, 0, 0.5);
	padding: 3em 2em;
	line-height: 1.5;
	font-size: 40px;
	color: #fff;
}

#mainvisual .index_top h1 small {
	display: block;
	text-transform: lowercase;
	font-size: 25px;
}

#mainvisual .index_top h1 small:first-child {
	border-bottom: 1px solid rgba(255, 255, 255, 0.25);
	padding-bottom: 0.5em;
}

#mainvisual .index_top h1 small:last-child {
	border-bottom: 1px solid rgba(255, 255, 255, 0.25);
	padding-top: 0.5em;
}

#contents section .vision_ttl h2 {
	text-align: right;
	display: flex;
	align-items: center;
	animation-duration: 1.5s;

}

#contents section .vision_ttl h2:before {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
	margin-right: .4em;
}

#contents section .vision_ttl h2 strong {
	font-size: 10rem;
	line-height: 1.2;
	margin-bottom: 40px;
	padding-right: 0.5em;
	color: #707070;
	text-align: center;
	position: relative;
	text-shadow: 0 0 2px white;
	z-index: 1;
	font-family: 'Oswald', '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', sans-serif;
	letter-spacing: 4px;
}

#contents section .work_ttl h2 {
	text-align: left;
	display: flex;
	align-items: center;
	animation-duration: 1.5s;
	visibility: visible;
    animation-name: fadeInRight;
}

#contents section .work_ttl h2:after {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
	margin-left: .4em;
}

#contents section .work_ttl h2 strong {
	padding-left: 0.5em;
}




#contents section .welfare_ttl h2 {
	text-align: right;
	display: flex;
	align-items: center;
	animation-duration: 1.5s;
	visibility: visible;
    animation-name: fadeInLeft;

}

#contents section .welfare_ttl h2:before {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
	margin-right: .4em;
}

#contents section .welfare_ttl h2 strong {
	padding-right: 0.5em;
}



#contents section .interview_ttl h2 {
	text-align: left;
	display: flex;
	align-items: center;
	animation-duration: 2s;
	border: none;
    visibility: visible;
    animation-name: fadeInRight;
}

#contents section .interview_ttl h2:after {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
	margin-left: .4em;
}

#contents section .interview_ttl h2 strong {
	padding-left: 0.5em;
}



#contents section .message_ttl h2 {
	text-align: right;
	display: flex;
	align-items: center;
	animation-duration: 1.5s;
	visibility: visible;
    animation-name: fadeInLeft;

}

#contents section .message_ttl h2:before {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
	margin-right: .4em;
}

#contents section .message_ttl h2 strong {
	padding-right: 0.5em;
}


#contents section .guideline_ttl h2 {
	text-align: left;
	display: flex;
	align-items: center;
	animation-duration: 1.5s;
	visibility: visible;
    animation-name: fadeInRight;
}

#contents section .guideline_ttl h2:after {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
	margin-left: .4em;
}

#contents section .guideline_ttl h2 strong {
	padding-left: 0.5em;
}



#contents section .entry_ttl h2 {
	text-align: right;
	display: flex;
	align-items: center;
	animation-duration: 1.5s;
	visibility: visible;
    animation-name: fadeInLeft;
}

#contents section .entry_ttl h2:before {
	content: "";
	flex-grow: 1;
	height: 1px;
	background: #444;
	display: block;
	margin-right: .4em;
}

#contents section .entry_ttl h2 strong {
	padding-right: 0.5em;
}

#contents section h2 span {
	font-size: 2.0rem;
	text-align: center;
	display: block;
}

#contents section h2.sp-only {
	clear: both;
}

.no-top #contents section .container {
	max-width: 1584px;
	margin-top: 3em;
}

#contents .bg_color {
	background: #f7f7f7;
}

#message .container {
	position: relative;
	width: 100%;
	height: 100%;
}

#message .container .photoBox {
	position: relative;
	width: 100%;
	padding-left: 37.5vw;
}

#message .container .txtBox {
	/* display: flex; */
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	align-content: center;
	position: absolute;
	top: 20em;
	left: 4em;
	width: 50vw;
	/* height: 24em; */
	padding: 4vh 2.5vw 3vh;
	z-index: 1;
	background: #fff;
}

@media screen and (max-width: 1050px) {
	#message .container .txtBox {
		width: 74vw;
	}
}

@media screen and (min-width: 769px) {
	#contents section h2 {
		font-size: 2.2rem;
		font-weight: 600;
		letter-spacing: 0px;
	}


	#contents section h2 span {
		font-size: 2.0rem;

	}
}

.privacy_txt {
	padding: 5rem 10px;
}

@media screen and (max-width:767px) {
	#contents .bg_color {
		background: #f7f7f7;
		padding-bottom: 5em;
	}

	#mainvisual .index_top h1 {
		position: absolute;
		max-width: 800px;
		width: 87%;
		top: 65%;
		left: 50%;
		transform: translate3d(-50%, -50%, 0);
		z-index: 99;
		text-align: center;
		font-family: Raleway, sans-serif;
		font-weight: 300;
		text-transform: uppercase;
		background-color: rgba(255, 255, 255, 0.75);
		box-shadow: 0 1em 2em -1em rgba(0, 0, 0, 0.5);
		padding: 3em 1em;
		line-height: 1.5;
		font-size: 18px;
	}

	#mainvisual h1 small {
		display: block;
		text-transform: lowercase;
		font-size: 12px;
	}

	.no-top #contents section .container {
		max-width: 1584px;
		display: block;
		padding: 0 30px;
		margin: 5em auto 0;
	}

	.slideshow {
		position: absolute;
		width: 100vw;
		/* height: 65vh; */
		overflow: hidden;
	}

	.eachTextAnime {
		position: absolute;
		width: 93%;
		top: 50%;
		left: 5%;
		color: #fff;
		font-size: 2em;
		-webkit-font-smoothing: auto;
		/* font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",sans-serif; */
		font-size: 1vw;
		letter-spacing: .2em;
	}

	.kv_subtxt {
		position: absolute;
		top: 50%;
		left: 5%;
		color: #fff;
		font-size: 1.3em;
		-webkit-font-smoothing: auto;
		/* font-family: 游明朝,"Yu Mincho",YuMincho,"Hiragino Mincho ProN","Hiragino Mincho Pro",sans-serif; */
		font-size: 3.2vw;
		letter-spacing: .1em;
		margin-top: 35px;
		text-align: left;
		/* text-shadow: 0 0 5px #000; */
	}

	.eachTextAnime span {
		opacity: 0;
		font-size: 4vw;
	}

	.eachTextAnime.appeartext span {

		animation: text_anime_on 1s ease-out forwards;
	}

	@keyframes text_anime_on {
		0% {
			opacity: 0;
		}

		50% {
			opacity: 0;
		}


		100% {
			opacity: 1;
		}
	}

	.txt-wrapper {
		padding: 0;
		margin: 0;
	}

	.txt-wrapper h2 strong {
		font-size: 3.6rem;
	}

	.txt-wrapper p {
		text-align: left;
		line-height: 1.8;
	}

	#contents section {
		padding: 0;
	}

	#contents section h2 strong {
		font-size: 3.6rem !important;
		margin-bottom: 0;
	}

	#contents section .about_ttl h2 {
		margin-bottom: 2em !important;
	}

	#contents section .vision_ttl h2 strong {
		font-size: 3.6rem;
		margin-bottom: 0;
	}

	#contents section h2 span {
		font-size: 1.5rem;
	}

	#contents section h2 {
		font-size: 2rem;
		letter-spacing: 3px;
		margin: 20px auto;
		font-weight: 600;
		padding: 2rem 0 1em
	}

	.no-top #introduction .container .text-box h2 {
		position: relative;

	}

	.no-top #introduction .container .text-box h2:before {
		content: '';
		display: block;
		/* background-color: #0000B3; */
		background-color: #0A015A;
		left: calc(50% - 25px);
		position: absolute;
		top: auto;
		bottom: 0px;
		width: 50px;
		height: 2px;
	}

	.no-top #introduction .container .text-box h2:after {
		content: '';
		display: block;
		position: absolute;
		background: #0088C0;
		left: 50%;
		top: auto;
		bottom: 0px;
		width: 25px;
		height: 2px;
	}

	#contents section .thanx_ttl h2 {
		margin-bottom: 3em !important;
		margin-top: 0;
	}

	#message .container {
		position: relative;
		width: 100%;
		height: 100%;
		padding: 0 20px;
	}

	#message .container .photoBox {
		padding-left: 0;
	}

	#message .container .txtBox {
		position: inherit;
		top: 0;
		left: 0;
		width: 100%;
		height: auto;
		padding: 5%;
		z-index: 1;
		background: #fff;
	}

	.no-top #message {
		padding-bottom: 20em !important;
	}

	.privacy_txt {
		padding: 5rem 10px;
		margin-top: 2em;
	}

	.privacy_txt h3 {
		font-size: 20px;
	}

	.button {
		max-width: 200px;
		width: 40%;
		font-weight: normal;
		margin: 2em auto 0;
		font-size: 1.5rem;
		padding: 0.4rem;
		color: #333;
		border: 1px solid #333;
	}

	footer h1 img {
		width: 20rem;
	}


	footer .footer_table {
		width: 100%;
		max-width: 800px;
		margin: 20px auto;
		display: block;
	}

	footer table {
		width: 100%;
		margin: auto;
	}

	footer table th {
		width: 34%;
		font-weight: 600;
	}

	footer table th::before {
		display: none;
	}

	footer table td,
	footer table td {
		padding: 10px 15px;
	}
}

/** info-wrapper **/
.info-wrapper {
	background: linear-gradient(rgba(76, 76, 76, .5), rgba(76, 76, 76, .5)), url(../img/info_back.jpg) fixed center no-repeat;
	background-size: cover;
	padding: 40px 0;
}

.info-wrapper .d-flex {
	justify-content: space-between;
	flex-flow: column;
	align-items: center;
}

.info-wrapper .d-flex>div {
	margin: 0 auto 4.0rem;
	width: 100%;
	text-align: center;
}

.info-wrapper .d-flex .tel-box h2 {
	font-size: 1.8rem;
	margin-bottom: 0;
	color: #fff;
	text-align: center;
	font-weight: 600;
}

.info-wrapper .d-flex .tel-box p {
	margin-bottom: 0;
	line-height: 1.5;
	text-align: center;
}

.info-wrapper .d-flex .tel-box a[href^="tel:"] {
	font-size: 4.0rem;
	font-family: 'Oswald', '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', sans-serif;
	letter-spacing: 2px;
	color: #fff;
	/*text-decoration: none;*/
	font-weight: bold;
}

.info-wrapper .d-flex .tel-box a[href^="tel:"]:before {
	content: "\f095";
	font-family: FontAwesome;
	display: inline-block;
	margin-right: 16px;
}

.info-wrapper .d-flex .tel-box .time-box {
	width: 100%;
	text-align: center;
	font-size: 1.5rem;
	color: #fff;
}

.btn-box {
	justify-content: center;
	display: flex;
}

.info-wrapper .d-flex .btn-box .button {
	width: 75%;
	font-size: 1.8rem;
	padding: 0 16px;
	margin-bottom: 2.4rem;
	background-color: #fff;
	height: 72px;
	line-height: 72px;
	color: #333;
	position: relative;
	font-weight: normal;
}

.info-wrapper .d-flex .btn-box .button.button-caution {
	width: 75%;
	font-size: 2.0rem;
	padding: 0 16px;
	margin-bottom: 2.4rem;
	background-color: #333;
	height: 72px;
	line-height: 72px;
	color: #FFF;
	position: relative;
	font-weight: normal;
}


@media screen and (min-width: 769px) {
	.info-wrapper .d-flex .tel-box a[href^="tel:"] {
		font-size: 5.2rem;
	}

	.info-wrapper .d-flex {
		/* flex-flow: row; */
		justify-content: center;
	}

	.info-wrapper .d-flex>div {
		width: 60%;

	}

	.info-wrapper .d-flex .tel-box p {
		margin-bottom: 0;
		line-height: 1.5;
		text-align: center;
	}

	.info-wrapper .d-flex .tel-box .time-box {
		text-align: center;
	}

	.info-wrapper .d-flex>div h2 {
		text-align: left;
	}

	.info-wrapper .d-flex .tel-box a[href^="tel:"] {
		font-size: 5rem;
		/*text-decoration: none;*/
	}

}


@media screen and (min-width: 769px) {
	.no-top #introduction .container.d-flex {
		justify-content: space-between;
		flex-flow: row;
	}

	.about_img {
		width: 47%;
	}

	.no-top #introduction .container .photo-box,
	.no-top #introduction .container .text-box {
		width: 50%;
	}

	.no-top #introduction .container .text-box h2 {
		font-size: 2.7rem;
		text-align: left;
		background: none;
		letter-spacing: 5px;
		font-weight: 600;
		/* font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif, メイリオ, Meiryo, ＭＳ Ｐゴシック, MS P Gothic, Verdana, sans-serif; */
		padding-bottom: 1em;
		position: relative;
	}

	.no-top #introduction .container .text-box h2:before {
		content: '';
		display: block;
		/* background-color: #0000B3; */
		background-color: #0A015A;
		left: calc(50% - 25px);
		position: absolute;
		top: auto;
		bottom: 0px;
		width: 50px;
		height: 4px;
	}

	.no-top #introduction .container .text-box h2:after {
		content: '';
		display: block;
		position: absolute;
		background: #0088C0;
		left: 50%;
		top: auto;
		bottom: 0px;
		width: 25px;
		height: 4px;
	}

	.no-top #introduction .container .text-box p {
		padding: 1% 0 1% 0%;
		text-align: left;
	}


	.no-top #introduction.rec02 .container {
		background: url("../img/bg_intro_rec02.jpg") no-repeat left;
		padding: 40px 0 40px 48%;
	}

	.no-top #introduction.rec02 .container .text-box {
		width: 100%;
	}
}

/** .no-top #vision **/

.no-top #vision .container .eng_tit {
	position: absolute;
	left: 0;
	top: 0;
	width: 5%;
	max-width: 70px;
}

.no-top #vision .container .txtBox {
	position: relative;
}

.no-top #vision .container .txtBox .step1_img,
.no-top #vision .container .txtBox .step2_img,
.no-top #vision .container .txtBox .step3_img {
	width: 80%;
	margin: 0 auto 40px;
}

.no-top #vision .container .txtBox .stepBox {
	display: flex;
	flex-flow: column;
	align-items: center;
	justify-content: center;
	margin: 0 auto 40px;
}

.no-top #vision .container .txtBox .stepBox img {
	margin-bottom: 20px;
}

@media screen and (max-width:460px) {
	.no-top #welfare .container .fBox .text-box h3 {
		font-size: 1.7rem;
	}

	.no-top #welfare .container .fBox .text-box {
		padding: 25px 10px;
	}
}

.no-top #mainvisual .img-wrapper .d-flex .pointWrap {
	display: flex;
	justify-content: center;
	padding-bottom: 40px;
}

@media screen and (min-width: 769px) {
	.no-top #mainvisual {
		position: relative;
		padding-top: 8.8em;
	}

	.no-top #mainvisual .inner {
		position: relative;
		z-index: 4;
		top: 40%;

	}

	.no-top #mainvisual .img-wrapper .icon {
		position: absolute;
		right: 40px;
		top: 90px;
		width: 18%;
		margin: 0;
	}

	.no-top #mainvisual .img-wrapper .d-flex .pointWrap {
		display: flex;
		justify-content: center;
		padding-bottom: 20px;
		padding-top: 20px;
	}

	.no-top #mainvisual .img-wrapper .d-flex .pointWrap li {
		width: 110px;
		height: 95px;
		/* color: #0000B3; */
		color: #0A015A;
		background-color: #fff;
		text-align: center;
		font-size: 18px;
		line-height: 1.4;
		display: flex;
		justify-content: center;
		align-items: center;
		font-weight: 400;
		margin: 0 1.5%;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit h1 {
		font-size: 2rem;
		color: #fff;
		margin-bottom: 0em;
		text-align: center;
		/* font-family: "游教科書体"; */
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit .kv_koyo {
		padding: 5px 0;
		margin: 1em auto;
		max-width: 350px;
		background: #fff;
		/* color: #0000B3; */
		color: #0A015A;
		text-shadow: none;
		border: none;

	}
}

@media screen and (max-width: 480px) {
	.slideshow {
		height: 500px;
	}

	.no-top #mainvisual .img-wrapper img {
		width: 100%;
		height: 500px;
		object-fit: cover;
	}

	.text {
		margin: 200px 0 0;
		text-align: center;
		opacity: 0;
		position: absolute;
		top: -35em;
		padding: 1em 0.5em;
		/* font-family: 'Playfair Display', serif; */
		text-shadow: 0px 0px 10px #0000B3;
		color: #fff;
	}

	.text.active .text-move {
		font-size: 2.5rem;
		letter-spacing: 5px;
	}

	.no-top #contents section .container {
		display: block;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit h1 strong {
		font-size: 4rem;
		margin-bottom: .25em;
		text-align: center;
		color: #fff;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit h1 {
		font-size: 4rem;
		margin-bottom: 1.25em;
		text-align: center;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit p strong {
		font-size: 2.3rem;
		/* font-family: "游教科書体"; */
		font-weight: 600;
		text-shadow: 0 0 4px #000;
		letter-spacing: 0px;
		color: #fff;
	}

	.point_box1 {
		display: flex;
		justify-content: space-between;
		width: 160px;
	}

	.point_box2 {
		display: flex;
		justify-content: space-between;
		width: 160px;
	}

	.no-top #mainvisual .img-wrapper {
		height: 450px;
	}

	.no-top #mainvisual .img-wrapper.detail2 {
		height: 450px;
	}

	.no-top #mainvisual .img-wrapper .d-flex .copy-box {
		margin-top: 5em;
		width: 100%;
		height: 350px;
		padding: 6% 3% 3%;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit h1 {
		font-size: 1.3rem;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit h1 strong {
		font-size: 1.7rem;
		/* font-family: 'Oswald', '游ゴシック' ,'YuGothic' ,'メイリオ' ,'Meiryo' ,'ＭＳ Ｐゴシック' ,sans-serif; */
		letter-spacing: 2px;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit p {
		font-size: 1rem;
	}

	.no-top #mainvisual .img-wrapper .d-flex .copy-box span {
		font-size: 1.4rem;
	}

	.no-top #mainvisual .img-wrapper .d-flex .pointWrap {
		padding-top: 0;
	}

	.no-top #mainvisual .img-wrapper .d-flex .pointWrap li {
		width: 60px;
		height: 60px;
		background: #fff;
		/* color: #0000B3; */
		color: #0A015A;
		text-align: center;
		font-size: 1.1rem;
		line-height: 1.2;
		display: flex;
		justify-content: center;
		align-items: center;
		font-weight: 400;
		margin: 0 1.5%;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit .kv_koyo {
		padding: 5px 0;
		margin: 0 auto 1em;
		max-width: 180px;
		background: #fff;
		/* color: #0000B3; */
		color: #0A015A;
		text-shadow: none;
		border: none;

	}
}

@media screen and (min-width: 769px) {
	.no-top #vision .container .txtBox .step1_img {
		position: absolute;
		right: 0;
		top: 0;
		width: 21%;
		max-width: 220px;
	}

	.no-top #vision .container .txtBox .step2_img {
		position: absolute;
		right: 44%;
		bottom: 0;
		width: 21%;
		max-width: 220px;
		margin: 0;
	}

	.no-top #vision .container .txtBox .step3_img {
		position: absolute;
		right: 21%;
		bottom: 0;
		width: 21%;
		max-width: 220px;
		margin: 0;
	}

	.no-top #vision .container .txtBox {

		position: relative;
	}

	.no-top #vision .container .txtBox .text-lead {
		font-size: 3.0rem;
		text-align: center
	}

	.no-top #vision .container .txtBox .stepBox {
		display: flex;
		flex-flow: row;
		align-items: center;
		margin: 0;
	}

	.no-top #vision .container .txtBox .stepBox img {
		width: 160px;
		margin-right: 24px;
	}

	.no-top #vision .container .txtBox .stepBox p {
		/* max-width:300px; */
	}

	.no-top #vision .container .txtBox .stepWrap>.stepBox:nth-of-type(2) {

		margin-top: -12px;
	}

	.no-top #vision .container .txtBox .stepWrap>.stepBox:nth-of-type(3) {
		margin-top: -12px;
	}
}





/** detail #interview **/
.photoBox {
	max-width: 1584px;
	width: 100%;
	margin: 0 auto;
}

.no-top #interview {
	padding: 56px 0 0;

}

.no-top #interview .main-title {
	position: relative;
	text-align: center;
}

.no-top #interview .main-title .figure-box {
	margin-bottom: 20px;
	max-width: 1584px;
	width: 85%;
	margin: 0 auto 20px;
}

.no-top #interview .main-title .prof {
	color: #333;
	padding: 0 50px 5px;
	font-size: 2.2rem;
	margin: 0;
	display: inline-block;
	line-height: 2;
	font-weight: 400;
	position: relative;
	margin: auto;
	border: 1px solid #ccc;
}

.no-top #interview .main-title .prof span {
	font-size: 1.6rem;
}

.no-top #interview .qa-wrapper {
	margin-top: 40px;
}

.no-top #interview .qa-wrapper .qa-box {
	display: flex;
	justify-content: flex-start;
	flex-flow: column;
	margin-bottom: 40px;
	align-items: flex-start;
	margin-bottom: 40px;
}

.no-top #interview .qa-wrapper>.qa-box:nth-of-type(2n) {
	display: flex;
	justify-content: flex-start;
	flex-flow: column;
	margin-bottom: 40px;
	align-items: flex-end;
	margin-bottom: 40px;
}


.no-top #interview .qa-wrapper .qa-box .q-box .title {
	font-family: "lato", sans-serif;
	font-size: 4.5rem;
	font-weight: 400;
	color: #333;
	line-height: 1.2;
}

.no-top #interview .qa-wrapper .qa-box .q-box .fukidashi {
	position: relative;
	display: inline-block;
	padding: 16px 32px;
	width: auto;
	color: #333;
	font-weight: 400;
	background: rgba(0, 29, 71, 0.1);
	font-size: 2.4rem;
}

.no-top #interview .qa-wrapper .qa-box .q-box .fukidashi:before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 0;
	height: 0;
	border: 36px solid transparent;
	border-top-color: rgba(0, 29, 71, 0.1);
	border-bottom: 0;
	border-right: 0;
	margin-left: -18px;
	margin-bottom: -36px;
}

.no-top #interview .qa-wrapper>.qa-box:nth-of-type(2n) .q-box .fukidashi:before {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 0;
	height: 0;
	border: 36px solid transparent;
	border-top-color: rgba(0, 29, 71, 0.1);
	border-bottom: 0;
	border-left: 0;
	margin-right: -18px;
	margin-bottom: -36px;
}

.no-top #interview .qa-wrapper .qa-box .a-box {
	width: 100%;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	margin-top: 48px;
}

.no-top #interview .qa-wrapper .qa-box:nth-of-type(2n) .a-box {
	width: 100%;
	display: flex;
	justify-content: flex-end;
	align-items: flex-start;
	margin-top: 48px;
}

.no-top #interview .qa-wrapper .qa-box .a-box>div {
	width: 90%;
	background-color: #FFF;
	border: #333 1px solid;
	padding: 24px;
	position: relative;

}

.no-top #interview .qa-wrapper .qa-box .a-box>div p {
	padding-left: 48px;
	font-weight: 600;
}

.no-top #interview .qa-wrapper .qa-box .a-box>div p:before {
	content: "A";
	font-family: 'Noto Sans', sans-serif;
	color: #333;
	font-style: italic;
	font-weight: 200;
	font-size: 4.8rem;
	position: absolute;
	left: 24px;
	line-height: 1.2;
	top: 12px;
}




/** detail #message **/

.no-top #message {
	position: relative;
	padding-bottom: 29em;
	/* background: linear-gradient(180deg, rgba(0, 0, 0, 0)0%, rgba(0, 0, 0, 0)40%, #1d2188 40%, #1d2188 100%); */
	background: linear-gradient(180deg, rgba(0, 0, 0, 0)0%, rgba(0, 0, 0, 0)40%, #0A015A 40%, #0A015A 100%);
}

.no-top #message .photoBox {
	margin-bottom: 20px;
}

.no-top #contents #message h3 {
	color: #000;
	font-size: 2rem;
	text-align: center;
}

.no-top #contents #message p {
	text-align: left;
}

@media screen and (min-width: 769px) {
	.no-top #message .photoBox {
		margin-bottom: 0;
		max-width: 1584px;
		width: 100%;
		margin: 0 auto;
		animation-name: fadein;
		animation-duration: 2s;
	}
}

/** detail #guideline **/

.no-top #guideline {
	padding: 160px 0;
	margin-top: -80px;
}

.no-top #guideline .container table {
	width: 100%;
	max-width: 1024px;
	margin: auto;
}

.no-top #guideline .container table td {
	width: 80%;
}

.no-top #guideline .container table td p {
	font-size: 1.4rem;
}

@media screen and (max-width: 769px) {
	.no-top #guideline {
		padding: 50px 0 80px;
   		margin-top: 120px;
	}
}
@media screen and (max-width: 560px) {
	.no-top #guideline {
		padding: 50px 0 80px;
    	margin-top: 260px;
	}
}
/** detail #entry **/

.no-top #entry {
	padding: 130px 0 10em;
    background-color: #f7f7f7;
    margin-top: -74px;
}
@media screen and (max-width: 769px) {
	.no-top #entry {
		padding: 56px 0 10em;
		margin-top: initial;
	}
}

.no-top #entry .container form {
	width: 100%;
	max-width: 1020px;
	margin: auto;
}

.no-top #entry .container .CMS-FORM-GROUP {
	margin-bottom: 24px;
}

.no-top #entry .container .CMS-FORM-GROUP label,
.no-top #entry .container .CMS-FORM-GROUP input {
	border-bottom: none;
	display: block;
	padding: 8px 0;
}

.no-top #entry .container .CMS-FORM-GROUP .CMS-FORM-INPUT-LABEL {
	margin-bottom: 16px;
}

.CMS-FORM-INPUT-LABEL:after,
.CMS-FORM-EMAIL-LABEL:after,
.CMS-FORM-NUMBER-LABEL:after,
.CMS-FORM-TEL-LABEL:after,
.CMS-FORM-SELECT-LABEL:after {
	content: "必須";
	display: inline-block;
	font-size: 12px;
	color: #FFF;
	text-align: center;
	width: 45px;
	height: 25px;
	/* background: #1d2188; */
	background: #0A015A;
	margin-left: 16px;
	line-height: 25px;
	font-weight: 500;
}

.no-top #entry .container .CMS-FORM-GROUP input {
	width: 100%;
	border: 1px solid #DDDDDD;
	outline: none;
	padding-left: 1rem;
	transition: .5s;
}

.no-top #entry .container .CMS-FORM-GROUP input:hover {
	background: rgba(1, 87, 156, 0.1);
}

.no-top #entry .container .CMS-FORM-GROUP:last-child {
	text-align: center;
	margin: 40px auto 0;
	width: 330px;
	display: block;
	border: none;
}

.no-top #entry .container .CMS-FORM-GROUP input[type="submit"] {
	margin: auto;
	font-size: 2.0rem;
	padding: 1.6rem;
	color: #333;
	border: 1px solid #333;
}


/*****************
  thanks
************************/
.thanks {
	padding-top: 64px;
}

.thanks .text-lead {
	text-align: center;
	padding: 0 25px;
}

.thanks .button.button_back {
	max-width: 200px;
	width: 40%;
	font-weight: normal;
	margin: 4em auto 0;
	font-size: 1.5rem;
	padding: 0.4rem;
	color: #333;
	border: 1px solid #333;
}

@media screen and (min-width: 769px) {
	.thanks {
		padding-top: 80px;
	}
}

/*****************
  privacy
************************/
@media screen and (min-width: 769px) {
	.privacy {
		padding-top: 80px;
	}

	.privacy p {
		padding: 0 100px;
	}

	.privacy h3 {
		padding: 0 100px;
		text-align: center;
	}
}

/*guideline_txt-------------------------*/
#guideline_txt {
	margin: 10px 0 25px;
}

#guideline_txt .txt_box {
	max-width: 1000px;
	width: 100%;
	margin: 0 auto;
	padding: 15px 10px;
	text-align: center;
}

#guideline_txt .txt_box h3 {
	text-align: center;
	color: #000;
	font-size: 22px;
}

@media screen and (max-width:767px) {
	#guideline_txt .txt_box h3 {
		text-align: left;
		color: #000;
		font-size: 18px;
	}

	.thanks .text-lead {
		text-align: left;
		max-width: 500px;
		margin: 0 auto;
	}

	.info-wrapper .d-flex .tel-box a[href^="tel:"] {
		font-size: 3.7rem;
		font-family: 'Oswald', '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', sans-serif;
		letter-spacing: 2px;
		color: #fff;
		/*text-decoration: none;*/
		font-weight: bold;
	}

	.info-wrapper .d-flex .btn-box .button {
		width: 100%;
		max-width: 350px;
		font-size: 1.5rem;
		padding: 0 45px;
		margin: 0 auto 2.4rem;
		background-color: #fff;
		height: 55px;
		line-height: 55px;
		color: #333;
		position: relative;
		font-weight: normal;
	}

	.info-wrapper .d-flex .btn-box .button.button-caution {
		width: 75%;
		font-size: 1.7rem;
		padding: 0 16px;
		margin-bottom: 2.4rem;
		background-color: #333;
		height: 55px;
		line-height: 55px;
		color: #fff;
		position: relative;
		font-weight: normal;
	}

	.no-top #message p.name {
		font-size: 15px;
	}

	#contents section .about_ttl h2 {
		margin-top: 10rem;
	}

	.no-top #mainvisual .img-wrapper .d-flex .pointWrap {
		padding: 10px 0px;
	}
}



.recruit_info-box .button-more::after {
	position: absolute;
	top: 50%;
	right: .8em;
	content: '';
	margin-top: -5px;
	border: 7px solid transparent;
	border-top-width: 5px;
	border-bottom-width: 5px;
	border-left-color: #fff;
	opacity: 0;
}

.recruit_info-box .button-more:hover::after {
	animation: arrow 1.2s infinite;
}

@keyframes arrow {
	50% {
		right: .2em;
		opacity: 1;
	}

	100% {
		right: -.4em;
		opacity: 0;
	}
}

.top_txt {
	border: 1px solid #fff;
}

#top_sec01 .ph {
	width: 100%;
	max-width: 640px;
	padding: 20px;
	margin: 0 auto
}

#top_sec01 .ph img {
	display: block
}

.recruit_menu_cnt .cmenu_list .item a .ph {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1
}

.recruit_menu_cnt .cmenu_list .item a .ph div {
	position: relative;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center center
}

.greeting_cnt .base_width .inner .column .ph {
	padding: 10px 20px
}

#btm_article .article_body .item a .ph {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	overflow: hidden
}

#btm_article .article_body .item a .ph div {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-size: cover;
	background-position: center center;
	transform: scale(1.01)
}

html.no_touch_device #btm_article .article_body .item a .ph div {
	transition: all .5s ease-in-out
}

html.no_touch_device #btm_article .article_body .item a:hover .ph div {
	transform: scale(1.2)
}

.recruit_menu_cnt .cmenu_list {
	flex-wrap: wrap;
	text-align: left
}

@media screen and (min-width: 769px) {
	.recruit_menu_cnt .cmenu_list {
		align-items: stretch;
		padding: 0 2%;
	}
}

.recruit_menu_cnt .cmenu_list .item {
	position: relative;
	z-index: 1
}

.recruit_menu_cnt .cmenu_list .item a {
	position: relative;
	display: block;
	height: 100%;
	text-decoration: none;
	color: #111;
	background: #fff
}

.recruit_menu_cnt .cmenu_list .item a .ph {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}

.recruit_menu_cnt .cmenu_list .item a .ph div {
	position: relative;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center center;
	overflow: hidden;
	margin: 0 auto;
}

.recruit_menu_cnt .cmenu_list .item a .txt {
	position: relative;
	padding: 40px 20px;
	z-index: 10;
}

.post {
	position: relative;
}

.post .caption {
	font-size: 40px;
	text-align: center;
	color: #0A015A;
	padding-top: 20%;
	font-family: 'Oswald', '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', sans-serif;
	letter-spacing: 2px;
	text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
              -1px 1px 0 #FFF, 1px -1px 0 #FFF,
              0px 1px 0 #FFF,  0-1px 0 #FFF,
              -1px 0 0 #FFF, 1px 0 0 #FFF;
}

.post .mask {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	/* マスクを表示しない */
	/* background-color:	rgba(0,0,0,0.4); */
	-webkit-transition: all 0.6s ease;
	transition: all 0.6s ease;
}

.post:hover .mask {
	opacity: 1;
	/* マスクを表示する */
	padding-top: 80px;
	/* ホバーで下にずらす */
}

@media screen and (min-width: 769px) {
	.recruit_menu_cnt .cmenu_list .item a .txt {
		padding: 80px 20px;
		background: rgba(0, 0, 0, 0.35);

	}
}

@media screen and (max-width: 768px) {
	.info-wrapper {
		background: linear-gradient(rgba(76, 76, 76, .5), rgba(76, 76, 76, .5)), url(../img/info_back.jpg) center no-repeat;
		background-size: cover;
		padding: 40px 0;
	}

	.recruit_menu_cnt .cmenu_list .item a .txt {
		padding: 80px 20px;
		background: rgba(0, 0, 0, 0.35);
	}
}

.recruit_menu_cnt .cmenu_list .item a .txt h3 {
	font-size: 3.2rem;
}

.recruit_menu_cnt .cmenu_list .item a .txt p {
	margin: 0 0 1em;
	line-height: 2em;
	font-size: 1.4rem
}

.recruit_menu_cnt .cmenu_list .item a .txt .more {
	display: inline-block;
	padding: 10px;
	font-weight: 600;
	line-height: 1;
	border: 1px solid #fff;
	color: #fff;
	float: right;
}

.recruit_menu_cnt .cmenu_list .item a:hover .txt .more {
	background: #fff;
	color: #333;
	border: 1px solid #fff;
	font-weight: 600;
	transition: 0.5s all;
}

html.touch_device .recruit_menu_cnt .cmenu_list .item a .txt .more {
	background: #333;
	color: #fff
}

.recruit_menu_cnt .cmenu_list.col3 .item {
	margin: 5px auto 3em;
	max-width: 1200px;
}

@media screen and (max-width: 768px) {
	.recruit_menu_cnt .cmenu_list.col3 .item {
		width: 100%
	}
}

@media screen and (max-width: 480px) {
	.recruit_menu_cnt .cmenu_list.col3 .item {
		width: 100%
	}

	header .container h1 img {
		width: 200px;
	}
}

.recruit_menu_cnt .cmenu_list2 {
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-align-items: center;
	align-items: center;
}

@media screen and (min-width: 769px) {
	.recruit_menu_cnt .cmenu_list2 {
		align-items: stretch
	}
}

.recruit_menu_cnt .cmenu_list2 .box2 .txt {
	position: relative;
	padding: 20px 20px;
	z-index: 10;
	text-shadow: 0 0 10px rgba(255, 255, 255, 0.5);
	text-align: left;
}

.recruit_menu_cnt .cmenu_list .box2 .txt p {
	margin: 0 0 1em;
	line-height: 2em;
	font-size: 1.2rem
}

@media screen and (min-width: 769px) {
	.recruit_menu_cnt .cmenu_list2 .box2 .txt {
		padding: 20px 20px
	}
}

.txt h3 strong {
	color: #fff;
	font-size: 2.5rem;
	padding-right: 0.5em;
}

.txt span {
	font-size: 1.4rem;
	color: #fff;
	background-color: #2b5595;
	display: inline-block;
	vertical-align: middle;
	padding: 0.2em 0.5em;
	margin-right: 8px;
}

.txt h4 {
	color: #fff;
	border-bottom: 1px dotted #fff;
}

.txt p {
	color: #fff;
}

.accordion_area {
	max-width: 1584px;
	width: 65%;
	margin: 2em auto 20px;
}

.accordion_area .accordion_one .ac_header {
	background-color: #f2f2f2;
	border: 1px solid #ccc;
	padding: 1.5rem 4rem 1.5rem 2rem;
	position: relative;
	z-index: 0;
	cursor: pointer;
	transition: .2s;
}

.accordion_area .accordion_one .ac_header:not(.open):hover {
	background: rgba(0, 0, 179, 0.05);
}

.accordion_area .accordion_one:nth-child(odd) .ac_header {
	background-color: #f2f2f2;
}

.accordion_area .accordion_one:nth-child(odd) .ac_header:not(.open):hover {
	background: rgba(0, 0, 179, 0.05);
}

.accordion_area .accordion_one .ac_header .i_box {
	position: absolute;
	top: 50%;
	right: 2rem;
	width: 20px;
	height: 20px;
	margin-top: -10px;
}

.accordion_area .accordion_one .ac_header .i_box:before,
.accordion_area .accordion_one .ac_header .i_box:after {
	position: absolute;
	content: "";
	margin: auto;
	box-sizing: border-box;
	vertical-align: middle;
}

.accordion_area .accordion_one .ac_header .i_box:before {
	border-top: 2px solid #333;
	width: 20px;
	height: 0;
	top: 0;
	bottom: 0;
	right: 0;
}

.accordion_area .accordion_one .ac_header .i_box:after {
	border-left: 2px solid #333;
	width: 0;
	height: 20px;
	top: 0;
	bottom: 0;
	right: 9px;
	transition: .3s;
}

.accordion_area .accordion_one .ac_header.open .i_box:after {
	height: 0;
}

.accordion_area .accordion_one .ac_inner {
	display: none;
	padding: 1.5rem 2rem 1.5rem 2rem;
	border-left: 1px solid #ccc;
	border-right: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
	box-sizing: border-box;
	background: #fff;
}

.gutter>*:not(:last-child) {
	margin-bottom: 1.5rem;
}

@media screen and (max-width: 736px) {
	.accordion_area .accordion_one .ac_header {
		padding: 1.5rem 2rem 1.5rem 1.0rem;
	}

	.accordion_area .accordion_one .ac_header .i_box {
		right: 0.8rem;
		width: 15px;
		height: 15px;
		margin-top: -7px;
	}

	.accordion_area .accordion_one .ac_header .i_box:before {
		width: 15px;
	}

	.accordion_area .accordion_one .ac_header .i_box:after {
		height: 15px;
		right: 7px;
	}

	.accordion_area .accordion_one .ac_inner {
		padding: 1.5rem 1.5rem 1.5rem 1.5rem;
	}
}

/*=========
faq
=========*/

.p-faq__headinner {
	display: block;
	padding-left: 35px;
	position: relative;
	line-height: 1.5;
}

.p-faq__headinner::before {
	position: absolute;
	left: 0;
	content: "Q．";
	color: #000;
	font-size: 1.7rem;
	font-weight: bold;
}

.p-faq__headinner p.p-faq__q-txt {
	font-size: 1.5rem;
}

@media screen and (max-width: 736px) {
	.p-faq__headinner {
		padding-left: 25px;
	}

	.p-faq__headinner::before {
		font-size: 12px;
	}

	.p-faq__headinner p.p-faq__q-txt {
		font-size: 12px;
	}
}

.p-faq__bodyinner {
	display: block;
	padding-left: 35px;
	position: relative;
	line-height: 1.5;
}

.p-faq__bodyinner::before {
	position: absolute;
	left: 0;
	content: "A．";
	color: #de0000;
	font-size: 1.7rem;
	font-weight: bold;
}

.p-faq__bodyinner p.p-faq__a-txt {
	font-size: 1.5rem;
}

@media screen and (max-width: 736px) {
	.p-faq__bodyinner {
		padding-left: 25px;
	}

	.p-faq__bodyinner::before {
		font-size: 12px;
	}

	.p-faq__bodyinner p.p-faq__a-txt {
		font-size: 12px;
	}
}

@media screen and (max-width: 767px) {
	.no-top #interview .main-title .prof span {
		font-size: 1.2rem;
	}

	.no-top #interview .main-title .prof {
		color: #333;
		padding: 0 30px 5px;
		font-size: 1.5rem;
		margin: 0;
		display: inline-block;
		line-height: 2;
		font-weight: 400;
		position: relative;
		margin: auto;
		border: 1px solid #ccc;
	}

	.card {
		margin: 5px 0 0;
	}

	.qa-list dl {
		margin: 10px 0 0;
	}

	.qa-list dl:after {
		top: 20px;
		right: 20px;
		width: 7px;
		height: 7px;
	}

	.qa-list dl dt {
		padding: 16px 16px 16px 50px;
		font-size: 14px;
	}

	.qa-list dl dt::before {
		font-size: 14px;
		top: 20px;
		left: 20px;
	}

	.qa-list dl dd::before {
		font-size: 14px;
		left: 20px;
		margin-top: 5px;
	}

	.qa-list dl dd {
		margin: 0;
		padding: 16px 16px 16px 50px;
		font-size: 14px;
	}

	.qa-list dl dd p {
		margin: 30px 0 0;
	}

	.qa-list dl dd p:first-child {
		margin-top: 0;
	}
}

.box_txt {
	position: relative;
	margin: 0em 1.5em;
	padding: 25px 10px 20px;
	border: solid 2px #333;
	width: 400px;
	min-height: 200px;
}

.box_txt .box-title {
	position: absolute;
	display: inline-block;
	top: -1px;
	left: -1px;
	padding: 0 15px;
	height: 35px;
	line-height: 35px;
	font-size: 17px;
	background: #1d2188;
	color: #ffffff;
	font-weight: bold;
}

.box_txt p {
	margin: 0;
	padding: 0;
}

.box_txt h3 {
	font-size: 1.5em;
	text-align: center;
	margin: 0 auto 0.5em;
	padding: 2rem 0 0.5em;
	position: relative;
}

.box_txt h3:before {
	content: '';
	display: block;
	background-color: #0000B3;
	left: calc(50% - 25px);
	position: absolute;
	top: auto;
	bottom: 0px;
	width: 50px;
	height: 4px;
}

.box_txt h3:after {
	content: '';
	display: block;
	position: absolute;
	background: #0088C0;
	left: 50%;
	top: auto;
	bottom: 0px;
	width: 25px;
	height: 4px;
}

@media screen and (max-width: 768px) {
	header .container nav ul li a.button {
		font-size: 12px;
		padding: 14px 6px;
		position: relative;
		background: #333;
	}

	.sp-only ul.d-flex li {
		width: 200px;
	}

	.no-top #vision .container .txtBox .text-lead {
		font-size: 2.3rem;
		text-align: center;
	}

	.no-top #vision .container .txtBox .text-lead strong {
		font-size: 4rem;
		color: #333;
	}

	.box_txt {
		position: relative;
		margin: 1em 0.5em;
		padding: 25px 10px 7px;
		border: solid 1px #333;
		width: 300px;
		height: 200px;
	}

	.box_txt h3 {
		font-size: 18px;
		padding-bottom: 10px;
		position: relative;
	}

	.box_txt h3:before {
		content: '';
		display: block;
		background-color: #0000B3;
		left: calc(50% - 25px);
		position: absolute;
		top: auto;
		bottom: 0px;
		width: 50px;
		height: 2px;
	}

	.box_txt h3:after {
		content: '';
		display: block;
		position: absolute;
		background: #0088C0;
		left: 50%;
		top: auto;
		bottom: 0px;
		width: 25px;
		height: 2px;
	}
}

@-webkit-keyframes drop {
	0% {
		top: -50%;
	}

	100% {
		top: 110%;
	}
}

@keyframes drop {
	0% {
		top: -50%;
	}

	100% {
		top: 110%;
	}
}

.grid {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	max-width: 700px;
	margin: 0 auto;
}

@media screen and (min-width: 768px) {
	.grid {
		max-width: 1580px;
	}

	.grid_margin {
		margin-bottom: 7em !important;
	}
}

.card {
	position: relative;
	flex: 1 1 100%;
	margin: 5px 0 0;
	padding: 20px 5px;
	background: #f3f2f4;
}

#recruit .container {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 95%;
	max-width: 900px;
	margin: 0 auto;
}

.post h2 {
	/* background: #0000B3; */
	background: #0A015A;
	color: #fff !important;
	line-height: 0.8;
	padding: 20px 0;
}

.post h2 span {
	border-bottom: 1px solid #fff;
	width: 16vw;
	margin: 0 auto;
	padding-bottom: 10px;
}

.post h3 {
	text-align: center;
	padding-bottom: 1em;
	position: relative;
}

.post h3:before {
	content: '';
	display: block;
	/* background-color: #0000B3; */
	background-color: #0A015A;
	left: calc(50% - 25px);
	position: absolute;
	top: auto;
	bottom: 0px;
	width: 50px;
	height: 4px;
}

.post h3:after {
	content: '';
	display: block;
	position: absolute;
	background: #0088C0;
	left: 50%;
	top: auto;
	bottom: 0px;
	width: 25px;
	height: 4px;
}

.post p {
	padding: 10px 25px 30px;

}

.post {
	margin: 50px 0 0;
	background: #fff;
	/* flex: 1; */
	width: 48%;
}

a .image {
	/* height: 450px; */
	overflow: hidden;
}

a .image img {
	width: 100%;
	height: auto;
	transition: all .6s ease-out 0.1s;
	display: block;
}

a:hover .image img {
	transform: scale(1.2);
}

@media screen and (min-width: 768px) {
	.card {
		flex-basis: calc(33.33% - (62px + 40px));
		margin: 0 1em;
		width: 600px;
	}
}

.card__thumb {
	overflow: hidden;
}

.card__img {
	margin: -20px -20px 0;
}

.card__img img {
	max-width: 100%;
	width: 100%;
	height: auto;
	border: 0;
	vertical-align: middle;
	box-sizing: border-box;
}

.card__desc {
	/* margin-top: 20px; */
	background: #f7f7f7;
	padding-bottom: 3em;
}

.card__desc p {
	padding: 0 2%;
	min-height: 65px;
	color: #4e4e4e;
}

.more {
	float: right;
	margin-right: 1rem;
	position: relative;
	display: inline-block;
	text-decoration: none;
}

.more::after {
	position: absolute;
	bottom: -4px;
	left: 0;
	content: '';
	width: 100%;
	height: 1px;
	background: #333;
	transform: scale(0, 1);
	transform-origin: right top;
	transition: transform .3s;
}

.more:hover::after {
	transform-origin: left top;
	transform: scale(1, 1);
}

a {
	text-decoration: none;
}

.card__desc h3 {
	text-align: center;
	color: #fff;
	font-size: 2.2rem;
	/* background: #1d2188; */
	background: #0A015A;
	padding: 2.5% 2%;
	line-height: 2.2;
}

.card__desc h3 span {
	padding: 5px 10px;
	background: #fff;
	color: #4e4e4e;
	margin-bottom: 1rem;
	font-size: 12px;
}

.card__two .card__img {
	padding: 20px 20px 0;
}


.card__two::before,
.card__two::after {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	transition: opacity 0.38s ease-in-out, transform 0.35s ease-in-out;
	content: "";
	opacity: 0;
	pointer-events: none;
}

.card__two::before {
	transform: scale3d(0, 1, 1);
	transform-origin: left top;
	border-top: 1px solid #acacac;
	border-bottom: 1px solid #acacac;
}

.card__two::after {
	transform: scale3d(1, 0, 1);
	transform-origin: right top;
	border-right: 1px solid #acacac;
	border-left: 1px solid #acacac;
}

.card__two:hover::before,
.card__two:hover::after,
.card__two:focus::before,
.card__two:focus::after {
	transform: scale3d(1, 1, 1);
	opacity: 1;
}

.navigation {
	font-family: "Pathway Gothic One", sans-serif;
	font-size: 22px;
}

.menu {
	display: flex;
	justify-content: center;
	max-width: 1150px;
	margin: 0 auto;
	padding-left: 0;
}

.menu__item {
	display: inline-block;
	white-space: nowrap;
}

@media screen and (max-width: 480px) {
	.menu__item:nth-child(n+3) {
		display: none;
	}

	.menu__item:nth-child(2) .menu__link {
		border-right: 0;
	}
}

@media screen and (max-width: 768px) {
	#recruit .container {
		display: flex;
		justify-content: space-between;
		/* flex-wrap: wrap; */
		width: 100%;
		max-width: 900px;
		margin: 0 auto;
	}

	.post h2 {
		background: #0A015A;
		color: #fff !important;
		line-height: 0.8;
		padding: 20px 0;
	}

	.post h2 span {
		border-bottom: 1px solid #fff;
		width: 20vw;
		margin: 0 auto;
		padding-bottom: 10px;
	}

	.post h3 {
		text-align: center;
		font-size: 16px;
	}

	.post p {
		padding: 0;

	}

	.post {
		margin: 0 20px;
		background: #fff;
		flex: 1;
	}

	a .image {
		/* height: 450px; */
		overflow: hidden;
	}

	a .image img {
		width: 100%;
		height: auto;
		transition: all .6s ease-out 0.1s;
		display: block;
	}

	a:hover .image img {
		transform: scale(1.2);
	}

	.card {
		padding: 20px 0;
	}

	.card__desc p {
		line-height: 1.8;
	}

	.card__desc h3 {
		font-size: 1.6rem;
	}

	.card__desc h2 {
		position: relative;
		font-size: 1.6rem !important;
		letter-spacing: 1px !important;

	}

	.card__desc h2:before {
		content: '';
		display: block;
		/* background-color: #0000B3; */
		background-color: #0A015A;
		left: calc(50% - 25px);
		position: absolute;
		top: auto;
		bottom: 0px;
		width: 50px;
		height: 2px;
	}

	.card__desc h2:after {
		content: '';
		display: block;
		position: absolute;
		background: #0088C0;
		left: 50%;
		top: auto;
		bottom: 0px;
		width: 25px;
		height: 2px;
	}

	.menu__item:nth-child(n+4) {
		display: none;
	}

	.menu__item:nth-child(3) .menu__link {
		border-right: 0;
	}
}

@media screen and (max-width: 992px) {
	.menu__item:nth-child(n+5) {
		display: none;
	}

	.menu__item:nth-child(4) .menu__link {
		border-right: 0;
	}
}

.menu__item:last-child .menu__link {
	border-right: 0;
}

.menu__link {
	display: block;
	padding: 6px 30px 3px;
}

.menu__link:hover .menu__first-word,
.menu__link:focus .menu__first-word {
	transform: translate3d(0, -105%, 0);
}

.menu__link:hover .menu__second-word,
.menu__link:focus .menu__second-word {
	transform: translate3d(0, 105%, 0);
}

@media screen and (min-width: 768px) {
	.menu__link {
		padding: 6px 0px 3px;
		font-family: 'Oswald', '游ゴシック', 'YuGothic', 'メイリオ', 'Meiryo', 'ＭＳ Ｐゴシック', sans-serif;
		letter-spacing: 2px;
		font-size: 25px;
	}
}

.menu__title {
	display: inline-block;
	overflow: hidden;
	/* border-bottom: 1px solid #4e4e4e; */
}

.menu__first-word,
.menu__second-word {
	display: inline-block;
	position: relative;
	transition: transform 0.3s;
}

.menu__first-word::before,
.menu__second-word::before {
	position: absolute;
	content: attr(data-hover);
}

.menu__first-word {
	/* color: #0000B3; */
	color: #0A015A;
}

.menu__first-word::before {
	top: 105%;
	color: #0088C0;
}

.menu__second-word {
	color: #0088C0;
}

.menu__second-word::before {
	bottom: 105%;
	/* color: #0000B3; */
	color: #0A015A;
}

.outline-outward {
	display: inline-block;
	position: relative;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
	transform: translateZ(0);
	box-shadow: 0 0 1px rgba(0, 0, 0, 0);
}

.outline-outward:before {
	content: "";
	position: absolute;
	border: #ececec solid 1px;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	transition-duration: 0.3s;
	transition-property: top right bottom left;
}

.outline-outward:hover:before {
	top: -8px;
	right: -8px;
	bottom: -8px;
	left: -8px;
}

.button {
	margin: 0.4em;
	padding: 1em;
	cursor: pointer;
	background: #ececec;
	text-decoration: none;
	color: #333;
}

.outline-outward2 {
	display: inline-block;
	position: relative;
	-webkit-tap-highlight-color: #333;
	transform: translateZ(0);
	box-shadow: 0 0 1px #333;
	border: 0.5px solid #333;
	width: 25%;
}

.outline-outward2:before {
	content: "";
	position: absolute;
	border: #333 solid 0.5px;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	transition-duration: 0.3s;
	transition-property: top right bottom left;
}

.outline-outward2:hover:before {
	top: -8px;
	right: -8px;
	bottom: -8px;
	left: -8px;
}

.button {
	margin: 0.4em;
	padding: 0.5em 1em;
	cursor: pointer;
	background: #fff;
	text-decoration: none;
	color: #333;
	font-size: 1.8rem;
}

@media screen and (max-width: 480px) {
	.btn-box {
		display: grid;
	}

	.outline-outward2 {
		width: 65%;
	}

	#page-top {
		position: fixed;
		right: -25px;
		bottom: 45px;
		height: 50px;
		text-decoration: none;
		font-weight: 400;
		transform: rotate(90deg);
		font-size: 1em;
		line-height: 3.5rem;
		color: #0088C0;
		padding: 0 0 0 35px;
		border-top: solid 1px;
		letter-spacing: 2px;
	}
}

.sideways {
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	position: fixed;
	left: -10px;
	bottom: -2em;
	font-weight: 600;
	font-size: 8px;
	line-height: 1.9;
	letter-spacing: 4px;
	/* color: #0000B3; */
	color: #0088C0;
	/* font-family: 'Playfair Display', serif; */
	display: block;
    z-index: 1;
}

/*****************
  SNSbtn
************************/
/* アイコン周り全体 */
.flowbtn16 {
	font-family: 'Georgia', sans-serif;
	/* 好きなフォントに変えてね */
	display: inline-block;
	width: 61px;
	height: 57px;
	font-size: 25px;
	transition: .5s;
	text-decoration: none;
	background: transparent;
	color: #4e4e4e;
}

.flowbtn16:hover {
	text-decoration: none;
}

/* Twitterマウスホバー時 */
.flowbtn16.fl_tw2:hover {
	background: #4e4e4e;
	color: #fff;
}

/* Instagramマウスホバー時 */
.flowbtn16.insta_btn2:hover {
	background: #4e4e4e;
	color: #fff;
}

/* Facebookマウスホバー時 */
.flowbtn16.fl_fb2:hover {
	background: #4e4e4e;
	color: #fff;
}

/* ボタン内テキスト調整 */
.flowbtn16 div {
	font-size: 9px;
	letter-spacing: 0;
	font-weight: bold;
	position: relative;
	bottom: 16px;
}

/* ulタグの内側余白を０にする */
ul.snsbtniti {
	padding: 3rem 0 0;
}

/* アイコンボタンの位置調整 */
.snsbtniti {
	display: flex;
	justify-content: center;
}

/* アイコンボタン同士の余白調整 */
.snsbtniti li {
	flex: 0 0 7%;
	text-align: center !important;
}

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

	/*****************
	  SNSbtn
	************************/
	/* アイコン周り全体 */
	.flowbtn16 {
		height: 50px;
	}

	/* ボタン内テキスト調整 */
	.flowbtn16 div {
		bottom: 8px;
	}

	/* アイコンボタン同士の余白調整 */
	.snsbtniti li {
		flex: 0 0 22%;
	}
}


.main_imgBox {
	width: 600px;
	height: 390px;
	overflow: hidden;
	position: relative;
}

.main_logo {
	z-index: 11;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 50%;
	height: auto;
}

.main_imgM {
	opacity: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: absolute;
	left: 0;
	top: 0;
	-webkit-animation: anime 36s 0s infinite;
	animation: anime 36s 0s infinite;
}

.main_imgM:nth-of-type(2) {
	-webkit-animation-delay: 6s;
	animation-delay: 6s;
}

.main_imgM:nth-of-type(3) {
	-webkit-animation-delay: 12s;
	animation-delay: 12s;
}

.main_imgM:nth-of-type(4) {
	-webkit-animation-delay: 18s;
	animation-delay: 18s;
}

.main_imgM:nth-of-type(5) {
	-webkit-animation-delay: 24s;
	animation-delay: 24s;
}

.main_imgM:nth-of-type(6) {
	-webkit-animation-delay: 30s;
	animation-delay: 30s;
}

@keyframes anime {
	0% {
		opacity: 0;
	}

	8% {
		opacity: 1;
	}

	17% {
		opacity: 1;
	}

	25% {
		opacity: 0;
		transform: scale(1.2);
		z-index: 9;
	}

	100% {
		opacity: 0
	}
}

@-webkit-keyframes anime {
	0% {
		opacity: 0;
	}

	8% {
		opacity: 1;
	}

	17% {
		opacity: 1;
	}

	25% {
		opacity: 0;
		-webkit-transform: scale(1.2);
		z-index: 9;
	}

	100% {
		opacity: 0
	}
}

@media screen and (max-width:767px) {
	.button {
		margin: 0.4em;
		padding: 0.4em 1em;
		cursor: pointer;
		background: #fff;
		text-decoration: none;
		color: #333;
		font-size: 1.4rem;
	}

	.main_imgBox {
		max-width: 400px;
		height: 245px;
		overflow: hidden;
		position: relative;
		width: 100%;
		margin: 0 auto;
	}
}

.intro {
	padding-bottom: 20px;
	/* background-image: url(../img/recruit_intro_r.jpg), url(../img/recruit_intro_l.jpg); */
	background-repeat: no-repeat;
	background-position: right top, left bottom;
	background-size: contain !important;
	max-width: 1200px;
	margin: 0 auto;
}

.intro .inner {
	max-width: 1000px;
	width: 100%;
	margin: 0 auto;
	padding: 100px 0 120px;
}

.intro .inner h1 {
	padding-bottom: 30px;
	max-width: 1000px;
	text-align: center;
	width: 90%;
	margin: 0 auto 4rem;
	font-weight: 600;
	position: relative;
	color: #0A015A;
	font-size: 46px;
	line-height: 0.8;
	letter-spacing: 3px;
	font-family: 'Saira Semi Condensed', sans-serif;
}

.intro h3 {
	font-size: 23px;
	font-weight: bold;
	color: #0A015A;
	padding-bottom: 10px;
	text-align: left;
	line-height: 1.2;
}

.intro p {
	line-height: 1.6;
	padding: 0 10px 0 0;
	text-align: left;
}


.intro .intro_box {
	background: #fff;
	padding: 15px;
	position: relative;
	min-height: 160px;
	margin: 0 8% 30px;
	text-align: center;
	border-radius: 10px;
}

/*
.intro .intro_box img {
	filter: invert(72%) sepia(26%) saturate(6428%) hue-rotate(1deg) brightness(105%) contrast(102%);
}*/



.intro .intro_box div:first-child {
	text-align: center;
	margin-bottom: 15px;
}

@media screen and (min-width:768px) {
	.intro .inner {
		max-width: 1000px;
		width: 100%;
		margin: 0 auto;
		padding: 100px 0 120px;
	}

	.intro .intro_box {
		background: #fff;
		padding: 45px 0;
		display: flex;
		justify-content: flex-end;
		position: relative;
		width: 80%;
		box-shadow: 0px 0px 16px 5px rgb(0 0 0 / 10%);
		margin: 0 auto 40px;
		align-items: center;
	}

	.intro .inner h1 span {
		font-size: 1.5rem;
	}


	.intro .intro_box div:first-child {
		width: 20%;
		padding: 0 4% 0 4%;
		text-align: center;
	}

	.intro .intro_box div:last-child {
		width: 680px;
	}


}

@media screen and (max-width:768px) {
	.intro {
		padding-bottom: 20px;
		max-width: 1200px;
		margin: 0 auto;
	}

	.intro .inner {
		padding: 65px 0 65px;
	}

	.intro h1 {
		font-size: 3.2rem;
		font-weight: 600;
		text-align: center;
		color: #333;
		font-family: 'Saira Semi Condensed', sans-serif;
		letter-spacing: 4px;
		line-height: 0.8;
		max-width: 1000px;
		width: 90%;
		padding-bottom: 10px;
		margin: 0 auto 2rem;
		position: relative;
	}

	.intro h1 span {
		font-size: 1rem;
		color: #8d7558;
	}

	.intro .intro_box {
		background: #fff;
		padding: 30px 10px;
		position: relative;
		margin: 0 8% 30px;
		text-align: center;
	}

	.intro .intro_box div:first-child {
		text-align: center;
		margin-bottom: 15px;
	}

	.intro .intro_box img {
		width: 150px;
		/*filter: invert(72%) sepia(26%) saturate(6428%) hue-rotate(1deg) brightness(105%) contrast(102%);*/
	}

	.intro h3 {
		font-size: 18px;
		font-weight: 600;
		color: #0A015A;
		padding-bottom: 10px;
		text-align: center;
		line-height: 1.2;
	}

	.intro p {
		text-align: left;
	}
}



#work_txt .inner ul {
	background: linear-gradient(rgba(0, 0, 0, .5), rgba(0, 0, 0, .5)), url(../img/work_back.jpg) fixed center no-repeat;
	background-size: cover;
	background-repeat: no-repeat;
	background-size: cover;
	position: relative;
}
/*
#work_txt .inner ul::before {
	content:"";
    display:block;
    position:fixed;
    top:0;
    z-index:-1;
    width:100%;
	height: 100%;
	background: linear-gradient(rgba(0, 0, 0, .5), rgba(0, 0, 0, .5)), url(../img/work_back.jpg) fixed center no-repeat;
	background-size: cover;
	background-repeat: no-repeat;
	background-size: cover;
	background-attachment: fixed;
}*/


#work_txt .inner ul li {
	padding: 90px 100px 70px 93px;
	color: #FFFFFF;
	display: flex;
	-moz-transition-duration: 0.6s;
	-o-transition-duration: 0.6s;
	-webkit-transition-duration: 0.6s;
	transition-duration: 0.6s;
	animation-name: fadein;
	animation-duration: 2s;
	margin-bottom: 0;
}

#work_txt .inner ul li:hover {}

#work_txt .inner ul li>div {
	width: 100%;
	padding: 0 20px;
	animation-name: fadein;
	animation-duration: 2s;
}

#work_txt .inner ul li .vctitle {
	display: flex;
	align-items: center;
	margin-bottom: 30px;
}

#work_txt .inner ul li .vctitle .vctitleno {
	font-size: 40px;
	font-weight: bold;
	letter-spacing: 0.165em;
	margin-right: 20px;
}

#work_txt .inner ul li .vctitle .vctitletxt {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	font-size: 2.2rem;
	font-weight: 500;
	letter-spacing: 0.06em;
	line-height: 23px;
}

#work_txt .inner ul li .vstext {
	line-height: 1.8;
	margin-bottom: 38px;
}

#work_txt .inner ul li .vsusre {
	font-size: 14px;
	line-height: 17px;
	text-align: right;
}

#work_txt,
#welfare,
#guideline-title {
    padding-top: 50px !important;
    margin-top: -50px !important; 
}
#welfare {
    padding-top: 50px;
    margin-top: -50px;
}
.tbl-r02 {
	max-width: 1000px;
	/* margin: 0 auto; */
	width: 100%;
}

.tbl-r02 th {
	/* background: #0088C0; */
	/* border: solid 1px #ccc; */
	color: #0088C0;
	padding: 10px;
	font-size: 12px;
}

.tbl-r02 th:before {
	position: initial;
	bottom: -2px;
	left: 0;
	width: 90%;
	height: 2px;
	content: '';
	/* background: #0000B3; */
	background: #0A015A;
}

.tbl-r02 th,
.tbl-r02 td {
	border-bottom: 1px dotted #fff;
}

.tbl-r02 td {
	/* border: solid 1px #ccc; */
	padding: 10px;
	font-size: 12px;
	/* background: #fff; */
	color: #fff;
	width: 70%;
}

#work_txt .inner ul li:after {
	clear: both;
	content: '';
	display: block;
}

#work_txt .inner ul li:nth-child(2n) {
	display: block;
	background-color: rgba(30, 144, 255, 0.8);
}

#work_txt .inner ul li:nth-child(2n) .vcright {
	opacity: 1;
	float: right;
	display: inline-block;
	width: 50%;
}

#work_txt .inner ul li:nth-child(2n) .vcleft {
	opacity: 1;
	width: 50%;
}

@media screen and (max-width: 780px) {
	#work_txt .inner {
		margin-left: 0;
		width: 100%;
	}

	#work_txt .inner ul {
		padding-top: 25px;
	}

	#work_txt .inner ul li {
		display: block;
		padding: 25px 18px;
	}

	#work_txt .inner ul li .vcleft {
		margin-bottom: 20px;
	}

	#work_txt .inner ul li .vctitle {
		margin-bottom: 25px;
	}

	#work_txt .inner ul li .vctitle .vctitleno {
		font-size: 37px;
		line-height: 1;
		margin-right: 18px;
	}

	#work_txt .inner ul li .vctitle .vctitletxt {
		font-size: 18px;
		line-height: 22px;
	}

	#work_txt .inner ul li .vstext {
		margin-bottom: 15px;
	}

	#work_txt .inner ul li .vsusre {
		font-size: 14px;
		line-height: 17px;
		text-align: right;
	}

	.tbl-r02 td {
		border: solid 1px #ccc;
		padding: 10px;
		font-size: 12px;
		background: #fff;
		color: #333;
		width: 70%;
	}

	#work_txt .inner ul li .vcleft,
	#work_txt .inner ul li .vcright {
		padding: 0;
	}

	#work_txt .inner ul li .vcimg {
		width: 100%;
	}

	#work_txt .inner ul li .vcimg img {
		width: 100%;
	}

	#work_txt .inner ul li:nth-child(2n) .vcleft {
		width: 100%;
	}

	#work_txt .inner ul li:nth-child(2n) .vcright {
		float: none;
		display: block;
		width: 100%;
		margin-bottom: 20px;
	}

	#slide_wrap .slide_item p {
		position: absolute;
		bottom: 0.1em;
		right: 3em;
		width: 100px;
		text-align: center;
		color: #4e4e4e;
		background: #fff;
		font-size: 13px;
		padding: 5px 10px;
	}
}

/*=== 9-1-4 矢印が動いてスクロールを促す  ====*/

/*スクロールダウン全体の場所*/
@media screen and (min-width: 768px) {
	.scroll_text {
		display: inline-block;
		position: absolute;
		right: 44%;
		bottom: -18%;
		z-index: 2;
		padding: 10px 10px 110px;
		padding-right: 80px;
		overflow: hidden;
		color: #333;
		font-size: 2rem;
		text-shadow: 0 0 5px #fff;
		font-family: 'Playfair Display', serif;
		line-height: 1;
		letter-spacing: 0.05em;
		text-transform: uppercase;
		text-decoration: none;
		writing-mode: vertical-lr;
		animation: arrowmove 1s ease-in-out infinite;
	}

	.scroll_text::before {
		content: "";
		position: absolute;
		bottom: 50%;
		right: 52%;
		width: 1px;
		height: 30px;
		background: #333;
		transform: skewX(-31deg);
	}

	.scroll_text::after {
		content: '';
		position: absolute;
		bottom: 50%;
		right: 60%;
		width: 1px;
		height: 100px;
		background: #333;
	}

	/* 
.scroll_text::after {
	bottom: -15%;
	animation: arrowmove2 1s ease-in-out infinite;
} */

	@keyframes arrowmove {
		0% {
			bottom: -18%;
		}

		50% {
			bottom: -21%;
		}

		100% {
			bottom: -18%;
		}
	}

}

.fa-instgram,
.fa-facebook {
	color: #0A015A;
}

.pc {
	display: block;
}
.sp {
	display: none;
}

@media screen and (max-width: 768px) {
	.pc {
		display: none;
	}
	.sp {
		display: block;
	}
}

.price {
	font-size: 3rem !important;
}


.fadeInRight {
	visibility: visible; 
	animation-name: fadeInRight !important;
}

.fadeInleft {
	visibility: visible; 
	animation-name: fadeInLeft !important;
}

.ml-15 {
	margin-left: 15px;
}

.t-a-r {
	text-align: right !important;
}

.fa-twitter:before {
    content: '𝕏';
    font-family: unset;
    font-weight: bold;
}