@charset "utf-8";
body {
  background: #FFFFFF;
  color: #333333;
  font-family: 'Lato', 'Noto Sans JP', "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
  font-size: 1.4rem;
  line-height: 1.6;
  -webkit-text-size-adjust: 100%;
}
.pankuzu_bg {
  background-color: #eeeeee;
}
.site_wrapper {
  width: 1080px;
  margin: 0 auto;
  text-align: left;
  position: relative;
}
@media screen and (max-width: 767px) {
  .site_wrapper {
    width: 100%;
    box-sizing: border-box;
  }
}
#wrapper_all {
  text-align: center;
  min-width: 1100px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  #wrapper_all {
    min-width: 100%;
  }
}
/* header
-------------------------------------------------------------------*/
.header {}
@media screen and (max-width: 767px) {
  .header {
    padding-bottom: 0;
  }
}
.bg_h1 {
  padding: 5px;
  font-size: 1.2rem;
  background: #42a96b;
	color: #fff;
	text-align: left;
}
.bg_f1 {
  background: #fff;
  color: #333;
  padding: 5px 0;
  font-size: 1.2rem;
}
@media screen and (max-width: 767px) {
  .bg_h1, .bg_f1 {
    padding: 5px 15px;
    font-size: 1.0rem;
  }
}

.head_bd{
	min-width:1200px;
	margin: 0 auto;
	padding: 15px 30px;
	text-align: left;
	box-sizing: border-box;
}
@media screen and (max-width: 767px) {
.head_bd{
	min-width: 100%;
}
}

@media screen and (max-width: 767px) {
  .area_hd01 {
    box-sizing: border-box;
	min-width:100%;
  }
}

.area_hd01 .left_area {
  float: left;
  width: 185px;
}

.area_hd01 .right_area {
  float: right;
  width: 885px;
}

@media screen and (max-width: 767px) {
  .area_hd01 .left_area {
    width: 45%;
    padding: 0;
  }
  .area_hd01 .right_area {
    width: 85px;
	  padding: 3px 0;
	  box-sizing: border-box;
  }
	.area_hd01 .center_area {
 display: none;
	}
}
.tel_area > li {
	display: inline-block;
}
.tel_area li:first-child {
  font-weight: bold;
  font-size: 2.8rem;
  line-height: 2;
  text-align: center;
	color: #000066;
	box-sizing: border-box;
	padding:0 10px;
}
@media screen and (max-width: 1300px) {
.tel_area li:first-child {
  font-size: 2rem;
	padding:0 10px;
}
	
}
.tel_area li:first-child span{
	background: url("../img/common/ico_tel.png") left center no-repeat;
	padding-left: 25px;
}

.tel_area li:last-child {
}
.sp_hd_area li {
  display: table-cell;
  padding: 0 10px;
}
.mail_hd a {
  background: #222;
  color: #fff;
  padding: 10px 30px;
  width: 100%;
  box-sizing: border-box;
  line-height: 0;
  font-size: 1.6rem;
  font-weight: bold;
  display: block;
  text-align: center;
}
.hd_tel{
	text-align:right;
	font-size: 2.4rem;
	font-weight: bold;
	color: #42a96b;
	letter-spacing: 1px;
}
/* navi
-------------------------------------------------------------------*/
.g_nav{
	padding:5px 0;
}
.g_nav li {
	display: inline-block;
  overflow: hidden;
  position: relative;
	line-height: 1;
	font-size: 1.6rem;
	letter-spacing: 1px;
}
.g_nav li a {
  display: block;
  position: relative;
  font-weight: bold;
  padding: 0 12px;
  overflow: hidden;
  text-align: center;
  line-height: 1.2;
}


.g_nav li a:hover, .g_nav li.current a  {
	color: #42a96b;
}
/*sp_nev
-------------------------*/
.close {
  font-weight: bold;
  font-size: 20px;
  text-align: right;
}
.button-toggle {}
@media screen and (max-width : 767px) {
  .button-toggle {}
}
@media screen and (max-width: 767px) {
  .menu {
    position: fixed;
    top: 0;
    left: 0px;
    width: 100%;
    background: #42a96b;
    overflow: hidden;
    z-index: 9999;
    padding: 20px;
    box-sizing: border-box;
  }
  .menu a {
    display: block;
    text-decoration: none;
    padding: 15px 25px;
    font-size: 15px;
	  color: #fff;
  }
}
.active {}
/* contents
-------------------------------------------------------------------*/
.content_area {
  margin-bottom: 30px;
}
.content_area .main_area {
  float: left;
  width: 800px;
  box-sizing: border-box;
}
.content_area .side_area {
  float: right;
  width: 240px;
  box-sizing: border-box;
}
@media screen and (max-width: 767px) {
  .content_area .main_area {
    float: none;
    width: 100%;
    margin-bottom: 25px;
  }
  .content_area .side_area {
    float: none;
    width: 100%;
  }
}
.side_ttl {
  background: #42a96b;
  text-align: center;
  color: #fff;
  line-height: 1;
  padding: 10px;
}
ul.cate li {
  margin-bottom: 5px;
}
ul.cate li a {
  text-decoration: underline;
}
ul.cate li:before {
  content: "＞";
}
.article_list li {
  padding-bottom: 20px;
  margin-bottom: 15px;
  border-bottom: 1px solid #ccc;
}
.article_list li:last-child {
  background: none;
  margin-bottom: 0;
}
.side_txt_area {
  padding: 20px;
  border: #42a96b 1px solid;
  border-top: none;
}
.btn_pink a {
  border: #ff6357 1px solid;
  font-size: 1.4rem;
  color: #ff6357;
  display: block;
  text-align: center;
  padding: 15px 30px;
  line-height: 1;
  background: #fff;
}
.btn_green a {
  background: url(../img/common/arrow_03.png) no-repeat right 10px center #fff;
  border: #181715 1px solid;
  font-size: 1.8rem;
  color: #181715;
  display: block;
  text-align: center;
  padding: 20px 30px;
  line-height: 1; /*	font-family: "游明朝", YuMincho,"ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif;*/
}
.btn_green a:hover {
  color: #fff;
  background: url(../img/common/arrow_04.jpg) no-repeat right 10px center #181715;
}
.btn_green_2 a {
  background: url(../img/common/arrow_04.png) no-repeat right 10px center #181715;
  border: #181715 1px solid;
  font-size: 1.8rem;
  color: #fff;
  display: block;
  text-align: center;
  padding: 20px 30px;
  line-height: 1; /*	font-family: "游明朝", YuMincho,"ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "ＭＳ Ｐ明朝", "MS PMincho", serif;*/
}
.btn_green_2 a:hover {
  color: #181715;
  background: url(../img/common/arrow_03.png) no-repeat right 10px center #fff;
}
.bg_top_area {
  background: url(../img/common/bg_area_01.png) no-repeat center top #fef6e6;
}
.bg_top_area_02 {
  background: url(../img/common/bg_area_01.png) no-repeat center top #cc8f8f;
}
.bg_top_area_03 {
  background: url(../img/common/bg_area_01.png) no-repeat center top #ffffff;
}
.ico_tel_in {
  display: block;
}
.btn_black a, .btn_black input {
  border: #333 1px solid;
  font-size: 1.4rem;
  color: #333;
  display: block;
  text-align: center;
  padding: 15px 30px;
  line-height: 1;
  background: #fff;
}
.btn_black_02 a, .btn_black_02 input {
  background: #42a96b;
  font-size: 1.4rem;
  color: #fff;
  display: block;
  text-align: center;
  padding: 15px 30px;
  line-height: 1;
  border: 0;
  transition: 0.5s all;
  -webkit-transition: 0.5s all;
  -moz-transition: 0.5s all;
  -o-transition: 0.5s all;
  -ms-transition: 0.5s all;
  width: 400px;
  -webkit-appearance: none;
	margin: 0 auto;
	border-radius: 50px
}
@media screen and (max-width: 767px) {
	.btn_black_02 a, .btn_black_02 input {
		width:100%;
	}
}
.btn_black_02 input:hover {
  cursor: pointer;
  opacity: 0.7;
}
.txt_area01 {
  position: relative;
  padding: 0.25em 1em;
  border-top: solid 1px black;
  border-bottom: solid 1px black;
  background: #fff;
}
.txt_area01:before, .txt_area01:after {
  content: '';
  position: absolute;
  top: -7px;
  width: 1px;
  height: -webkit-calc(100% + 14px);
  height: calc(100% + 14px);
  background-color: black;
}
.txt_area01:before {
  left: 7px;
}
.txt_area01:after {
  right: 7px;
}
.txt_area02 {
  background-color: #fff;
  border: 1px solid #181715;
  padding: 15px 30px;
}
@media screen and (max-width: 767px) {
  .txt_area02 {
    padding: 15px 20px;
  }
}
.txt_area02_tit {
  color: #181715;
  margin-bottom: 10px;
  font-weight: bold;
  font-size: 1.8rem;
}
.txt_side01 {
  border-bottom: #222 1px solid;
  border-top: #222 1px solid;
  text-align: center;
}
/*
.txt_area02:before,
.txt_area02:after{ 
  content:'';
width: 20px;
height: 30px;
position: absolute;
display: inline-block;
}

.txt_area02:before{
  border-left: solid 1px #ccc;
  border-top: solid 1px #ccc;
  top:0;
  left: 0;
}


.txt_area02:after{
  border-right: solid 1px #ccc;
  border-bottom: solid 1px #ccc;
  bottom:0;
  right: 0;
}

*/



.icon_list li, .post-categories li, .news_ico {
  display: inline-block;
  min-width: 50px;
  text-align: center;
  margin: 0 5px 5px 0;
  line-height: 1;
  font-size: 1.2rem;
  /* padding: 2px 10px; */
  box-sizing: border-box;
}
.icon_list li.important, .post-categories li.important, .news_ico {
  color: #fff;
  background: #b7ad02;
}
.icon_list li.news, .post-categories li.news {
  border: #f5a53c 1px solid;
  background-color: #fff;
  color: #f5a53c;
}
.icon_list li, .post-categories li { /*	border: #c85554 1px solid;*/ /* background-color: #583c32; */ color: #fff;
}
.icon_list li a, .post-categories li a {
  display: inline-block;
  padding: 5px 10px;
  border-radius: 5px;
  font-size: 1.2rem;
  color: #fff !important;
  background-color: #42a96b;
}
.icon_list li.cat_01 a{
  color: #fff !important;
  background-color: #42a96b;
}
.icon_list li.cat_02 a{
  color: #fff !important;
  background-color: #42a96b;
}
.icon_list li.cat_03 a{
  color: #fff !important;
  background-color: #42a96b;
}
.icon_list li.cat_04 a{
  color: #fff !important;
  background-color: #42a96b;
}
.icon_list li.cat_05 a{
  color: #fff !important;
  background-color: #42a96b;
}
.icon_list li.cat_06 a{
  color: #fff !important;
  background-color:#42a96b;
}



.column_ico li {}
.column_ico li a {
  background: #42a96b;
  color: #fff !important;
	border: #42a96b 1px solid;
  display: block;
}
.top_column_fig_area {}


.txt_area_column {
  height: 120px;
  position: relative;
}
.column_txt {
  position: relative;
}
@media screen and (max-width: 767px) {
  .column_top > li {
    width: 100%;
    margin-right: 0;
    float: none;
  }
  .column_tit {
    background-position: left 0 top 3px;
    padding: 0 0 5px 30px;
    margin-bottom: 10px;
    border-bottom: 1px solid #aaaaaa;
    min-height: auto;
  }
  .column_top .top_column_fig_area {
    float: left;
    width: 30%;
  }
  .column_top .column_fig {}
  .column_top .column_txt {
    width: 65%;
    float: right;
  }
  .column_top .txt_area_column {
    height: auto;
    padding-bottom: 30px;
    font-size: 1.2rem;
  }
}
.seminar_btn {
  background: url(../img/common/arrow_02.png)no-repeat left center;
  position: absolute;
  right: 0;
  bottom: 5px;
  padding-left: 20px;
}
@media screen and (max-width: 767px) {
  .seminar_btn {
    position: relative;
    overflow: hidden;
    float: right;
    margin: 10px 0;
    clear: both;
  }
}

/* footer
-------------------------------------------------------------------*/
.btn_tel{
	border-radius: 15px;
	border: #F39801 2px solid;
	position: relative;
	padding: 15px 30px 15px 160px;
	box-sizing: border-box;
	overflow: hidden;
	text-align: center;
	
}
@media screen and (max-width: 767px) {
	.btn_tel{
	padding: 15px;
	
}
}
.btn_tel::before{
	content: "";
	background: url("../img/common/character_4.png") left top no-repeat;
	width: 130px;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}
@media screen and (max-width: 767px) {
	.btn_tel::before{
		content: none;

}
}

.tel_01{
	color:#F39801;
	border-bottom: #F39801 2px solid;
	padding-bottom: 10px;
	margin-bottom: 10px;
	font-weight: bold;
}
.tel_02{
	color:#F39801;
	font-weight: bold;
	font-size:4rem;
	background: url("../img/common/ico_tel.png") left center no-repeat;
	padding: 0 0 0 45px;
	line-height: 1;
	display: inline-block;
}
@media screen and (max-width: 767px) {
	.tel_02{
	font-size:2.4rem;
	background: url("../img/common/ico_tel.png") left center no-repeat;
		background-size: 20px;
	padding: 0 0 0 35px;
}
}
.btn_mail a{
	display: block;
	background:#F39801;
	padding: 20px;
	text-align: center;
	color: #fff !important;
	border-radius: 15px;
}
@media screen and (max-width: 767px) {
	.btn_mail a{
	padding: 15px;
}
	.btn_mail a .f_26{
		font-size: 1.8rem !important;
	}
}
.ft_contact_tit {
  position: relative;
  margin-bottom: 20px;
}
.ft_contact_tit h2 {
  font-size: 1.6rem;
  border-bottom: 1px solid #fff;
  position: relative;
  padding-bottom: 10px;
  margin-bottom: 10px;
}
.ft_contact_tit h2::after {
  content: "";
  position: absolute;
  left: 48%;
  bottom: -3px;
  width: 4%;
  height: 5px;
  overflow: hidden;
  background-color: #fff;
}
.ft_contact_en {
  font-size: 4.8rem;
  font-weight: bold;
  line-height: 1.1;
}
@media screen and (max-width: 767px) {
  .ft_contact_tit h2::after {
    content: "";
    position: absolute;
    left: 45%;
    bottom: -3px;
    width: 10%;
    height: 5px;
    overflow: hidden;
    background-color: #fff;
  }
}
.footer {
	background:#dcf9e7;
	padding: 60px 0 20px;
}
@media screen and (max-width: 767px) {
.footer {
	margin-bottom: 75px;
}
}
.ft_area {
  padding: 50px 0;
}
@media screen and (max-width: 767px) {
  .ft_area {
    padding: 25px 15px;
  }
}
.ft_area .left_area {
  float: left;
  width: 615px;
}
.ft_area .right_area {
  float: right;
  width: 315px;
}
@media screen and (max-width: 767px) {
  .ft_area .left_area {
    float: none;
    width: 100%;
    margin-bottom: 10px;
  }
  .ft_area .right_area {
    float: none;
    width: 100%;
  }
}
.ft_nav{
	text-align:center;
	padding: 60px 0;
}
@media screen and (max-width: 767px) {
	.ft_nav{
	padding: 30px 0;
}
}
.ft_nav li {
	display: inline-block;
    padding: 0 15px;
	line-height: 1;
}
@media screen and (max-width: 767px) {
  .ft_nav li {
    width: 50%;
	  display: block;
	  float: left;
    padding: 5px;
    box-sizing: border-box;

  }
}
.ft_nav li a{
	color: #222;
}
.btn_top {
	position: fixed;
	bottom: 40px;
	right: 10px;
	z-index: 99;
}
@media screen and (max-width: 767px) {
.btn_top {
	width: 40px;
	bottom: 20px;
}
}

.btn_top a:hover *, .btn_top2 a:hover * {
	opacity: 0.35;
}

.btn_online a{
	display:block;
	background: #42a96b;
	color: #fff;
	font-size: 2rem;
	font-weight: bold;
	padding:20px 10px;
	border-top-left-radius: 5px;
	border-bottom-left-radius: 5px;
	writing-mode: vertical-rl;
-webkit-writing-mode: vertical-rl;
-ms-writing-mode: tb-rl;
	position: fixed;
	top: 180px;
	right: 0;
	z-index: 99;
}
.btn_online a span{
		background: url("../img/common/ico_pc.png") top center no-repeat;
	padding: 35px 5px 0 5px;
}
@media screen and (max-width: 767px) {
	.ft_btn{
		position: fixed;
		bottom: 0;
		left: 0;
		width: 100%;
		background: #fff;
		padding: 10px;
			border-top: #ccc 1px solid;

	}
	.ft_btn .left_area{
		float: left;
		width: 70%;
		border-right: #ccc 1px solid;
		box-sizing: border-box;
		padding: 15px;
		font-weight: bold;
		font-size: 1.5rem;
	}
	.ft_btn .left_area span{
background: url("../img/common/sp_ico_pc.png") left center no-repeat;
		background-size: 20px;
		padding-left: 30px;
	}
	.ft_btn .right_area{
		float: right;
		width: 30%;
		box-sizing: border-box;
		padding: 10px;
	}
	.ft_btn .right_area a p{
		position: relative;
		padding-top: 10px;
	}
	.ft_btn .right_area a p::before{
		content: "";
		position: absolute;
		width: 0;
height: 0;
border-style: solid;
border-width: 0 6px 6px 6px;
border-color: transparent transparent #F39801 transparent;
		top: 0;
		left: 0;
		right: 0;
		margin: 0 auto;
	}
}
/*ggmap
--------------------------------*/
  .ggmap iframe
	  {width: 100%;
		  border:none;
	  }
@media screen and (max-width: 767px) {
  .ggmap {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
  }
  .ggmap iframe, .ggmap object, .ggmap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }
}
.border_double {
  border: #aaaaaa double 3px;
  padding: 15px;
}
.ico_f01 {
  background: url(../img/common/ico_f01.png) left center no-repeat;
  padding-left: 20px;
}
.ico_f02 {
  background: url(../img/common/ico_f02.png) left center no-repeat;
  padding-left: 20px;
}
.ico_f03 {
  background: url(../img/common/ico_f03.png) left center no-repeat;
  padding-left: 20px;
}
.list_f01 li {
  border-top: #ccc 1px dotted;
  padding-top: 15px;
  margin-top: 15px;
  width: 33.3333%;
  float: left;
  font-size: 85.7% !important;
}
.slider_txt {
  position: absolute;
  bottom: 190px;
  left: 0;
}
@media screen and (max-width: 767px) {
  .slider_txt {
    bottom: 50px;
  }
}
.access_detail {
  display: table;
  clear: both;
  width: 100%;
}
.access_detail dt {
  display: table-cell;
  width: 15%;
}
.access_detail dd {
  display: table-cell;
  width: 85%;
}
@media screen and (max-width: 767px) {
  .access_detail, .access_detail dt, .access_detail dd {
    display: block;
    width: 100%;
  }
  .access_detail dt {
    background: #f2f2f2;
  }
}
.bg_movie {
  background: url(../img/top/bg_top_01.png) left top no-repeat, url(../img/top/bg_top_02.png) right bottom no-repeat;
  padding: 80px 0;
}
@media screen and (max-width: 767px) {
  .bg_movie {
    padding: 30px 0;
    background-size: 50%;
  }
}
.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  margin-bottom: 30px;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}
@media screen and (max-width: 767px) {
  .li_link_bnr img {
    width: 100%;
  }
}