@charset "utf-8";

/*--------------------------------------------------------------
	header
--------------------------------------------------------------*/

.header_wrap {
	overflow: hidden;
}

#header {
	position: relative;
	padding: 0;
	background-color: #fff;
	height: 175px;
	z-index: 999;
}

.header_logo_area {
	position: fixed;
	z-index: 1000000;
	top: 0;
	left: 0;
	width: 100%;
	height: 175px;
	padding: 0;
	/* overflow: hidden; */
	background-color: #fff;
	box-shadow: 0px 4px 5px -2px rgba(10,10,10,0.2);
}

h1.site_title {
	float: left;
	margin: 35px 0 0;
}

h1.site_title a {
	display: inline-block;
}

h1.site_title a:hover {
	opacity: .7;
}

.header_btn {
	float: right;
	margin: 20px 0 0;
}

.header_btn ul {
	display: flex;
	justify-content: flex-end;
	margin: 0;
	padding: 0;
}

.header_btn ul li {
	list-style: none;
	display: flex;
	align-items: center;
	margin-left: 25px;
}

.header_btn a {
	color: #12a73b;
	display: flex;
	align-items: center;
}

.header_btn a img {
	margin: 0;
	height: 100%;
	margin-right: 13px;
}

.header_btn .line {

}

.header_btn .line a {
	font-family: "LINE Seed JP_OTF B";
	font-weight: 600;
	font-size: 22px;
	font-size: 2.2rem;
	letter-spacing: 1px;
	padding: 10px 20px;
	box-shadow: 0px 0px 10px 0px rgba(161, 203, 178, 0.7);
	transition: .3s;
}
.header_btn .line a:hover {
	box-shadow: inset 0px 0px 10px 0px rgba(161, 203, 178, 0.7);
}

.header_btn .tel {
	display: block;
	text-align: center;
	padding-left: 25px;
}

.header_btn .tel a {
	position: relative;
	font-family: TBUD丸ゴシック Std B;
	font-weight: 700;
	font-size: 28px;
	font-size: 2.8rem;
	line-height: 1;
}

.header_btn .tel a::before {
	position: absolute;
	content: "";
	left: -25px;
	background-image: url(../img/top-tel.png);
	width: 19px;
	height: 31px;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
}

.header_btn .tel p {
	font-size: 14px;
	font-size: 1.4rem;
	margin: 0;
	letter-spacing: 1px;
}

.header_btn_area {
	position: fixed;
	top: 196px;
	right: 0;
	z-index: 9999999;
}

.header_mail {
	margin: 0 0 20px;
}

.header_mail a {
	font-size: 20px;
	font-size: 2.0rem;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #fff;
	background-color: #ec9a0b;
	border-radius: 15px 0 0 15px;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	text-orientation: upright;
	letter-spacing: 5px;
	padding: 25px 12px;
	box-sizing: border-box;
	transition: all .3s;
	border-top: 1px solid #fff;
	border-left: 1px solid #fff;
	border-bottom: 1px solid #fff;
	transition: .2s all;
}

.header_mail a:hover {
	padding: 15px 12px 35px;
}

.page-top {
	line-height: 1.0;
	width: 60px;
	height: 67px;
	border-radius: 10px 0 0 10px;
	text-align: center;
	font-size: 1.2rem;
	z-index: 999;
	border-top: 1px solid #fff;
	border-left: 1px solid #fff;
	border-bottom: 1px solid #fff;
	background-image: -moz-linear-gradient( 90deg, rgb(48,163,100) 0%, rgb(0,215,97) 100%);
	background-image: -webkit-linear-gradient( 90deg, rgb(48,163,100) 0%, rgb(0,215,97) 100%);
	background-image: -ms-linear-gradient( 90deg, rgb(48,163,100) 0%, rgb(0,215,97) 100%);
}

.page-top a {
	display: block;
	height: 57px;
	color: #fff;
	padding-top: 10px;
	transition: .2s all;
}

.page-top a:hover {
	padding-top: 5px;
}



@media screen and (max-width : 1024px) {
		h1.site_title {
		height: 100%;
		float: none;
		display: flex;
		align-items: center;
	}

	.mobile_btn_area {
		position: fixed;
		width: 100%;
		z-index: 999;
		bottom: 0;
		/* border-top: 1px solid #fff; */
	}

	.mobile_btn_area ul {
		display: flex;
		margin: 0;
		padding: 0;
	}

	.mobile_btn_area ul li {
		flex: 1; 
		list-style: none;
		width: 100%;
	}

	.mobile_btn_area ul li a {
		/* font-size: 14px; */
		/* font-size: 1.4rem; */
		font-size: 12px;
		font-size: 1.2rem;
		text-align: center;
		color: #fff;
		background-image: -moz-linear-gradient( 90deg, rgb(48,163,100) 0%, rgb(0,215,97) 100%);
		background-image: -webkit-linear-gradient( 90deg, rgb(48,163,100) 0%, rgb(0,215,97) 100%);
		background-image: -ms-linear-gradient( 90deg, rgb(48,163,100) 0%, rgb(0,215,97) 100%);
		/* padding: 15.25px 0; */
		padding: 13.5px 0;
		box-sizing: border-box;
		/* display: flex; */
		/* justify-content: center; */
		/* align-items: center; */
		display: block;
		line-height: 1;
	}

	.mobile_btn_area ul li a:hover {
		background-image: -moz-linear-gradient( 90deg, rgb(0,215,97) 0%, rgb(48,163,100) 100%);
		background-image: -webkit-linear-gradient( 90deg, rgb(0,215,97) 0%, rgb(48,163,100) 100%);
		background-image: -ms-linear-gradient( 90deg, rgb(0,215,97) 0%, rgb(48,163,100) 100%);
	}

	.mobile_btn_area ul li a i {
		font-size: 16px;
		font-size: 1.6rem;
		/* margin-right: 5px; */
		margin: 0 0 5px;
		display: block;
	}

	.mobile_btn_area .sns a {
		background: linear-gradient(45deg, #feda75 0%, #fa7e1e 25%, #d62976 50%, #962fbf 75%, #4f5bd5 100%);
	}

	.mobile_btn_area .tel a {
		background-color: #12a73b;
	}

	.mobile_btn_area .tel a:hover {
		background-color: #0395f3;
	}

	.mobile_btn_area .mail a {
		background-color: #ff9e13;
	}
	
	.mobile_btn_area .mail a:hover {
		background-color: #e1880d;
	}

}



@media screen and (min-width: 768px) and ( max-width: 1024px) {
	#header {
		height: 65px;
	}

	h1.site_title {
		width: 40%;
		float: left;
		margin: 0 0 0 2%;
	}

}



@media screen and (max-width : 767px) {
	#header {
		height: 65px;
		padding: 0;
		box-shadow: none;
		margin: 0;
	}

	.home #header {
		margin: 0;
	}

	.home .header_wrap {
		/* padding-bottom: 10px; */
	}

	.header_wrap {
		padding-bottom: 0;
	}

	h1.site_title {
		width: 60%;
		margin: 0 0 0 10px;
		/* padding: 13px 0 0 0; */
	}

	h1.site_title img {
		width: 100%;
	}

	.contact_area {
		display: none;
	}

}



/*--------------------------------------------------------------
	container・contents・rowの設定
--------------------------------------------------------------*/

#container {
	/*ページの大枠*/
	width: 100%;
}

.row {
	max-width: 1000px;
	margin: 0 auto;
}

.row_header {
	padding: 0 50px;
}

.row_relative {
	max-width: 1000px;
	margin: 0 auto;
	position: relative;
}

#contents {
	/*ページの中枠*/
	padding: 0 0 30px;
	overflow: hidden;
}

.home #contents {
	/*ページの中枠*/
	padding: 0;
	overflow: hidden;
}



@media screen and (min-width: 768px) and ( max-width: 1024px) {
	.row,
	.row_header,
	.row_relative {
		padding: 0 15px;
	}

	#contents {
		/* padding: 60px 0 30px; */
	}

}


@media screen and (max-width : 767px) {
	.row,
	.row_header,
	.row_relative {
		padding: 0 15px;
	}

	#contents {
		/*ページの中枠*/
		padding: 0 0 30px;
	}

	.home #contents {
		/*ページの中枠*/
	}

}



/*--------------------------------------------------------------
	パンくずリスト
--------------------------------------------------------------*/

.breadcrumbs {
	margin: 0 auto 20px;
	padding-top: 2px;
}

.breadcrumbs span a,
.archive .breadcrumbs span a,
.category .breadcrumbs span a {
	font-size: 1.2rem;
	margin: 0;
	color: #666;
	display: inline-block;
}

.breadcrumbs span a span:hover {
	text-decoration: underline;
}
.single .breadcrumbs span,
.single .breadcrumbs span.post,
.blog .breadcrumbs span.post,
.archive .breadcrumbs span,
.archive .breadcrumbs span.archive,
.page .breadcrumbs span.post,
.search .breadcrumbs span.search {
	font-size: 1.2rem;
	margin: 0;
	display: inline-block;
	line-height: 1.5;
}

.breadcrumbs span.current-item {
	color: #12a73b;
}

.breadcrumbs .fa-chevron-right {
	margin: 0 5px;
	font-size: 1.2rem;
	color: #666;
}

.breadcrumb a {
	/*パンくずリストのリンクの設定*/
	color: #666;
}

.breadcrumb a:hover,
.breadcrumb a:active {
	/*パンくずリストのリンクホバー時の設定*/
	color: #12a73b;
}



@media screen and (max-width : 767px) {
	.breadcrumbs {
		margin: 0 auto 15px;
		padding: 3px 15px 0;
		line-height: 1.5;
	}
}



/*--------------------------------------------------------------
	main
--------------------------------------------------------------*/

#main {

}

#sidebar {

}

.cat_main,
.search_main {
	width: 75%;
	float: right;
}

.cat_sidebar {
	width: 22%;
	float: left;
}



@media screen and (max-width : 767px) {
	#main {
		float: none;
		padding: 0;
		width: 100%;
	}

	.blog #main,
	.single #main {
		padding: 10px 0 0;
	}

	#sidebar {
		float: none;
		width: 100%;
	}

	.cat_main,
	.search_main,
	.cat_sidebar	{
		width: 100%;
		float: none;
	}

}



/*--------------------------------------------------------------
	mainvisu
--------------------------------------------------------------*/

.mainvisu {
	/*メイン画像の大枠*/
	width: 100%;
	margin: 0 auto;
	padding: 0;
	/*メイン画像の背景　削除もしくは変更*/
	background-color: #fff;
	background-image: none;
	background-position: none;
	background-size: none;
}

.slide_area,
.fs-main {
	/*スライダー*/
	position: relative;
	margin: 0 auto 0;
	border: none;
}

.my_slick {
	padding: 0;
	margin: 0;
	line-height: 0;
}

.my_slick .slick-slide img {
	display: block;
	width: 100%;
	margin: 0 auto;
}



@media screen and (min-width: 768px) and ( max-width: 1024px) {
	/*　画面サイズが768pxから1024pxまではここを読み込む　*/
	.mainvisu {
		/* padding: 60px 0 0; */
		width: 100%;
		height: unset;
		padding: 0;
		/* margin: 40px auto 0;*/
	}

}

@media screen and (max-width : 767px) {
	/*768以下の設定*/
	.mainvisu {
		/*メイン画像の大枠*/
		height: auto;
		margin: 0 auto;
	}

}



/*--------------------------------------------------------------
	post
--------------------------------------------------------------*/

ul.post-meta {
	padding: 0;
	margin: 0;
}

ul.post-meta li {
	list-style: none;
}

span.post-meta-key {
	display: block;
	text-align: center;
	font-size: 4.0rem;
	font-family: "TBUDGothic B";
	color: #fff;
	letter-spacing: .1em;
	line-height: 1.5;
}

.entry_header h1 {
	text-align: center;
	font-size: 40px;
	font-size: 4rem;
	font-weight: 400;
	color: #fff;
	margin: 0;
	letter-spacing: .1em;
	line-height: 1.2;
}

.entry_header h1 span {
	font-size: 24px;
	font-size: 2.4rem;
	color: #dfcdb3;
	letter-spacing: .1em;
	display: block;
	font-family: "aisha-latin";
	font-weight: 400;
	font-style: normal;
}

.entry_content {
	padding: 30px 0 0;
	/* width: 85%; */
	margin: 0 0 100px;
}

.blog .entry_content,
.single .entry_content,
.archive .entry_content {
	margin: 0 0 80px;
	padding: 30px 20px 0;
}

.single .entry_footer {
	margin: 0 0 30px;
}



@media screen and (min-width: 768px) and ( max-width: 1024px) {
	.entry_content {
		padding: 30px 15px 0;
		margin: 0 0 60px;
	}

}

@media screen and (max-width : 767px) {
	span.post-meta-key {
		font-size: 3.0rem;
		letter-spacing: .1em;
		line-height: 1.3;
	}

	.entry_header h1 {
		font-size: 2.8rem;
		letter-spacing: .1em;
		line-height: 1.2;
	}

	.entry_header h1 span {
		font-size: 1.8rem;
	}

	.entry_content {
		padding: 0;
		margin: 0 0 50px;
	}

	.blog .entry_content,
	.single .entry_content,
	.archive .entry_content {
		margin: 0 0 50px;
		padding: 0;
	}

}



/*--------------------------------------------------------------
	subvisu
--------------------------------------------------------------*/

.subvisu {
	width: 100%;
	/* max-height: 150px; */
	/* min-height: 150px; */
	background-image: url("../img/subvisu-bg.png");
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	padding: 75px 0;
}

.subvisu h1,
.single .subvisu h2,
.archive .subvisu h2,
.blog .subvisu h2 {
	text-align: center;
	font-size: 4rem;
	font-weight: 400;
	color: #666;
	margin: 0;
	letter-spacing: .1em;
	line-height: 1.2;
}

.subvisu h1 span,
.single .subvisu h2 span,
.archive .subvisu h2 span,
.blog .subvisu h2 span {
	font-size: 2.4rem;
	color: #dfcdb3;
	letter-spacing: .1em;
	display: block;
	font-family: "aisha-latin";
	font-weight: 400;
	font-style: normal;
}



@media screen and (max-width : 767px) {
	.subvisu {
		padding: 35px 0;
	}

	.subvisu h1,
	.single .subvisu h2,
	.archive .subvisu h2,
	.blog .subvisu h2 {
		font-size: 2.8rem;
		letter-spacing: .1em;
		line-height: 1.2;
	}

	.subvisu h1 span,
	.single .subvisu h2 span,
	.archive .subvisu h2 span,
	.blog .subvisu h2 span {
		font-size: 1.8rem;
	}

}



/*--------------------------------------------------------------
	widget
--------------------------------------------------------------*/

.widget_title {
	text-align: center;
	background: #12a73b;
	padding: 5px 0;
	font-size: 1.6rem;
	margin: 10px 0 10px;
	position: relative;
	color: #fff;
	cursor: pointer;
}

.widget ul {
	padding: 0 5px;
	margin: 0 0 20px;
}

.widget ul li {
	list-style: none;
	position: relative;
	border-bottom: 1px solid #eee;
}

.widget ul li::after {
	font-family: "Font Awesome 5 Free";
	content: '\f054';
	font-weight: 900;
	position: absolute;
	top: 30%;
	right: 5px;
	font-size: 1rem;
	color: #cccccc;
}

.widget ul li a {
	font-size: 1.4rem;
	display: block;
	color: #333;
	padding: 8px 15px 8px 5px;
}

.widget_recent_entries ul li a {
	font-size: 1.3rem;
	line-height: 1.5;
	padding: 10px 15px 10px 5px;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.widget ul li a:hover {
	background: #fefbf0;
}

.widget ul li a.current,
.widget ul li a.current ul.children li {
	background: #fefbf0;
}

.widget ul li ul.children {
	border-top: 1px solid #eee;
	padding: 0;
	margin: 0;
}

.widget ul li ul.children li {
	border-bottom: 1px solid #eee;
}

.widget ul li ul.children li a {
	font-weight: 400;
	font-size: 1.3rem;
	padding: 4px 0 4px 20px;
}

.widget ul li ul.children li:last-child {
	border-bottom: none;
}

.widget ul li.current ul.children,
.widget ul li.current ul.children li {
	background: #fff;
}



@media screen and (max-width: 767px) {
	.widget_title {
		margin: 10px 0 15px;
		padding: 10px 0;
		border-radius: 30px;
	}

	.widget span {
		position: absolute;
		top: 0;
		right: 0;
		display: block;
		height: 100%;
		width: 35.5px;
	}

	.widget span::before,
	.widget span::after {
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		display: block;
		background-color: #fff;
		content: '';
		margin: auto;
		-webkit-transition: all 0.4s;
		transition: all 0.4s;
	}

	.widget span::before {
		height: 1px;
		width: 15px;
	}

	.widget span::after {
		height: 15px;
		width: 1px;
	}

	.widget .qa-open span::after {
		opacity: 0;
	}
	.widget ul.widget_cat,
	.widget_archive ul,
	.widget_recent_entries ul {
		display: none;
	}

}


/*--------------------------------------------------------------
	page link 投稿のページでのページ送り
--------------------------------------------------------------*/

.nav-links {
	overflow: hidden;
	/* display: block; */
	display: flex;
	justify-content: space-between;
	width: 100%;
	margin: 0 auto 50px;
	line-height: 1;
}

.pagination .nav-links {
	justify-content: center;
}

.nav_next {
	/*次の記事へのリンク*/
	text-align: right;
	display: block;
	float: right;
}

.nav_previous {
	/*次の記事へのリンク*/
	display: block;
	text-align: left;
	float: left;
}

.nav-links,
.nav_previous,
.nav_next {
	/*ページ送りの共通スタイル*/
	padding: 0;
}

.single .nav-links a {
	/*ページ送りのリンク*/
	display: block;
	padding: 8px 15px 8px;
	border-radius: 5px;
	/* background-color: #d0eec1; */
	color: #333;
	line-height: 1.5;
}

.single .nav-links a:hover {
	/*ページ送りのリンクホバー時*/
	background-color: #62c27d;
}

.blog .nav-links .page-numbers,
.category .nav-links .page-numbers,
.archive .nav-links .page-numbers {
	/*ページ送りのナンバー設定*/
	padding: 12px;
	margin: 0 2px;
	border: 1px solid #12a73b;
	color: #333;
	border-radius: 3px;
}

.nav-links .current {
	/*ページ送りの現在のページ箇所の設定*/
	/* line-height: 30px; */
	/* height: 30px; */
	padding: 10px;
	text-align: center;
}

.link_page_nav {
	/*ページを分割したときのリンクの設定*/
	margin-bottom: 50px;
	text-align: right;
}

.link_page_nav span {
	/*ページを分割したときのリンクの設定*/
	display: inline-block;
	padding: 0;
}

.link_page_nav span {
	/*ページを分割したときのリンクの設定*/
	font-size: 13px;
	line-height: 30px;
	display: inline-block;
	overflow: hidden;
	/* width: 30px; */
	/* height: 30px; */
	margin: 0 5px 0 0;
	-webkit-transition: 0.2s;
	transition: 0.2s;
	text-align: center;
	white-space: nowrap;
	text-decoration: none;
	text-overflow: ellipsis;
	color: #999;
	border-radius: 3px;
	background: #ccc;
}

.link_page_nav a span {
	/*ページを分割したときのリンクの設定*/
	color: #fff;
	background: #ccc;
}

.link_page_nav a:hover span {
	/*ページを分割したときのリンクの設定*/
	color: #000;
	background: #ccc;
}

.blog .nav-links,
.category .nav-links,
.archive .nav-links {
	text-align: center;
	padding: 10px 0;
}

.blog .pagination h2,
.category .pagination h2,
.archive .pagination h2 {
	display: none;
}

.blog .page-numbers:hover,
.category .page-numbers:hover,
.archive .page-numbers:hover {
	background-color: #12a73b;
	color: #fff;
}

.blog .page-numbers.current,
.category .page-numbers.current,
.archive .page-numbers.current {
	padding: 12px;
	margin: 0 2px;
	background-color: #12a73b;
	border: 1px solid #12a73b;
	color: #fff;
	border-radius: 3px;
}



@media screen and (max-width : 767px) {
	/*ページ送りの768px以下の設定*/
	.nav-links {
		overflow: hidden;
		margin: 0 auto 30px;
	}

	.nav_next {
		width: 48%;
	}

	.nav_previous {
		width: 48%;
	}

}



/*--------------------------------------------------------------
	category
--------------------------------------------------------------*/

.category_area {
	padding: 0 15px;
}

.category_area a {
	/*お知らせのカテゴリーのリンクの設定*/
	font-size: 13px;
	font-size: 1.3rem;
	padding: 4px 10px 2px 10px;
	white-space: nowrap;
	text-decoration: none;
	border-radius: 5px;
	background: #fff0f0;
	color: #333;
	display: inline-block;
}

.category_area a:hover {
	/*お知らせのカテゴリーのホバー時の設定*/
	color: #fff;
	background: #c31230;
}



/*--------------------------------------------------------------
	tag（タグを使わない場合は不要）
--------------------------------------------------------------*/
.tagcloud a {
	/*お知らせのタグクラウドのリンクの設定*/
	font-size: 12px;
	font-size: 1.2rem;
	padding: 5px 10px;
	white-space: nowrap;
	text-decoration: none;
	border: 1px solid #ccc;
}

.tagcloud a:hover {
	/*お知らせのタグクラウドのホバー時の設定*/
	color: #fff;
	border: 1px solid #ccc;
	background-color: #999;
}

.tagcloud a:hover span {
	/*お知らせのタグクラウドのリンク背景の設定*/
	color: #999;
	background-color: #fff;
}

.tag-area a {
	/*お知らせのタグのリンクの設定*/
	font-size: 13px;
	font-size: 1.3rem;
	padding: 4px 10px 2px 10px;
	white-space: nowrap;
	text-decoration: none;
	border-radius: 5px;
	background: #999;
}
/*お知らせのタグのホバー時の設定*/
.tag-area a:hover {
	color: #fff;
	background: #ccc;
}



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

.footer {
	padding: 0 0 5px;
	overflow: hidden;
	position: relative;
}

.footer h2 {
	margin: 0;
}

.footer h2 a {
	display: inline-block;
}

.footer h2 a:hover {
	opacity: .7;
}

.footer h2 img {
	display: block;
	height: 100%;
}

.footer_other {
	padding: 90px 0 80px;
	background-image: url(../img/footer-bg.png);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
}

.footer_other h2 {
	font-size: 30px;
	font-size: 3.0rem;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 0 20px;
}

.footer_other .left h2 {
	margin: 0 0 10px;
}

.footer_other h2 img {
	margin: 0 15px 0 0;
}

.footer_other .left {
	float: left;
}

.footer_other .right {
	float: right;
}

.footer_other .left,
.footer_other .right {
	width: 49%;
}

.footer_other ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 0;
}

.footer_other ul li {
	width: 48%;
	list-style: none;
	margin: 0 0 13px;
	text-align: center;
}

.footer_other ul li a {
	display: inline-block;
}

.footer_other ul li p {
	font-size: 15px;
	font-size: 1.5rem;
	text-align: center;
	margin: 0;
	color: #666;
}

.footer_other ul li img {
	margin: 0 0 10px;
	border-radius: 15px;
	box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 10px 0px;
	transition: .3s all;
}

.footer_other ul li img:hover {
	transform: scale(0.97);
}

.footer_other ul li p:hover {
	color: #12a73b;
}

.footer_contact {
	text-align: center;
	padding: 95px 0 42px;
	background-image: url("../img/footer-contact-bg.png");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
}

.footer_contact h2 {
	font-size: 30px;
	font-size: 3.0rem;
	color: #fff;
	letter-spacing: 2px;
}

.footer_contact p {
	color: #fff;
	margin: 30px 0;
	letter-spacing: 1px;
}

.footer_contact ul {
	display: flex;
	justify-content: space-between;
	margin: 0;
	padding: 0;
}

.footer_contact ul li {
	width: 32%;
	list-style: none;
	margin: 0 0 15px;
}

.footer_contact ul li a {
	font-size: 18px;
	font-size: 1.8rem;
	color: #fff;
	background-image: -moz-linear-gradient( 90deg, rgb(48,163,100) 0%, rgb(0,215,97) 100%);
	background-image: -webkit-linear-gradient( 90deg, rgb(48,163,100) 0%, rgb(0,215,97) 100%);
	background-image: -ms-linear-gradient( 90deg, rgb(48,163,100) 0%, rgb(0,215,97) 100%);
	border-radius: 50px;
	padding: 15px 0;
}

.footer_contact ul li a:hover {
	background-image: -moz-linear-gradient( 90deg, rgb(0,215,97) 0%, rgb(48,163,100) 100%);
	background-image: -webkit-linear-gradient( 90deg, rgb(0,215,97) 0%, rgb(48,163,100) 100%);
	background-image: -ms-linear-gradient( 90deg, rgb(0,215,97) 0%, rgb(48,163,100) 100%);
}

.footer_conts {
	padding: 0;
}

.footer_conts .inner_wrap {
	padding: 45px 0 0;
	text-align: center;
	overflow: hidden;
	/* margin-bottom: 40px; */
}

.office_address {
	margin: 0 0 28px;
}

.office_address p {
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 2.5;
	letter-spacing: 3px;
	margin: 0;
}

.office_address p span {
	font-size: 1.7rem;
}

.office_address p a {
	display: inline-block;
	color: #666;
}

.copyright_area {
	text-align: center;
	color: #666;
	font-size: 12px;
	font-size: 1.2rem;
}

.copyright_area a {
	display: inline-block;
	color: #666;
}

.copyright_area a:hover {
	opacity: .7;
}



@media screen and (max-width : 1024px) {
	.footer.active {
		/* 電話ボタンがある場合 */
		margin: 0 0 60px;
	}

	.footer_contact {
		background-repeat: repeat-x; /* 横に繰り返す */
		background-size: auto;
		animation: scrollBg 11s linear infinite;
	}

	@keyframes scrollBg {
		from {
			background-position: 0 0;
		}
		to {
			background-position: -1400px 0;
			/* 画像の横幅1400pxに合わせる */
		}
	}

}



@media screen and (min-width: 768px) and ( max-width: 1024px) {
	.footer h2 {
		text-align: center;
	}

	.footer_other {
		padding: 60px 0 30px;
	}

	.footer_contact {
		padding: 60px 0 20px;
	}

	.footer_contact p {
		margin: 20px 0;
	}

	.footer_contact ul li a {
		font-size: 16px;
		font-size: 1.6rem;
	}

	.office_address p {
		margin: 5px 0 30px;
		font-size: 1.5rem;
		text-align: center;
	}

}



@media screen and (max-width : 767px) {
	.page-top {
		bottom: 70px;
		width: 50px;
		height: 57px;
	}

	.page-top a {
		height: 47px;
		padding-top: 7px;
	}

	.footer_top {
		padding: 20px 0;
	}

	.footer_top ul {
		margin: 0 0 20px;
	}

	.footer_other .left,
	.footer_other .right {
		float: none;
		width: 100%;
	}

	.footer_other .left {
		margin: 0 0 30px;
	}

	.footer_other ul li {
		margin: 0 0 15px;
	}

	.footer_other ul li p {
		font-size: 14px;
		font-size: 1.4rem;
	}

	.footer_contact {
		padding: 25px 0 15px;
	}

	.footer_contact p {
		margin: 15px 0;
	}

	.footer_contact ul {
		display: block;
	}

	.footer_contact ul li {
		width: 100%;
	}

	.footer_contact ul li a {
		padding: 10px 0;
	}

	.footer_conts {
		padding: 40px 0 0;
	}

	.footer_conts .inner_wrap {
		margin-bottom: 0;
		padding: 0;
	}

	.footer_conts .inner_wrap .left,
	.footer_conts .inner_wrap .right {
		float: none;
		width: 100%;
	}

	.footer h2 {
		text-align: center;
	}

	.footer_other {
		padding: 60px 0 5px;
	}

	.footer_other h2 {
		font-size: 20px;
		font-size: 2.0rem;
	}

	.footer_other h2 img {
		margin: 0 10px 0 0;
	}

	.footer_other .left h2 img {
		width: 25px;
	}
	
	.footer_other .right h2 img {
		width: 30px;
	}

	.footer_contact h2 {
		font-size: 25px;
		font-size: 2.5rem;
	}

	.office_address {
		padding: 0;
		margin: 10px 0 20px;
	}

	.office_address p {
		line-height: 1.75;
		text-align: center;
	}

	.footer_link ul li {
		margin-right: 20px;
	}

}



/*--------------------------------------------------------------
	original class
--------------------------------------------------------------*/

.required {
	/*注目箇所のフォントカラー*/
	color: red;
}

.display_sp {
	display: none;
}

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

.text-right {
	text-align: right;
}

.mb-30 {
	margin-bottom: 30px;
}



@media screen and (max-width : 1024px) {
	/*スマホ用設定*/
	.display_pc {
		display: none;
	}

	.display_sp {
		display: block;
	}

}



/*--------------------------------------------------------------
	google map
	GoogleMapをレスポンシブにする設定
--------------------------------------------------------------*/
.ggmap {
 position: relative;
 overflow: hidden;
 height: 0;
 padding-top: 30px;
 padding-bottom: 64%;
}

.ggmap iframe,
.ggmap object,
.ggmap embed {
 position: absolute;
 top: 0;
 left: 0;
 width: 100%;
 height: 100%;
}



@media screen and (max-width : 767px) {
	.ggmap,
	.iframe_wrap {
		/*GoogleMapを入れるときはclass名にggmapを入れてください*/
		position: relative;
		overflow: hidden;
		height: 0;
		padding-top: 30px;
		padding-bottom: 56.25%;
	}

	.ggmap iframe,
	.ggmap object,
	.ggmap embed,
	iframe {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}

}
