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

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

body {
	font-family: Helvetica Neue, Helvetica, Arial, '游ゴシック', YuGothic, 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
	font-weight: 400;
	font-style: normal;
	font-kerning: auto;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 2.0;
	color: #000;
	overflow-x: hidden;
	letter-spacing: .5px;
	-webkit-font-smoothing: antialiased;
	font-feature-settings: "palt";
}

.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;
}

span.ilb {
	display: inline-block !important;
	font-size: inherit !important;
}


@media screen and (min-width: 769px) {
	.pc-only {
		display: block;
	}

	.time-box .pc-only {
		display: inline-block;
	}

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

	a[href^="tel:"] {
		pointer-events: none !important;
	}
}

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

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

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

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

	.scroll_text {
		display: none;
	}

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

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

}

@media screen and (min-width: 897px) {
	.point {
		padding: 3% 0% 5%;
	}

	.point .inner {
		max-width: 1000px;
		margin: 0 auto;
		padding: 0 30px;
	}

	.point .box {
		max-width: 1000px;
		height: 212px;
		padding: 60px 0;
		margin-bottom: 5px;
		border-radius: 8px
	}

	.point .box .txt {
		font-size: 4rem;
		font-weight: 400;
		color: #fff;
		width: 600px;
		background: #000;
		text-align: center;
		margin: 0 auto;
		border-bottom: 1px solid #fff;
		padding: 20px;
	}

	.point_section section+section {
		margin-left: 0;
		margin-top: 30px;
	}

	.point .box .bolod {
		font-size: 5rem;
		font-weight: 600;
		color: #004b9d;
		text-align: center;
		padding-top: 20px;
		/* font-family: "Noto Sans JP", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, Verdana, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Meiryo, Osaka, "MS PGothic", "M+ 1p", sans-serif; */
	}


	.point_section section {
		margin-top: 30px;
		text-align: center;
		background-color: #fff !important;
		width: 32%;
		padding: 40px 0;

	}

	.point_section section+section {
		margin-left: 2%;
	}

	.point_section section {
		margin-top: 30px;
		text-align: center;
		background-color: #fff !important;
	}

	.point_section {
		display: flex;
		justify-content: space-between;
	}

	.point_section section p {
		font-size: 2rem;
		font-weight: 500;
		line-height: 2.5;
		/* border-radius: 25px; */
		color: #000;
		/* border-bottom: 1px solid #000; */
		width: auto;
		margin: 0.5em auto 0;
	}

}

@media screen and (max-width: 896px) {
	.point {
		padding-bottom: 60px;
		padding-top: 60px;
	}

	.point .inner {
		padding: 0 30px 50px;
	}

	.point .box {
		margin-bottom: 5px;
	}

	.inner .box {
		width: 100%;
		height: 100px;
		padding: 35px 0 0;
		/* border: 5px solid #004b9d; */
		border-radius: 8px;
	}

	.point .box .txt {
		font-size: 2rem;
		font-weight: 600;
		padding: 10px 0;
		color: #fff !important;
		width: 90%;
		background-color: #000;
		text-align: center;
		margin: 0 auto;
	}

	.point .box .bolod {
		font-size: 3rem;
		font-weight: 800;
		color: #000;
		text-align: center;
		padding-top: 20px;
	}

	.point_section {
		display: flex;
		justify-content: space-between;
	}

	.point_section section {
		margin-top: 30px;
		width: 32%;
		background-color: #fff;
		padding: 20px 25px !important;
		text-align: center;

	}

	.point_section section+section {
		margin-left: 2%;
	}

	.point_section img {
		max-width: 100%;
		height: auto;
	}

	.point_section section p {
		font-size: 15px;
		font-weight: 600;
		line-height: 2.5;
		color: #000;
		/* border-bottom: 1px solid #000; */
		width: auto;
		margin: 0.5em auto 0;
	}
}


@media screen and (min-width: 769px) {
	a[href^="tel:"] {
		pointer-events: 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;
	min-width: 250px;
	font-size: 1.8rem;
	font-weight: normal;
	margin: auto;
	font-size: 2.0rem;
	padding: 0.5rem 1.6rem;
	color: #000;
	border: 1px solid #000;
}

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

.btn_corp .button-normal {
	background-color: #000;
	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;
	box-shadow: 0 10px 25px 0 rgb(0 0 0 / 8%);
}

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

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

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

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;
}

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

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 {
	background-color: #956f29;
}
.sp-only-header nav ul {
	display: block;
}
.sp-only-header nav ul li a {
	display: block;
	color: #fff;
	padding: 0 15px 10px;
	text-decoration: none;
	font-weight:400;
}
.sp-only-header nav ul li a span{
	color: #999;
	background: #fff;
	font-size: 12px;
	padding: 2px 10px;
	line-height: 35px;
}
.sp-only-header nav ul li {
	/* border-bottom:1px dotted #999; */
	margin-bottom: 0;
}
.sp-only-header nav > ul > li:last-of-type {
	padding-top: 1.5rem;
}

.sp-only-header {
	top: 0em;
	left: 0;
	z-index: 1000;
	width: 100%;
	position: fixed;
}
.sp-only-header .drawer-hamburger {
	background: #956f29 !important;
	color: #fff;
	padding: 0;
	height: 62px;
	font-size: 12px;
	width: 70px;
	text-align: center;
	line-height: 1.2;
	font-weight: 500;
	z-index: 11;
	margin-bottom: 0;
	display: flex;
	align-items: center;
	justify-content: center;
}
.drawer--right.drawer-open .drawer-hamburger {
	right: 25rem;
}
.sp-only-header .drawer-nav {
	position: fixed;
	z-index: 11;
	top: 0;
	right: -25rem;
	overflow: hidden;
	width: 25rem;
	height: 100%;

}
.drawer-overlay {
	z-index: 10;
}
.sp-only ul.d-flex{
	background:#999;
	margin-top: 62px;
	text-align: center;
	display: flex;
	justify-content: space-between;
	z-index: 900;
	width: 100%;
	position: fixed;
}
.sp-only ul.d-flex li {
	padding:8px 7px;
	margin-bottom:0;
	border-top: 1px solid #fff;
	border-right: 1px solid #fff;
	width: 100px;
	line-height: 1.0;
}
.sp-only ul.d-flex li.brder-none {
	border:none;
}
.sp-only ul.d-flex li:nth-child(5){
	border-right:none;
}
.sp-only ul.d-flex li a{
	color:#fff;
	font-size:3vw;
	line-height: 1.7;
	/* padding: 10px 3px; */
}
.sp-only ul li ul {
	margin: 0;
}
.sp-only ul li ul {
	font-size: 100%;
	border-bottom: 1px solid #999;
}
.sp-only ul li ul li.add {
	color: #fff;
	border-bottom: 1px dotted #999;
	padding: 10px 10px 10px 0;
	margin: 0 0 15px 15px;
	position: relative;
}
.sp-only ul li ul li.add:after {
	content: "";
	position: absolute;
	right: 0;
	bottom: -12px;
	left: -25px;
	width: 20px;
	height: 20px;
	border: 1px dotted;
	border-color:  transparent transparent #999 #999;
	transform: rotate(-45deg);
}
.sp-only ul li.add-1 {
	border-bottom: 1px solid #999;
	margin-top: 10px;
}
.sp-only ul li.add-2 {
	/* border-top: 1px solid #999; */
	padding-top: 10px;
}
.sp-only ul li.add-2 img {
	width: 30px;
	vertical-align: -10px;
	margin-right: 10px;
}
.sp-only ul li.add-2.add-2--type2 {
	margin-top: 10px;
}

.sp-only ul li:last-child a:before {
	content: ""
}
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: 250px;
		width: 100%;
		margin: 0 auto;
	}
	header .container h1 a {
		font-size:2.0rem;
	}
	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: #000;
	}
	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 #000; */
	padding-top: 3em;
	background: #956f29;
}

footer h1 {
	margin-bottom: 10px;
}

footer h1 img {
	max-width: 280px;
	width: 88%;
}

footer .footer_top {
	/* background: #FFF; */
	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.6rem;
	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;
	background: rgba(178, 140, 110, 0.7);
	color: #fff;
	margin-top: 2rem;
}

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

footer table {
	width: 100%;
	color: #fff;
	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.5rem;
	border-bottom: 1px dotted #999;
}

/***追従するトップへ戻るボタン***/
#page-top {
	position: fixed;
  right: -15px;
  bottom: 40px;
  height: 50px;
  text-decoration: none;
  font-weight: 500;
  transform: rotate(90deg);
  font-size: 1.0em;
  line-height: 3.0rem;
  color: #999;
  padding: 0 0 0 35px;
  border-top: solid 1px;
  letter-spacing: 0.05em;
  font-family: 'Hind', sans-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.7);
	padding: 3%;
	/* height: 440px; */
	/* 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: 2em;
	}
}


/** 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;
	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: 'Hind', sans-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;
	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;
}

.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 {
  height: 700px;
  position: relative;
}
.no-top.detail #mainvisual .img-wrapper {
	background: url(../img/mainimg_rec01.jpg) no-repeat center;
  background-size: cover;
}

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

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

.no-top.detail4 #mainvisual .img-wrapper {
	background: url("../img/mainimg_rec04.jpg") no-repeat right;
	background-size: cover;
	height: 700px;
}
.no-top #mainvisual .img-wrapper.img-wrapper--type2 {
	height: 750px !important;
}
.no-top #mainvisual .img-wrapper.img-wrapper--type3 {
	height: 800px !important;
}
  

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

.no-top.detail #mainvisual .img-wrapper .container {
	max-width: 1728px;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%,-50%);
	transform: translate(-50%,-50%);
	height: auto;
	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: 'Hind', sans-serif; */
	letter-spacing: 2px;
}

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

}

.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: 768px) {
	header {
		background: #fff;
	}

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

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

	.no-top #mainvisual {
		padding-top: 62px;
		/* margin-bottom: 3em; */
	}

	.no-top.detail #mainvisual {
		padding-top: 96px;
		/* 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: 'Hind', sans-serif; */
		letter-spacing: 2px;
		font-weight: 600;
		text-align: center;
		color: #fff;
		padding: 10px 0 10px 10px;
		text-shadow: 1px 1px 20px #000;
		border-top: 1px solid #999;
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit .kv_koyo {
		display: inline-block;
		padding: 5px 8px;
		margin: 0.5em auto 1em;
		background: #000;
		color: #fff;
		text-shadow: none;
		border: none;
	}

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

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

	.no-top #mainvisual .img-wrapper .d-flex .copy-box span.price {
    font-size: 3.5rem;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.2;
	}

	.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: #000;
		background-color: #fff;
		text-align: center;
		font-size: 1.4rem;
		line-height: 1.2;
		display: flex;
		justify-content: center;
		align-items: center;
		font-weight: 400;
		margin: 0 1%;
	}
}


@media screen and (max-width:460px) {
	.no-top #mainvisual {
		padding-top: 62px;
		margin-bottom: 3em;
	}

	.no-top.detail #mainvisual {
		padding-top: 96px;
		margin-bottom: 3em;
	}

	.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 (max-width:360px) {

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

@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: 0.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.7);
		/* padding: 3%; */
		height: 100%;
		/* margin-top: 6em; */
	}

	.no-top #mainvisual .img-wrapper .d-flex .maiTit p {
		color: #fff;
		text-shadow: 0 0 8px #000;
		font-size: 2.4rem;
		font-weight: 600;
		max-width: 800px;
		text-align: center;
		padding: 10px 0;
		line-height: 1.8;
		font-size: 2rem;
		border-top: 1px solid #999;
		/* font-family: 'Hind', sans-serif; */
		letter-spacing: 2px;
	}

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

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

	.no-top #mainvisual .img-wrapper .d-flex .copy-box span.price {
    font-size: 4.0rem;
    font-weight: 400;
    letter-spacing: 0;
    line-height: 1.2;
	}
}

.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%;
	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;
	text-shadow: 2px 2px 10px #000;
}

.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: 5.2vw;
	text-align: left;
	letter-spacing: .2em;
	text-shadow: 2px 2px 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: 1.4rem;
	padding: 20px 0 0;
}

.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 #recruit {
	background: #e6d4c6;
}

#contents iframe {
	vertical-align:bottom;
}

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

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

#contents section h2 strong {
	font-size: 10rem;
	line-height: 1.2;
	/* margin-bottom: 40px; */
	font-weight: 500;
	text-align: center;
	position: relative;
	text-shadow: 0 0 2px white;
	z-index: 1;
	font-family: 'Hind', sans-serif;
	letter-spacing: 4px;
}

#contents section .about_ttl h2 {
	text-align: left;
	display: flex;
	align-items: center;
	margin-top: 1.5em;
	animation-duration: 1.5s;

}

#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: 6%;
}


#contents section .privacy_ttl h2 {
	text-align: left;
	display: flex;
	align-items: center;
	margin: 5em  100px  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 {
	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 {
	font-size: 7rem;
	margin-bottom: 0;
}


#contents section .recruit_ttl h2 strong {
	padding-right: 6%;
}

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

}

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

.slideshow {
	position: absolute;
	width: 100vw;
	/* height: 90vh; */
	height: 100%;
	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 {
	padding: 56px 0 100px;
}

#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: #999;
	text-align: center;
	position: relative;
	text-shadow: 0 0 2px white;
	z-index: 1;
	font-family: 'Hind', sans-serif;
	letter-spacing: 4px;
}

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

}

#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: 6%;
}

#contents .point {
    background: #fffcf1;
}

#contents #welfare {
    background: #fffcf1;
}

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

}

#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: 6%;
}



#contents section .interview_ttl h2 {
	text-align: left;
	display: flex;
	align-items: center;
	animation-duration: 2s;
}

#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: 6%;
}



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

}

#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;
}


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

}

#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: 6%;
}



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

}

#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: 6%;
}

#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: 2em;
}

#contents .bg_color {
	width: 90%;
	margin: 0 auto;
}

#message .container{
	position: relative;
	width: 100%;
	height: 100%;
}
/* #message .container .photoBox{
	position: relative;
	width: 100%;
	padding-left: 37.5vw;
}
#message .container .txtBox{
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	align-content: center;
	position: absolute;
	top: 7em;
	left: 0;
	max-width: 630px;
	text-align: left;
	padding: 3vw 2vw;
	z-index: 1;
	background: #000;
	margin: 0 auto;
} */
#message .container .txtBox p{
	color: #000;
}
#message .container .txtBox ul{
	display: inline-block;
	font-family: 'Cabin', sans-serif;
	font-size: 2.0rem;
	font-weight: 700;
	text-align: left;
	line-height: 1.8;
	letter-spacing: 0.02em;
	margin-bottom: 3.0rem;
}
#message .container .txtBox-txt {
	/* display: flex; */
	/* flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	align-content: center;
	position: absolute; */
	/* right: 4em; */
	/* width: 43vw; */
	/* height: 22em; */
	width: 90%;
	z-index: 1;
	color: #000;
	margin: 0 auto;
}
@media screen and (max-width: 1050px) {
	#message .container .txtBox {
		top: 20em;
	}
}
/* @media screen and (min-width: 851px) and (max-width: 900px) {
	#message .container .txtBox-txt {
		margin: 15em auto 0;
	}
} */

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

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

	}

	#contents section .about_ttl h2 {
    margin-top: 4em;
	}

	.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;
		justify-content: space-between;
		margin:0 auto 25px;
		max-width: 1100px;
	}
	.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;
	}
}

@media screen and (min-width: 751px)  {
	.no-top #vision .container .txtBox .stepBox.last-LineBox .box_txt {
		margin: 0 1%;
	}
}

@media screen and (max-width:768px) {
	#contents .bg_color {
		padding-bottom: 1em;
	}

	#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;
		margin: 5em auto 0;
	}

	.no-top #contents section#introduction .container {
		margin: 0 auto;
	}

	.no-top #contents section#recruit .container {
		margin: 0 auto;
	}
	.no-top #contents section#welfare {
		padding: 56px 0 0;
	}

	.no-top #contents section#welfare .container {
		margin: 0 auto;
	}

	.no-top #contents section#recruit .container {
	}

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

	.eachTextAnime {
		position: absolute;
		top: 55%;
		left: 5%;
		color: #fff;
		font-size: 2em;
		-webkit-font-smoothing: auto;
		font-size: 1vw;
		letter-spacing: .2em;
		text-shadow: 2px 2px 10px #000;
	}

	.kv_subtxt {
		position: absolute;
		top: 60%;
		left: 5%;
		color: #fff;
		font-size: 1.3em;
		-webkit-font-smoothing: auto;
		font-size: 4.2vw;
		letter-spacing: .1em;
		margin-top: 15.5vw;
		text-align: left;
		text-shadow: 2px 2px 10px #000;
	}

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

	.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;
	}

	.txt-wrapper p:last-child {
		margin-bottom: 2.5rem !important;
	}

	#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: 2.0rem;
	}

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

	#contents section .recruit_ttl h2 {
		padding: 50px 0;
	}

	.no-top #introduction .container .text-box h2 {
		margin-bottom: 1em;
		position: relative;
	}

	.no-top #introduction .container .text-box h2:before {
		content: '';
		display: block;
		background-color: #000;
		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: #999;
		left: 50%;
		top: auto;
		bottom: 0px;
		width: 25px;
		height: 2px;
	}

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

		#contents section .thanx_ttl h2:after, #contents section .thanx_ttl h2:before {
	    width: 100%;
	}

	.no-top #contents section#message .container {
		position: relative;
		width: 100%;
		height: 100%;
		padding: 0 20px;
		margin:  0 auto;
	}

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

	#message .container .txtBox-txt {
		width: 100%;
		padding-top: 3rem;
	}

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

	.no-top #message {
		padding: 56px 0 2em !important;
	}

	#contents .bg_color {
		width: 88%;
		margin: 0 auto;
	}

	#contents section .privacy_ttl h2 {
		margin: 5em auto 1em !important;
	}

	#contents section .privacy_ttl h2:after, #contents section .privacy_ttl h2:before {
		width: 100%;
	}

	.privacy_txt {
    margin: 2em auto 0;
	}

	.privacy_txt h3 {
		font-size: 20px;
		text-align: center;
		font-weight: 600;
	}

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

	footer h1 img {
		margin: 20px 0 32px;
	}

	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;
	}
}

@media screen and (max-width: 540px) {
	/* .slideshow {
		height: 90vh;
	} */

	.no-top #contents section .container {
		margin: 1em auto 0;
	}
}

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

.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: 2.0rem;
	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: 7rem;
	font-family: 'Hind', sans-serif;
	letter-spacing: 2px;
	color: #fff;
	text-decoration: none;
	font-weight: bold;
}

.info-wrapper .d-flex .tel-box a[href^="tel:"]:before {
content: "\f10b";
	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.6rem;
	line-height: 1.5;
	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: #fff;
	border: 2px solid #fff;
	height: 72px;
	line-height: 72px;
	color: #000;
	font-weight: 600;
	position: relative;
}

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

.info-wrapper .d-flex .btn-box .button.button-caution {
	width: 75%;
	font-size: 2.0rem;
	padding: 0 16px;
	margin-bottom: 2.4rem;
	background-color: #000;
	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.3;
		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: 7rem;
		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: 45%;
	}

	.about_img img {
		height: auto;
	}

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

	.no-top #introduction .container .text-box h2 {
		font-size: 3rem;
		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: #999;
		/* 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: #000;
		/* left: 50%; */
		top: auto;
		bottom: 0px;
		width: 25px;
		height: 4px;
	}

	.no-top #introduction .container .text-box p {
		/* padding: 1% 0 1% 4%; */
		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 p{
	text-align: center;
}
.no-top #vision .container .txtBox p.p-item {
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	font-size: 2.0rem;
	position: relative;
}
.no-top #vision .container .txtBox p.p-item:before,
.no-top #vision .container .txtBox p.p-item:after {
	content: '';
	width: 1px;
	height: 50px;
	background-color: #333;
	position: static;
}

.no-top #vision .container .txtBox p.p-item:before {
	margin-right: 15px;
	transform: rotate(-35deg)
}
.no-top #vision .container .txtBox p.p-item:after {
	margin-left: 15px;
	transform: rotate(35deg)
}

.no-top #vision .container .txtBox p:first-child{
	text-align: center;
	font-size: 2.0rem;
}

.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;
	justify-content: center;
	margin:0 auto 40px;
}
.no-top #vision .container .txtBox .stepBox.first-LineBox {
	font-size: 16px;
	font-weight: 500;
	line-height: 1.8;
	text-align: center;
}
.no-top #vision .container .txtBox .stepBox.last-LineBox {
	justify-content: center;
}
/* .no-top #vision .container .txtBox .stepBox {
font-size: 1.2em;
font-weight: 700;
line-height: 1.8;
text-align: center;
} */
.no-top #vision .container .txtBox .stepBox {
	font-size: 16px;
	font-weight: 500;
	line-height: 1.8;
	text-align: center;
}
.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: 20px;
  margin-bottom: 0;
}

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

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

	}

	.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: #000;
		background-color: #fff;
		text-align: center;
		font-size: 17px;
		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 {
		display: inline-block;
		padding: 5px 8px;
		margin: 0.5em auto 1em;
		background: #000;
		color: #fff;
		font-weight: 400;
		text-shadow: none;
		border: none;

	}
}

@media screen and (max-width: 480px) {
	.no-top #mainvisual .img-wrapper img {
		width: 100%;
		height: 460px;
		object-fit: cover;
	}

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

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

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

	.no-top #mainvisual .img-wrapper .d-flex .maiTit h1 {
		font-size: 4rem;
		margin-bottom: 0.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: 15em;
		width: 100%;
		height: 296px;
		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: 'Hind', 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: #000;
		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 10px;
		margin: 0 auto 1em;
		max-width: 180px;
		background: #fff;
		color: #000;
		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;
		justify-content: space-between;
		margin:0 auto 25px;
	}
	.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;
	}
}
@media screen and (min-width: 751px)  {
	.no-top #vision .container .txtBox .stepBox.last-LineBox .box_txt {
		margin: 0 1%;
	}
}





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

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

}

.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: #000;
	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: #000;
	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: #000;
	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: #000 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: #000;
	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: 4em;
	background: linear-gradient(180deg,rgba(0,0,0,0)0%,rgba(0,0,0,0)40%,#956f29 40%,#956f29 100%);
}
.no-top #message .photoBox {
	margin-bottom:20px;
}
.no-top #contents #message h3 {
	color: #fff;
	font-weight: 600;
	font-size:2.5rem;
	line-height: 1.7;
	margin-bottom: 0.6em;
}
.no-top #contents #message h3 span {
	color: #fff;
	font-size:1.6rem;
	line-height: 2;
	position: relative;
	display: block;
	padding: 0 55px 0 0;
}
.no-top #contents #message h3 span:after {
	content: '';
	position: absolute;
	top: 50%;
	display: inline-block;
	width: calc(100% - 8em);
	height: 1px;
	background-color: #fff;
}
.no-top #contents #message h3 span:after {
	right: 0;
}
.no-top #contents #message .txtBox-txt h3 span {
	color: #fff;
}
.no-top #contents #message .txtBox-txt h3 span:after {
	background-color: #fff;
}
.no-top #contents #message p {
	color: #fff;
	text-align: left;
}

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

/** detail #guideline **/

.no-top #guideline {
	padding: 130px 0;
}

.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;
}

/** detail #entry **/

.no-top #entry {
	padding: 56px 0 5em;
	background-color: #fffcf1;
}

.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 laber,
.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-NUMBER-LABEL:after,
.CMS-FORM-TEL-LABEL:after,
.CMS-FORM-EMAIL-LABEL:after,
.CMS-FORM-SELECT-LABEL:after {
	content: "必須";
	display: inline-block;
	font-size: 12px;
	color: #fff;
	text-align: center;
	width: 45px;
	height: 25px;
	background: #956f29;
	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;
}

.CMS-COMENT-GROUP textarea{
	height:180px;
	width:100%;
}

.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: 100%;
	max-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: #fff;
	border: 2px solid #956f29;
	background: #956f29;
}

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


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

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

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

@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;
		font-weight: 600;
	}
}

/*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:768px) {

	.no-top #guideline {
		padding: 60px 0;
	}

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

	.thanks .text-lead:last-child {
		text-align: left;
		margin: 0 auto 30px !important;
	}

	.info-wrapper .d-flex .tel-box a[href^="tel:"] {
		font-size: 7rem;
		font-family: 'Hind', 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 1% 2.4rem;
		background: #fff;
		border: 2px solid #fff;
		height: 55px;
		line-height: 55px;
		color: #000;
		position: relative;
		font-weight: 600;
	}

	.info-wrapper .d-flex .btn-box .button:hover {
		width: 100%;
		max-width: 350px;
		font-size: 1.5rem;
		padding: 0 45px;
		margin: 0 1% 2.4rem;
		background: #000;
		border: 2px solid #000;
		height: 55px;
		line-height: 55px;
		color: #fff;
		position: relative;
		font-weight: 600;
	}

	.info-wrapper .d-flex .btn-box .button.button-caution {
		width: 75%;
		font-size: 1.7rem;
		padding: 0 16px;
		margin-bottom: 2.4rem;
		background-color: #000;
		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: 2rem;
	}

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

@media screen and (max-width: 539px) {
	.info-wrapper .d-flex .tel-box a[href^="tel:"] {
		font-size: 4.2rem;
	}
	.no-top #message {
		padding-bottom: 4em;
		background: linear-gradient(180deg,rgba(0,0,0,0)0%,rgba(0,0,0,0)25%,#956f29 25%,#956f29 100%);
	}
}
@media screen and (max-width: 450px) {

	.no-top #message {
		padding-bottom: 4em;
		background: linear-gradient(180deg,rgba(0,0,0,0)0%,rgba(0,0,0,0)25%,#956f29 25%,#956f29 100%);
	}
}

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

.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: #fff;
	font-family: 'Hind', sans-serif;
	font-weight: 500;
	letter-spacing: 2px;
	line-height: 1.5;
	position: relative;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.post .caption span {
	display: inline-block;
	font-family: Helvetica Neue, Helvetica, Arial, '游ゴシック', YuGothic, 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
	font-size: 20px;
	font-weight: 600;
	position: relative;
  padding-bottom: 1em;
  margin-bottom: 0.6em;
}

.post .caption span:before {
	content: '';
	display: block;
	background-color: #fff;
	left: 50%;
	transform: translateX(-50%);
	position: absolute;
	top: auto;
	bottom: 0px;
	width: 30px;
	height: 3px;
}

.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: 0.8;
	/* マスクを表示する */
	padding-top: 80px;
	/* ホバーで下にずらす */
	background: #000;
}

@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: url("../img/contact_back.jpg") left no-repeat; */
		background: linear-gradient(rgba(76, 76, 76, .5), rgba(76, 76, 76, .5)), url("../img/contact_back.jpg") center no-repeat;
		background-size: cover;
		padding: 40px 0;
	}
	.info-wrapper--detail2 {
		/* background: url("../img/contact_back.jpg") left no-repeat; */
		background: linear-gradient(rgba(76, 76, 76, .5), rgba(76, 76, 76, .5)), url("../img/contact_back2.jpg")  center no-repeat;
		background-size: cover;
	}

	.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: #000;
	border: 1px solid #fff;
	font-weight: 600;
	transition: 0.5s all;
}

html.touch_device .recruit_menu_cnt .cmenu_list .item a .txt .more {
	background: #000;
	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: 150px;
	}
}

.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 #000;
	width: 20px;
	height: 0;
	top: 0;
	bottom: 0;
	right: 0;
}

.accordion_area .accordion_one .ac_header .i_box:after {
	border-left: 2px solid #000;
	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 {
    width: 88%;
	}
	.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 {
		padding-bottom: 120px;
	}
	.no-top #interview .main-title .prof span {
		font-size: 1.2rem;
	}

	.no-top #interview .main-title .prof {
		color: #000;
		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: 0;
	padding: 20px;
	border: solid 1px #b28c6e;
	width: calc(95% / 5);
	/* min-height: 200px; */
}

.first-LineBox .box_txt {
	width: calc(97% / 3);
	/* min-height: 200px; */
	position: relative;
	margin: 0;
	padding: 20px;
	border: solid 2px #b28c6e;
	background: #fff;
}

.detail3 .first-LineBox .box_txt,
.detail4 .first-LineBox .box_txt {
	width: calc(97% / 3);
}

#contents section .work_ttl h2.txtBox-title {
	text-align: center;
	color: #b28c6e;
	font-size: 2.0rem;
}

.box_txt .box-title {
	font-family: 'Hind', sans-serif;
	display: inline-block;
	padding: 0 15px 5px;
	line-height: 1.5;
	font-size: 30px;
	color: #b28c6e;
	font-weight: 600;
	position: relative;
}

.box_txt .box-title:after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  width: 1em;
  height: 2px;
  margin: 0 auto;
  background: #b28c6e;
}

.box_txt p {
	font-weight: 400;
	margin: 0;
	padding: 0;
}
.box_txt h3{
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-size: 1.3em;
	color: #b28c6e;
	text-align: center;
	margin: 0;
	padding: 1rem 0;
}
.no-top #vision .container .txtBox .stepBox.first-LineBox .box_txt h3{
	color: #000;
	font-weight: 600;
	padding: 20px 0 1rem;
}

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

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

	.no-top #vision .container .txtBox .stepBox {
		display: flex;
		flex-flow: row;
		justify-content: space-between;
		margin: 0 auto 40px;
	}

	.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: #000;
	}

	.box_txt {
		position: relative;
		margin: 0;
		padding: 10px;
	}
	.box_txt h3{
		padding: 0;
	}
}

@media screen and (max-width: 750px) {
	#contents section .vision_ttl .work_ttl h2 {
		font-size: 2.5rem;
	}
	#contents section .vision_ttl .work_ttl h2:before, #contents section .vision_ttl .work_ttl h2:after {
    height: 30px;
	}
	.no-top #vision .container .txtBox .stepBox.first-LineBox {
		flex-flow: column;
		margin: 0 auto 25px;
	}
	.no-top #vision .container .txtBox .stepBox {
		flex-flow: column;
		margin: 0 auto 25px;
	}
	.first-LineBox .box_txt {
		position: relative;
		margin: 0 auto 25px;
		padding: 15px;
		width: 100% !important;
		min-height: auto;
	}
	.first-LineBox .box_txt:last-child {
		margin: 0 auto 25px !important;
	}
	.box_txt {
		position: relative;
		margin: 0 auto 25px;
		padding: 25px 15px;
		border: solid 1px #b28c6e;
		width: 100% !important;
		min-height: auto;
	}
}

@media screen and (max-width: 550px) {
	.no-top #vision .container .txtBox .stepBox {
		flex-flow: column;
		margin: 0 auto 25px;
	}
	#contents section .work_ttl h2 {
		margin-top: 7%;
	}
	.box_txt {
		position: relative;
		margin: 0 auto 25px;
		padding: 25px 15px;
		border: solid 1px #b28c6e;
		width: 80% !important;
		min-height: auto;
	}
	.first-LineBox .box_txt {
		width: 80% !important;
	}
	.first-LineBox .box_txt h3 {
		padding: 0;
	}
}

@media screen and (max-width: 480px) {
	#contents section .work_ttl h2 {
		font-size: 2.5rem;
	}
	.box_txt {
		width: 90% !important;
	}
	.first-LineBox .box_txt {
		width: 90% !important;
	}
}

@-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: 600px;
	margin: 0 auto;
}
.grid.detail {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	max-width: 100%;
	margin: 0 auto 30px !important;
}
@media screen and (min-width: 768px) {
	.grid {
		max-width: 1580px;
	}
	/* .grid.detail {
		max-width: 85%;
	} */
	.grid_margin{
		margin-bottom: 5em!important;
	}
	.grid_margin .card__desc {
		padding-bottom: 5%;
	}
}

@media screen and (max-width: 767px) {
	.grid_margin{
		margin-bottom: 3em!important;
	}
	.grid.detail {
		max-width: 80%;
	}
}

@media screen and (max-width: 540px) {
	.grid.detail {
		max-width: 100%;
	}
}

.card {
	position: relative;
	flex: 1 1 100%;
	margin: 5px 0 0;
	/* padding: 20px 5px; */
	background: #e7f9ff;
}
.detail .card {
	position: static;
	flex: none;
	/* margin: 30px 5px 0; */
	padding: 0;
	background: none;
	border: 2px solid #b28c6e;
	background: #fff;
}

@media screen and (min-width: 768px) {
	.card {
		flex-basis: calc(95% / 2);
		margin: 0 1.0em 0 0;
	}

	.detail .card {
		flex-basis: calc(95% / 2);
		/* margin: 0; */
	}

	.detail .card:last-child {
		margin: 0;
	}

	.detail.detail-2 .card {
		flex-basis: calc(80% / 1);
		margin: 30px auto 0;
	}
}

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

	.detail .card {
		flex-basis: calc(95% / 3);
		margin: 0 0 3em;
		flex: 1 1 100%;
	}
}

.card__thumb {
	overflow: hidden;
}

.card__img {
	margin: -20px -20px 0;
}
.card__img img {
	max-width: 100%;
	height: auto;
	border: 0;
	vertical-align: middle;
	box-sizing: border-box;
}
.card__desc {
	/* margin-top: 20px; */
	background: #e7f9ff;
	padding-bottom: 5%;
}
.detail .card__desc {
	/* margin-top: 20px; */
	background: none;
	padding-bottom: 0;
}
.card__desc p{
	padding:0 5%;
}
.detail .card__desc p{
	text-align: center;
	line-height: 1.8;
	padding: 5%;
}
.more-group {
	display: flex;
	justify-content:flex-end;
	width: calc(95% + 1em);
}
.more-wrap{
	display: flex;
	/* position: absolute; */
	/* bottom: 2%; */
}

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

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

.post h2 span {
	color: #fff;
	margin: 0 auto;
	padding-bottom: 10px;
}

.post h3 {
	font-weight: 600;
	text-align: center;
	padding-bottom: 1em;
	margin: 1em 25px;
	position: relative;
}

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

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

.post p {
	padding: 10px 25px;

}

.post {
	margin: 0 20px;
	background: #fff;
	width: calc(100% / 2 - 40px)
}

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);
}

.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: #000;
	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;
	font-size: 2.3rem;
	color: #333;
	border-bottom:2px solid #b28c6e;
	padding: 0 0 5% 0;
	margin: 5% 5% 0;
}

.card__desc h3 span {
	display: inline-block;
	padding: 10px;
	margin: 0.5em 0 0 0;
	border:1px solid #333;
	font-size: 15px;
}

.card__desc h3 span.pc-only{
	padding:0 10px;
	margin: 0;
	border: none;
}

.detail .card__desc h3{
	color: #b28c6e;
	font-weight: 600;
}

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

.navigation {
	font-family: "Pathway Gothic One", sans-serif;
	font-size: 22px;
	line-height: 1;
	padding-top: 0.5em;
}

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

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

.insta {
	width: 65px;
	margin-top: -20px;
	text-align: center;
}
.insta:nth-of-type(1) {
	margin-right: 0;
}
.insta span {
	font-size: 12px;
	text-align: center;
	display: block;
	padding-bottom: 5px;
	font-weight: bold;
}
.insta img {
	width: 55%;
	margin: 0 auto;
}

@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: 88%;
		max-width: 900px;
		margin: 0 auto;
	}

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

	.post h2 span {
		color: #fff;
		margin: 0 auto;
		padding-bottom: 10px;
	}

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

	.post p {
		padding: 0 15px 15px;
		margin-bottom: 0;
	}

	.post {
		display: block;
		margin: 0 auto 30px;
		background: #fff;
		width: 100%;
	}

	.post:last-child {
		margin: 0 auto 30px !important;
	}

	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: #000;
		left: calc(50% - 25px);
		position: absolute;
		top: auto;
		bottom: 0px;
		width: 50px;
		height: 2px;
	}

	.card__desc h2:after {
		content: '';
		display: block;
		position: absolute;
		background: #999;
		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;
	}

	footer .footer_top {
		padding: 0;
		width: 88%;
		margin: 0 auto;
	}

}

@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 40px 3px; */
		font-family: 'Hind', 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: #000;
	font-weight: 500;
}

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

.menu__second-word {
	color: #999;
	font-weight: 500;
}

.menu__second-word::before {
	bottom: 105%;
	color: #000;
}

.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: #000;
}

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

/* .outline-outward2:before {
	content: "";
	position: absolute;
	border: #000 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;
	border: 2px solid #fff;
	text-decoration: none;
	color: #000;
	font-size: 1.8rem;
	font-weight: 600;
}

.button:hover {
	margin: 0.4em;
	padding: 0.5em 1em;
	cursor: pointer;
	background: #956f29;
	border: 2px solid #fff;
	text-decoration: none;
	color: #fff;
	font-size: 1.8rem;
	font-weight: 600;
	opacity: 1;
}

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

	.outline-outward2 {
		width: 65%;
	}

	#page-top {
		position: fixed;
		right: -15px;
		bottom: 30px;
		height: 50px;
		text-decoration: none;
		font-weight: 500;
		transform: rotate(90deg);
		font-size: 0.8em;
		line-height: 2.0rem;
		padding: 0 0 0 35px;
		border-top: solid 1px;
		letter-spacing: 0.05em;
	}

	.point .inner .box {
		padding: 5px 20px;
		padding-top: 25px;
		height: 80px;
		width: auto;
	}

	.inner .box .txt {
		padding: 0 20px;
		font-size: 1.5rem;
		/* font-family: "Noto Sans JP", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, Verdana, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Meiryo, Osaka, "MS PGothic", "M+ 1p", sans-serif; */
	}

	.point .box .bolod {
		font-size: 2.2rem;
		color: #000;
		padding-top: 20px;
		line-height: 1.3;
		font-weight: 600;
		text-align: center;
		/* font-family: "游明朝体", YuMincho, "游明朝", "Yu Mincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "游明朝", YuMincho, serif; */
	}

	.point_section {
		display: block;
	}

	.point_section {
		margin-top: 30px;
		margin: 0 5px;
	}

	.point_section section {
		width: 100%;
	}

	.point_section section+section {
		margin-left: 0;
	}

	.point_section section img {
		width: auto;
	}

	.point_section section p {
		font-size: 10px;
		width: auto;
	}
}

.sideways {
	-webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  position: fixed;
  left: -10px;
  bottom: 20em;
  font-weight: 700;
  font-size: 10px;
  line-height: 1.9;
  letter-spacing: 4px;
  color: #999;
	/* font-family: 'Hind', sans-serif; */
}

/*****************
  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: #000;
		font-size: 1.4rem;
	}

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

.no-top #contents section#work_txt .container {
	margin: 0 auto 2em !important;
}

#work_txt .inner ul {
	/* background-image: url(../img/work_back.jpg); */
	background-repeat: no-repeat;
	background-size: cover;
}

#work_txt .inner ul li {
	padding: 0 0 70px;
	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:last-child {
	padding: 0;
}

#work_txt .inner ul li:hover {}

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

#work_txt .inner ul li:nth-child(2n)>div {
	/* color: #fff; */
}



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

#work_txt .inner ul li .vctitle .vctitleno {
	font-family: 'Hind', sans-serif;
	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: 600;
	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 .vstext.detail {
	line-height: 1.8;
	margin-bottom: 0.5em;
}

#work_txt .inner ul li .vstext span {
    display: inline-block;
    width: 9em;
    color: #b28c6e;
    font-size: 17px;
		font-weight: 600;
    line-height: 1.7;
		border-bottom: 2px solid #b28c6e;
    margin-bottom: 0.2em;
}

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

.tbl-r02 {
	max-width: 1000px;
	/* margin: 0 auto; */
	width: 100%;
}

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

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

.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: #000; */
}

#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) {
	#contents section#work_txt {
    padding: 56px 0 0;
	}
	#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: #000;
		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;
	}
}

@media screen and (max-width: 399px) {
	.no-top #contents section#recruit .container {
		padding: 0;
	}
	.post {
		width: 100%;
	}
}

/*=== 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: #000;
		font-size: 2rem;
		text-shadow: 0 0 5px #fff;
		font-family: 'Hind', sans-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: #000;
		transform: skewX(-31deg);
	}

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

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

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

		50% {
			bottom: -21%;
		}

		100% {
			bottom: -18%;
		}
	}

}


/* @keyframes sdl {
	0% {
		transform: scale(1, 0);
		transform-origin: 0 0;
	}

	50% {
		transform: scale(1, 1);
		transform-origin: 0 0;
	}

	50.1% {
		transform: scale(1, 1);
		transform-origin: 0 100%;
	}

	100% {
		transform: scale(1, 0);
		transform-origin: 0 100%;
	}
} */




  /*
 * privacy policy
 */

 .detail_privacy {
	width: 100% !important;
  max-width: 1020px;
	border: 1px solid #100201;
	height: 500px;
	overflow: auto;
	overflow-y: scroll !important;
	background-color: #fff;
	font-size: 1.4rem;
	margin: 4rem auto 0rem;
  padding: 20px;
  }
  .detail_privacy .sp2 {
  display: none;
  }
  .detail_privacy p {
	color: #000;
	padding: 0 0 20px;
  /* padding: 0; */
	font-weight: normal;
  }
  .detail_privacy span {
	font-weight: bold;
  }
  .detail_privacy .p_head {
	padding-bottom: 0px;
  margin-bottom: 0.8em;
  }
  .detail_privacy ul {
	font-weight: normal;
	list-style: disc !important;
	padding-left: 2em;
	padding-bottom: 1em;
  }
  .detail_privacy ul li {
	font-weight: normal;
	list-style: disc !important;
  }
  
  p.detail_privacy_notes {
	max-width: 1020px;
	margin: 6rem auto 0;
	padding: 0px 0 0px;
	padding-left: 1em;
	text-indent: -1em;
	font-weight: normal;
	font-size: 1.6rem;
  }
  
  @media screen and (max-width: 767px) {
  .detail_privacy {
	width: calc(100% - 20px) !important;
	width: 100% !important;
	height: 500px;
	margin: 4rem auto 0rem;
	font-size: 1.4rem;
	}
	.detail_privacy .sp2 {
	display: initial;
  }
  p.detail_privacy_notes {
	font-size: 1.5rem;
  }

  }



.footer_insta {
	display: flex;
	justify-content: center;
	margin: 50px 0 -10px;
}
.footer_insta li a {
	color: #fff;
}
@media screen and (max-width: 768px) {
	.footer_insta {
		margin: 50px 0 10px;
	}

}

