@charset "UTF-8";
/* --------------------------------------------------
Base
-------------------------------------------------- */

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap');

@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;700;900&display=swap');

@import url('https://fonts.googleapis.com/earlyaccess/notosansjapanese.css');


body, ol, ul, dl, li, dt, dd, table, th, td, input, textarea, select, h1, h2, h3, h4, h5, h6 {
	color: #373737;
	font-family: "Noto Sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
	font-weight: 500;
	letter-spacing: -0.04em;
	margin: 0;
	padding: 0;
	-webkit-text-size-adjust: 100%;
}

.font-style-01 {
	font-family: "Noto Serif JP", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "Times New Roman", serif;
}

.font-style-02 {
	font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", 'Noto Sans Japanese', Verdana, Roboto, "Droid Sans", "游ゴシック", YuGothic, "メイリオ", Meiryo, sans-serif;
}

html, body {
	overflow-x: hidden;
}

html {
	scroll-behavior: smooth;
}

body {
	min-width: 320px;
	line-height: 2;
	font-size: 100%;
	color: #1d1d1f;
	word-break: break-all;
	position: relative;
	overflow-x: hidden;
}

@keyframes pageLoad {
	0% {
			opacity: 0;
	}
	100% {
			opacity: 1;
	}
}

@media screen and (max-width: 1000px) {
	body {
		font-size: 90%;
	}
}

@media screen and (max-width: 767px) {
	body {
			line-height: 1.8;
	}
}

img {
	max-width: 100%;
	vertical-align: middle;
}

input {
	padding: 5px 8px;
}

::placeholder {
  color: #d2d2d0;
  opacity: 1;
}
textarea {
	padding: 3px;
}

ul {
	list-style: none;
}

ol {
	margin: 0px 0px 0px 21px;
}

ol>li {
	list-style: decimal outside;
	margin: 0px 0px 3%;
}

a {
	color: #252525;
	text-decoration: underline;
	outline: 0;
}

a:hover, a:active {
	color: #252525;
	text-decoration: none;
}


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

em {
	font-style: normal;
	font-weight: bold;
}

strong {
	font-style: normal;
	font-weight: bold;
}

/* --------------------------------------------------
Wrapper
-------------------------------------------------- */

#wrapper {
	width: 100%;
	position: relative;
	box-sizing: border-box;
}

/* --------------------------------------------------
drw-nav-btn
-------------------------------------------------- */

#drw-nav-trigger {
	display: none;
}

.drw-nav-btn {
	position: fixed;
	top: 0;
	right: 0;
	/* right: 10px; */
	display: none;
	width: 50px;
	height: 50px;
	text-align: center;
	cursor: pointer;
	background-color: #fff;
	z-index: 998;
	border-bottom-left-radius: 10px;
	border-top-left-radius: 10px;
	transition: all 0.4s;
}

#drw-nav-trigger:checked~.drw-nav-btn {
	width: 44px;
	height: 44px;
}

.drw-line {
	position: relative;
	/* width: calc(100% - 5px); */
	width: 100%;
	height: calc(100% - 25px);
}

.drw-nav-btn-bar {
	position: absolute;
	top: 0;
	right: 0;
	display: block;
	width: 26px;
	height: 1px;
	background: #1a5b27;
	border: 1px solid rgba(255,255,255,0.2);
	border-radius: 2px;
	transition: all 0.4s;
	transform-origin: left top;
	margin: 0 auto;
}

#drw-nav-trigger:checked~.drw-nav-btn .drw-nav-btn-bar {
	box-shadow: none;
}

.drw-nav-btn-bar.top {
	top: 0px;
	left: 5px;
	right: 5px;
}

.drw-nav-btn-bar.middle {
	top: 8px;
	left: 5px;
	right: 5px;
	opacity: 1;
}

.drw-nav-btn-bar.bottom {
	top: 16px;
	left: 5px;
	right: 5px;
	transform-origin: left bottom;
}

#drw-nav-trigger:checked~.drw-nav-btn .drw-nav-btn-text {
	line-height: 5px;
	opacity: 0;
}

#drw-nav-trigger:checked~.drw-nav-btn .drw-nav-btn-bar.top {
	width: 26px;
	left: 14px;
	transform: rotate(45deg);
}

#drw-nav-trigger:checked~.drw-nav-btn .drw-nav-btn-bar.middle {
	opacity: 0;
}

#drw-nav-trigger:checked~.drw-nav-btn .drw-nav-btn-bar.bottom {
	width: 26px;
	left: 14px;
	top: 19px;
	transform: rotate(-45deg);
}

#drw-nav-trigger:checked~.drw-nav-btn .drw-nav-btn-bar {
	background: #1a5b27;
}

.drw-nav-btn-text {
	margin: auto;
	transition: all 0.3s;
	display: block;
	visibility: visible;
	line-height: 20px;
	font-size: 50%;
	font-weight: bold;
	letter-spacing: -0.04em;
	color: #1a5b27;
	opacity: 1;
	/* padding-right: 5px; */
	margin-top: 5px;
}

/* #drw-nav-trigger:checked~.drw-nav-btn .drw-nav-btn-text {
	visibility: hidden;
	opacity: 0;
} */

.drw-nav-close {
	position: fixed;
	top: 0;
	right: 0;
	width: 100%;
	height: 100vh;
	background: #000;
	transition: all 0.4s;
	visibility: hidden;
	opacity: 0;
}

#drw-nav-trigger:checked~.drw-nav-close {
	transition: all 0.4s 0.3s;
	background: rgba(0, 0, 0, 0.6);
	visibility: visible;
	opacity: 1;
	z-index: 993;
	box-shadow: -1px 0px 3px rgba(0, 0, 0, 0.35);
}

#drw-nav {
	box-sizing: border-box;
	position: fixed;
	top: 0;
	right: 0;
	width: 300px;
	height: 100%;
	background: #fff;
	transition: all 0.4s;
	opacity: 0;
	overflow: hidden;
	transform-origin: left center;
	transform: translateX(300px);
	z-index: 993;
}

#drw-nav-trigger:checked~#drw-nav {
	transition-delay: 0.3s;
	transform: none;
	opacity: 1;
	z-index: 999;
}

#drw-nav-trigger:checked~.drw-nav-btn {
	transition-delay: 0.3s;
	/* transform: translateX(-300px); */
}

.drw-nav-inner {
	background-color: #fff;
	box-sizing: border-box;
	width: 100%;
	min-width: 300px;
	height: 100%;
	overflow-x: hidden;
	overflow-y: auto;
	padding-bottom: 40px;
}

#drw-nav .sub-logo {
	max-width: 180px;
	text-align: center;
	margin: 30px auto 0;
	padding: 0 20px;
	position: relative;
	box-sizing: border-box;
}

#drw-nav .logo {
	max-width: 240px;
	text-align: center;
	margin: 40px auto 30px;
	padding: 0 20px;
	position: relative;
	box-sizing: border-box;
}

#drw-nav .sub-logo {
	max-width: 300px;
	text-align: center;
	margin: -10px auto 30px;
	padding: 0 20px;
	position: relative;
	box-sizing: border-box;
}

#sub.sub-house #drw-nav .logo,
#recruit.sub-house #drw-nav .logo {
	max-width: 180px;
	margin: 10px auto 0;
}

#sub.sub-house #drw-nav .toggle-main-nav,
#recruit.sub-house #drw-nav .toggle-main-nav {
	margin-bottom: 30px;
}

#sub.sub-house #drw-nav .sub-ttl,
#recruit.sub-house #drw-nav .sub-ttl {
	position: relative;
	text-align: center;
	font-size: 80%;
	font-weight: 500;
	background-color: rgb(219, 254, 221);
	padding: 8px 5px 12px;
}

#sub.sub-house #drw-nav .sub-ttl::after,
#recruit.sub-house #drw-nav .sub-ttl::after {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 3px;
	font-family: "Font Awesome 5 Free";
	content: '\f106';
	font-weight: 900;
	font-size: 14px;
	line-height: 1;
	transform: rotate(180deg);
	transition: 300ms all ease-in-out;
	margin: 0 auto;
}

#sub.sub-house #drw-nav .sub-ttl.onclick::after,
#recruit.sub-house #drw-nav .sub-ttl.onclick::after {
	transform: rotate(0);
}

#drw-nav .g-nav {
	margin: 20px auto 30px;
	position: relative;
	background-color: #fff;
}

#drw-nav .g-nav li {
	position: relative;
	line-height: 1.8;
	color: #000;
	border-bottom: 1px solid #eee;
	font-size: 14px;
	font-weight: 400;
	margin-bottom: 0;
}

#drw-nav .g-nav li:nth-child(1) {
	border-top: 1px solid #eee;
}

#drw-nav .g-nav li a {
	color: #000;
	font-size: 14px;
	font-weight: 400;
	text-decoration: none;
	display: block;
	position: relative;
}

#drw-nav .g-nav li > a,
#drw-nav .g-nav li > .ttl {
	position: relative;
	display: block;
	padding: 12px 20px 13px;
}

#drw-nav .g-nav li > a::before,
#drw-nav .g-nav li.accordion > .ttl::before {
	font-family: "Font Awesome 5 Free";
	content: '\f105';
	font-weight: 900;
	font-size: 14px;
	margin: auto 0;
	display: flex;
	align-items: center;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 15px;
}

/* #drw-nav .g-nav li > a::after, */
/* #drw-nav .g-nav li.accordion > .ttl::after {
	content: "";
	background-color: #D8D8D8;
	width: 100%;
	height: 1px;
	position: absolute;
	bottom: 0;
	left: 0;
} */

#drw-nav .g-nav li.accordion > .ttl::before {
	content: '\f107';
}

#drw-nav .g-nav li.accordion > .ttl.onclick::before {
	content: '\f106';
}

#drw-nav .g-nav li.accordion > .accord-content {
	background-color: #f1f7f4;
}

#drw-nav .g-nav li.accordion > .accord-content li {
	border-color: rgba(211, 231, 221, 1);
}

#drw-nav .g-nav li.accordion > .accord-content li.main > a,
#drw-nav .g-nav li > a::before {
	color: #1a5b27;
}

#drw-nav .g-nav li.accordion > .accord-content li.main > a {
	font-weight: 600;
}

#drw-nav .g-nav li.accordion > .accord-content li > a::after {
	background-color: #000;
}

#drw-nav .g-nav li.accordion > .accord-content li:nth-last-child(1) > a::after {
	display: none;
}

#drw-nav .g-nav li .txt  {
	position: relative;
	display: inline-block;
	background-position: left center;
	background-repeat: no-repeat;
	background-size: auto 32px;
	text-decoration: none;
	line-height: 1.6;
	font-size: 120%;
	font-weight: 400;
	letter-spacing: 1px;
	padding: 0 5px 0 40px;
}

#drw-nav .access {
	margin-bottom: 20px;
}

#drw-nav .access .tel-blc {
	text-align: center;
}

#drw-nav .access .tel-blc {
	font-size: 120%;
}

#drw-nav .access .tel-blc > .tel {
	margin-bottom: 15px;
}

#drw-nav .access .tel-blc > .tel::before {
	display: inline-block;
	width: 25px;
	height: 35px;
	content: '';
	background: url('../img/common/tel.png') no-repeat left center;
	background-size: contain;
	padding-right: 5px;
	transform: translateY(8px);
}

#drw-nav .access .tel > a {
	line-height: 1;
	text-decoration: none;
	font-size: 180%;
	font-weight: bold;
}

#drw-nav .access .btn > a {
	text-decoration: none;
	font-size: 90%;
	color: #fff;
	background-color: #1a5b27;
	padding: 10px 20px;
	font-weight: lighter;
}

.drw-close-blc {
	display: none;
	width: 100%;
	box-sizing: border-box;
}

.drw-close-blc .drw-close-btn {
	position: relative;
	display: block;
	width: 100%;
	text-align: center;
	color: #fff;
	padding: 10px 20px;
	box-sizing: border-box;
}

.drw-close-blc .drw-close-btn .txt {
	position: relative;
	display: inline-block;
	padding: 0 10px 0 15px;
}

.drw-close-blc .drw-close-btn .txt::before {
	font-family: "Font Awesome 5 Free";
	content: '\f00d';
	font-weight: 900;
	font-size: 17px;
	margin: auto 0;
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
}

#drw-nav .recruit-btn,
#drw-nav .home-btn {
	text-align: center;
	margin-bottom: 30px;
	padding-top: 10px;
}

#drw-nav .recruit-btn > a,
#drw-nav .home-btn > a {
	position: relative;
	text-decoration: none;
	font-size: 120%;
	color: #fff;
	display: inline-block;
	background-color: #1a5b27;
	border: 1px solid #1a5b27;
	font-weight: lighter;
	white-space: nowrap;
	padding: 10px 20px 10px 75px;
	transition: 300ms all ease-in-out;
}

#drw-nav .home-btn > a {
	padding: 10px 20px 10px 20px;
}

#drw-nav .recruit-btn > a::after {
	position: absolute;
	left: 10px;
	bottom: -1px;
	display: block;
	content: '';
	width: 60px;
	height: calc(100% + 15px);
	background-image: url('../img/common/btn_bg_01.png');
	background-position: bottom left;
	background-repeat: no-repeat;
	background-size: contain;
}

#drw-nav .recruit-btn > a:hover,
#drw-nav .home-btn > a:hover {
	color: #1a5b27;
	background-color: #fff;
}


@media screen and (min-width: 1201px) {
	#drw-nav {
		display: none;
		opacity: 1;
		transform: translateX(0px);
	}
	.drw-nav-close {
		display: none;
	}
}

@media screen and (max-width: 1200px) {
	#drw-nav {
		display: flex;
	}
	.drw-nav-btn {
		display: block;
	}
	#drw-nav-trigger:checked ~ .drw-nav-btn {
		display: none;
	}
	.drw-close-blc {
		position: absolute;
		right: 0;
		display: inline-block;
		width: 50px;
		height: 50px;
		text-align: center;
		cursor: pointer;
		border-bottom-left-radius: 10px;
		border-top-left-radius: 10px;
		transition: all 0.4s;
		z-index: 999999;
	}
	.drw-close-blc .drw-close-btn {
		display: none;
	}
	.drw-close-blc::before,
	.drw-close-blc::after {
		position: absolute;
		content: '';
		display: block;
		height: 1px;
		background: #1a5b27;
		border: 1px solid rgba(255,255,255,0.2);
		border-radius: 2px;
		transition: all 0.4s;
		transform-origin: left top;
		margin: 0 auto;
	}
	.drw-close-blc::before {
		width: 26px;
		top: 35px;
		left: 12px;
		transform: rotate(-45deg);
		margin: auto;
	}
	.drw-close-blc::after {
		width: 26px;
		top: 15px;
		left: 15px;
		transform: rotate(45deg);
		margin: auto;
	}
}

@media screen and (max-width: 380px) {
	.drw-nav-btn {
		display: block;
	}
}

/* --------------------------------------------------
Header
-------------------------------------------------- */

#header {
	position: relative;
	top: 0;
	left: 0;
	width: 100%;
	min-width: 320px;
	text-align: center;
	display: flex;
	justify-content: center;
	background-color: #fff;
	padding: 15px 2%;
	margin: 0 auto;
	z-index: 992;
	box-sizing: border-box;
	transition: 500ms all ease-in-out;
}

#header.fixed {
	position: fixed;
	z-index: 992;
	box-shadow: 3px 0 3px rgba(0, 0, 0, 0.35);
}

#header > .inner {
	display: flex;
	justify-content: space-between;
	width: 1400px;
	padding: 0 5px;
}

#header > .inner > .top-bar {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	max-width: 280px;
}

#recruit #header > .inner > .top-bar {
	max-width: 440px;
}

#header > .inner > .top-bar > .logo {
	margin-right: 20px;
}

#header .nav-bar {
	position: static;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	width: calc(100% - 300px);
}

#recruit #header .nav-bar {
	width: calc(100% - 700px);
}

#header .nav-bar #g-nav {
	position: static;
	width: 100%;
	height: 100%;
	max-width: 700px;
	text-align: center;
	display: flex;
	justify-content: space-between;
	align-items: center;
	transition: all 200ms ease-in-out;
	letter-spacing: -0.4em;
}

#header .nav-bar #g-nav > li {
	position: static;
	height: 100%;
	display: flex;
	align-items: center;
	text-align: center;
	letter-spacing: normal;
	margin-right: 2%;
}

#header .nav-bar #g-nav > li:nth-last-child(1) {
	margin-right: 0;
}

#header .nav-bar #g-nav > li > a {
	position: relative;
	text-decoration: none;
}

#header .nav-bar #g-nav > li.sub-nav > .txt {
	position: relative;
	cursor: pointer;
}

#header .nav-bar #g-nav > li > a::after,
#header .nav-bar #g-nav > li.sub-nav > .txt::after {
	position: absolute;
	left: 0;
	bottom: -15px;
	content: '';
	width: 0%;
	height: 3px;
	background-color: #1a5b27;
	transition: 300ms all ease-in-out;
}

#header .nav-bar #g-nav > li > a:hover::after,
#header .nav-bar #g-nav > li.sub-nav:hover > .txt::after {
	width: 100%;
}

#header .nav-bar #g-nav > li.active > a::after {
	width: 100%;
}

#header .nav-bar #g-nav > li > a,
#header .nav-bar #g-nav > li.sub-nav > .txt {
	display: flex;
	align-items: center;
	height: 100%;
}

#header .nav-bar #g-nav > li.sub-nav .sub-nav-area {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	width: auto;
	margin: 0 auto;
	transform: translateY(-100%);
	z-index: -1;
	opacity: 0;
	visibility: hidden;
	transition: all 300ms ease-in-out;
	animation: subOut .3s;
}

/* #header .nav-bar #g-nav > li.sub-nav:hover .sub-nav-area {
	transform: translateY(-25px);
	z-index: -1;
	opacity: 1;
	visibility: visible;
} */

#header .nav-bar #g-nav > li.sub-nav:hover .sub-nav-area {
	animation: subHover .3s;
	animation-fill-mode: forwards;
	padding-top: 15px;
}

@keyframes subHover {
  0% {
    transform: translateY(-100%);
		opacity: 0;
		visibility: hidden;
		z-index: -1;
  }
  10% {
    transform: translateY(-30px);
		opacity: 0;
		visibility: hidden;
		z-index: 0;
  }
  100% {
		transform: translateY(-15px);
		opacity: 1;
		visibility: visible;
		z-index: 0;
  }
}

@keyframes subOut {
  0% {
    transform: translateY(-15px);
		opacity: 1;
		visibility: visible;
		z-index: -1;
  }
  90% {
    transform: translateY(-30px);
		opacity: 0;
		visibility: hidden;
		z-index: -1;
  }
  100% {
		
		transform: translateY(-100%);
		opacity: 0;
		visibility: hidden;
		z-index: -1;
  }
}

#header .nav-bar #g-nav > li.sub-nav .sub-nav-area > .inner {
	position: relative;
	background-color: #f1f7f4;
}

#header .nav-bar #g-nav > li.sub-nav .sub-nav-area > .inner > .nav {
	max-width: 1000px;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	margin: 0 auto;
}

#header .nav-bar #g-nav > li.sub-nav .sub-nav-area > .inner > .nav > .main {
	position: relative;
	text-align: left;
	display: flex;
	align-items: center;
	width: auto;
	padding: 15px 40px 15px 10px;
	margin-right: 10px;
	flex: none;
	box-sizing: border-box;
}

#header .nav-bar #g-nav > li.sub-nav .sub-nav-area > .inner > .nav > .main::before {
	position: absolute;
	top: 10px;
	right: 0;
	content: '';
	width: 2px;
	height: calc(100% - 20px);
	background-color: #1a5b27;
	transition: 300ms all ease-in-out;
}

#header .nav-bar #g-nav > li.sub-nav .sub-nav-area > .inner > .nav > .main > a::after {
	position: absolute;
	bottom: 0;
	right: 0;
	content: '';
	width: 0;
	height: 2px;
	background-color: #1a5b27;
	transition: 300ms all ease-in-out;
}

#header .nav-bar #g-nav > li.sub-nav .sub-nav-area > .inner > .nav > .main > a:hover::after {
	width: 100%;
}

#header .nav-bar #g-nav > li.sub-nav .sub-nav-area > .inner > .nav > .main > a {
	position: relative;
	text-decoration: none;
	font-weight: 600;
	color: #1a5b27;
	padding: 15px 0 20px;
}

#header .nav-bar #g-nav > li.sub-nav .sub-list > .sub-nav-list {
	display: flex;
	justify-content: flex-start;
	flex-wrap: wrap;
	box-sizing: border-box;
}

#header .nav-bar #g-nav > li.sub-nav .sub-list > .sub-nav-list > li {
	box-sizing: border-box;
}

#header .nav-bar #g-nav > li.sub-nav .sub-list > .sub-nav-list > li.main {
	border-right: 2px solid #1a5b27;
	margin-right: 10px;
}

#header .nav-bar #g-nav > li.sub-nav .sub-list > .sub-nav-list > li > a {
	position: relative;
	display: block;
	text-decoration: none;
	font-weight: 400;
	padding: 15px 0 20px;
	margin: 0 30px;
	box-sizing: border-box;
	transition: all 300ms ease-in-out;
}

#header .nav-bar #g-nav > li.sub-nav .sub-list > .sub-nav-list > li > a::after {
	position: absolute;
	left: 0;
	bottom: 0;
	content: '';
	width: 0%;
	height: 2px;
	background-color: #1a5b27;
	transition: 300ms all ease-in-out;
}

#header .nav-bar #g-nav > li.sub-nav .sub-list > .sub-nav-list > li.main > a {
	font-weight: 600;
	color: #1a5b27;
}

#header .nav-bar #g-nav > li.sub-nav .sub-nav-list > li > a:hover::after {
	width: 100%;
}

#header .nav-bar .recruit-btn,
#header .nav-bar .home-btn {
	margin-left: 40px;
}

#header .nav-bar .recruit-btn > a,
#header .nav-bar .home-btn > a {
	position: relative;
	text-decoration: none;
	font-size: 120%;
	color: #fff;
	background-color: #1a5b27;
	border: 1px solid #1a5b27;
	font-weight: lighter;
	white-space: nowrap;
	padding: 15px 20px 15px 75px;
	transition: 300ms all ease-in-out;
}

#header .nav-bar .home-btn > a {
	font-size: 100%;
	padding: 15px 20px 15px 20px;
}

#header .nav-bar .recruit-btn > a::after {
	position: absolute;
	left: 10px;
	bottom: -1px;
	display: block;
	content: '';
	width: 60px;
	height: calc(100% + 15px);
	background-image: url('../img/common/btn_bg_01.png');
	background-position: bottom left;
	background-repeat: no-repeat;
	background-size: contain;
}

#header .nav-bar .recruit-btn > a:hover,
#header .nav-bar .home-btn > a:hover {
	color: #1a5b27;
	background-color: #fff;
}

@media screen and (max-width: 1400px) {
	#recruit #header .nav-bar {
		width: calc(100% - 550px);
	}
}

@media screen and (max-width: 1200px) {
	#header {
		position: fixed;
		top: 0;
		left: 0;
		height: 60px;
		padding: 8px 2%;
		overflow: hidden;
		box-shadow: 5px 0 5px rgba(0, 0, 0, 0.35);
		z-index: 992;
	}
	#recruit #header > .inner > .top-bar {
		width: 100%;
		max-width: 300px;
		display: flex;
		justify-content: space-between;
	}
	#recruit #header > .inner > .top-bar > .logo {
		margin: 0;
	}
	#header > .inner > .top-bar > .logo img {
		max-height: 40px;
	}
	#header > .inner > .top-bar > a > img {
		max-height: 10px;
	}
	#header .nav-bar  {
		display: none;
	}
}

@media screen and (max-width: 1000px) {
	#header .nav-bar {
		display: none;
	}
	#header > .inner {
		justify-content: center;
	}
	#header > .inner > .top-bar > .logo {
		margin: 0 auto;
	}
	#header > .inner > .top-bar > .logo img {
		height: 40px;
	}
	#header > .inner > .top-bar > .contact-btn {
		display: none;
	}
}

@media screen and (max-width: 480px) {
	#recruit #header > .inner {
    justify-content: flex-start;
	}
	#recruit #header > .inner > .top-bar {
		max-width: 260px;
	}
	#header > .inner > .top-bar > .logo img {
		height: 40px;
	}
	#header > .inner > .top-bar > a > img {
		max-height: 8px;
	}
}

#keyvisual {
	position: relative;
	width: 100vw;
	z-index: 2;
	overflow: hidden;
}

#keyvisual::after {
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

#recruit #keyvisual::after {
	background-color: rgba(29,29,31,.6);
	z-index: 1;
}

#recruit.index #keyvisual::after {
	background-color: initial;
}

#keyvisual .main-slide {
	margin-bottom: 0;
}

#keyvisual .slide {
	display: block!important;
}

#keyvisual .bg-area {
	display: block;
	width: 100%;
	overflow: hidden;
}

#keyvisual .bg-area .bg-slide { 
	position: relative;
}

#keyvisual .bg-area .bg-slide::after { 
	position: absolute;
	top: 0;
	left: 0;
	content: '';
	width: 100%;
	height: 100%;
	background-color: rgba(29, 29, 35, .3);
}

#keyvisual .bg-area .bg-slide .s-img {
	width: 100%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding-bottom: 37%;
}

#sub #keyvisual .bg-area .s-img,
#recruit #keyvisual .bg-area .s-img {
	position: relative;
	width: 100%;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding-bottom: 18%;
}

#sub #keyvisual .bg-area .s-img::after,
#recruit #keyvisual .bg-area .s-img::after { 
	position: absolute;
	top: 0;
	left: 0;
	content: '';
	width: 100%;
	height: 100%;
	background-color: rgba(29, 29, 35, .3);
}

.sub-ttl #keyvisual .bg-area .bg-slide .s-img {
	padding-bottom: 25%;
}

#keyvisual .bg-txt {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	width: 100%;
	max-width: 1920px;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	box-sizing: border-box;
	padding: 0 4%;
	margin: 0 auto;
	z-index: 2;
}

#keyvisual .bg-txt .ttl {
	position: relative;
	max-width: 1000px;
	line-height: 1.5;
	text-align: center;
	font-size: 220%;
	color: #1a5b27;
	font-weight: 600;
	text-shadow: 0 0 2px #fff, 0 0 2px #fff, 0 0 2px #fff, 0 0 2px #fff, 0 0 2px #fff;
	margin-bottom: 15px;
}

#sub #keyvisual .bg-txt .ttl,
#recruit #keyvisual .bg-txt .ttl {
	margin-bottom: 0;
}

#keyvisual .bg-txt .ttl.style-01 {
	font-size: 170%;
	margin-bottom: 0;
}

#keyvisual .bg-txt .sub-ttl {
	position: relative;
	max-width: 600px;
	line-height: 1.5;
	text-align: center;
	font-size: 100%;
	color: #2f3330;
	font-weight: 600;
	text-shadow: 0 0 2px #fff, 0 0 2px #fff, 0 0 2px #fff, 0 0 2px #fff, 0 0 2px #fff;
	margin-bottom: 15px;
}

#keyvisual .bg-txt .txt {
	position: relative;
	max-width: 600px;
	line-height: 1.5;
	text-align: left;
	font-size: 200%;
	color: #fff;
	font-weight: 600;
	text-shadow: 1px 1px 2px #000;
}

#keyvisual .bg-txt .ttl br.br-sp {
	display: none;
}

@media screen and (max-width: 1200px) {
	#keyvisual .bg-area .bg-slide .s-img {
		padding-bottom: 50%;
	}
	#sub #keyvisual .bg-area .s-img,
	#recruit #keyvisual .bg-area .s-img {
		padding-bottom: 20%;
	}
	#keyvisual .bg-txt .ttl.style-01 {
		font-size: 150%;
	}
}

@media screen and (max-width: 1000px) {
	#keyvisual .bg-area .bg-slide .s-img {
		padding-bottom: 55%;
	}
	#sub #keyvisual .bg-area .s-img,
	#recruit #keyvisual .bg-area .s-img {
		padding-bottom: 22%;
	}
	#keyvisual .bg-txt .inner {
		padding: 8% 5%;
	}
	#keyvisual .bg-txt .inner .ttl {
		font-size: 180%;
	}
	#keyvisual .bg-txt .inner .txt {
		font-size: 160%;
	}
	#keyvisual .bg-txt .ttl.style-01 {
		font-size: 140%;
	}
}

@media screen and (max-width: 767px) {
	#keyvisual .bg-area .bg-slide .s-img {
		padding-bottom: 60%;
	}
	#sub #keyvisual .bg-area .s-img,
	#recruit #keyvisual .bg-area .s-img {
		padding-bottom: 28%;
	}
	#keyvisual .bg-txt .ttl {
		width: 80%;
	}
	#keyvisual .bg-txt .ttl {
		font-size: 160%;
	}
	#keyvisual .bg-txt .txt {
		font-size: 140%;
	}
	#keyvisual .bg-txt .ttl.style-01 {
		font-size: 120%;
	}
	#keyvisual .bg-txt .ttl.style-01 br.br-sp {
		display: block;
	}
}

@media screen and (max-width: 480px) {
	#sub #keyvisual .bg-area .s-img,
	#recruit #keyvisual .bg-area .s-img {
		padding-bottom: 50%;
	}
	#keyvisual .bg-txt .ttl {
		width: 60%;
	}
	#keyvisual .bg-txt .ttl {
		font-size: 120%;
	}
	#sub #keyvisual .bg-txt .ttl,
	#recruit #keyvisual .bg-txt .ttl {
		width: 94%;
		font-size: 140%;
	}
	#sub #keyvisual .bg-txt .ttl.style-01,
	#recruit #keyvisual .bg-txt .ttl.style-01 {
		width: 100%;
		font-size: 110%;
	}
	#keyvisual .bg-txt .txt {
		font-size: 100%;
	}
}

@media screen and (max-width: 380px) {
	#sub #keyvisual .bg-area .s-img,
	#recruit #keyvisual .bg-area .s-img {
		padding-bottom: 60%;
	}
}

@media screen and (max-width: 320px) {
	#keyvisual .bg-area .bg-vid {
		min-width: 320px;
	}
}

/* --------------------------------------------------
Contents
-------------------------------------------------- */

#contents {
	width: 100%;
	position: relative;
	z-index: 1;
}

@media screen and (max-width: 1000px) {
	#main {
		font-size: 90%;
	}
}

@media screen and (max-width: 767px) {
	#main {
		font-size: 80%;
	}
}

.contact-blc {
	background-color: #f1f7f4;
}

.contact-blc > .inner > .area {
	display: flex;
	justify-content: space-around;
	background-color: #fff;
	padding: 40px 2% 20px;
}

.contact-blc > .inner > .area > .cont01,
.contact-blc > .inner > .area > .cont02 {
	display: block;
	text-align: center;
	width: 48%;
}

.contact-blc > .inner > .area > .cont01 > .inner,
.contact-blc > .inner > .area > .cont02 > .inner {
	display: inline-block;
	text-align: left;
}

.contact-blc > .inner > .area > .cont02 > .tel {
	position: relative;
	display: inline-block;
	text-decoration: none;
	font-size: 200%;
	letter-spacing: 1px;
	padding-bottom: 10px;
	margin-bottom: 10px;
}

.contact-blc > .inner > .area > .cont02 > .tel::before {
	display: inline-block;
	width: 30px;
	height: 40px;
	content: '';
	background: url('../img/common/tel.png') no-repeat left center;
	background-size: contain;
	padding-right: 10px;
	transform: translateY(8px);
}

.contact-blc > .inner > .area > .cont02 > .btn-blc {
	display: block;
	text-align: center;
}

.contact-blc > .inner > .area > .cont02 > .btn-blc > a {
	display: inline-block;
	text-align: center;
	font-weight: lighter;
	letter-spacing: .8px;
	font-size: 120%;
	color: #fff;
	background-color: #1a5b27;
	border: 1px solid #1a5b27;
	text-decoration: none;
	padding: 12px 12%;
	transition: 300ms all ease-in-out;
}

.contact-blc > .inner > .area > .cont02 > .btn-blc > a:hover {
	background-color: #fff;
	color: #1a5b27;
}

@media screen and (max-width: 767px) {
.contact-blc > .inner > .area {
	flex-wrap: wrap;
	padding: 20px 2%;
}
	.contact-blc > .inner > .area > .cont01,
	.contact-blc > .inner > .area > .cont02 {
		width: 100%;
	}
	.contact-blc > .inner > .area > .cont02 > .btn-blc > a {
		padding: 6px 6%;
	}
}

/* --------------------------------------------------
Footer
-------------------------------------------------- */

#footer {
	position: relative;
	width: 100%;
	box-sizing: border-box;
	z-index: 0;
	border-top: 4px solid #f1f7f4;
	background-color: #fff;
	z-index: 1;
}

#footer > .inner {
	max-width: 1200px;
	width: 96%;
	display: flex;
	align-items: center;
	border-bottom: 1px solid #f5f6f7;
	padding: 20px 2%;
	margin: 0 auto;
	box-sizing: border-box;
}

#footer > .inner .footer-main {
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-direction: column;
}

#footer > .inner .footer-main a:hover {
	opacity: .8;
}

#footer > .inner .footer-nav {
	max-width: 1000px;
	width: 100%;
	margin: 0 auto;
	margin-left: 50px;
}

#footer > .inner .footer-nav > .recruit-nav {
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	flex-wrap: wrap;
	font-size: 100%;
}

#footer > .inner .footer-nav > .recruit-nav li {
	letter-spacing: 1px;
	margin-right: 40px;
	margin-bottom: 20px;
}

#footer > .inner .footer-nav > .recruit-nav a {
	position: relative;
	text-decoration: none;
	color: #000;
	padding-bottom: 5px;
}

#footer > .inner .footer-nav > .nav {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
	font-size: 100%;
}

#footer > .inner .footer-nav > .nav li {
	letter-spacing: 1px;
}

#footer > .inner .footer-nav > .nav a {
	position: relative;
	text-decoration: none;
	color: #000;
	padding-bottom: 5px;
}

#footer > .inner .footer-nav > .nav a:hover {
	opacity: .7;
}

#footer .footer-copy {
	text-align: center;
	font-size: 95%;
	color: #86868b;
	letter-spacing: 1px;
	font-weight: lighter;
	padding: 25px 4% 30px;
}

@media screen and (max-width: 1200px) {
	#footer > .inner .footer-nav {
		font-size: 90%;
	}
	#footer .footer-copy {
		font-size: 90%;
	}
}

@media screen and (max-width: 1000px) {
	#footer > .inner {
		flex-direction: column;
		padding: 20px 0;
	}
	#footer > .inner .footer-main {
		flex-direction: row;
		margin-bottom: 40px;
	}
	#footer > .inner .footer-main .logo {
		margin-right: 10px;
	}
	#footer > .inner .footer-nav {
		font-size: 90%;
		margin-left: 0;
	}
	#footer > .inner .footer-nav > .recruit-nav {
		justify-content: space-between;
		margin-bottom: 30px;
	}
	#footer > .inner .footer-nav > .recruit-nav li {
		margin-right: 0;
		letter-spacing: .5px;
	}
	#footer > .inner .footer-nav > .recruit-nav > li {
		width: calc((100% / 3) - (10px / 3));
		margin-bottom: 20px;
	}
	#footer > .inner .footer-nav > .recruit-nav > li.col-2 {
		width: calc(((100% / 3) * 2) - ((10px / 3) * 1));
	}
	#footer > .inner .footer-nav > .recruit-nav > li .sub-nav > .nav li::before {
		margin-right: 5px;
	}
	#footer > .inner .footer-nav > .recruit-nav > li:nth-last-child(3) {
		margin-bottom: 20px;
	}
	#footer > .inner .footer-nav > .nav li {
		letter-spacing: .5px;
	}
	#footer > .inner .footer-nav > .nav > li {
		width: calc((100% / 3) - (10px / 3));
		margin-bottom: 20px;
	}
	#footer > .inner .footer-nav > .nav > li.col-2 {
		width: calc(((100% / 3) * 2) - ((10px / 3) * 1));
	}
	#footer > .inner .footer-nav > .nav > li .sub-nav > .nav li::before {
		margin-right: 5px;
	}
	#footer > .inner .footer-nav > .nav > li:nth-last-child(3) {
		margin-bottom: 20px;
	}
	#footer .footer-copy {
		padding: 15px 4% 20px;
	}
}

@media screen and (max-width: 767px) {
	#footer > .inner .footer-nav > .recruit-nav > li {
		width: calc((100% / 2) - (20px / 2));
		margin-bottom: 20px;
	}
	#footer > .inner .footer-nav > .recruit-nav > li.col-2 {
		width: calc(((100% / 2) * 2) - ((20px / 2) * 1));
	}
	#footer > .inner .footer-nav > .nav > li {
		width: calc((100% / 2) - (20px / 2));
		margin-bottom: 20px;
	}
	#footer > .inner .footer-nav > .nav > li.col-2 {
		width: calc(((100% / 2) * 2) - ((20px / 2) * 1));
	}
	#footer .footer-copy {
		font-size: 80%;
	}
}

@media screen and (max-width: 480px) {
	#footer > .inner {
		width: 98%;
		padding: 20px 4%;
	}
	#footer > .inner .footer-main {
		text-align: center;
		flex-direction: column;
		padding: 0 30px;
		margin-bottom: 40px;
	}
	#footer > .inner .footer-main .logo {
		margin-right: 0;
		margin-bottom: 15px;
	}
	#footer > .inner .footer-nav > .nav > li.col-2 {
		width: calc(100%);
	}
	#footer > .inner .footer-nav > .nav > li:nth-last-child(2) {
		margin-bottom: 20px;
	}
	#footer > .inner .footer-nav > .nav > li .sub-nav {
		flex-direction: column;
	}
	#footer > .inner .footer-nav > .nav > li .sub-nav > .nav {
		width: 100%;
		margin-left: 10px;
	}
	#footer .footer-copy {
		font-size: 80%;
	}
}



/* --------------------------------------------------
Other
-------------------------------------------------- */

.hide {
	opacity: 0;
}

