@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400,500,700,900&display=swap&subset=japanese');
@import url('https://fonts.googleapis.com/css2?family=Quicksand:wght@400;500;600&family=Ubuntu:wght@300&display=swap');
html {
	overflow-y: scroll;
	font-size: 62.5%;
	scroll-behavior: smooth;
}

body {
	font-family: 'Noto Sans JP', sans-serif;
	font-size: 16px;
	color: #121212;
}

a,
a:link,
a:active,
a:visited {
	transition: all 0.5s ease-out;
	outline: none;
	text-decoration: none;
	color: #121212;
}

@media only screen and (max-width: 1100px) {
	html {
		font-size: 50%;
	}
}

/*---------------------------------------------------------common*/

* {
	box-sizing: border-box;
}

img {
	width: 100%;
	height: auto;
}

.spnomi {
	display: none;
}

.spnomi1100 {
	display: none;
}

.spnomi480 {
	display: none;
}

.spnomi760 {
	display: none;
}

.pcnomi480 {
	display: block;
}

.pcnone {
	display: none;
}

.clear {
	clear: both;
}

.maincolor {
	color: #000;
}

@media only screen and (max-width: 1100px) {
	.spnomi1100 {
		display: block;
	}
}

@media only screen and (max-width: 1100px) {
	.spnomi {
		display: block;
	}
	.pcnomi {
		display: none;
	}
}

@media only screen and (max-width: 760px) {
	.spnomi760 {
		display: block;
	}
	.pcnone {
		display: block;
	}
	.spnone {
		display: none;
	}
}

@media only screen and (max-width: 480px) {
	.spnomi480 {
		display: block;
	}
	.pcnomi480 {
		display: none;
	}
	.pcnone {
		display: block;
	}
	.spnone {
		display: none;
	}
}

/*------------------------------------------------Fade Animation*/

.fadein {
	opacity: 0;
	margin-top: 10px;
	-webkit-transition: all 1.2s;
	-moz-transition: all 1.2s;
	-o-transition: all 1.2s;
	-ms-transition: all 1.2s;
	transition: all 1.2s;
}

.fade-on {
	opacity: 1;
	margin-top: 0;
}

/*---------------------------------------------------------main,logo*/

header {
	height: auto;
	position: relative;
}

#logo {
	width: 230px;
	display: inline-block;
	padding: 0 0 10px 0;
	vertical-align: bottom;
}

#logo img {
	width: 210px;
	height: 100%;
	object-fit: contain;
}

#logo00 {
	width: 180px;
	padding: 0px 10px 0 10px;
	float: left;
}

.wrap_main {
	width: 100%;
	position: absolute;
	bottom: -200px;
	left: 0;
	z-index: 4;
}

.for_main {
	z-index: 2;
	position: absolute;
	bottom: 5rem;
	left: 0;
	width: 100%;
	padding: 20px;
}

.main_li {
	width: 30%;
	display: inline-block;
	color: red;
}

.main_li li {
	text-align: center;
	font-size: 1.8rem;
	font-weight: 600;
	margin-bottom: 5px;
	border: 2px solid red;
	padding: 1.5rem 0;
	background-color: rgba(255, 255, 255, .8);
	letter-spacing: 1px;
	line-height: 1.3;
}

a.btn_main {
	display: inline-block;
	background-color: #f15a24;
	color: #fff;
	padding: 2rem 3rem 1.5rem;
	position: absolute;
	right: 0;
	bottom: 0;
	font-size: 1.8rem;
	font-weight: 500;
}

a.btn_main:hover {
	transform: scale(1.05, 1.05);
	box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
}

.btn_main .far {
	font-size: 15px;
	margin-right: 10px;
}

	

@media only screen and (max-width: 1100px) {
	#logo {
		width: 230px;
		display: inline-block;
		float: left;
		padding-top: 10px;
	}
	.wrap_main {
		z-index: 4;
	}
	.for_main {
		position: absolute;
		bottom: 10px;
		left: 0;
		width: 100%;
		padding: 20px;
	}
	.main_li {
		display: table;
		width: 340px;
		border-spacing: 2px 0;
		border-collapse: separate;
	}
	.main_li li {
		font-size: 12px;
		display: table-cell;
		padding: 5px;
		height: 70px;
		vertical-align: middle;
	}
}

@media only screen and (max-width: 760px) {
	.for_main {
		position: absolute;
		bottom: 80px;
		background-color: transparent;
		padding: 5px;
	}
	.main_li {
		width: 100%;
	}
	.main_li li {
		height: auto;
	}
	a.btn_main {
		position: relative;
		margin: 10px auto 0;
		width: 100%;
		display: block;
		text-align: center;
	}
	
}

/* -------------------------------------------------------------swiper */

.wrap {
	width: 100%;
	height: auto;
}



@keyframes fadein01 {
	from {
		opacity: 0;
		transform: translateY(-10px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes fadein02 {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}


.slide-img {
	width: 100%;
	height: auto;
	overflow: hidden;
}

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



@media only screen and (max-width: 480px) {
	.slide-img img {
		width: auto;
		height: 90vh;
		margin-left: 0;
		overflow: hidden;
	}
}

/*---------------------------------------------------------fix_right*/

a.top {
	width: 40px;
	height: 40px;
	background-color: #005bac;
	display: inline-block;
	margin-top: 30px;
	position: relative;
	padding: 5px 14px 0 0;
	right: 4px;
	border-radius: 50%
}

.arrow-top {
	display: block;
	width: 12px;
	height: 12px;
	border-left: 2px solid #fff;
	border-bottom: 2px solid #fff;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
	vertical-align: middle;
}

.text_totop {
	font-size: 10px;
}

.fix_right {
	position: fixed;
	z-index: 100;
	top: 0px;
	right: 5px;
	writing-mode: vertical-rl;
	font-family: gill-sans-nova, sans-serif;
	font-weight: 600;
	font-style: normal;
	letter-spacing: 3px;
	text-align: center;
	width: 30px;
	height: 750px;
}

.fix_name {
	margin-bottom: 10px;
	width: 30px;
	font-size: 10px;
}

.fix_right span {
	display: inline-block;
}

.reserv a {
	height: auto;
	padding: 10px 0;
	display: block;
	width: 30px;
	text-align: center;
	padding-right: 7px;
	font-size: 12px;
	border: 2px solid red;
	background-color: #fff;
}

.jp_reserv {
	display: inline-block;
}

.fix_right span.fix_tel {
	display: none;
}

.fix_line a,
.fix_insta a,
.fix_mail a {
	display: block;
	width: 25px;
	height: 30px;
	text-align: center;
}

.fix_line a {
	margin-top: 20px;
}

.fix_insta a {
	width: 20px;
	margin-top: 10px;
}

.fix_mail a {
	width: 19px;
	margin-top: 10px;
}

.far {
	margin-bottom: 5px;
}

.fix_right span.fix_text {
	display: none;
}

.btn_main .far {
	margin-bottom: 5px;
	font-size: 15px;
	margin-right: 5px;
}

@media only screen and (max-width: 1100px) {
	.fix_right {
		position: fixed;
		top: auto;
		right: auto;
		bottom: 0;
		left: 0;
		z-index: 11;
		writing-mode: horizontal-tb;
		letter-spacing: 2px;
		text-align: center;
		height: 60px;
		width: 100%;
		padding-top: 5px;
		padding-bottom: 3px;
		box-shadow: 0 0 4px rgba(0, 0, 0, 0.2);
		background: #fbb03b;
	}
	.fix_right span.fix_name,
	.fix_right span.en_reserv {
		display: none;
	}
	.reserv {
		width: 28%;
		margin: 0 0.2% 0 1.2%;
		display: block;
		float: left;
	}
	.reserv a {
		width: 100%;
		padding: 19px 0 0 0;
		height: 50px;
		border: none;
		border-radius: 5px;
		background-color: #ef6e26;
		color: #fff;
	}
	.fix_right span.fix_tel {
		display: block;
	}
	.fix_line,
	.fix_insta,
	.fix_mail,
	.fix_tel {
		width: 13.5%;
		text-align: center;
		vertical-align: top;
		margin: 0 0.2%;
		display: block;
		float: left;
	}
	a.top {
		width: 13.5%;
		text-align: center;
		vertical-align: top;
		margin: 0 0.2%;
		display: inline-block;
		writing-mode: horizontal-tb;
		transform: rotate(0);
		position: relative;
		bottom: auto;
		right: auto;
		height: 50px;
		box-sizing: border-box;
		background-color: #fff;
		background-color: #ef6e26;
		border-radius: 5px;
		padding: 0;
		display: block;
		float: left;
	}
	.arrow-top {
		display: block;
		margin: 20px auto 0;
		width: 12px;
		height: 12px;
		border-left: 1px solid #fff;
		border-bottom: 1px solid #fff;
		-webkit-transform: rotate(135deg);
		transform: rotate(135deg);
		vertical-align: middle;
	}
	.fix_line a,
	.fix_insta a,
	.fix_mail a,
	.fix_tel a {
		height: 50px;
		background-color: #ef6e26;
		width: 100%;
		display: block;
		color: #fff;
		margin-top: 0;
		border-radius: 5px;
		text-align: center;
	}
	.fix_line a img.spnomi,
	.fix_insta a img.spnomi,
	.fix_mail a img.spnomi {
		display: inline;
	}
	.fix_line a img {
		width: 22px;
		padding-top: 14px;
	}
	.fix_insta a img {
		width: 17px;
		padding-top: 15px;
	}
	.fix_mail a img {
		width: 17px;
		padding-top: 17px;
	}
	.fix_tel a i {
		font-size: 20px;
		padding-top: 15px;
	}
	.top a img {
		width: 17px;
		padding-top: 17px;
	}
	.fix_right span.fix_text {
		display: inline-block;
		vertical-align: top;
		margin-left: 10px;
		padding-top: 3px;
	}
}

/*---------------------------------------------------------nav*/

nav {
	display: inline-block;
}

.navigation {
	font-weight: 500;
	letter-spacing: 1px;
	/*border-bottom: 2px solid red;*/
	height: 76px;
	background: #fff;
	margin-top: 20px;
	/*padding-top: 2px;*/
}

.fixed {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
}

.navigation.fixed {
	margin-top: 0;
	box-shadow: 0 0 5px rgba(0, 0, 0, 0.2);
}

.menu_fix {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 12;
	width: 100%;
}

.nav-container {
	max-width: 1200px;
	margin: 0 auto;
	position: relative;
	z-index: 10;
	text-align: center;
	height: 70px;
}

.nav_li_menu,
.nav_template,
.li_logo {
	display: none;
}

#top_head {
	font-size: 10px;
	color: #664E1A;
	padding: 0px 0 0 0px;
	line-height: 1.5;
	float: left;
	position: absolute;
	left: 10px;
	top: 70px;
}

#top_head br {
	display: none;
}

nav ul {
	list-style: none;
	margin: 0;
	padding: 0;
	font-size: 0;
}

nav ul li {
	display: inline-block;
	position: relative;
	text-align: center;
	font-size: 13px;
	border-left: 1px solid #c7b299;
}

nav ul li::after {
	position: absolute;
}

nav ul li:first-child::after {
	display: none;
}

nav ul li:last-child {
	border-right: 1px solid #c7b299;
}

nav ul li span {
	display: block;
	margin-top: 7px;
	font-size: 12px;
	font-family: 'Ubuntu', sans-serif;
	font-weight: 600;
	letter-spacing: 2px;
}

nav ul li a,
nav ul li a:visited {
	display: block;
	padding: 11px 10px 0 13px;
	line-height: 1.2;
	height: 58px;
	text-decoration: none;
}

.fixed nav ul li a {
	padding-right: 8px;
	padding-left: 10px;
}

nav ul li a:hover,
nav ul li a:visited:hover {}

.sns {
	width: 20px;
}

.sns img {
	width: 20px;
	height: auto;
}

nav ul li.nav_blog {
	position: relative;
	right: 0;
	top: -40px;
	width: 120px;
	height: 120px;
	border-left: none;
	vertical-align: top;
}

nav ul li.nav_blog>span.blog1 a {
	display: block;
	height: 120px;
	background-color: red;
	color: #fff;
	font-size: 11px;
	padding: 30px 0 0 0;
	line-height: 1.8;
}

.fixed nav ul li.nav_blog {
	top: -30px;
	height: 80px;
}

.fixed nav ul li.nav_blog a {
	padding-top: 15px;
	height: 100px;
}

nav ul li.nav_blog a span {
	font-size: 16px;
	position: relative;
	padding-top: 3px;
}

.fixed nav ul li.nav_blog a span {
	padding-top: 1px;
}

nav ul li.nav_blog a span::before {
	position: absolute;
	content: "";
	top: 0;
	left: 50%;
	margin-left: -34px;
	height: 1px;
	width: 68px;
	background-color: #fff;
}

/* -------------------------------------------Mobile navigation */

.nav-mobile {
	display: none;
	position: absolute;
	top: -5px;
	right: 0;
	height: 85px;
	width: 85px;
	z-index: 10;
	border-radius: 0;
	background-color: red;
}

.fixed .nav-mobile {
	height: 60px;
	width: 60px;
	top: 12px;
}

@media only screen and (max-width: 1100px) {
	.navigation.fixed {
		height: 60px;
		padding-top: 0;
		background-color: #fff;
		transition: all 200ms ease-in-out;
	}
	.nav-mobile a:after {
		content: "menu";
		text-transform: uppercase;
		position: absolute;
		bottom: -16px;
		left: 3px;
		font-family: 'Ubuntu', sans-serif;
		font-weight: bold;
		font-size: 11px;
		color: #fff;
		letter-spacing: 2px;
	}
	.fixed .nav-mobile a:after {
		bottom: -12px;
		left: 0px;
		font-size: 10px;
	}
	.nav-mobile.open a:after {
		content: "close";
		text-transform: uppercase;
	}
	.navigation {
		position: fixed;
		top: 0;
		left: 0;
		z-index: 10;
		width: 100%;
		height: 60px;
		border-bottom: none;
		margin-top: 10px;
	}
	.nav_li_menu {
		display: block;
		font-family: 'Ubuntu', sans-serif;
		color: #fff;
		text-align: center;
		font-size: 24px;
		margin-bottom: 8px;
	}
	.nav-mobile {
		display: block;
	}
	nav {
		width: 100%;
		position: absolute;
		display: block;
		margin-top: -12px;
		z-index: 20;
	}
	.nav-list {
		background: #000;
		z-index: 10;
		height: 102vh;
		padding-top: 30px;
	}
	
	
	nav ul {
		display: none;
	}
	
	
	nav ul li {
		display: block;
		margin: 0 auto;
		border-right: 0;
		border: none;
		text-align: left;
		max-width: 250px;
		width: 100%;
	}
	nav ul li a,
	nav ul li a:link,
	nav ul li a:active,
	nav ul li a:visited {
		color: #fff;
	}
	nav ul li a {
		padding: 15px 0 0;
		line-height: 20px;
		font-size: 14px;
		color: #fff;
		height: 48px;
		position: relative;
		border-bottom: 1px solid #fff;
	}
	nav ul li>a::after {
		content: "＞";
		position: absolute;
		right: 3px;
		top: 14px;
		font-size: 12px;
	}
	nav ul li ul li a {
		padding-left: 30px;
	}
	nav ul li::after {
		display: none;
	}
	.nav-dropdown {
		position: static;
	}
	nav ul li:last-child {
		border-right: none;
	}
	nav ul li span {
		display: none;
	}
	nav ul li.nav_blog {
		right: auto;
		top: auto;
		width: 250px;
		height: auto;
		position: relative;
		overflow: hidden;
	}
	.fixed nav ul li.nav_blog {
		top: 0;
		height: 90px;
	}
	nav ul li.nav_blog>span.blog1 a {
		background-color: transparent;
	}
	nav ul li.nav_blog>span.blog1 {
		position: relative;
		width: 125px;
		height: 90px;
		vertical-align: top;
		text-align: center;
		float: left;
		display: block;
	}
	.fixed nav ul li.nav_blog a {
		padding-top: 0;
		height: 100px;
	}
	nav ul li.nav_blog>span.spnomi1100 {
		position: absolute;
		padding: 0;
		margin-top: 0;
	}
	nav ul li.nav_blog a>span.spnomi1100 {
		padding: 0;
	}
	nav ul li.nav_blog>span.spnomi1100 a {
		font-size: 32px;
	}
	nav ul li.nav_blog>span.nav_reserv {
		left: 140px;
		top: 10px;
	}
	nav ul li.nav_blog>span.nav_youtube {
		left: 190px;
		top: 10px;
	}
	nav ul li.nav_blog>span.nav_insta {
		left: 140px;
		top: 60px;
	}
	nav ul li.nav_blog>span.nav_line {
		left: 195px;
		top: 60px;
	}
	nav ul li.nav_blog span {
		display: block;
	}
	nav ul li.nav_blog span.blog1 a {
		border-bottom: none;
		border-right: 1px solid #fff;
		padding-top: 10px;
		margin-top: 5px;
	}
	nav ul li.nav_blog>span.spnomi1100 a {
		border-bottom: none;
		padding-top: 0;
	}
	nav ul li.nav_blog span.blog1 a::after,
	nav ul li.nav_blog>span.spnomi1100 a::after {
		display: none;
	}
	nav ul li.nav_template {
		margin-top: 30px;
		display: flex;
		height: 50px;
		border-bottom: none;
		position: relative;
		justify-content: space-between;
	}
	nav ul li.nav_template>a::after {
		display: none;
	}
	nav ul li.nav_template a {
		border-bottom: none;
		font-size: 30px;
	}
	nav ul li.nav_template a img {
		width: 30px;
	}
}

@media screen and (min-width: 1101px) {
	.nav-list {
		display: block !important;
		height: 70px;
		padding: 7px;
	}
}

#nav-toggle {
	position: absolute;
	left: 20px;
	top: 26px;
	cursor: pointer;
	padding: 10px 35px 16px 0px;
}

.fixed #nav-toggle {
	top: 12px;
	left: 13px;
}

#nav-toggle span,
#nav-toggle span:before,
#nav-toggle span:after {
	cursor: pointer;
	border-radius: 1px;
	height: 3px;
	width: 45px;
	background: #fff;
	position: absolute;
	display: block;
	content: "";
	transition: all 200ms ease-in-out;
}

.fixed #nav-toggle span,
.fixed #nav-toggle span:before,
.fixed #nav-toggle span:after {
	height: 2px;
	width: 35px;
	background: #fff;
	position: absolute;
}

#nav-toggle span:before {
	top: -10px;
}

.fixed #nav-toggle span:before {
	top: -8px;
}

#nav-toggle span:after {
	bottom: -10px;
}

.fixed #nav-toggle span:after {
	bottom: -8px;
}

#nav-toggle.active span {
	background-color: transparent;
}

#nav-toggle.active span:before,
#nav-toggle.active span:after {
	top: 0;
}

#nav-toggle.active span:before {
	transform: rotate(45deg);
}

#nav-toggle.active span:after {
	transform: rotate(-45deg);
}

/* -------------------------------------------------------------/nav */

/*----------------------------------------------------Constitution*/

.pdt {
	padding-top: 15rem;
}

.pdt02 {
	padding-top: 7rem;
}

.cont_100 {
	width: 100%;
	height: auto;
	overflow: hidden;
	position: relative;
}

.cont_small_0_10 {
	width: 100%;
	padding: 0 10px;
	max-width: 1200px;
	overflow: hidden;
	margin: 0 auto;
	position: relative;
}

.cont_small_70_10 {
	width: 100%;
	padding: 70px 10px;
	max-width: 1100px;
	margin: 0 auto;
	position: relative;
}

.tal_c {
	text-align: center;
}

/* -------------------------------------------------------------head,text */

.head01 {
	font-size: 3.2rem;
	display: block;
	padding: 0;
	position: relative;
	text-align: center;
	font-family: a-otf-midashi-go-mb31-pr6n, sans-serif;
	letter-spacing: .2rem;
	line-height: 1.5;
}

.head01.big {
	font-size: 3.8rem;
}

.head01 span {
	display: block;
	font-size: 5rem;
	margin-bottom: 10px;
	font-family: vatican, sans-serif;
	font-weight: 300;
	font-style: normal;
}

.head02 {
	font-size: 14px;
	letter-spacing: 2px;
	padding: 0px 0 40px;
	position: relative;
	font-weight: 600;
	text-indent: 10px;
	text-align: center;
	font-family: 'Ubuntu', sans-serif;
}


.head03{
	font-size: 2.8rem;
	text-align: center;
	font-family: a-otf-midashi-go-mb31-pr6n, sans-serif;
	margin: 30px 0;
}

.head03 a{
	display: block;
	margin-top: 20px;
	font-family: 'Ubuntu', sans-serif;
	font-size: 2.0rem;
}

.res{
	margin: 5rem 0 20px;
}

.mgtext{
	margin-bottom: 30px;
}

.mgthead {
	margin-top: 8rem;
}

.text01 {
	line-height: 1.8;
	text-align: left;
}

@media only screen and (max-width: 760px) {
	.pdt {
	padding-top: 7rem;
}
}

@media only screen and (max-width: 480px) {
	.text01 {
		text-align: left;
	}
	.text01 h4 {
		text-align: center;
		margin-bottom: 20px;
	}
}

/* -------------------------------------------------------------contents */

.for_line {
	width: 100%;
	height: 70px;
	box-sizing: content-box;
}

.lineanime {
	width: 1px;
	height: 70px;
	margin: 0 auto;
	background-color: red;
	animation: line 3s linear 0s infinite;
}

.pd_for_line {
	padding: 40px 0;
}

@keyframes line {
	0% {
		height: 0;
	}
	50% {
		height: 70px;
	}
	100% {
		height: 0px;
	}
}

.box {
	width: 90%;
	margin: 0 auto;
	padding: 7rem 5% 10rem;
}

.box01 {
	position: absolute;
	left: 0;
	top: 0;
	border-left: 2px solid red;
	border-top: 2px solid red;
}

.box02 {
	position: absolute;
	right: 0;
	top: 0;
	border-right: 2px solid red;
	border-top: 2px solid red;
}

.box03 {
	position: absolute;
	right: 0;
	bottom: 0;
	border-right: 2px solid red;
	border-bottom: 2px solid red;
}

.box04 {
	position: absolute;
	left: 0;
	bottom: 0;
	border-left: 2px solid red;
	border-bottom: 2px solid red;
}

.boxeffect {
	opacity: 0;
	height: 500px;
	width: 500px;
	-webkit-transition: all 1.2s;
	-moz-transition: all 1.2s;
	-o-transition: all 1.2s;
	-ms-transition: all 1.2s;
	transition: all 1.2s;
}

.boxeffect-on {
	opacity: 1;
	height: 100px;
	width: 100px;
}

.one_photo {
	margin: 5rem auto 0;
	width: 100%;
	text-align: center;
}

.one_photo img {
	width: 33%;
	display: inline-block;
}

a.btn01 {
	width: 100%;
	display: block;
	margin: 5rem auto 0;
	padding: 15px 0;
	color: #fff;
	background-color: red;
	font-weight: 500;
	text-align: center;
	line-height: 1.8;
}

a.btn01.color02 {
	background-color: #f15a24;
	margin: 3rem auto 0;
}

a.btn01:hover {
	transform: scale(1.05, 1.05);
	box-shadow: 0 5px 10px rgba(0, 0, 0, 0.2);
}

.youtube {
	text-align: center;
	margin-bottom: 30px;
}

.youtube a {
	display: inline-block;
	width: 40%;
	margin: 0 1.5%;
}

.outer_reasens {
	margin: 5rem auto 0;
	width: 100%;
	text-align: center;
}

.box_reasens {
	width: 30%;
	border: 2px solid red;
	text-align: center;
	padding: 30px 10px 0 10px;
	height: 200px;
	display: inline-block;
	line-height: 1.8;
	font-size: 13px;
	vertical-align: top;
	margin: 0 1% 20px;
}

.box_reasens i {
	font-size: 28px;
	color: #c7b299;
}

.box_reasens h3 {
	font-size: 2rem;
	font-weight: 600;
	margin: 1rem 0 1rem;
	font-family: a-otf-midashi-go-mb31-pr6n, sans-serif;
	font-style: normal;
}

.flow {
	display: flex;
	flex-wrap: wrap;
	text-align: left;
	line-height: 1.5;
}

.flow dt {
	width: 200px;
	position: relative;
	padding: 20px 0 20px 0;
	border-top: 1px solid red;
	border-left: 1px solid red;
	border-bottom: 1px solid red;
	font-weight: 600;
	color: red;
	text-align: center;
	align-items: center;
	margin-bottom: 70px;
}

.flow dt span {
	position: absolute;
	left: -1px;
	top: -40px;
	height: 40px;
	color: #fff;
	background-color: red;
	width: 200px;
	font-weight: 600;
	padding: 10px 0 0 0;
	letter-spacing: 1.5px;
	text-align: center;
}

.flow dd {
	width: calc(100% - 200px);
	padding: 20px;
	border-top: 1px solid red;
	border-right: 1px solid red;
	border-bottom: 1px solid red;
	position: relative;
	margin-bottom: 70px;
}

.flow dd::after {
	content: "";
	width: 1px;
	height: 30px;
	position: absolute;
	left: calc(50% - 100px);
	bottom: -50px;
	background-color: red;
}

.flow dd:last-child::after {
	display: none;
}

.flow dd:last-child,
.flow dt:last-child,
.flow dt.mgb20 {
	margin-bottom: 20px;
}

@media only screen and (max-width: 999px) {
	.box {
		width: 96%;
	}
	.box_reasens {
		width: 47%;
	}
}

@media only screen and (max-width: 760px) {
	.box_reasens {
		width: 100%;
		margin: 0 0 20px;
		height: auto;
		padding: 20px 10px;
	}
	.flow dt span {
		width: calc(100% + 2px);
	}
	.flow dt {
		width: 100%;
		border-bottom: none;
		border-right: 1px solid red;
		padding: 20px 0 0 0;
		margin-bottom: 0;
	}
	.flow dt.mgb20 {
		margin-bottom: 0;
	}
	.flow dd {
		width: 100%;
		border-left: 1px solid red;
		border-top: none;
		margin-bottom: 100px;
	}
	.flow dd::after {
		left: 50%;
		height: 20px;
		bottom: -40px;
	}
	.youtube a {
	width: 100%;
	margin: 0 auto 10px;
}
	.one_photo img {
		width: 100%;
		margin-bottom: 10px;
	}
}

@media only screen and (max-width: 480px) {
	
	.boxeffect-on {
		opacity: 1;
		height: 50px;
		width: 50px;
	}
}

/* -------------------------------------------------------------lessons */

.head_lesson {
	font-size: 2.4rem;
	letter-spacing: .18rem;
	padding: 20px 0 20px;
	position: relative;
	font-weight: 500;
	text-indent: 10px;
	text-align: center;
	background-color: red;
	font-family: a-otf-midashi-go-mb31-pr6n, sans-serif;
	color: #fff;
	clear: both;
}

/*.head_lesson::before {
	content: '●';
	position: absolute;
	font-size: 20px;
	top: 50%;
	left: 2%;
	margin-top: -10px;
	color: #fff;
	width: 15%;
	height: 3px;
}

.head_lesson::after {
	content: '●';
	position: absolute;
	font-size: 20px;
	top: 50%;
	right: 2%;
	margin-top: -10px;
	color: #fff;
	width: 15%;
	height: 3px;
}*/

.box_lesson {
	overflow: hidden;
	width: 100%;
	margin: 0 auto 4rem;
	color: #fff;
}

.bg_orange01 {
	background-color: #f15a24;
}

.bg_orange02 {
	background-color: #f7931e;
}

.bg_orange03 {
	background-color: #ef6e26;
}

.box_left {
	width: calc(45% - 0px);
	float: left;
	overflow: hidden;
	position: relative;
	padding: 20px;
}

.box_right {
	width: calc(55% - 0px);
	float: right;
	overflow: hidden;
	position: relative;
	align-items: center;
}

.box_left_float_right {
	width: calc(45% - 0px);
	float: right;
	overflow: hidden;
	position: relative;
	padding: 20px;
}

.box_right_float_left {
	width: calc(55% - 0px);
	float: left;
	overflow: hidden;
	position: relative;
	align-items: center;
}

.box_lesson h5 {
	font-size: 14px;
	text-align: center;
	letter-spacing: 2px;
	margin-bottom: 5px;
	font-weight: 500;
}

.level {
	text-align: center;
}

.level li {
	display: inline-block;
	font-size: 12px;
}

.condi_box {
	margin-top: 15px;
	text-align: center;
}

.condi_box span {
	border: 1px solid #fff;
	padding: 3px 15px;
	margin: 0;
	display: inline-block;
	font-size: 13px;
}

.menu {
	text-align: center;
	margin: 25px 0;
	padding: 20px;
	position: relative;
}

.menu h5 {
	display: inline-block;
	position: relative;
	z-index: 2;
	padding: 0 20px;
	margin-bottom: 10px;
}

.menu::before {
	position: absolute;
	width: 90%;
	height: 1px;
	content: "";
	background: #fff;
	top: 26px;
	left: 5%;
}

.menu li {
	text-align: left;
	font-size: 14px;
	line-height: 1.5;
	list-style: circle;
	list-style-position: outside;
	margin-left: 50px;
}

.menu P {
	line-height: 1.8;
}

.ph_lesson img {
	width: 50%;
	float: left;
	align-items: center;
}

.ph_lesson_omo img {
	width: 100%;
}

a.btn_lesson {
	width: 100%;
	display: block;
	margin: 2rem auto 0;
	padding: 10px 0;
	color: #fff;
	font-weight: 500;
	text-align: center;
	line-height: 1.8;
}

a.mgb10rem,
.mgb10rem {
	margin-bottom: 13rem;
}

a.mgb5rem {
	margin-bottom: 5rem;
}

@media only screen and (max-width: 999px) {
	.box_left,
	.box_left_float_right {
		width: 100%;
		float: none;
		padding: 20px;
	}
	.box_right,
	.box_right_float_left {
		width: 100%;
		float: none;
	}
}

/* -------------------------------------------------------------info */

.box_info {
	width: 100%;
	max-width: 1000px;
	margin: 0 auto;
}

.li_info li {
	width: 100%;
	border-bottom: 1px dotted #E6E6E6;
	position: relative;
	padding: 20px 20px 15px 10px;
	box-sizing: border-box;
	text-align: left;
}

.li_info li:last-child {
	border: none;
}

.li_info li:after {
	content: "";
	position: absolute;
	right: 10px;
	top: 50%;
	font-size: 12px;
	margin-top: -8px;
	width: 40px;
	height: 3px;
	border-bottom: 1px solid red;
	border-right: 2px solid red;
	transform: skew(60deg);
	display: inline-block;
}

.date {
	font-size: 15px;
	margin-right: 10px;
	letter-spacing: 1.5px;
}


.info_title {
	font-weight: 400;
	font-size: 14px;
	line-height: 1.5;
	display: block;
	margin-top: 15px;
	
}

.box_insta {
	width: 100%;
}

@media only screen and (max-width: 999px) {
	.date {
		left: 20px;
		top: 20px;
	}
	.info_title {
		padding: 10px 0 5px 0;
		margin-top: 0;
	}
	
}
@media only screen and (max-width: 760px) {
	.date {
		display: block;
		margin-bottom: 10px;
	}
	
}

/* -------------------------------------------------------------footer */

footer {
	background-color: #000;
	color: #fff;
	overflow: hidden;
	padding-bottom: 20px;
	font-size: 12px;
	line-height: 1.5;
}

.foot_sns {
	margin: 30px auto 50px;
	position: relative;
	display: flex;
	justify-content: space-between;
	width: 80%;
	padding: 0 10px;
}

.box_sns a {
	color: #fff;
}

.box_sns {
	width: 18%;
	height: 150px;
	background-color: red;
	border:1px solid;
	display: inline-block;
	padding-top: 10px;
	text-align: center;
}

.box_sns a h3,
.box_sns h3,
.box_sns {
	font-size: 14px;
	text-align: center;
	letter-spacing: 1px;
	color: #fff;
}

.box_sns img {
	width: 40%;
	height: auto;
	display: block;
	margin: 20px auto 0;
}

.box_sns i {
	font-size: 30px;
	margin-top: 20px;
}

a.tocontact {
	font-size: 12px;
	padding: 15px 0;
	width: 80%;
	border: 1px solid #61959E;
	border-radius: 20px 0 20px 0;
	margin: 20px auto 0;
	display: block;
	color: #3B5D66;
}

.snstel p {
	font-size: 11px;
	padding-top: 5px;
}

.snscontact p {
	font-size: 11px;
	padding-top: 5px;
}

.sns_bottom {
	margin-top: -470px;
	padding-top: 150px;
	height: 230px;
	margin-bottom: 150px;
}

footer a {
	color: #fff;
}

.foot_left {
	padding-top: 30px;
}

.foot_left img {
	max-width: 220px;
	width: 50%;
	margin-bottom: 10px;
	display: block;
	margin: 0 auto;
}

.foot_right {
	font-size: 14px;
	text-align: center;
	padding-top: 40px;
}

.foot_nav a {
	font-size: 12px;
	color: #fff;
	position: relative;
	padding-left: 12px;
	letter-spacing: 1px;
}

.foot_nav a:hover {
	color: yellow;
}

.foot_nav li {
	display: inline-block;
	margin: 0 5px 5px;
	line-height: 1.8;
}

.copy {
	text-align: right;
}

@media only screen and (max-width: 999px) {
	footer {
		text-align: center;
		/*margin-bottom: 50px;*/
	}
	.outer_sns {
		display: none;
	}
	.foot_sns {
		display: none;
	}
	.foot_right {
		padding-top: 20px;
		padding-bottom: 20px;
	}
	.copy {
		text-align: center;
		padding: 0 10px;
		font-size: 9px;
	}
	.common_contact {
		padding: 0 0 0 0;
	}
}

/* --------------------------------------------------contactform*/

.contact_box {
	width: 100%;
	margin: 0 auto;
	max-width: 1000px;
	font-size: 11px;
	text-align: left;
	padding: 0 10% 5%;
	;
}

label {
	margin-bottom: 5px;
	margin-top: 20px;
	display: block;
	font-size: 16px;
}

placeholder {
	color: #ccc;
}

input,
textarea,
select {
	display: block;
	margin: 10px 0 0;
	padding: 20px 20px;
	width: 100%;
	box-sizing: border-box;
	background: #fff;
	border: 1px solid red;
	outline: none;
	font-size: 16px;
	line-height: 1;
	-moz-appearance: none;
	-webkit-appearance: none;
	-o-appearance: none;
	-ms-appearance: none;
	transition: all 0.2s ease;
	-webkit-transition: all 0.2s ease;
	-moz-transition: all 0.2s ease;
	border-radius: 25px;
}

select {
	padding-right: 46px;
	background-image: url(images/ico_arrow.png);
	background-position: right center;
	background-repeat: no-repeat;
	-webkit-background-size: 46px auto;
	background-size: 46px auto;
	position: relative;
}

.contact_box input[type="date"] {
	width: 100%;
	display: inline-block;
}

.f_date {
	float: left;
	display: block;
	width: 45%;
	margin: 0 3% 0 0;
	height: 120px;
}

.f_time {
	float: left;
	display: block;
	width: 47%;
	margin: 0 0 0 3%;
	height: 120px;
}

.f_date input,
.f_time input {
	height: 46px;
}

.f_float {
	clear: both;
	float: none;
	display: block;
}

.n_p {
	display: inline-block;
	margin-left: 5px;
	vertical-align: text-bottom;
}

.required {
	background-color: red;
	color: #fff;
	padding: 2px 8px 4px;
	margin-right: 10px;
	line-height: 13px;
	font-size: 12px;
	letter-spacing: 1px;
}

.norequired {
	background-color: #000;
	color: #fff;
	padding: 2px 8px 4px;
	margin-right: 10px;
	line-height: 13px;
	font-size: 9px;
	letter-spacing: 1px;
}

textarea {
	width: 100%;
}

.contact_box input[type="submit"] {
	color: #fff;
	background-color: red;
	display: block;
	padding: 20px 0;
	width: 100%;
	margin: 5rem auto 0;
	font-size: 14px;
	letter-spacing: 2px;
	transition: 1s;
	font-weight: bold;
	clear: both;
}

.contact_box input[type="submit"]:hover {
	opacity: .7;
}

.contact_box input[type="submit"]:active {
	-webkit-transform: translateY(2px);
	transform: translateY(2px);
	/*沈むように*/
	box-shadow: 0 0 1px rgba(0, 0, 0, 0.15);
}

.thanks_outer {
	font-size: 13px;
	color: #222;
	text-align: center;
	line-height: 2.0;
	margin: 0 0 50px;
}

/* エラーメッセージの上部を消去 */

div.screen-reader-response {
	display: none;
}

/* 送信NG時の枠の色  */

div.wpcf7-validation-errors,
div.wpcf7-acceptance-missing {
	border: 1px solid #F78181;
	margin: 0 auto;
	text-align: center;
	display: block;
	padding: 5px;
	width: 400px;
}

input[type="checkbox"] {
	width: 30px;
	height: 30px;
	appearance: checkbox;
	display: inline-block;
	margin-right: 10px;
	float: left;
}

.checkbox p {
	display: inline-block;
	font-size: 12px;
	vertical-align: top;
	margin-top: 15px;
	line-height: 1.5;
	float: left;
}

.checkbox {
	width: 100%;
	max-width: 500px;
	margin: 0 auto;
	text-align: left;
	overflow: hidden;
}

.check {
	text-align: center;
}

.check li {
	display: inline-block;
	margin: 30px;
}

.check li a {
	font-size: 14px;
	text-decoration: underline;
	color: dodgerblue;
	display: inline-block;
}

table.tbl-contact tr td {
    border: 1px solid #000;
    padding: 10px;
    /* width: 100%; */
}

table.tbl-contact {
    width: 100%;
}

table.tbl-contact tr td:first-child {
    background-color: #000;
    color: #fff;
    font-weight: bold;
}

.foot_left a img {
    filter: invert(1);
}

p.footer-txt {
    text-align: center;
    margin: 30px;
    line-height: 1.8em;
    font-size: 14px;
}

@media only screen and (max-width: 999px) {
	.contact_box {
		padding: 0 0 5%;
	}
	.contact_box input[type="submit"],
	input.form_submit02 {
		padding: 20px 0;
		width: 80%;
	}
}

@media only screen and (max-width: 480px) {
	.checkbox p {
		margin-top: 5px;
	}
}

.icon_category a {
    border: 1px solid red;
    color: red;
}

.mgt-30 {
	margin-top: 30px;
}

table#wp-calendar caption {
    text-align: left;
    margin: 0 0 10px;
}

.ezenglish-cont {
    display: flex;
    width: 100%;
    margin: 20px 0;
}

.ezenglish-cont-reasons {
    display: flex;
    width: 100%;
    margin: 20px 0;
    flex-wrap: wrap;
}

.achievement-tbl {
    width: 50%;
    margin: 20px auto 0 auto;
}

.achievement-tbl tr td {
    border: 1px solid red;
    padding: 20px;
    /* width: 100%; */
}

ul.achievement-list {
    width: 50%;
    margin: 0 auto;
}

.achievement-tbl tr:nth-child(2n-1) {
	background-color: #d7e5ff;
}

.achievement-tbl tr:nth-child(2n) {
	background-color: #fff;
}

ul.achievement-list li::before {
    content: '\f14a';
    margin: 0 10px 0 0;
    font-size: 20px;
    vertical-align: middle;
    font-family: "Font Awesome 5 Free";
}

ul.achievement-list1 {
    display: flex;
    flex-wrap: wrap;
}

ul.achievement-list1 li {
    margin: 0 10px 10px 0;
    list-style: none;
    padding: 5px 10px;
    width: calc(100% / 2 - 10px);
}

ul.achievement-list1 li::before {
    content: '\f14a';
    margin: 0 10px 0 0;
    font-size: 20px;
    vertical-align: middle;
    font-family: "Font Awesome 5 Free";
}

.ezenglish-reasons {
    width: calc(100% / 2 - 30px);
    margin: 15px;
    border: 2px solid red;
    padding: 20px;
    text-align: center;
}

.ezenglish-reasons span {
    font-size: 16px;
    font-weight: bold;
    color: red;
}

.ezenglish-reasons-title {
    font-weight: bold;
    margin: 10px 0;
}

.sect-hdr {
    position: relative;
    padding: 40px 0;
    margin: 0 0 30px;
}

.sect-hdr h2, .sect-hdr h3 {
    position: relative;
    z-index: 1;
}

.sect-hdr img {
    position: absolute;
    top: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.95) contrast(0.9) opacity(0.8);
}

.sect-hdr-txt {
    background: #FFF3;
    position: relative;
    padding: 0 0 10px;
}

/*.sect-hdr h2 {
    text-shadow: 1px 1px #fff, -1px -1px #fff, -1px 1px #fff, 1px -1px #fff;
    padding: 0;
}*/

.sect-hdr-jp {
    text-shadow: 1px 1px #fff, -1px -1px #fff, -1px 1px #fff, 1px -1px #fff;
    padding: 0;
}

/*.sect-hdr h3 {
    color: #FFF;
    text-shadow: 1px 1px red, -1px -1px red, -1px 1px red, 1px -1px red;
    padding: 0;
}*/

.sect-hdr-english {
    color: #FFF;
    text-shadow: 1px 1px #000, -1px -1px #000, -1px 1px #000, 1px -1px #000;
    padding: 0;
}

.fees-tbl {
    width: 100%;
    margin: 20px 0;
}

.fees-tbl tr td {
    border: 1px solid red;
    padding: 20px;
}

.fees-tbl tr:nth-child(2n-1) {
	background-color: #d7e5ff;
}

.fees-tbl tr:nth-child(2n) {
	background-color: #fff;
}

.lesson-tbl {
    width: 100%;
    margin: 20px 0;
}

.lesson-tbl tr th {
    border: 1px solid red;
    padding: 20px;
    vertical-align: middle;
    text-align: center;
}

.lesson-tbl tr td {
	border: 1px solid red;
	padding: 20px;
}

.sh-ez1 {
    font-weight: bold;
}

.features-flow {
    position: relative;
    background: #fff;
    border: 1px solid red;
    margin: 0 0 60px;
    padding: 15px;
}

.features-flow::after {
    content: "\f0ab";
    font-family: 'Font Awesome 5 Free';
    position: absolute;
    bottom: -65px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 40px;
    color: red;
    font-weight: 900;
}

.features-flows .features-flow:last-child {
    margin: 0;
}
.features-flows .no-arrow.features-flow::after {
    content: unset;
}

.ez-steps {
    counter-reset: ezstep;
}

.ez-step {
    counter-increment: ezstep;
    text-align: center;
}

.ez-step::before {
    content: "STEP 0"counter(ezstep);
    background-color: red;
    text-align: center;
    width: 200px;
    display: block;
    color: #FFF;
    padding: 12px 0;
    font-weight: bold;
}

.ez-step-cont {
    padding: 20px;
    border: 1px solid red;
    text-align: left;
}

.ez-step::after {
    content: "";
    display: block;
    width: 1px;
    height: 35px;
    background-color: red;
    margin: 20px auto 0;
}

.ez-steps .no-arrow.ez-step::after {
    content: unset;
}

.pdb-contact {
	padding-bottom: 15rem;
}

#n05 .sect-hdr img {
    object-position: center -94px;
}

.contact-box {
    border: 2px solid red;
    width: 80%;
    padding: 20px;
    margin: 0 auto 20px auto;
}

.contact-box-1 {
    width: 80%;
    padding: 20px;
    margin: 0 auto 20px auto;
    text-align: center;
}

a.ez-hover:hover {
    color: red;
}

.bg-blue {
	background-color: #d7e5ff;
}

.first-pdf {
	width: 98%;
	margin-top: 8px;
}

.achievement-tbl-txt {
    margin: 0 auto;
    width: 50%;
}

.uppercase-word {
    text-transform: uppercase;
    color: #000!important;
    font-weight: normal!important;
}

.mgb-20 {
	margin-bottom: 20px;
}

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

.uppercase-word-menu {
	text-transform: uppercase;
}

nav.wp-calendar-nav {
    width: auto;
    position: unset;
    margin: 20px 0 0;
    z-index: unset;
}

li.cat-item.cat-item-2 {
    margin: 0 0 10px 0;
}

.pdf-first-img {
	width: 100%;
	height: calc(100% - 2px);
	margin: 0;
	object-fit: cover;
}

.pdf-img-cont {
    justify-content: space-between;
}

.pdf-img-cont .ezenglish-cont-50 {
    width: calc(50% - 10px);
}

.mgt-30 {
	margin-top: 30px;
}

.business-img-txt_cont {
    display: flex;
    width: 100%;
}

.text01.business-img-txt_cont--txt {
    margin: 0 0 0 70px;
}

.business-img-txt_cont--img img {
    object-fit: cover;
    height: 450px;
}

.mgt-40 {
	margin-top: 40px;
}

.section1-img-txt_cont {
	display: flex;
    width: 100%;
}

.text01.section1-img-txt_cont--txt {
    margin: 0 0 0 20px;
}

.section1-img-txt_cont--img {
	flex: 50%;
}

.section1-img-txt_cont--txt {
	flex: 50%;
}

.section1-img-txt_cont--img img {
    height: 450px;
    object-fit: cover;
}

.sns {
    width: 20px;
}

.sns-top {
    border-left: none;
}

.sns-top a {
    display: inline-block;
    border-left: none;
}

.sns-top i {
    width: 32px;
    height: auto;
    display: inline-block;
/*    padding: 0px 5px 0;*/
/*    vertical-align: middle;*/
    font-size: 38px;
}

.sns i {
    width: 20px;
    height: auto;
}

.sns-top img {
    width: 33px;
    height: auto;
    display: inline-block;
/*    padding: 0px 5px 0;*/
/*    vertical-align: middle;*/
    font-size: 30px;
}

.sns img {
    width: 20px;
    height: auto;
}

i.fab.fa-facebook-square {
    color: #3b5998;
}

i.fab.fa-instagram {
	background: #d6249f;
 	background: radial-gradient(circle at 30% 107%, #fdf497 0%, #fdf497 5%, #fd5949 45%,#d6249f 60%,#285AEB 90%);
    height: 38px;
    border-radius: 10px;
    color: #fff;
    color: transparent;
    background-clip: text;
    -webkit-background-clip: text;

}

.dt-rec_cards {
	margin: 20px 0;
}

.dt-rec_cards_cont {
	display: flex;
}

.dt-rec_card-img {
	width: calc(30% - 40px);
	margin: 0 20px 0 0;
	text-align: center;
	background-color: #EEE;
    border-radius: 20px;
}
.dt-rec_card-txt {
    border: 1px solid #CCC;
    border-radius: 10px;
    padding: 20px;
    box-shadow: 0 0 10px #AAA8;
    width: 70%;
    line-height: 1.8em;
    order: 1;
}

.dt_rec_cards_cont {
    display: flex;
}

.dt-rec_card-img-right {
    width: calc(30% - 40px);
    margin: 0 0 0 20px;
    text-align: center;
    background-color: #EEE;
    border-radius: 20px;
    order: 2;
}

.dt-rec_card-img img,
.dt-rec_card-img-right img {
    height: 100%;
    width: 100%;
    object-fit: contain;
    margin: 0 auto;
    object-position: center;
    max-width: 200px;
}

b {
	font-weight: bold;
}

.dt-bsns-2imgov-cont {
    position: relative;
    width: 100%;
    height: auto;
    letter-spacing: -4px;
}

.dt-bsns-2imgov-img {
    display: inline-block;
    width: 50%;
    margin: 0;
    padding: 0;
    border: unset;
}

.dt-bsns-2imgov-txt {
    letter-spacing: initial;
    position: absolute;
    background-color: #FFFFFFE0;
    padding: 20px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    line-height: 1.8;
}

table.dt-rec_job-details tr td {
    border: 1px solid;
    padding: 10px;
    line-height: 1.8em;
}

table.dt-rec_job-details {
    width: 100%;
    margin: 20px 0;
}

table.dt-rec_job-details tr td:first-child {
    background-color: #000;
    color: #fff;
    font-weight: bold;
    border: 1px solid #000;
    width: 20%;
}

.mgb-40 {
	margin-bottom: 40px;
}

ul.bussiness-list li {
    list-style: disc;
}

ul.bussiness-list {
    padding-left: 20px;
}

.recruitment-images {
    display: flex;
    width: 100%;
	margin: 30px 0;
}

.recruitment-image {
    width: calc(100% - 40px);
    margin: 10px;
}

.recruitment-image:first-child {
    margin: 10px 0 10px 0;
}

.recruitment-image:last-child {
    margin: 10px 0 10px 0;
}

.recruitment-image img {
    width: 300px;
    height: 400px;
}

.recruitment-images-2 {
    display: flex;
    width: 100%;
    justify-content: center;
}

.recruitment-image-2 img {
    width: 300px;
    height: 400px;
}

.recruitment-image-2 img:first-child {
    margin: 0 10px 0 0;
}
  

@media only screen and (max-width: 1100px) {
	.nav-container {
		height: 60px;
	}
}

@media only screen and (max-width: 767px) {
	
	.recruitment-images {
		display: block;
	}
	
	.recruitment-image {
		width: 100%;
		margin: 0;
	}
	
	.recruitment-image img {
		width: 100%;
		height: auto;
	}
	
	.recruitment-images-2 {
		display: block;
	}
	
	.recruitment-image-2 img {
		width: 100%;
	}
	
	.recruitment-images {
		margin: unset;
	}
	
	.recruitment-image-2 img:first-child {
		margin: 0 0px 10px 0;
	}

	.dt-bsns-2imgov-txt {
	    width: 90%;
	}

	.dt-bsns-2imgov-img {
	    width: 100%; 
	}

	.sns-top {
		display: none;
	}

	.section1-img-txt_cont {
		display: block;
	}

	.text01.section1-img-txt_cont--txt {
	    margin: 20px 0 0 0;
	}

	.tbl-contact,
	.tbl-contact tbody,
	.tbl-contact tr,
	.tbl-contact tr td {
	    display: block;
	    width: 100%;
	}

	table.tbl-contact tr td {
	    border: unset;
	}

	table.tbl-contact tr {
	    border: 2px solid #000;
	    margin: 0 0 20px;
	}

	.dt-rec_job-details,
	.dt-rec_job-details tbody,
	.dt-rec_job-details tr,
	.dt-rec_job-details tr td {
		display: block;
	    width: 100%;
	}

	table.dt-rec_job-details tr td {
	    border: unset;
	}

	table.dt-rec_job-details tr {
	    border: 2px solid #000;
	    margin: 0 0 20px;
	}

	table.dt-rec_job-details tr td:first-child {
	    width: 100%;
	}

	.text01.business-img-txt_cont--txt {
	    margin: 20px 0;
	}

	.business-img-txt_cont {
	    display: block;
	}

	.pdf-img-cont .ezenglish-cont-50 {
	    width: 100%;
	    margin-bottom: 20px;
	}

	.mgb-20-sp {
		margin-bottom: 20px;
	}

	.achievement-tbl-txt {
	    width: 100%;
	}

	ul.achievement-list {
	    width: 100%;
	}

	.achievement-tbl {
	    width: 100%;
	}

	.slide-img img {
		width: 100%;
		height: auto;
		margin-left: 0;
		overflow: hidden;
		object-fit: contain;
	}

	#logo{
		width: 190px!important;
		padding-top: 0;
	}

	#logo img {
	    width: 170px;
	}

	.ezenglish-cont {
	    display: block;
	}

	.ezenglish-cont-50 {
	    width: 100%;
	}

	.ezenglish-reasons {
	    width: 100%; 
	}

	.achievement-tbl tr td {
	    display: block;
	    padding: 10px 15px;
	    background-color: #d7e5ff;
	    border: unset;
	}

	.achievement-tbl tr td:first-child {
	    background-color: red;
    	color: #fff;
	}

	.achievement-tbl tr {
	    display: block;
	    margin: 0 0 20px;
	    border: 1px solid red;
	}

	.fees-tbl tr td {
	    display: block;
	    padding: 10px 15px;
	    background-color: #f0f8ff;
	    border: unset;
	}

	.fees-tbl tr td:first-child {
	    background-color: red;
    	color: #fff;
	}

	.fees-tbl tr {
	    display: block;
	    margin: 0 0 20px;
	    border: 1px solid red;
	}

	.bg-blue {
		background-color: unset;
	}

	.lesson-tbl tr {
	    display: block;
	    background-color: red;
	    padding: 0 0 5px;
	}

	.lesson-tbl tr td {
	    display: block;
	    padding: 10px 15px;
	    margin: 0 5px;
	    background-color: #d7e5ff;
	}

	.lesson-tbl tr th {
	    display: block;
	    color: #FFF;
	    margin: 20px 0 0 !important;
	}

	.lesson-tbl tr td:last-child {
	    background-color:#f0f8ff;
	}

	#n05 .sect-hdr img {
	    object-position: center -20px;
	}

	.contact-box {
	    width: 100%;
	    margin: 20px auto 20px auto;
	}

	.dt-rec_card-img, .dt-rec_card-img-right {
	    float: right;
	    border-radius: 50%;
	    width: 25vw;
	    height: 25vw;
	    margin: 20px 20px 10px;
	    padding: 15px;
	}
	.dt-rec_card-txt {
	    width: 100%;
	}

	.dt_rec_cards_cont {
	    display: unset;
	}
}

.business-img-section1 {
  overflow: hidden;
  position: relative;
  margin: 20px 0;
  padding: 40px 20px;
}

.business-img-section1-img {
  opacity: 0.5;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -1;
  filter: contrast(0.5);
}

.business-img-section1-txt {
  position: relative;
}

