@charset "utf-8";
/* CSS Document */
/*------------------- header ------------------- */
header {
    transition: .3s;
    background-color: #fff;
}
header .head_cont {
    width: auto;
    max-width: 940px;
    padding: 0 20px;
    margin: 0 auto;
	position: relative;
}
.head_cont .h_cont_left {
    max-width: 246px;
	margin: 0 auto;
	text-align: center;
	padding-top: 20px;
	padding-bottom: 20px;
}
.h_cont_left a:hover{
	opacity: 0.6;
}
.head_cont .h_cont_right {
	position: absolute;
	top: 0;
	right: 40px;
	min-width: 295px;
}
.head_cont .h_cont_right ul{
	float: left;
	margin-top: 15px;
}
.head_cont .h_cont_right ul li{
	display: inline-block;
	font-size: 0.75rem;
	padding-right: 5px;
}
.head_cont .h_cont_right ul li .fa{
	color: #8ec32f;
	padding-right: 5px;
}
.head_cont .h_cont_right p{
	text-align: right;
	float: right;
	margin: 0;
	padding: 0;
}
.recruit_top_btn {
position: relative;
display: inline-block;
font-weight: bold;
padding: 14px 10px 12px 10px;
text-decoration: none;
color: #fff;
background: #fab928;/*背景色*/ 
border-bottom: solid 3px #f0af1e;/*少し濃い目の色に*/ 
border-radius: 0 0 10px 10px;/*角の丸み*/
}.recruit_top_btn:hover {
background: #ffc25c;
color: #FFF;
} 
/*------------------- △header fin△ ------------------- */

/*------------------- ▽global nav▽ ------------------- */
nav{
    margin: 0 auto;
    max-width: 940px;
    position: relative;
    padding: 0;
}
nav .global_nav{
	width: 100%;
	padding-bottom: 10px;
}
.nav_list{
    display:-webkit-box;
    display:-moz-box;
    display:-webkit-flexbox;
    display:-moz-flexbox;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:flex;
    -webkit-box-direction:normal;
    -moz-box-direction:normal;
    box-direction:normal;
    -webkit-box-orient:horizontal;
    -moz-box-orient:horizontal;
    box-orient:horizontal;
    -ms-flex-direction:row;
    -webkit-flex-direction:row;
    -moz-flex-direction:row;
    flex-direction:row;
}
.global_nav li{
    display: inline-block;
    width: 19.5%;
    text-align: center;
    margin: 0 0.4255%;
    color: #5e5e5e;
}
.global_nav li:first-child{
	margin-left: 0;
}
.global_nav li:last-child{
	margin-right: 0;
}
.global_nav li a{
	font-size: 1.2rem;
	font-weight: 500;
    display: block;
    padding-bottom: 10px;
    border-bottom: 3px solid #8ec32f;
}
.nav_list > li.menu_single {
    position: relative;
}
ul.menu_second_level {
    visibility: hidden;
    opacity: 0;
    z-index: 1;
}
ul.menu_second_level > li {
    width: 100%;
	text-align: left;
}
ul.menu_second_level > li > a {
    color: #fff;
    border-bottom: 1px solid #fff;
    margin: 10px 15px;
	display: block;
	font-size: 1rem;
	font-weight: normal;
}
ul.menu_second_level > li > a:hover {
	opacity: 0.6;
}
li.menu_single ul.menu_second_level {
    position: absolute;
    top: 40px;
    width: 100%;
    background: #072A24;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
	background-color: rgba(120,195,30,0.8)
}

li.menu_single:hover ul.menu_second_level {
    top: 50px;
    visibility: visible;
    opacity: 1;
}
.menu_second_level .global-nav__list_order_first {
    border: none;
    padding-bottom: 0;
    margin-bottom: 0;
}
.menu_third_level li {
	width: 100%;
	text-align: left;
}
.menu_third_level li a{
	border-bottom: 1px solid #fff;
    color: #fff;
    font-weight: normal;
    font-size: 1rem;
    margin: 0 20px;
    padding-left: 20px;
}
.menu_third_level li a:hover{
	opacity: 0.6;
}
/*------------------- ▽global nav fin▽ ------------------- */

/*------------------- sp_nav ------------------- */
#menu{
 position: fixed;
 top: 0;
 right: -200px;
 width: 200px;
 height: 100%;
 z-index:2!important;
 background-color: rgba(0,0,0,0.6)
}
#menu ul{
 padding-top: 50px;
}
#menu ul li{
    display: block;
 position: relative;
}
#menu ul li a{
	 padding:15px 20px;
	 color: #FFF;
	 display: block;
	 text-decoration: none;
	 border-bottom:1px dotted #FFF;
    }
#menu ul li a:hover{
    background: #bab6e7;
}

.slide-menu-button{
	position: absolute;
	top:0;
	right:0;
	padding: 5px;
	outline: none;
	border: none;
	font-size: 20px;
	cursor: pointer;
	z-index:12;
}
.slide-menu-button .menu-icon {
    display: block;
    margin: 5px;
    float: left;
    cursor: pointer;
    background-color: #8ec32f;
    padding: 10px 9px 6px 9px;
}
.slide-menu-button .menu-icon span {
    display: block;
    width: 20px;
    height: 3px;
    background: #fff;
    margin-bottom: 4px;
}

/*------------------- sp_nav fin ------------------- */

/*------------------- pagetop ------------------- */

#page-top {
    position: fixed;
    bottom: 20px;
    right: 30px;
    font-size: 1.3em;
    z-index: 100;
}
#page-top a {
	background: #946134;
    text-decoration: none;
    color: #fff;
    width: 50px;
    padding: 9px 0;
    text-align: center;
    display: block;
    border-radius: 50px;
}
/*------------------- △pagetop fin△ ------------------- */

.main_content {
    width: auto;
    max-width: 820px;
    padding: 0 20px;
    margin: 0 auto;
}
.flexbox{
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  height: 100vw; /* ビューポート(幅)を基準に表示高を指定 */
}
.item {
  background: #ddd;
  padding: 10px;
  border-radius: 8px;
  border: 3px solid #ccc;
  width: 25%;
}

/*------------------- ▽ footer start ▽ ------------------- */
footer {
	background-color: #fff;
	border-top: 3px solid #946134;
}
footer .footer_cont {
	width: auto;
	max-width: 940px;
	padding: 20px 0 30px 0;
	margin: 0 auto;
	background-color: #fff;
}
footer .foot_list{
	max-width: 940px;
}
footer .outer_list{
	float: left;
	width: 20%;
}
footer .main_list h2{
	font-size: 1rem;
	margin: 10px 0 0 0;
	font-weight: 500;
}
footer .main_list .fa{
	color: #8ec32f;
    padding-right: 6px;
}
footer .sub_list{
	margin: 0 0 10px 10px;
}
footer .sub_sub_list{
	margin: 0 0 0 5px;
  font-size: 0.8em;
}
footer .sub_list .inner_sub_list{
	width: 50%;
	float: left;
}
footer .foot_info{
	border-top: 1px solid #aaa9a9;
	padding-top: 30px;
}
footer .foot_info .f_info_left{
	float: left;
	max-width: 282.5px;
}
footer .foot_info .f_info_right{
	float: right;
	text-align: right;
}
footer .foot_info .f_info_right p{
	margin: 0;
	padding: 0;
	line-height: 1;
}
footer .foot_info .f_info_right h4{
	font-size: 3rem;
	margin: 0;
	padding: 0;
	line-height: 1;
}
footer .copyright {
	background-color: #8ec32f;
	margin: 0 auto;
	padding: 6px;
	text-align: center;
	font-size: 0.75em;
	color: #fff;
}
.sp_block{
	display: none;
}
/*------------------- △ footer fin △ ------------------- */
/*------------------- nav表示、非表示設定 ------------------- */
@media only screen and (max-width: 960px) {
.nav_list{
	margin: 0 30px;
}
}


/*------------------- nav表示、非表示設定 ------------------- */
@media only screen and (min-width: 830px) {
.spmenu_btn {
	display: none;
}
.pc_none{
	display: none;
}
}
@media only screen and (max-width: 830px) {
.g_menu {
	display: none;
}
.h_cont_right{
		display: none;
}
.global_nav li a{
	font-size: 1.0rem;
	white-space: nowrap;
}
}

/*------------------- SP適用 ------------------- */
@media only screen and (max-width: 640px) {
#page-top{
    bottom: 0;
    right: 5px;
}
.head_cont .h_cont_left{
	padding-bottom: 5px;
}
.sp_block{
	display: block;
}
.sm_none{
	display: none!important;
}
.sm_nowrap{
	white-space: nowrap;
	text-indent: -3px;
}
.nav_list{
	display: block;
	}
.global_nav li{
    width: 45.21693122%;
	margin: 0 1.587301587%;
	margin-bottom: 10px;
}
.global_nav li:first-child{
	margin-left: 1.587301587%;
}
.global_nav li:last-child{
	margin-right: 1.587301587%;
}
.global_nav li a {
    font-size: 0.9rem;
}
.head_logo{
	max-width: 246px;
}
footer .foot_nav{
	padding: 0 30px;
}
footer .outer_list{
	float: none;
	width: 100%;
}
footer .sub_list{
	display: none;
}
footer .main_list{
	border-bottom: 1px solid #666;
	margin-bottom: 15px;
}
footer .main_list a{
	display: block;
	width: 100%;
}
footer .foot_info{
	border-top: none;
	padding-top: 0;
}
footer .foot_info .f_info_left{
	float: none;
	margin: 0 auto;
}
footer .foot_info .f_info_left img{
    display: block;
}
footer .foot_info .f_info_right{
	float: none;
	text-align: center;
	margin-top: 20px;
}
footer .foot_info .f_info_right h4{
	margin-top: 10px;
	font-size: 2.2rem;
}

}

@media only screen and (max-width: 340px) {
.head_cont .h_cont_left{
		max-width: 210px;
}

.head_logo{
	max-width: 210px;
}


}

