/*style_common*/
body{
	font-family: "游ゴシック Medium", "Yu Gothic Medium",YuGothic,"Yu Gothic M","游ゴシック体","ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN","ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
	font-size: 18px;
	line-height: 1.6;
	overflow: hidden;
}
html {
  scroll-behavior: smooth;
}
img{
	vertical-align:top;
	image-rendering:-webkit-optimize-contrast;
}
p{line-height: 1.8;text-align: justify;}
.family_serif{ font-family: YuMincho, "Yu Mincho",'Noto Serif JP', serif; color: #1B1B38;}
.inner{width: 90%; max-width: 1100px; margin: auto;}
.inner1000{width: 90%; max-width: 1000px; margin: auto;}
.inner960{width: 90%; max-width: 960px; margin: auto;}
.sp{display: none;}
h2.top{ font-size: 32px; text-align: center; font-weight: bold; position: relative;margin-bottom: 1em;font-family: 'Roboto Condensed', sans-serif;}
.w1280{display: block!important;}
.w1280-2{display: none!important;}
.w1024{display: block!important;}
.w1024-2{display: none!important;}
.w960{display: block!important;}
.w960-2{display: none!important;}
.w768{display: block!important;}
.w768-2{display: none!important;}
.w624{display: none;}
.w624-2{display: block;}
.w580{display: none!important;}
.w580-2{display: block!important;}
.w428{display: none!important;}
.w428-2{display: block!important;}
.w414-2{display: none;}
.w375{display: none!important;}
.w375-2{display: block!important;}
a:link, a:visited{color: #000000; text-decoration: none;}
.mt70{margin-top: 70px;}
.mb20{margin-bottom: 20px;}
.mb50{margin-bottom: 50px;}
.f16{font-size: 16px;}
@media screen and (max-width: 1280px){
	.w1280{display: none!important;}
	.w1280-2{display: block!important;}
}
@media screen and (max-width: 1024px){
	.w1024{display: none!important}
	.w1024-2{display: block!important;}
}
@media screen and (max-width: 960px) {
	h2.top{ font-size: 28px; }
	.w960{display: none!important;}
	.w960-2{display: block!important;}
}
@media screen and (max-width: 768px){
	.w768{display: none!important;}
	.w768-2{display: block!important;}
	.mt70 {margin-top: 50px;}
}
@media screen and (max-width: 624px){
	.w624{display: block;}
	.w624-2{display: none;}
}
@media screen and (max-width: 580px){
	.w580{display: block!important;}
	.w580-2{display: none!important;}
}
@media screen and (max-width: 428px){
	body{ font-size: 14px;}
	.w428{display: block!important;}
	.w428-2{display: none!important;}
	.mt70 {margin-top: 30px;}
}
@media screen and (max-width: 414px){
	.w414-2{display: block;}
}
@media screen and (max-width: 375px){
	.w375{display: block!important;}
	.w375-2{display: none!important;}
}

/*HEADER***************/
#header{width: 97.5%;padding: 0 10px 0 1.5%;height: 70px;display: flex;}
.hd_between{
	display:-webkit-box; display:-ms-flexbox; display:flex;
	-webkit-box-pack: justify;	-ms-flex-pack: justify;	justify-content: space-between;
	-webkit-box-align: center;	-ms-flex-align: center;	align-items: center;
}
#subheader{width: 97.5%;padding: 0 10px 0 1.5%;height: 70px;display: flex;}
@media screen and (max-width: 428px){
	.header_logo img{width: 35%; height: auto;}
	#header,#subheader {height: 50px;}
}

/**　ハンバーガーボタン（トップ） ************************************************/
html.is-fixed,html.is-fixed body {
  height: 100%;
  overflow: hidden;
}
.hamburger-top {
  display : block;
  z-index : 3;
  left: 2.7%;
  top   : 50%;
  width : 40px;
  height: 40px;
  cursor: pointer;
  text-align: center;
	position: absolute;
	transform: translate(-50%, 0%);
}
.hamburger-top span {
  display : block;
  position: absolute;
  width   : 40px;
  height  : 3px ;
  left    : 6px;
  background : #1B1B38;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition   : 0.3s ease-in-out;
  transition        : 0.3s ease-in-out;
}
.hamburger-top span:nth-child(1) {
  top: 10px;
}
.hamburger-top span:nth-child(2) {
  top: 20px;
}
.hamburger-top span:nth-child(3) {
  top: 30px;
}

/* ナビ開いてる時のボタン */
.hamburger-top.active span:nth-child(1) {
  top : 16px;
  left: 6px;
  background :#fff;
  -webkit-transform: rotate(-45deg);
  -moz-transform   : rotate(-45deg);
  transform        : rotate(-45deg);
}

.hamburger-top.active span:nth-child(2),
.hamburger-top.active span:nth-child(3) {
  top: 16px;
  background :#fff;
  -webkit-transform: rotate(45deg);
  -moz-transform   : rotate(45deg);
  transform        : rotate(45deg);
}

nav.globalMenuSp-top {
  position: fixed;
	display: none;
}

nav.globalMenuSp-top ul {
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

nav.globalMenuSp-top ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
  transition: .4s all;
}
nav.globalMenuSp-top ul li:last-child {
  padding-bottom: 0;
}
nav.globalMenuSp-top ul li:hover{
  opacity: 0.3;
}

nav.globalMenuSp-top ul li a {
  display: block;
  color: #fff;
  padding: 1em 0;
  text-decoration :none;
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp-top.active {
  opacity: 100;
	height: 100%;
	display: flex;
    justify-content: center;
    align-items: center;
	z-index : 2;
  top  : 0;
  left : 0;
  color: #fff;
  background: rgba(27,27,56,0.9);
  text-align: center;
  width: 100%;
  transition: opacity .6s ease, visibility .6s ease;

}
.hamburger-topw960 {
  display : block;
  position: fixed;
  z-index : 3;
  right: 15px;
  width : 42px;
  height: 42px;
  cursor: pointer;
  text-align: center;
	top: 1.2%;
}
.hamburger-topw960 span{
  display : block;
  position: absolute;
  width: 40px;
  height: 3px;
  left    : 0px;
  background : #1B1B38;
  -webkit-transition: 0.5s all;
  -moz-transition   : 0.5s all;
  transition        : 0.5s all;
}
.hamburger-topw960 span:nth-child(1){
  top: 10px;
}
.hamburger-topw960 span:nth-child(2){
  top: 20px;
}
.hamburger-topw960 span:nth-child(3){
  top: 30px;
}

/* ナビ開いてる時のボタン */
.hamburger-topw960.active span:nth-child(1) {
  top : 20px;
  left: 0px;
  width: 40px;
  -webkit-transform: rotate(-45deg);
  -moz-transform   : rotate(-45deg);
  transform        : rotate(-45deg);
	background: #fff;
}
.hamburger-topw960.active span:nth-child(2) {
  left: 60%;
  opacity: 0;
  -webkit-animation: active-btn17-bar02 .8s forwards;
  animation: active-hamburger-bar02 .8s forwards;
}
@-webkit-keyframes active-hamburger-bar02 {
  100% {
    height: 0;
  }
}
@keyframes active-hamburger-bar02 {
  100% {
    height: 0;
  }
}
.hamburger-topw960.active span:nth-child(3) {
  top: 20px;
	left: 0px;
  width: 40px;
  -webkit-transform: rotate(45deg);
  -moz-transform   : rotate(45deg);
  transform        : rotate(45deg);
	background: #fff;
}
.hamburger-topw960::after {
  position: absolute;
  top: 75%;
  left: 55%;
  display: block;
  content: '';
  width: 40px;
  height: 40px;
  margin: -32px 0 0 -25px;
  border-radius: 50%;
  border: 2px solid rgba(0, 0, 0, 0);
  transition: all .75s;
}
/*.hamburger.active::after {
  border: 2px solid #555;
}*/
nav.globalMenuSp-topw960 {
  position: fixed;
  z-index : 2;
  top  : 0;
  left : 0;
  color: #000;
  background: #fff;
  text-align: center;
  transform: translateY(-100%);
  transition: all 0.6s;
  width: 100%;
}
nav.globalMenuSp-topw960 ul {
  background: #1B1B38;
  margin: 0 auto;
  padding: 20px 0;
  width: 100%;
}
nav.globalMenuSp-topw960 ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
}
nav.globalMenuSp-topw960 ul li:last-child {
  padding-bottom: 0;
}
nav.globalMenuSp-topw960 ul li a:hover{
  color:#fff;
}

nav.globalMenuSp-topw960 ul li a {
  display: block;
  padding: 1.5em 0;
  text-decoration :none;
	color: #fff;
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp-topw960.active {
  transform: translateY(0%);
}

.scroll-menu{
  position: fixed;
  /*デフォルトで非表示にする*/
  opacity: 0;
  visibility: hidden;
width: 100%;
	background: rgba(27,27,56,0.9);
	top: 1%;
	left: 0;
	z-index: 10;
}
/*このクラスが付与されると表示する*/
.active{
  opacity: 1;
  visibility: visible;
}

/**　ハンバーガーボタン（トップ用スクロール時に表示） ************************************************/
.hamburger-scroll {
  display : block;
  position: fixed;
  z-index : 3;
  right : 25px;
  width : 42px;
  height: 42px;
  cursor: pointer;
  text-align: center;
}
.hamburger-scroll span{
  display : block;
  position: absolute;
  width: 40px;
  height: 3px;
  left    : 0px;
  background : #1B1B38;
  -webkit-transition: 0.5s all;
  -moz-transition   : 0.5s all;
  transition        : 0.5s all;
}
.hamburger-scroll span:nth-child(1){
  top: 10px;
}
.hamburger-scroll span:nth-child(2){
  top: 20px;
}
.hamburger-scroll span:nth-child(3){
  top: 30px;
}

/* ナビ開いてる時のボタン */
.hamburger-scroll.active span:nth-child(1) {
  top : 20px;
  left: 0px;
  width: 40px;
  -webkit-transform: rotate(-45deg);
  -moz-transform   : rotate(-45deg);
  transform        : rotate(-45deg);
	background: #fff;
}
.hamburger-scroll.active span:nth-child(2) {
  left: 60%;
  opacity: 0;
  -webkit-animation: active-btn17-bar02 .8s forwards;
  animation: active-hamburger-bar02 .8s forwards;
}
@-webkit-keyframes active-hamburger-bar02 {
  100% {
    height: 0;
  }
}
@keyframes active-hamburger-bar02 {
  100% {
    height: 0;
  }
}
.hamburger-scroll.active span:nth-child(3) {
  top: 20px;
	left: 0px;
  width: 40px;
  -webkit-transform: rotate(45deg);
  -moz-transform   : rotate(45deg);
  transform        : rotate(45deg);
	background: #fff;
}
.hamburger-scroll::after {
  position: absolute;
  top: 75%;
  left: 55%;
  display: block;
  content: '';
  width: 40px;
  height: 40px;
  margin: -32px 0 0 -25px;
  border-radius: 50%;
  border: 2px solid rgba(0, 0, 0, 0);
  transition: all .75s;
}
/*.hamburger.active::after {
  border: 2px solid #555;
}*/
nav.globalMenuSp-scroll {
  position: fixed;
  z-index : 2;
  top  : 0;
  left : 0;
  color: #000;
  background: #fff;
  text-align: center;
  transform: translateY(-100%);
  transition: all 0.6s;
  width: 100%;
}
nav.globalMenuSp-scroll ul {
  background: #1B1B38;
  margin: 0 auto;
  padding: 20px 0;
  width: 100%;
}
nav.globalMenuSp-scroll ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
}
nav.globalMenuSp-scroll ul li:last-child {
  padding-bottom: 0;
}
nav.globalMenuSp-scroll ul li a:hover{
  color:#fff;
}

nav.globalMenuSp-scroll ul li a {
  display: block;
  padding: 1.5em 0;
  text-decoration :none;
	color: #fff;
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp-scroll.active {
  transform: translateY(0%);
}

/**　ハンバーガーボタン（下層） ************************************************/
.hamburger {
  display : block;
  position: fixed;
  z-index : 3;
  right : 25px;
  width : 42px;
  height: 42px;
  cursor: pointer;
  text-align: center;
}
.hamburger span{
  display : block;
  position: absolute;
  width: 40px;
  height: 3px;
  left    : 0px;
  background : #1B1B38;
  -webkit-transition: 0.5s all;
  -moz-transition   : 0.5s all;
  transition        : 0.5s all;
}
.hamburger span:nth-child(1){
  top: 10px;
}
.hamburger span:nth-child(2){
  top: 20px;
}
.hamburger span:nth-child(3){
  top: 30px;
}

/* ナビ開いてる時のボタン */
.hamburger.active span:nth-child(1) {
  top : 20px;
  left: 0px;
  width: 40px;
  -webkit-transform: rotate(-45deg);
  -moz-transform   : rotate(-45deg);
  transform        : rotate(-45deg);
	background: #fff;
}
.hamburger.active span:nth-child(2) {
  left: 60%;
  opacity: 0;
  -webkit-animation: active-btn17-bar02 .8s forwards;
  animation: active-hamburger-bar02 .8s forwards;
}
@-webkit-keyframes active-hamburger-bar02 {
  100% {
    height: 0;
  }
}
@keyframes active-hamburger-bar02 {
  100% {
    height: 0;
  }
}
.hamburger.active span:nth-child(3) {
  top: 20px;
	left: 0px;
  width: 40px;
  -webkit-transform: rotate(45deg);
  -moz-transform   : rotate(45deg);
  transform        : rotate(45deg);
	background: #fff;
}
.hamburger::after {
  position: absolute;
  top: 75%;
  left: 55%;
  display: block;
  content: '';
  width: 40px;
  height: 40px;
  margin: -32px 0 0 -25px;
  border-radius: 50%;
  border: 2px solid rgba(0, 0, 0, 0);
  transition: all .75s;
}
/*.hamburger.active::after {
  border: 2px solid #555;
}*/
nav.globalMenuSp {
  position: fixed;
  z-index : 2;
  top  : 0;
  left : 0;
  color: #000;
  background: #fff;
  text-align: center;
  transform: translateY(-100%);
  transition: all 0.6s;
  width: 100%;
}
nav.globalMenuSp ul {
  background: #1B1B38;
  margin: 0 auto;
  padding: 20px 0;
  width: 100%;
}
nav.globalMenuSp ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
}
nav.globalMenuSp ul li:last-child {
  padding-bottom: 0;
}
nav.globalMenuSp ul li a:hover{
  color:#fff;
}

nav.globalMenuSp ul li a {
  display: block;
  padding: 1.5em 0;
  text-decoration :none;
	color: #fff;
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
  transform: translateY(0%);
}
@media screen and (max-width: 428px){
	.hamburger {right: 10px;}
}

/*メインビジュアル***************/
.catchbg{
	width: 94%;
	height: 100vh;
	margin-left: auto;
	background: linear-gradient(180deg, #fff 0%, #fff 70px, #F4F4F4 70px, #F4F4F4 100%);
}
.slider {
	width: 77%;
    height: 100vh!important;
    margin-left: auto;
	margin-top: -70px;
}
.catchposition{
	top: 50%;
    left: 23%;
    transform: translate(-50%, -50%);
    position: absolute;
}
.catchposition img{display: block;}
.maincatch{
	font-size: 23px;
    color: #1B1B38;
    font-weight: bold;
    display: inline;
    line-height: 2.3;
}
.maincatch span{
    border-bottom: 2px solid #1B1B38;
	padding-bottom: 12px;
}
.vegas-timer{display: none;}
@media screen and (max-width: 1672px){
	.catchposition{left: 25%;}
}
@media screen and (max-width: 1366px){
	.slider {width: 75%;}
	.catchposition {left: 28%;}
}
@media screen and (max-width: 1280px){
	.hamburger-top {
    top: 50%;
    position: absolute;
    transform: translate(-50%, -50%);
	}
	.catchposition {
    transform: translate(-50%, -50%);
    left: 40%;
    top: 50%;
    position: absolute;
	}
	.catchimg{width: 60%;height: auto;}
}
@media screen and (max-width: 959px){
	nav.globalMenuSp-top.active{height: auto;}
}
@media screen and (max-width: 768px){
	.hamburger-topw960 {top: 1.5%;}
	.slider {
		width: 95%;
		height: 65vh!important;
		top: 70px;
	}
	.catchbg {
		width: 100%;
		height: 100vh!important;
		margin-left: auto;
		background: linear-gradient(180deg, #fff 0%, #fff 20%, #F4F4F4 20%, #F4F4F4 100%);
	}
	.catchposition {
		transform: translate(-50%, -50%);
		left: 50%;
		top: 80%;
		text-align: center;
		width: 80%;
	}
	.catchposition img {
		display: block;
		margin: 0 auto;
		width: 80%;
	}
	.maincatch {line-height: 2;}
	.maincatch span {padding-bottom: 10px;}
}
@media screen and (max-width: 428px){
	.hamburger-topw960 {top: 0.5%;right: 1.5%;}
	.slider {height: 60vh!important;}
	.catchbg {height: 103vh!important;}
	.catchposition img {margin: 0 auto;width: 100%;}
	.maincatch {font-size: 18px;}
	.maincatch span {padding-bottom: 8px;}
}
@media screen and (max-width: 414px){
	.slider {height: 65vh!important;}
	.catchposition {top: 80%;}
}
@media screen and (max-width: 375px){
	.slider {height: 55vh!important;}
	.catchposition {top: 75%;}
}


/*サブビジュアル***************/
#subvisual{
    background-repeat: no-repeat;
    background-size: cover;
    background-position: top;
	height: 350px;
}
.ab{background-image: url(../images/subvisual1.jpg);}
.me428{background-image: url(../images/subvisual2.jpg);display: block;}
.sub_ttl{display: block;margin: -30px auto 0;}
#recruitvisual{
    background-image: url(../images/recruit_mainvisual.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    height: 100vh;
    margin-top: -70px;
    margin-left: auto;
    width: 75%;
    border-bottom-left-radius: 50px;
	position: relative;
}
.recruitvisual_position1{position: absolute;top: 140px;left: 10%;width: 20%;}
.recruitvisual_position2{position: absolute;top: 400px;left: 10%;width: 20%;}
@media screen and (max-width: 1366px){
	.recruitvisual_position1{left: 5%;}
	.recruitvisual_position2{width: 25%;left: 5%;}
}
@media screen and (max-width: 1024px){
	#recruitvisual-w1024{
    background-image: url(../images/recruit_mainvisual.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    height: 500px;
    margin-top: -70px;
    margin-left: auto;
    width: 75%;
    border-bottom-left-radius: 50px;
	position: relative;
	}
	.recruitvisual_position1{top: 100px;}
	.recruitvisual_position2{bottom: 0%;top: 210px;width: 30%;}
}
@media screen and (max-width: 980px){
	#subvisual {height: 200px;}
}
@media screen and (max-width: 768px){
	#recruitvisual-w1024 {height: 450px;width: 70%;}
	.recruitvisual_position1{left: 5%;top: 110px;}
	.recruitvisual_position2{width: 30%;left: 5%;top: 190px;}
}
@media screen and (max-width: 428px){
	#subvisual {height: 100px;}
	.sub_ttl {width: 30%;height: auto;}
	#recruitvisual-w1024 {width: 60%;height: 310px;}
	.recruitvisual_position1 {top: 75px;left: 5%;}
	.recruitvisual_position2 {width: 40%;bottom: 0%;top: 120px;}
	.me428-2{background-image: url(../images/subvisual2-sp.jpg);display: block;}
}
@media screen and (max-width: 320px){
	#subvisual {height: 90px;}
	.sub_ttl {margin: -20px auto 0;}
	#recruitvisual-w1024 {height: 260px;}
	.recruitvisual_position1 {top: 80px;}
}
/*TOP Problem***************/
#problem{margin-top: 100px;}
#problem .problem_bg{
	background: linear-gradient(90deg, #F4F4F4 0%, #F4F4F4 95%, #fff 95%, #fff 100%);
	padding-bottom: 40px;
	margin-bottom: 100px;
}
#problem .problem_ttl{text-align: center;}
#problem .problem_ttl img{margin: -30px 0 20px;}
#problem p{text-align: center;}
#problem .problem_ttl h2{
	font-size: 28px;
	letter-spacing: 2px;
	margin-top: 4px;
}
#problem .problem_flex{display: flex;}
#problem .problem_item{display: flex;align-items: center;}
#problem .problem_flex{margin-top: 30px;}
#problem .problem_pic{
    background-image: url(../images/problem_pic.jpg);
    background-repeat: no-repeat;
	width: 60%;
    height: 550px;
    background-position: center 0%;
    background-size: cover;
}
#problem .problem_item{margin: 100px 40px 0 -100px;}
#problem .problem_item h3{
	text-align: center;
	width: 265px;
	height: 115px;
    font-size: 20px;
	background-color: #fff;
	margin: 0 6px 6px 0;
	display: flex;
	justify-content: center;
	align-items: center;
}
#problem .problem_item h3:nth-child(4){margin: 0 6px 0px 0;}
#problem .problem_soudan{text-align: center; font-size: 20px;}
#problem .problem_soudan img{display: block; margin: 30px auto;}
@media screen and (max-width: 1366px){
	#problem .problem_item {margin: 100px 40px 0 -150px;}
	#problem .problem_item h3 {width: 230px;}
}
@media screen and (max-width: 960px){
	#problem .problem_flex{display: block;}
	#problem .problem_pic {width: 90%;}
	#problem .problem_item {justify-content: center;margin: -50px 10% 0;}
	#problem .problem_item h3 {padding: 0 20px;}
}
@media screen and (max-width: 768px){
	#problem .problem_pic {height: 400px;}
	#problem .problem_item {margin: -100px 10% 0;}
}
@media screen and (max-width: 700px){
	#problem .problem_item {display: block;}
	#problem .problem_item h3{width: 90%; margin: 0 5% 5px;padding: 0;}
	#problem .problem_item h3:nth-child(4){margin: 0 5% 5px;}
}
@media screen and (max-width: 428px){
	#problem {margin-top: 60px;}
	#problem .problem_bg {margin-bottom: 60px;}
	#problem .problem_ttl h2 {font-size: 20px;margin-top: 0px;}
	#problem .problem_pic {height: 250px;}
	#problem .problem_item h3{font-size: 18px;height: auto;padding: 20px 0;}
	#problem .problem_soudan {font-size: 14px;}
	#problem .problem_soudan img {margin: 20px auto 10px;}
}
@media screen and (max-width: 375px){
	#problem {margin-top: 60px;}
	#problem .problem_ttl img {width: 40%;height: auto;margin: -20px 0 20px;}
}

/*TOP Feature***************/
#feature .feature_bg{
	background: linear-gradient(90deg, #fff 0%, #fff 5%, #F4F4F4 5%, #F4F4F4 100%);
	padding-bottom: 40px;
	margin-bottom: 100px;
}
#feature .feature_ttl img{margin-top: -30px;}
#feature .feature_ttl h2{
	font-size: 28px;
	letter-spacing: 2px;
	margin: 15px 0 10px 0;
}
#feature .feature_flex{display: flex; justify-content: space-between;}

/* ぼかしから出現 */
.blur{
	animation-name:blurAnime;
	animation-duration:1s;
	animation-fill-mode:forwards;
	opacity:0;
}

@keyframes blurAnime{
  from {
	filter: blur(10px);
	transform: scale(1.02);
	  opacity: 0;
  }

  to {
	filter: blur(0);
	transform: scale(1);
	  opacity: 1;
  }
}
/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.anime-blur{
	opacity: 0;
}



#feature .feature_box{text-align: center;}
#feature .feature_number{
    font-size: 30px;
    background-image: url(../images/feature_arrow.jpg);
    background-repeat: no-repeat;
	background-position: bottom;
    padding-bottom: 30px;
	position: relative;
}
#feature .feature_box img{margin: -25px 0 10px 0;}
#feature h3{font-size: 20px;}
#feature .f1{margin-top: 60px;}
#feature .f2{margin-top: 20px;}
#feature .f3{margin-top: -20px;}
#feature .f4{margin-top: -60px;}
@media screen and (max-width: 1366px){
	#feature .feature_ttl,#feature .feature_flex {padding-left: 30px;}
	#feature .feature_box img {width: 95%;height: auto;}
}
@media screen and (max-width: 959px){
	#feature .feature_bg {padding-bottom: 0px;margin-bottom: 60px;}
	#feature .feature_flex {flex-wrap: wrap;}
	#feature .feature_box {width: 50%;margin-bottom: 50px;}
}
@media screen and (max-width: 428px){
	#feature .feature_ttl h2 {font-size: 20px;margin: 15px 0 10px 0;}
	#feature .f1 {margin-top: 20px;}
	#feature .f4 {margin-top: -20px;}
	#feature .feature_number {font-size: 18px;}
	#feature h3 {font-size: 14px;}
}
@media screen and (max-width: 375px){
	#feature .feature_ttl, #feature .feature_flex {padding-left: 20px;}
	#feature .feature_ttl img {margin-top: -20px;width: 40%;height: auto;}
}
@media screen and (max-width: 320px){
	#feature h3 {font-size: 12px;}
}

/*TOP Contact***************/
#concept{
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
	margin-bottom: 100px;
}
#concept .concept_pic{width: 40%;}
#concept .concept_txt{width: 30%;margin: 30px 30% 0 5%;}
#concept .concept_txt h2{
	font-size: 28px;
	margin: 20px 0;
}
#concept .link_box,#top-menu .link_box{
	border-bottom: 1px solid #707070;
	text-align: center;
	position: absolute;
	bottom: 0;
	width: 25%;
	height: 80px;
	display: flex;
    justify-content: center;
    align-items: center;
	background-image: url(../images/btn1.png);
    background-repeat: no-repeat;
	background-position: right;
	background-size: 65px;
}
#concept a:hover{color: #D86F93;border-bottom: 1px solid #D86F93;background-image: url(../images/btn1_hover.png);}
@media screen and (max-width: 1920px){
	#concept {align-items: flex-start;}
}
@media screen and (max-width: 1565px){
	#concept .concept_txt {width: 40%;margin: 30px 20% 0 5%;}
	#concept .link_box, #top-menu .link_box {width: 35%;}
}
@media screen and (max-width: 1455px){
	#concept .concept_pic {width: 40%;}
	#concept .concept_txt {width: 40%;margin: 30px 15% 0 5%;}
	#concept .link_box, #top-menu .link_box {width: 40%;}
}
@media screen and (max-width: 1300px){
	#concept {align-items: flex-start;}
	#concept .concept_pic {width: 45%;}
	#concept .concept_txt {width: 45%; margin: 0px 5% 100px 5%;}
	#concept .link_box, #top-menu .link_box {width: 45%;}
}
@media screen and (max-width: 1148px){
	#concept {align-items: center;}
}
@media screen and (max-width: 959px){
	#concept {width: 90%;margin: 0 auto 60px;flex-flow: column-reverse;}
	#concept .concept_txt {margin: 0px 5% 40px;width: 100%;}
	#concept .concept_pic {width: 60%;margin-bottom: 100px;}
	#concept .link_box, #top-menu .link_box {width: 100%;}
}
@media screen and (max-width: 428px){
	#concept .concept_txt h2 {font-size: 20px;}
	#concept .concept_pic {width: 100%;}
}
@media screen and (max-width: 375px){
	#concept .concept_txt img{width: 40%; height: auto;}
}

/*TOP Menu***************/
#top-menu{
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
	margin-bottom: 100px;
}
#top-menu .t-menu_pic{width: 40%;}
#top-menu .t-menu_bikou{border: 1px solid #1B1B38;padding: 15px;margin-top: 20px;}
#top-menu .t-menu_txt{width: 30%; margin: 30px 5% 0 30%;}
#top-menu .t-menu_txt h2{
	font-size: 28px;
	margin: 20px 0;
}
#top-menu a:hover{color: #D86F93;border-bottom: 1px solid #D86F93;background-image: url(../images/btn1_hover.png);}
@media screen and (max-width: 1920px){
	#top-menu {align-items: flex-start;}
}
@media screen and (max-width: 1565px){
	#top-menu .t-menu_txt {width: 40%;margin: 30px 5% 0 20%;}
}
@media screen and (max-width: 1455px){
	#top-menu .t-menu_pic {width: 40%;}
	#top-menu .t-menu_txt {width: 40%;margin: 30px 5% 0 15%;}
}
@media screen and (max-width: 1300px){
	#top-menu{align-items: flex-start;}
	#top-menu .t-menu_pic {width: 45%;}
	#top-menu .t-menu_txt {width: 45%;margin: 0px 5% 100px 5%;}
}
@media screen and (max-width: 1148px){
	#top-menu {align-items: center;}
}
@media screen and (max-width: 959px){
	#top-menu{width: 90%;margin: 0 auto 60px;flex-flow: column;}
	#top-menu .t-menu_txt {margin: 0px 5% 40px;width: 100%;}
	#top-menu .t-menu_pic {width: 60%;margin-bottom: 100px;}
}
@media screen and (max-width: 428px){
	#top-menu .t-menu_txt h2 {font-size: 20px;}
	#top-menu .t-menu_pic {width: 100%;}
}
@media screen and (max-width: 375px){
	#top-menu .t-menu_txt img{width: 30%; height: auto;}
}

/*TOP matome***************/
#matome{
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
	margin-bottom: 150px;
}
#matome .matome_pic{width: 40%;}
#matome .matome_txt{width: 30%; margin: 30px 25% 0 5%; font-size: 20px;}
@media screen and (max-width: 1565px){
	#matome .matome_txt {width: 40%;margin: 0px 20% 0 5%;font-size: 20px;}
}
@media screen and (max-width: 1300px){
	#matome .matome_pic {width: 45%;}
	#matome .matome_txt {width: 45%;margin: 0px 5% 0 5%;}
}
@media screen and (max-width: 959px){
	#matome {flex-flow: column-reverse;}
	#matome .matome_txt {width: 90%;margin: 0 5% 40px;font-size: 18px;}
	#matome .matome_pic{width: 60%;}
}
@media screen and (max-width: 428px){
	#matome {margin-bottom: 80px;}
	#matome .matome_txt{font-size: 14px;}
	#matome .matome_pic {width: 90%;}
}

/*TOP banner***************/
#top-banner{text-align: center;}
#top-banner p{text-align: center;}
#top-banner .banner_pic{display: block; margin: 0 auto 20px;}
#top-banner .banner_flex{display: flex; align-items: center; justify-content: center;margin-top: 20px;}
#top-banner .banner_tel{font-size: 30px;margin-right: 20px;}
#top-banner .banner_flex a{display: contents;}
@media screen and (max-width: 768px){
	#top-banner{width: 90%;margin: auto;}
}
@media screen and (max-width: 768px){
	#top-banner .banner_pic {width: 80%;height: auto;}
}
@media screen and (max-width: 428px){
	#top-banner .banner_pic{width: 100%;}
	#top-banner .banner_flex {margin-top: 10px;flex-flow: column;}
	#top-banner .banner_flex img{width: 200px;height: auto;}
	#top-banner .banner_tel{margin-right: 0px;}
}

/*TOP sns***************/
#sns{
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #F4F4F4;
	padding: 50px 0;
	margin: 100px 0;
}
#sns h2{font-size: 26px;margin-right: 40px;}
#sns .sns_border{border-top: 1px solid #000000; width: 122px;}
#sns .sns_flex{display: flex; align-items: center;}
#sns .sns_flex img{margin: 0 10px 0 40px;}
#sns a:hover{opacity: 0.5;}
@media screen and (max-width: 595px){
	#sns {padding: 50px 5%;margin: 70px 0 30px;}
	#sns h2 {font-size: 18px; margin-right: 20px;}
	#sns .sns_border {width: 15%;}
	#sns .sns_flex img {margin: 0 10px 0 20px;}
}
@media screen and (max-width: 375px){
	#sns{display: block;padding: 30px 5%;}
	#sns h2 {margin-right: 0;text-align: center;margin-bottom: 10px;}
	#sns .sns_border {border-left: 1px solid #000000;width: 0;height: 30px;margin: 0 auto 20px;}
	#sns .sns_flex {justify-content: center;margin-bottom: 10px;}
	#sns .sns_flex img{margin: 0;margin-right: 10px;}
}

/*TOP reservation***************/
#reservation{padding-top: 100px;}
#reservation .reservation{
	background-color: #F4F4F4;
	padding-bottom: 100px;
}
#reservation .reservation_bg{
	background-image: url(../images/reservation_bg.jpg);
    background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	width: 100%;
	height: 572px;
	color: #fff;
	display: inline-block;
}
#reservation .reservation_ttl{margin: -35px auto 0;display: block;}
#reservation h2{
	text-align: center;
	font-size: 28px;
	margin: 50px 0 20px;
}
.white{color: #fff;}
.blue{color: #1B1B38;}
#reservation p{text-align: center;}
#reservation .link_flex{
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 50px 0 150px;
}
#reservation .link_btn{
	border-bottom: 1px solid #fff;
	width: 400px;
	margin-right: 50px;
	background-image: url(../images/btn2.png);
    background-repeat: no-repeat;
	background-position: right;
	background-size: 51px;
	height: 70px;
	display: flex;
	justify-content: center;
	align-items: center;
}
#reservation .link_btn:last-child{margin-right: 0px;}
#reservation a.link_btn p{font-size: 16px;line-height: 1.5;color: #fff;}
#reservation a.link_btn span{font-size: 18px;color: #fff;}
#reservation a:hover{opacity: 0.5;}
#reservation .reservation_bg-white{
	background-color: #fff;
	width: 90%;
    margin: -100px auto 0;
    position: relative;
	text-align: center;
}
#reservation .f_flow_box{
	width: 90%;
    max-width: 1920px;
    margin: auto;
    background-color: #fff;
	padding: 0 3%;
	display: table;
}
#reservation .f_flow_box p{color: #1B1B38;}
#reservation .f_flow_ttl{display: inline;margin: -40px auto 0;position: relative;}
#reservation .f_flow_f20{font-size: 20px;margin-top: -20px;}
#reservation .f_flow_f24{font-size: 24px;margin: 20px 0 50px;}
.w25{width: 25%;position: relative;}
.w50{width: 50%;position: relative;}
.f_flow_step{
    width: 110px;
    height: 110px;
    border-radius: 50%;
	background-color: #1B1B38;
	display: flex;
    justify-content: center;
    align-items: center;
	font-size: 20px;
    line-height: 1.3;
	margin: 0 auto 10px;
}
.image-wrap img{
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translate(-50%, 0%);
	height: 30vh;
}
#reservation .f_flow_flex{
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	color: #fff;
}
#reservation .f_flow_flex p{text-align: justify;color: #000;height: 45vh;}
.w50 p{width: 50%;margin: auto;height: 50vh;}
#reservation .f_sonota{display: flex; align-items: center;justify-content: center;margin-top: 70px;}
#reservation .f_sonota img{margin-right: 50px;}
#reservation .f_sonota_ttl{
    font-size: 24px;
    text-align: center;
    border-bottom: 1px solid #000000;
	color: #000;
    margin-bottom: 15px;
    padding-bottom: 10px;
}
#reservation .f_sonota_txt{text-align: center;}
#reservation .f_sonota_txt p{display: inline-block;text-align: left;}
#reservation .f_sonota_txt span{font-weight: bold;}
#reservation .f_sonota_txt ul{text-align: left;}
#reservation .f_sonota_txt li{margin-left: 1em;text-indent: -1em;}
@media screen and (max-width: 1325px){
	#reservation .f_flow_flex p {height: 50vh;}
}
@media screen and (max-width: 1155px){
	#reservation .f_flow_flex p {height: 55vh;}
}
@media screen and (max-width: 959px){
	#reservation .link_flex {flex-flow: column;margin: 40px 0 0;}
	#reservation .link_btn {width: 90%;margin-right: 0px;height: 90px;}
	#reservation .reservation_bg {height: 700px;}
	#reservation .f_flow_ttl {margin: -30px auto 0;}
}
@media screen and (max-width: 875px){
	#reservation {padding-bottom: 60px;}
	#reservation .f_flow_flex {display: block;}
	.w25,.w50{width: 100%;}
	#reservation .f_flow_flex p {height: auto;width: 100%;}
	.image-wrap img {
    position: static;
    bottom: 0;
    left: 0;
    transform: translate(0%, 0%);
    height: auto;
    margin: 20px auto;
    display: block;
	}
	.w25 img{width: 50%;}
	.w50 img{width: 100%;}
	#reservation .f_sonota {flex-flow: column-reverse;}
	#reservation .f_sonota img {
    margin-right: 0px;
    width: 50%;
    height: auto;
    margin-top: 40px;
	}
}
@media screen and (max-width: 428px){
	#reservation{padding-top: 60px;}
	#reservation .reservation {padding-bottom: 40px;}
	#reservation h2 {font-size: 20px;margin: 30px 0 20px;}
	#reservation .f_flow_f24 {font-size: 18px;margin: 20px 0 20px;}
	#reservation .f_flow_f20 {font-size: 14px;}
	#reservation a.link_btn p {font-size: 13px;text-align: left;}
	#reservation .reservation_bg {height: 650px;}
	.w25 img{width: 60%;}
	#reservation .f_sonota_ttl {font-size: 16px;}
	#reservation .f_sonota img {width: 70%;}
}
@media screen and (max-width: 375px){
	#reservation .reservation_ttl {margin: -25px auto 0;width: 60%;height: auto;}
	#reservation .f_flow_ttl {width: 30%;height: auto;}
	#reservation .link_btn {justify-content: flex-start;}
}

/*about***************/
#about{margin-bottom: 90px;}
#about h2{font-size: 28px;color: #1B1B38;text-align: center;letter-spacing: 3px;margin: 30px 0 20px;}
#about .about_txt{text-align: center;}
@media screen and (max-width: 428px){
	#about {margin-bottom: 60px;}
	#about h2{font-size: 20px;margin: 20px 0 10px;}
	#about .about_txt{text-align: justify;}
}
@media screen and (max-width: 320px){
	#about h2{font-size: 18px;letter-spacing: 2px;}
}

/*staff***************/
#staff{margin-bottom: 100px;}
#staff .staff_area{background-color: #fff;width: 30%;position: relative;padding: 3% 3% 0 0;margin-top: 50px;}
#staff .staff_ttl{position:absolute;top: -15px;}
#staff .staff_flex{display: flex;justify-content: space-between;}
#staff .staff_comment{position: absolute;right: -3px;bottom: 120px;}
#staff .staff_introduction{background-color: #F4F4F4;padding: 6% 5% 6% 0;width: 65%;margin-left: -5%;}
#staff .staff_name{font-size: 16px;display:flex;align-items: center;}
#staff .staff_name span{font-size: 28px;padding-left: 25px;}
#staff .staff_introduction p{margin-bottom: 30px;padding-left: 90px;}
#staff .staff_introduction ul{background-color: #fff;color: #1B1B38;padding: 20px 10px 20px 90px;text-align: justify;}
@media screen and (max-width: 960px){
	#staff .staff_comment {bottom: 40%;width: 100%;height: auto;}
}
@media screen and (max-width: 910px){
	#staff .staff_flex{display: block;}
	#staff .staff_area {padding: 0% 3% 3% 3%;margin: auto;}
	#staff .staff_ttl {top: -30px;left: -5px;}
	#staff .staff_comment {bottom: 10%;}
	#staff .staff_introduction{width: 90%;padding: 9% 5% 5%;margin: -40px 0 0;}
	#staff .staff_introduction p{padding-left: 0;margin-bottom: 20px;}
	#staff .staff_name{justify-content: center;}
	#staff .staff_introduction ul {padding: 20px;}
}
@media screen and (max-width: 768px){
	#staff .staff_area {width: 40%;}
}
@media screen and (max-width: 428px){
	#staff {margin-bottom: 70px;}
	#staff .staff_area {width: 60%;}
	#staff .staff_ttl {left: -40px;}
	#staff .staff_introduction {padding: 18% 5% 5%;}
	#staff .staff_name{display: block;text-align: center;line-height: 1.5;}
	#staff .staff_name span {font-size: 22px;padding-left: 0px;}
}
@media screen and (max-width: 375px){
	#staff .staff_ttl {left: -30px;width: 40%;height: auto;}
}

/*flow***************/
#flow{width: 96%;margin: 0 auto 100px;background-color: #F4F4F4;padding: 20px 0 50px;}
#flow .flow_ttl{margin: -50px 0 70px;}
#flow .flow_flex{display: flex;align-items: center;justify-content: space-between;}
#flow .flow_area{width: 65%;}
ul.stepflow > li:before, ol.stepflow > li:before {
	background-color:#1B1B38!important;
}
.stepflow li.stepflow_li,.stepflow li.stepflow_li-2 {
    position: relative;
    padding: 0 0 3em 3em;
	margin-top: -10px;
}
.stepflow>li.stepflow_li:before {
	content: "";
	width: 2px;
	background: #1B1B38;
	display: block;
	position: absolute;
	top: 20px;
	bottom: 0;
	left: 16px;
}
.stepflow-white {
	content: '';
	display: inline-block;
	position: absolute;
	top: 5px;
	left: 0;
	width: 14px;
	height: 14px;
	border-radius: 50%;
	border: solid 3px #1B1B38;
}
.stepflow-black {
	content: '';
	display: inline-block;
	position: absolute;
	top: 5px;
	left: 0;
	width: 30px;
    height: 30px;
	border-radius: 50%;
	border: solid 3px #1B1B38;
	background-color: #1B1B38;
}
.stepflow_title {
	font-size: 28px;
}
.stepflow_content {
	font-size: .9em;
	line-height: 1.5;
	margin-top: .5em;
	padding: 0 0 1.5em;
	border-bottom: dashed 1px #cccccc;
}
.flow_txt li{margin-left: 1em;text-indent: -1em;text-align: justify;}
#flow .flow_img{width: 30%; text-align: center;}
#flow .flow_img div span{
	background: url(../images/abaut_point.png) no-repeat center left, url(../images/abaut_point2.png) no-repeat center right;
    padding: 0px 20px;
}
#flow .flow_img div img{width: 100%;margin-bottom: 30px;}
@media screen and (max-width: 1024px){
	#flow .flow_img div img {margin-bottom: 110px;}
}
@media screen and (max-width: 987px){
	#flow .flow_img div span {padding: 0px 10px;}
}
@media screen and (max-width: 960px){
	#flow .flow_flex{display: block;}
	#flow .flow_area {width: 100%;}
	.flow_txt img{width: 70%;margin: 20px auto 0;display: block;}
	.flow_txt li span{
		text-align: center;
		background: url(../images/abaut_point.png) no-repeat center left, url(../images/abaut_point2.png) no-repeat center right;
		padding: 0px 20px;
		display: block;
		width: 70%;
		margin: 20px auto -15px;
	}
}
@media screen and (max-width: 428px){
	#flow {margin: 0 auto 60px;padding: 20px 0;}
	#flow .flow_ttl {margin: -50px 0 40px;}
	.stepflow-black {width: 15px;height: 15px;top: 9px;}
	.stepflow_title {font-size: 22px;}
	.stepflow li.stepflow_li, .stepflow li.stepflow_li-2 {padding: 0 0 3em 2.5em;}
	.stepflow>li.stepflow_li:before {left: 9px;}
	.flow_txt img {width: 100%;margin: 10px auto 0;}
	.flow_txt li span {width: 85%;padding: 0px 10px 0 25px;margin-bottom: 10px;}
}
@media screen and (max-width: 375px){
	#flow .flow_ttl {margin: -40px 0 40px;width: 25%;height: auto;}
}

/*shop data***************/
#shopdata .shopdata_ttl{display: block;margin: auto;}
#shopdata .shopdata_tel{color: #1B1B38;font-size: 40px;text-align: center;margin: 10px 0;}
#shopdata table{width: 100%; border-top: 1px solid #ADADAD;}
#shopdata table th,#shopdata table td{border-bottom: 1px solid #ADADAD;padding: 15px 0;}
#shopdata .link_flex{
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 60px 0 80px;
}
#shopdata .link_box{
	border-bottom: 1px solid #707070;
	text-align: center;
	width: 45%;
	height: 80px;
	display: flex;
    justify-content: center;
    align-items: center;
	background-image: url(../images/btn1.png);
    background-repeat: no-repeat;
	background-position: right;
	background-size: 65px;
	margin-right: 30px;
}
#shopdata .link_box:last-child{margin-right: 0px;}
#shopdata a:hover{color: #D86F93;border-bottom: 1px solid #D86F93;background-image: url(../images/btn1_hover.png);}
#shopdata .shopdata_taisaku,#shopdata .shopdata_taisaku p{text-align: center;}
#shopdata .shopdata_box{border: 1px solid #ADADAD;display: inline-block;text-align: left;padding: 40px 60px;line-height: 2;margin: 20px 0;}
#shopdata .shopdata_box li{margin-left: 1em;text-indent: -1em;}
#shopdata iframe{margin: 70px 1%;}
@media screen and (max-width: 960px){
	#shopdata table th{padding-right: 20px;}
}
@media screen and (max-width: 768px){
	#shopdata table th,#shopdata table td{display: block;width: 100%;text-align: center;}
	#shopdata table th{padding-right: 0px; padding-bottom: 0;border-bottom: none;}
	#shopdata table td{padding-top: 5px;}
	#shopdata .link_flex{display: block;}
	#shopdata .link_box{width: 100%;}
	#shopdata .shopdata_taisaku p{text-align: justify;}
}
@media screen and (max-width: 428px){
	#shopdata .shopdata_tel{font-size: 30px;}
	#shopdata .link_flex {margin: 20px 0 40px;}
	#shopdata .shopdata_box {padding: 20px 30px;}
	#shopdata iframe {height: 300px;}
}
@media screen and (max-width: 375px){
	#shopdata .shopdata_ttl {width: 50%;height: auto;}
	#shopdata .link_box {background-size: 15%;}
	#shopdata iframe {margin: 40px 1%;}
}

/*menu***************/
#menu{margin-bottom: 90px;}
#menu h2{font-size: 28px;color: #1B1B38;text-align: center;letter-spacing: 3px;margin: 30px 0 20px;}
#menu .menu_txt{text-align: center;}
@media screen and (max-width: 428px){
	#menu {margin-bottom: 60px;}
	#menu h2{font-size: 20px;margin: 20px 0 10px;}
	#menu .menu_txt{text-align: justify;}
}
@media screen and (max-width: 320px){
	#menu h2{font-size: 18px;letter-spacing: 2px;}
}

/*各コース***************/
#course{width: 96%; margin: auto;background-color: #F4F4F4;}
#course .course_centre{text-align: center;}
#course .course_gentei{
    text-align: center;
    font-size: 22px;
    font-weight: bold;
    color: #1B1B38;
    background-image: url(../images/menu_gentei.png);
	background-repeat: no-repeat;
    width: 467px;
    background-size: 100%;
    background-position: bottom;
    margin: 50px auto -30px;
    padding-bottom: 15px;
}
#course .course_off{margin: 20px auto 0; display: block;}
#course .course_ttl{display: inline;margin: -30px auto 5px;}
#course .course_ttl2{display: inline;margin: 70px auto 5px;}
#course .course_specialbg-left{background-color: #fff;margin-left: 40px;padding: 60px 0 70px;margin-top: 70px;}
#course .course_bg-left{background-color: #fff;margin-left: 40px;padding: 10px 0 70px;margin-top: 70px;}
#course .course_bg-right{background-color: #fff;margin-right: 40px;padding: 10px 0 70px;margin-top: 70px;}
#course table.course_special{margin-top: 70px;}
#course table.course_special,#course table.course_aging,#course table.course_usually{width: 100%;}
#course table.course_special th{font-weight: bold;font-size: 22px;line-height: 1.2;}
#course table.course_special th span{font-weight: normal;font-size: 18px;}
#course table.course_special td,#course table.course_aging td,#course table.course_usually td{text-align: right;width: 20%;}
#course table.course_aging th,#course table.course_aging td,#course table.course_usually th,#course table.course_usually td{border-bottom: 1px solid #ADADAD;padding: 20px 0;}
#course li {margin-left: 1em;text-indent: -1em;}
#course .course_flex{display: flex; align-items: center; justify-content: space-between;}
#course .course_flex-left{display: flex; align-items: center; justify-content: left;flex-flow: row-reverse;position: relative;}
#course .course_flex .course_special-box{position: relative;}
#course .course_special-img{position: absolute;bottom: 10px;left: -10px;}
#course table.course_aging th span,#course table.course_usually th span{font-size: 16px;color: #8A8A95;}
#course .time{font-size: 16px;color: #709BB0!important;}
#course .course_point-right{background-color: #EDE7E7;position: relative;padding: 90px 70px 90px 20%;width: 40%;margin: 0 0 0 auto;color: #1B1B38;}
#course .course_point-right h3{font-size: 22px;font-weight: bold;color: #1B1B38;margin-bottom: 10px}
#course .course_point-right img{position: absolute;right: 20px;top: -30px;}
#course .course_point-left {background-color: #EDE7E7;position: relative;padding: 90px 20% 90px 70px;width: 40%;color: #1B1B38;}
#course .course_point-left h3{font-size: 22px;font-weight: bold;color: #1B1B38;margin-bottom: 10px}
#course .course_point-left img{position: absolute;top: -30px;left: 20px;}
#course .course_dougu{position: absolute; z-index: 1;}
#course .course_dougu-left{position: absolute; z-index: 1;right: 0;}
#course .course_usually-ttl{margin-top: 70px;}
#course .course_usually-ttl th{font-weight: bold;font-size: 22px;display:flex;align-items: center;letter-spacing: 1.2px;}
#course .course_usually-ttl th span{font-weight: normal;font-size: 14px;padding-left: 20px;}
#course .course_bikou{font-size: 14px;color: #101055;}
.img-w-1{width: 45%;}
#course .course_centre span{padding-left: 10px;}
@media screen and (max-width: 1160px){
	#course .course_special-box .course_special-pic{width: 94%;height: auto;margin: auto 3%;}
	#course .course_special-img {left: 0px;}
}
@media screen and (max-width: 1100px){
	#course .course_point-right {padding: 90px 70px 90px 20%;width: 35%;}
	#course .course_point-left{width: 35%;}
}
@media screen and (max-width: 1024px){
	#course .course_point-right {padding: 50px 70px 50px 30%;width: 30%;}
	#course .course_point-left {padding: 50px 30% 50px 70px;width: 30%;}
}
@media screen and (max-width: 960px){
	#course .course_txt{text-align: justify;}
	#course .course_flex,#course .course_flex-left{display: block;}
	#course .course_special-box .course_special-pic {width: 70%;margin: 0 15% 10px;}
	#course .course_special-img {left: 90px;bottom: 20px;}
	#course table.course_special td, #course table.course_aging td, #course table.course_usually td {width: 15%;}
	#course .course_point-right,#course .course_point-left{padding: 5% 5% 10%;width: 90%;}
	#course .course_point-right h3,#course .course_point-left h3{text-align: center;}
	#course .course_point-left img {right: 20px;top: -30px;}
	#course .course_dougu,#course .course_dougu-left{position: relative;margin: -40px auto 0;width: 70%;height: auto;display: block;}
	.img-w-1{width: 35%;}
}
@media screen and (max-width: 800px){
	.img-w-1{width: 30%;}
	.img-w-2{width: 25%;height: auto;}
	.img-w-3{width: 20%;height: auto;}
	.img-w-4{width: 15%;height: auto;}
}
@media screen and (max-width: 768px){
	#course .course_gentei{margin-bottom: 0px;}
	#course .course_off{width: 100%;height: auto;}
	#course .course_special-box .course_special-pic {width: 90%;margin: 0 5% 10px;}
	#course .course_special-img {left: 10px;}
	#course .course_specialbg-left {padding: 30px 0 40px;margin-top: 40px;margin-left: 2%;}
	#course table.course_special {margin-top: 40px;}
	#course .course_dougu,#course .course_dougu-left {width: 90%;}
	#course .course_ttl2 {margin: 50px auto 5px;}
	#course .course_usually-ttl {margin-top: 30px;}
	#course .course_bg-right {margin-top: 50px;padding: 10px 0 50px;margin-right: 2%;}
	#course .course_bg-left {margin-top: 50px;padding: 10px 0 30px;margin-left: 2%;}
	#course table.course_special td, #course table.course_aging td, #course table.course_usually td {width: 20%;}
	#course .course_point-right img,#course .course_point-left img{top: -20px;}
}
@media screen and (max-width: 580px){
	#course .course_gentei{width: 100%;}
}
@media screen and (max-width: 428px){
	#course .course_gentei{font-size: 16px;margin-bottom: -20px;}
	#course table.course_special th,#course .course_usually-ttl th,#course .course_point-right h3,#course .course_point-left h3{font-size: 16px;}
	#course table.course_special th{text-align: justify;}
	#course table.course_special th span,#course table.course_aging th span, #course table.course_usually th span{font-size: 14px;}
	#course .course_special-box .course_special-pic {width: 100%;margin: 0 auto 10px;}
	#course .course_special-img {left: 0px;height: 18%;width: auto;}
	#course table.course_aging th, #course table.course_aging td, #course table.course_usually th, #course table.course_usually td {padding: 10px 0;}
	#course .course_point-right, #course .course_point-left {padding: 5% 5% 18%;width: 90%;}
	#course .course_point-right img,#course .course_point-left img{right: 0px;top: -15px;}
	#course .course_usually-ttl th {align-items: flex-start;flex-flow: column;margin-bottom: 20px;}
	#course .course_usually-ttl th span{padding-left: 0px;}
	#course .mb50 {margin-bottom: -10px;}
	.img-w-2,.img-w-3{width: 30%;}
	.img-w-4 {width: 22%;}
	#course .course_centre span{padding-left: 0px;}
	#course .time{font-size: 14px;}
}
@media screen and (max-width: 414px){
	#course table.course_special td, #course table.course_aging td, #course table.course_usually td {width: 25%;}
}
@media screen and (max-width: 375px){
	#course .course_gentei{margin-top: 30px;}
	#course .course_ttl{width: 70%; height: auto;}
	#course .course_ttl2{width: 30%; height: auto;}
	.img-w-2, .img-w-3 {width: 32%;}
}
@media screen and (max-width: 320px){
	#course table.course_special td, #course table.course_aging td, #course table.course_usually td {width: 30%;}
}

/*recruit***************/
#recruit .ringo_area{position: relative;}
#recruit .ringo_txt{margin: 100px auto;}
#recruit .ringo_txt img{display: block;margin: 0 auto 30px;}
#recruit .ringo_txt p{text-align: center; font-size: 20px;}
#recruit .ringo_txt .marker{background:linear-gradient(transparent 40%, #ff6 40%);}
#recruit .ringo_txt .unei{padding-top: 15px;display: block;font-size: 16px;}
#recruit .ringo_point1{position: absolute;top: -60%;right: 13%;z-index: -1;}
#recruit .ringo_point2{position: absolute;bottom: -20%;left: 13%;}
#recruit .point_bg-yellow{border-radius: 20px;background-color: #FAF7EF;width: 96%;margin: 0 2% 100px;padding-top: 90px;}
#recruit .point_bg-yellow-area{position: relative;margin-bottom: 90px;}
#recruit .point_bg-yellow-area h2,#recruit .voice_ttlarea h2,#recruit .recruitment_ttlarea h2,#recruit .contact_ttlarea h2{
	font-size: 40px;
	text-align: center;
	color: #1B1B38;
	font-weight: bold;
}
#recruit .point_bg-yellow-area h2 span,#recruit .voice_ttlarea h2 span,#recruit .recruitment_ttlarea h2 span,#recruit .contact_ttlarea h2 span{
	background-image : linear-gradient(to right, #000, #000 4px, transparent 4px, transparent 8px); 
	background-size: 8px 1.5px;
	background-position: left bottom;
	background-repeat: repeat-x;
	padding-bottom: 10px;
}
#recruit .point_bg-yellow-area .point_illust-left{position: absolute; left: 0;bottom: -30px;}
#recruit .point_bg-yellow-area .point_illust-right{position: absolute; right: 0;bottom: 0;}
#recruit .point_bg-white{background-color: #fff;border-top-left-radius: 20px;border-top-right-radius: 20px;width: 90%;margin: 0 5%;padding: 5% 0;}
#recruit .point_flex{display: flex;justify-content: space-between;align-items: flex-start;}
#recruit .point_flex-centre{display: flex;justify-content: center;align-items: center;}
#recruit .point_box{width: 30%;position: relative;}
#recruit .point_position{position: absolute;top: -20px;left: 15px;}
#recruit .point_box h3{font-size: 26px;font-weight: bold;color: #1B1B38;text-align: center;line-height: 1.5;margin: 20px 0;}
#recruit .point_pic{width: 100%;border-radius: 20px;}
#recruit .dashed{
	height: 2px;
	background-image : linear-gradient(to right, #000, #000 4px, transparent 4px, transparent 8px); 
	background-size: 8px 1.5px;          /* グラデーションの幅・高さを指定 */
	background-position: left bottom;  /* 背景の開始位置を指定 */
	background-repeat: repeat-x;       /* 横向きにのみ繰り返す */
	margin: 50px 0;
}
#recruit .point_sonota{font-size: 26px;font-weight: bold;color: #1B1B38;line-height: 1.5;margin-right: 50px;}
#recruit .point_sonota span{font-size: 18px;}
#recruit ul.list_mark li{
	background: url(../images/recruit_pointdesign.png) no-repeat 0 4px;
    background-size: auto 20px;
    padding-left: 25px;
	margin-bottom: 5px;
	text-align: justify;
}
#recruit ul.list_mark li:last-child{margin-bottom: 0px;}
#recruit .voice_ttlarea,#recruit .recruitment_ttlarea,#recruit .contact_ttlarea{position: relative;margin-bottom: 40px;}
#recruit .voice_ttlarea img{position: absolute;top: -30%;left: 42%;transform: translate(-50%, -50%);}
#recruit .voice_flex{display: flex;justify-content: space-between;align-items: center;}
#recruit .voice_txt{width: 60%;}
#recruit .voice_ttl{font-size: 26px; font-weight: bold;color: #1B1B38;margin-bottom: 20px;}
#recruit .voice_pic{width: 30%;}
#recruit .voice_nendai{position: relative;margin: 90px 0 200px;}
#recruit .voice_nendai-txt{text-align: center;color: #1B1B38;font-weight: bold;font-size: 20px;}
#recruit .voice_nendai-txt span{font-size: 30px;}
#recruit .voice_illust-left {position: absolute;bottom: -30px;left: 13%;}
#recruit .voice_illust-right{position: absolute;right: 20%;top: -50px;}
#recruit .recruitment_ttlarea img{position: absolute;top: -17%;left: 46%;transform: translate(-50%, -50%);}
#recruit .recruitment_txt,#recruit .contact_txt{font-size: 20px;text-align: center;margin-top: 20px;}
.accordion{margin-bottom: 200px;}
/*アコーディオン*/
.toggle {
	display: none;
}
.Label {		/*タイトル*/
    padding: 1%;
    display: block;
    color: #fff;
    background: #F48962;
    border-radius: 20px;
    text-align: center;
    font-weight: bold;
    font-size: 24px;
}
.Label span{font-size: 18px;padding-left: 20px;}
.Label::before{		/*タイトル横の矢印*/
	content:"";
	width: 10px;
	height: 10px;
	border-top: 3px solid #fff;
	border-right: 3px solid #fff;
	-webkit-transform: rotate(45deg);
	position: absolute;
	top:calc( 50% - 6px );
	right: 20px;
	transform: rotate(135deg);
}
.Label,
.content {
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	transform: translateZ(0);
	transition: all 0.3s;
}
.content {		/*本文*/
	height: 0;
	margin-bottom:10px;
	padding:0 20px;
	overflow: hidden;
}
.toggle:checked + .Label + .content {	/*開閉時*/
	height: auto;
	padding: 20px;
	transition: all .3s;
}
.toggle:checked + .Label::before {
	transform: rotate(-45deg) !important;
}
#recruit .recruitment_table{
	width: 100%;
    border-top: 1px solid #ADADAD;
}
#recruit .recruitment_table th,#recruit .recruitment_table td{border-bottom: 1px solid #ADADAD;padding: 20px 0;}
#recruit .recruitment_table th{vertical-align:top;color: #1B1B38;font-weight: bold;width: 13%;}
#recruit .recruitment_table td ul li{margin-left: 1em;text-indent: -1em;}
#recruit .contact_ttlarea img{position: absolute;top: -17%;left: 35%;transform: translate(-50%, -50%);}
#recruit .contact_maparea{
    width: 96%;
    margin: 0 2%;
    background-color: #FAF7EF;
    border-radius: 20px;
}
#recruit .contact_flex{display: flex;align-items: flex-start;height: 1050px;}
#recruit .contact_detail{
	width: 30%;
    border-top-left-radius: 20px;
    border-bottom-left-radius: 20px;
	padding: 0 10%;
}
#recruit .contact_logo{
    width: 90px;
    background-color: #fff;
    border-bottom-left-radius: 20px;
    border-bottom-right-radius: 20px;
    padding: 35px 40px;
	display: block;
    margin: 0 auto 40px;
}
#recruit .contact_detail .contact_tenpo{width: 100%;margin: 20px 0 0;}
#recruit .contact_dashed{
	height: 2px;
	background-image : linear-gradient(to right, #000, #000 4px, transparent 4px, transparent 8px); 
	background-size: 8px 1.5px;
	background-position: left bottom;
	background-repeat: repeat-x;
	margin: 20px 0;
}
#recruit .contact_detail table th{vertical-align: top;width: 15%;}
.line_link{margin: auto;display: block;width: 200px;height: auto;padding-bottom: 60px;}
#recruit iframe{
	width: 50%;
    border-top-right-radius: 20px;
    border-bottom-right-radius: 20px;
	height: 100%;
}
#recruit .contact_banner{padding: 190px 0 100px;}
#recruit .contact_banner a:hover{opacity: 0.5;}
@media screen and (max-width: 1920px){
	#recruit .contact_flex {height: 950px;}
}
@media screen and (max-width: 1366px){
	#recruit .ringo_point1{width: 20%;height: auto;}
	#recruit .ringo_point2 {width: 12%;height: auto;}
}
@media screen and (max-width: 1024px){
	#recruit .ringo_point1 {top: -50%;}
	#recruit .point_bg-yellow-area .point_illust-left {width: 20%;height: auto;}
	#recruit .point_bg-yellow-area .point_illust-right {width: 20%;height: auto;top: -100%;}
	#recruit .contact_flex {height: 800px;}
	#recruit .contact_detail {width: 40%;padding: 0 5%;}
	#recruit .contact_logo {width: 50px;padding: 25px 35px;margin: 0 auto 20px;}
	.line_link {width: 150px;}
	#recruit .contact_banner img{width: 90%;height: auto; display: block;margin: auto;}
}
@media screen and (max-width: 960px){
	#recruit .contact_flex {height:auto;display: block;}
	#recruit .contact_detail {width: 90%;padding: 0 5%;}
	#recruit .point_box h3,#recruit .point_sonota{font-size: 20px;}
	#recruit .point_sonota {width: 40%;}
	#recruit .voice_ttl {font-size: 20px;margin-bottom: 10px;}
	#recruit .voice_illust-left {bottom: -20px;left: 13%;width: 80px;height: auto;}
	#recruit .contact_ttlarea img {left: 31%;}
	#recruit .contact_detail .contact_tenpo {width: 70%;margin: 20px auto 0;display: block;}
	#recruit iframe {width: 100%;height: 300px;border-bottom-left-radius: 20px;border-bottom-right-radius: 20px;border-top-right-radius: 0px;vertical-align: bottom;}
}
@media screen and (max-width: 860px){
	#recruit .voice_illust-left {left: 8%;}
	#recruit .voice_illust-right {top: -30px;width: 200px;height: auto;}
}
@media screen and (max-width: 768px){
	#recruit .ringo_txt {margin: 60px auto;}
	#recruit .ringo_txt img {margin: 0 auto 20px;width: 70px;height: auto;}
	#recruit .ringo_point1{right: 5%;top: -40%;}
	#recruit .ringo_point2{left: 5%;}
	#recruit .point_bg-yellow-area h2, #recruit .voice_ttlarea h2, #recruit .recruitment_ttlarea h2, #recruit .contact_ttlarea h2 {font-size: 30px;}
	#recruit .point_bg-yellow {margin: 90px 2% 100px;padding-top: 50px;}
	#recruit .point_bg-white {padding: 10% 0;}
	#recruit .point_bg-yellow-area {margin-bottom: 60px;}
	#recruit .point_bg-yellow-area .point_illust-left {bottom: 0px;}
	#recruit .point_position {top: -10px;left: 60px;width: 15%;height: auto;}
	#recruit .point_flex,#recruit .point_flex-centre{display: block;}
	#recruit .point_box {width: 100%;margin-bottom: 40px;}
	#recruit .point_box:last-child{margin-bottom: 0px;}
	#recruit .point_pic {width: 70%;margin: 0 15%;}
	#recruit .point_box h3{margin-bottom: 10px;}
	#recruit .point_sonota {width: 100%;text-align: center;margin-bottom: 20px;}
	#recruit .voice_ttlarea img {width: auto;height: 90%;}
	#recruit .voice_pic {width: 35%;}
	#recruit .voice_nendai {margin: 60px 0 270px;}
	#recruit .voice_illust-right {right: 10%;}
	#recruit .voice_illust-left {top: 200%;left: 50%;transform: translate(-50%, -50%);}
	#recruit .recruitment_table th {width: 20%;padding-right: 5%;}
	#recruit .recruitment_table td{width: 75%;text-align: justify;}
	#recruit .contact_banner {padding: 110px 0;}
}
@media screen and (max-width: 580px){
	#recruit .point_bg-yellow-area .point_illust-left {bottom: -70px;}
	#recruit .point_bg-white {margin-top: 90px;}
	#recruit .voice_flex{display: block;}
	#recruit .voice_txt {width: 100%;}
	#recruit .voice_pic {width: 50%;margin: 10px auto;display: block;}
	#recruit .voice_nendai {margin: 20px 0 270px;}
	#recruit .voice_nendai-txt {line-height: 1.4;font-size: 18px;}
	#recruit .voice_illust-right {display: none;}
}
@media screen and (max-width: 428px){
	#recruit .ringo_txt {margin: 40px auto;}
	#recruit .ringo_txt img {width: 50px;}
	#recruit .ringo_txt p {font-size: 16px;}
	#recruit .ringo_txt span {padding-top: 10px;font-size: 14px;}
	#recruit .ringo_point1 {top: -25%;}
	#recruit .ringo_point2 {bottom: -10%;width: 15%;}
	#recruit .point_bg-yellow {margin: 50px 2% 100px;padding-top: 40px;}
	#recruit .point_bg-white {margin-top: -20px;padding: 5% 0;}
	#recruit .point_bg-yellow-area .point_illust-right {top: -70%;}
	#recruit .point_bg-yellow-area .point_illust-left {bottom: -30px;}
	#recruit .point_bg-yellow-area h2, #recruit .voice_ttlarea h2, #recruit .recruitment_ttlarea h2, #recruit .contact_ttlarea h2 {font-size: 22px;}
	#recruit .point_bg-yellow-area h2 span, #recruit .voice_ttlarea h2 span, #recruit .recruitment_ttlarea h2 span, #recruit .contact_ttlarea h2 span {padding-bottom: 7px;}
	#recruit .point_pic {width: 100%;margin: 0 auto;}
	#recruit .point_position {left: 15px;width: 20%;}
	#recruit .point_box h3, #recruit .point_sonota{font-size: 18px;}
	#recruit .dashed {margin: 40px 0;}
	#recruit ul.list_mark li {background-size: auto 15px;padding-left: 20px;}
	#recruit .voice_ttl{font-size: 18px;}
	#recruit .voice_nendai {margin: 20px 0 200px;}
	#recruit .voice_nendai-txt span {font-size: 22px;}
	#recruit .voice_ttlarea, #recruit .recruitment_ttlarea, #recruit .contact_ttlarea {margin-bottom: 20px;}
	#recruit .recruitment_ttlarea img {top: -15%;left: 45%;width: 35%;height: auto;}
	#recruit .recruitment_txt, #recruit .contact_txt {font-size: 14px;}
	.Label {font-size: 20px;}
	.Label::before {width: 6px;height: 6px;top: calc( 50% - 5px );}
	.Label span {font-size: 14px;padding-left: 10px;}
	#recruit .recruitment_table th {width: 25%;}
	.accordion {margin-bottom: 100px;}
	#recruit .contact_ttlarea img {left: 25%;width: 20%;height: auto;}
	#recruit .contact_banner {padding: 80px 0;}
	#recruit .contact_banner img {width: 100%;}
}
@media screen and (max-width: 375px){
	#recruit .recruitment_table th {width: 30%;padding-right: 5%;}
}
@media screen and (max-width: 320px){
	#recruit .ringo_point1 {top: -20%;}
	.accordion {margin-bottom: 100px;}
}

/*右下固定ボタン***************/
.kotei,.kotei2{
	color: #fff!important;
	background-color: #06063E;
	padding: 20px 20px 20px 0;
	position:fixed;
	right:0px;
	bottom:0px;
	display: flex;
	align-items: center;
}
.kotei2{z-index: 2;}
.kotei span,.kotei2 span{
    border-bottom: 1px solid #fff;
	width: 10px;
	display: block;
	margin-right: 10px;
}
.kotei:hover,.kotei2:hover{background-color: #D86F93;}
@media screen and (max-width: 647px){
	.kotei,.kotei2 {padding: 15px 15px 15px 0;font-size: 16px;}
}

/*footer***************/
footer .footer_pb,footer .footer_pb-recruit{padding: 0 0 30px;}
.pagetop{width: 100%;background-color: #1B1B38;display: block;padding: 20px 0;margin-bottom: 20px;}
.pagetop img{display: block; margin: auto;}
footer .siteMap ul{ display:-webkit-box; display:-ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content:center;}
footer .siteMap ul li{ padding: 1em;width: 50px;text-align: center;}
footer .siteMap ul li a{ color: #000; text-decoration: none;}
footer .siteMap ul li a:hover{opacity: 0.5;}
footer .footerInfo h2{margin: 20px 0;}
footer .footerInfo h2 img{display: block; margin: 0 auto -10px;}
footer .footerInfo p{text-align: center;}
footer .footerInfo .address{ font-size: 14px; line-height: 1.6em; margin: 10px 0;}
footer .footerInfo .tel{ font-size: 20px;}
@media screen and (max-width: 647px){
	footer .footer_pb{padding: 0 0 70px;}
}