@charset "utf-8";

/* noto-sans-jp-regular - latin */
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 400;
  src: local('Noto Sans Japanese Regular'), local('NotoSansJapanese-Regular'),
       url('../fonts/noto-sans-jp-v27-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
       url('../fonts/noto-sans-jp-v27-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
}
/* noto-sans-jp-500 - latin */
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 500;
  src: local('Noto Sans Japanese Medium'), local('NotoSansJapanese-Medium'),
       url('../fonts/noto-sans-jp-v27-latin-500.woff2') format('woff2'), /* Super Modern Browsers */
       url('../fonts/noto-sans-jp-v27-latin-500.ttf') format('truetype'), /* Safari, Android, iOS */
}
/* noto-sans-jp-700 - latin */
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 700;
  src: local('Noto Sans Japanese Bold'), local('NotoSansJapanese-Bold'),
       url('../fonts/noto-sans-jp-v27-latin-700.woff2') format('woff2'), /* Super Modern Browsers */
       url('../fonts/noto-sans-jp-v27-latin-700.ttf') format('truetype'), /* Safari, Android, iOS */
}


body {
	background: #FFFFFF;
	color: #222;
	font-family: 'Open Sans','Noto Sans JP', "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.6;
	-webkit-text-size-adjust: 100%;
}
.pankuzu_bg {
	background-color: #eeeeee;
}
.site_wrapper {
	width: 1130px;
	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: 1150px;
	position: relative;
	z-index: 1;
}

@media screen and (max-width: 767px) {
#wrapper_all {
	min-width: 100%;
}
}
/* header
-------------------------------------------------------------------*/
.bg_hd {
	background: rgba(255,255,255,.4);
	position: absolute;
	top: 0;
	width: 100%;
	padding: 5px 0;
	z-index: 100;
}
.bg_hd a {
}
.header {
}

@media screen and (max-width: 767px) {
.header {
	padding-bottom: 0;
}
}

.txt_h1{
	color: #fff;
}

@media screen and (max-width: 767px) {

.txt_h1{
	padding: 0;
}
}
.bg_h1 {
	padding: 5px 0;
	font-size: 1.2rem;
	background: #222;
	color: #fff;
}
.bg_f1 {
	background: #f8f8f8;
	padding: 5px 0;
	font-size: 1.2rem;
}

@media screen and (max-width: 767px) {
.bg_h1, .bg_f1 {
	padding: 5px 15px;
	font-size: 1.0rem;
}
}
.area_hd01 {
	padding: 20px 0;
	clear: both;
}

@media screen and (max-width: 767px) {
.area_hd01 {
	padding: 10px 10px;
	box-sizing: border-box;
}
}
.area_hd01 .left_area {
	float: left;
	width: 350px;
}
.area_hd01 .right_area {
	float: right;
	width: 550px;
	/* margin-top: 10px; */
}

@media screen and (max-width: 767px) {
.area_hd01 .left_area {
	float: left;
	width: 50%;
	padding: 0;
}
.area_hd01 .right_area {
	float: right;
	width: 45%;
}
}
.tel_area li {
	float: right;
	margin-left: 30px;
}
.tel_area li:last-child {
	margin-left: 0;
}
.tel {
	font-size: 2.8rem;
	line-height: 1;
	text-align: center;
	padding: 6px 0;
}
.tel i {
	position: relative;
	top: -2px;
}
.sp_hd_area > li {
	display: table-cell;
	padding: 0 10px;
	color: #fff;
}
.sp_hd_area > li a{
	color: #fff;
}
.mail_hd a {
	background: #181715;
	box-shadow: 0 0 0 1px #fff, 0 0 0 2px #181715;
	color: #fff;
	padding: 5px 15px;
	font-size: 1.8rem;
	display: block;
	text-align: center;
}
/* navi
-------------------------------------------------------------------

.head_bd{border-left: 5px solid #afda76;clear: both;}
.head_bd ::after {
    position: absolute;
    top: 0px;
    left: -5px;
    z-index: 2;
    content: '';
    width: 5px;
    height: 40px;
    background-color: #475f21;
}
*/

.g_nav_outer {
	clear: both;
	width: 100%;
}
.g_nav li {
	float: left;
	overflow: hidden;
	position: relative;
	margin-right: 40px;
}
.g_nav li:last-child {
	margin-right: 0;
}
.g_nav li a,.g_nav li span {
	display: block;
	position: relative;
	font-weight: bold;
	padding: 8px 0px;
	overflow: hidden;
	font-size: 1.4rem;
	text-align: center;
	line-height: 1.2;
}
.g_nav li a > span {
	display: block;
	font-size: 1.8rem !important;
}
.g_nav li a:after {
	display: block;
	content: "";
	width: 0%;
	height: 3px;
	background-color: #1d2088;
	/*	background-image: linear-gradient(
    90deg,
    #fff 50%,
    #00a0e9 50%, #00a0e9
  );
  background-size: 2px 3px;*/
  
	position: relative;
	top: 5px;
	margin: auto;
	transition: .25s ease-out;
	-webkit-transition: .25s ease-out;
	-moz-transition: .25s ease-out;
	-o-transition: .25s ease-out;
	-ms-transition: .25s ease-out;
}
.g_nav li a:hover:after, .g_nav li.current a:after {
	width: 60%;
}

.bg_hd .g_nav > li a {

color: #fff;
}


@media screen and (max-width : 767px ) {

.head_bd .sp_hd_area li {color: #000;}
.head_bd .sp_hd_area a{color: #000;}
.bg_hd .head_bd .sp_hd_area li {color: #fff;}
.bg_hd .head_bd .sp_hd_area a{color: #fff;}

}


/*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: #f2f2f2;
	overflow: hidden;
	z-index: 9999;
	padding: 20px;
	box-sizing: border-box;
}
.menu a {
	display: block;
	text-decoration: none;
	padding: 15px 25px;
	font-size: 1.5rem;
	font-weight: 700;
}
}
.active {
}
/* contents
-------------------------------------------------------------------*/
.content_area {
/*	margin-bottom: 30px;
*/}
.content_area .main_area {
	float: left;
	width: 840px;
	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: #1d2088;
	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: #1d2088 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.webp) 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: #1d2088;
	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: 100%;
	-webkit-appearance: none;
	font-family: 'Open Sans','Noto Sans JP', "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ ゴシック", sans-serif;
}
.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;
}

*/
.btn_top {
	display: none;
	position: fixed;
	top: 0px;
	right: 0px;
	z-index: 200;
}
.btn_top2 {
	text-align: center;
}
.btn_top2 a {
	display: block;
	width: 100%;
	padding: 15px;
	line-height: 1;
}
.btn_top a:hover *, .btn_top2 a:hover * {
	opacity: 0.35;
}

@media screen and (max-width: 767px) {
.btn_top {
	display: none;
}
.btn_top2 {
	width: 30px;
	position: fixed;
	top: auto;
	right: 0px;
	bottom: 10px;
	z-index: 10;
}
}
.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: 5px 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 {
	color: #fff;
}
.column_ico li {
	background: #1d2088;
	color: #fff;
}
.column_ico li a {
	background: #1d2088;
	color: #fff;
}
.column_fig {
	overflow: hidden;
	margin-bottom: 25px;
	height: 130px
}

@media screen and (max-width: 767px) {
.column_fig {
	overflow: hidden;
	margin-bottom: 15px;
	height: 75px
}
}
.column_tit {
	margin-bottom: 15px;
	border-bottom: 1px solid #aaaaaa;
	min-height: 70px;
	text-indent: -1.5em;
	padding: 0 0 15px 1.5em;
}
.column_tit:before {
	font-family: "Font Awesome 5 Free";
	content: "\f044";
	padding-right : 5px;/*文字との隙間*/
}
.txt_area_column {
	height: 120px;
	position: relative;
}
.column_txt {
	position: relative;
}

@media screen and (max-width: 767px) {
.column_top li {
	margin-bottom: 25px;
}
.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 .column_fig {
	float: none;
	width: 100%;
}
.column_top .column_txt {
	width: 100%;
	float: none;
}
.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;
}
}
.txt_voice {
	font-size: 1.8rem;
	font-weight: bold;
	text-align: left;
	text-indent: -1.5em;
	padding-left: 1.5em;
}
.txt_voice:before {
	font-family: "Font Awesome 5 Free";
	content: "\f4ad";
	padding-right : 5px;/*文字との隙間*/
}
/* footer
-------------------------------------------------------------------*/

.con_tel_box {
	border: 1px solid #181715;
	padding: 15px;
	font-size: 3.2rem;
	font-weight: bold;
}
.mail_side {
	margin-top: 15px;
}
.mail_side a {
	font-size: 1.8rem;
	background-color: #181715;
	font-weight: bold;
	border-radius: 5px;
	color: #fff;
	display: block;
	padding: 20px;
}
.mail_side .googlefont_01 {
	font-size: 3.6rem;
}

@media screen and (max-width: 767px) {
.mail_side {
	margin-top: 0;
}
}
.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 {
}
.ft_area {
	padding: 50px 0 10px;
	/* width: 490px; */
	margin: 0 auto;
}

@media screen and (max-width: 767px) {
.ft_area {
	padding: 25px 15px;
	width: 100%;
}
}
.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 {
	float: left;
	margin-right: 80px;
}
.nav01 {
	width: 110px;
}
.nav02 {
	width: 85px;
}
.nav03 {
	width: 130px;
	margin-right: 0;
}

@media screen and (max-width: 767px) {
.ft_nav {
	float: none;
	margin-right: 0;
}
.nav01 {
	width: 100%;
}
.nav02 {
	width: 100%;
}
.nav03 {
	width: 100%;
}
}
.ft_nav li {
	margin-bottom: 10px;
}

@media screen and (max-width: 767px) {
.ft_nav li {
	float: left;
	width: 50%;
	padding: 0 5px;
	box-sizing: border-box;
}
}
.ft_nav li:nth-child(3n) {
	margin-right: 0;
}
.ft_nav li a {
	/* color: #fff; */
}

@media screen and (max-width: 767px) {
.nav01 li:nth-child(1) {
	float: none;
	width: 100%;
}
.nav01 li:nth-child(2), .nav01 li:nth-child(3), .nav01 li:nth-child(4), .nav01 li:nth-child(5) {
	float: left;
	width: 50%;
	padding: 0 5px;
	box-sizing: border-box;
}
}
.ft_nav li:nth-child(3n) {
	margin-right: 0;
}

.f_nav{
	width: 80%;
	margin: 0 auto;
}
@media screen and (max-width: 767px) {
.f_nav{
	width: 100%;
}
	
}
.f_nav > li{
	width: 16.6666667%;
	float: left;
}
@media screen and (max-width: 767px) {
.f_nav > li{
	width: 50%;
	float: left;
	margin-bottom: 15px;
	padding:0 5px;
}
}
/*ggmap
--------------------------------*/
@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;
	text-shadow: 1px 2px 3px #0070c0;
	left: 0;
}

@media screen and (max-width: 767px) {
.slider_txt {
	bottom: 10px;
	left: 10px;
}
}
.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%;
}
}
