<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">@charset "utf-8";

/*============================
body
============================*/
body::before {
	content: "";
	width: 6.35rem;
	height: 5.50rem;
	background-image: url(../img/common/header_top_bg.svg);
	background-position: 0 0;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
}

@media screen and (max-width: 640px) {
	body::before {
		width: 3.50rem;
		height: 2.50rem;
	}
}

/* メニューオープン時はスクロールしない */
body.menu_active {
	overflow: hidden;
}

/*============================
背景画像
============================*/
main {
	position: relative;
}

main::before {
	content: "";
	width: 4.11rem;
	height: 100%;
	background-image: url(../img/common/bg_right.svg);
	background-position: right top;
	background-repeat: repeat-y;
	background-size: contain;
	position: absolute;
	top: 0;
	right: 0;
}

@media screen and (max-width: 640px) {
	main::before {
		width: 1.50rem;
		right: -0.50rem;
		opacity: 0.5;
	}
}

main::after {
	content: "";
	width: 1.53rem;
	height: 100%;
	background-image: url(../img/common/bg_left.svg);
	background-position: left top;
	background-repeat: repeat-y;
	background-size: contain;
	position: absolute;
	top: 8.00rem;
	left: 0;
}

@media screen and (max-width: 640px) {
	main::after {
		width: 0.60rem;
		opacity: 0.5;
	}
}

/*============================
ヘッダー
============================*/
header {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 10;
}

@media screen and (max-width: 640px) {
	header {
		/* スマホ用の記述 */
	}
}

/* ロゴ */
header .logo {
	width: 100%;
	max-width: 4.92rem;
	padding: 0.40rem;
}

@media screen and (max-width: 640px) {
	header .logo {
		max-width: 2.20rem;
		padding: 0.20rem 0.15rem;
	}
}

/* 問い合わせボタン */
header .contact_btn {
	width: 1.20rem;
	height: 1.20rem;
	position: fixed;
	top: 0;
	right: 1.20rem;
	z-index: 22;
}

@media screen and (max-width: 640px) {
	header .contact_btn {
		width: 0.60rem;
		height: 0.60rem;
		right: 0.60rem;
	}
}

header .contact_btn a {
	display: block;
	height: 100%;
	background-color: #F8DF09;
	color: #231815;
	position: relative;
	text-align: center;
}

header .contact_btn a::before {
	content: "";
	width: 0.39rem;
	height: 0.26rem;
	background-image: url(../common/img/icon_mail02_black.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: 0.35rem;
	left: 50%;
	transform: translateX(-50%);
}

@media screen and (max-width: 640px) {
	header .contact_btn a::before {
		width: 0.30rem;
		height: 0.30rem;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}
}

header .contact_btn a span {
	font-size: 0.14rem;
	font-weight: 500;
	display: block;
	width: 100%;
	text-align: center;
	position: absolute;
	bottom: 0.30rem;
	left: 0;
}

@media screen and (max-width: 640px) {
	header .contact_btn a span {
		display: none;
	}
}

header .contact_btn a:hover {
	background-color: #F86E09;
	color: #FFF;
}

header .contact_btn a:hover::before {
	background-image: url(../common/img/icon_mail02_white.svg);
}

/* メニューボタン */
header .glo_navi_btn {
	width: 1.20rem;
	height: 1.20rem;
	background-color: #231815;
	position: fixed;
	right: 0;
	top: 0;
	transition: all 0.3s;
	cursor: pointer;
	z-index: 21;
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn {
		width: 0.60rem;
		height: 0.60rem;
	}
}

header .glo_navi_btn:hover {
	background-color: #00913A;
}

header .glo_navi_btn .menu_bars {
	width: 0.30rem;
	height: 0.30rem;
	position: absolute;
	top: 0.30rem;
	left: 50%;
	transform: translateX(-50%)
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn .menu_bars {
		width: 0.22rem;
		height: 0.22rem;
		top: 36%;
		left: 50%;
		transform: translate(-50%, -50%)
	}
}

header .glo_navi_btn .menu_bars span {
	width: 0.06rem;
	height: 0.06rem;
	background-color: #FFF;
	position: absolute;
	transition: all 0.3s;
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn .menu_bars span {
		width: 0.04rem;
		height: 0.04rem;
	}
}

header .glo_navi_btn .menu_bars span:nth-child(2) {
	left: calc(50% - 0.03rem);
	top: 0;
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn .menu_bars span:nth-child(2) {
		left: calc(50% - 0.02rem);
	}
}

header .glo_navi_btn .menu_bars span:nth-child(3) {
	right: 0;
	top: 0;
}

header .glo_navi_btn .menu_bars span:nth-child(4) {
	left: 0;
	top: calc(50% - 0.03rem);
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn .menu_bars span:nth-child(4) {
		top: calc(50% - 0.02rem);
	}
}

header .glo_navi_btn .menu_bars span:nth-child(5) {
	left: calc(50% - 0.03rem);
	top: calc(50% - 0.03rem);
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn .menu_bars span:nth-child(5) {
		left: calc(50% - 0.02rem);
		top: calc(50% - 0.02rem);
	}
}

header .glo_navi_btn .menu_bars span:nth-child(6) {
	right: 0;
	top: calc(50% - 0.03rem);
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn .menu_bars span:nth-child(6) {
		top: calc(50% - 0.02rem);
	}
}

header .glo_navi_btn .menu_bars span:nth-child(7) {
	left: 0;
	bottom: 0;
}

header .glo_navi_btn .menu_bars span:nth-child(8) {
	left: calc(50% - 0.03rem);
	bottom: 0;
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn .menu_bars span:nth-child(8) {
		left: calc(50% - 0.02rem);
	}
}

header .glo_navi_btn .menu_bars span:nth-child(9) {
	right: 0;
	bottom: 0;
}

header .glo_navi_btn .menu_text {
	font-family: 'Roboto', sans-serif;
	font-size: 0.14rem;
	font-weight: 500;
	letter-spacing: 0.08em;
	display: block;
	width: 100%;
	text-align: center;
	position: absolute;
	bottom: 0.30rem;
	left: 0;
	color: #FFF;
	box-sizing: border-box;
	padding-left: 0.04rem;
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn .menu_text {
		font-size: 0.10rem;
		bottom: 0.10rem;
		padding-left: 0.01rem;
	}
}

header .glo_navi_btn .menu_text::before {
	content: "MENU";
}

header .glo_navi_btn.active .menu_text::before {
	content: "CLOSE";
}

/* メニューボタンがactive */
header .glo_navi_btn.active {
	background-color: #00913A;
}

header .glo_navi_btn.active .menu_bars span:nth-child(2) {
	top: calc(50% - 0.03rem);
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn.active .menu_bars span:nth-child(2) {
		top: calc(50% - 0.02rem);
	}
}

header .glo_navi_btn.active .menu_bars span:nth-child(4) {
	left: calc(50% - 0.03rem);
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn.active .menu_bars span:nth-child(4) {
		left: calc(50% - 0.02rem);
	}
}

header .glo_navi_btn.active .menu_bars span:nth-child(6) {
	right: calc(50% - 0.03rem);
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn.active .menu_bars span:nth-child(6) {
		right: calc(50% - 0.02rem);
	}
}

header .glo_navi_btn.active .menu_bars span:nth-child(8) {
	bottom: calc(50% - 0.03rem);
}

@media screen and (max-width: 640px) {
	header .glo_navi_btn.active .menu_bars span:nth-child(8) {
		bottom: calc(50% - 0.02rem);
	}
}

/*=================================
グローバルナビOPEN時
=================================*/
header .glo_navi {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 20;
	background-color: #FFF;
	width: 100%;
	height: 100vh;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	display: none;
}

header .glo_navi::before {
	content: "";
	width: 4.61rem;
	height: 5.98rem;
	background-image: url(../img/common/glo_navi_bg.svg);
	background-position: right bottom;
	background-repeat: no-repeat;
	background-size: contain;
	z-index: 0;
	position: absolute;
	right: 0;
	bottom: 0;
}

@media screen and (max-height: 800px) {
	header .glo_navi::before {
		width: 2.61rem;
		height: 3.98rem;
		opacity: 0.5;
	}
}

/* 右側のスライダーエリア */
header .glo_navi .slider_wrap {
	width: 39.28%;
	height: 100%;
	position: relative;
	z-index: 1;
}

@media screen and (max-width: 640px) {
	header .glo_navi .slider_wrap {
		display: none;
	}
}

header .glo_navi .slider_wrap .slide {
	height: 100vh;
	overflow: hidden;
}

header .glo_navi .slider_wrap .slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

header .glo_navi .slider_wrap .textbox {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	box-sizing: border-box;
	padding-left: 0.50rem;
	padding-bottom: 0.50rem;
	z-index: 100;
}

header .glo_navi .slider_wrap .textbox img {
	position: relative;
	z-index: 1;
	width: 60%;
	min-width: 2.80rem;
	max-width: 4.00rem;
}

header .glo_navi .slider_wrap .textbox::before {
	content: "";
	width: 100%;
	height: 30vh;
	min-height: 2.00rem;
	background: linear-gradient(to bottom, rgba(0,0,0,0) 0%,rgba(0,0,0,0.35) 100%);
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: 0;
}

/* ナビゲーション（全体） */
header .glo_navi .menu_list_wrap {
	position: absolute;
	top: 50%;
	left: 45%;
	transform: translateY(-50%);
	z-index: 2;
}

@media screen and (max-width: 640px) {
	header .glo_navi .menu_list_wrap {
		top: 0.70rem;
		left: 0;
		width: 100%;
		transform: translateY(0);
	}
}

/* メインナビゲーション */
header .glo_navi .menu_list_wrap .main_menu_wrap {
	min-width: 4.00rem;
	max-width: 6.00rem;
	width: 30vw;
}

@media screen and (max-width: 640px) {
	header .glo_navi .menu_list_wrap .main_menu_wrap {
		min-width: auto;
		max-width: auto;
		width: calc(100% - 0.40rem);
	}
	header .glo_navi .menu_list_wrap .main_menu_wrap .list {
		padding: 0 0.20rem;
		width: 100%;
	}
}

header .glo_navi .menu_list_wrap .main_menu_wrap .list .link a {
	display: block;
	font-size: 0.18rem;
	padding: 0.20rem 0;
	color: #231815;
	border-bottom: 1px solid #CCC;
	position: relative;
	cursor: pointer;
}

@media screen and (max-height: 800px) {
	header .glo_navi .menu_list_wrap .main_menu_wrap .list .link a {
		padding: 0.15rem 0;
		font-size: 0.16rem;
	}
}

@media screen and (max-width: 640px) {
	header .glo_navi .menu_list_wrap .main_menu_wrap .list .link a {
		font-size: 0.16rem;
		letter-spacing: 0.075em;
		padding: 0.15rem 0;
	}
}

@media screen and (max-width: 330px) {
	header .glo_navi .menu_list_wrap .main_menu_wrap .list .link a {
		font-size: 0.145rem;
		padding: 0.12rem 0;
	}
}

header .glo_navi .menu_list_wrap .main_menu_wrap .list .link a:hover {
	padding-left: 0.08rem;
	color: #00913A;
}

@media screen and (max-width: 640px) {
	header .glo_navi .menu_list_wrap .main_menu_wrap .list .link a:hover {
		padding-left: 0;
	}
}

header .glo_navi .menu_list_wrap .main_menu_wrap .list .link a::after {
	content: "";
	width: 0.25rem;
	height: 0.25rem;
	background-image: url(../img/common/glo_navi_arrow.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	transition: all 0.3s;
}

/* コース（アコーディオン） */
header .glo_navi .menu_list_wrap .main_menu_wrap .list .link a.acc::after {
	background-image: url(../img/common/glo_navi_acc.svg);
}

header .glo_navi .menu_list_wrap .main_menu_wrap .list .link a.acc.open {
	color: #00913A;
	padding-left: 0.10rem;
}

@media screen and (max-width: 640px) {
	header .glo_navi .menu_list_wrap .main_menu_wrap .list .link a.acc.open {
		padding-left: 0;
	}
}

header .glo_navi .menu_list_wrap .main_menu_wrap .list .link a.acc.open::after {
	transform: translateY(-50%) rotate(45deg);
}

header .glo_navi .menu_list_wrap .main_menu_wrap .list .link .acc_wrap {
	padding: 0.10rem 0;
	border-bottom: 1px solid #CCC;
	display: none;
}

@media screen and (max-height: 800px) {
	header .glo_navi .menu_list_wrap .main_menu_wrap .list .link .acc_wrap .link_wrap {
		display: flex;
		flex-wrap: wrap;
	}
	header .glo_navi .menu_list_wrap .main_menu_wrap .list .link .acc_wrap .link_wrap .acc_link {
		width: 50%;
	}
	header .glo_navi .menu_list_wrap .main_menu_wrap .list .link .acc_wrap .link_wrap .acc_link a {
		font-size: 0.14rem;
	}
}

header .glo_navi .menu_list_wrap .main_menu_wrap .list .link .acc_wrap .acc_link a {
	border-bottom: 0;
	font-size: 0.16rem;
	padding: 0.10rem;
}

@media screen and (max-width: 640px) {
	header .glo_navi .menu_list_wrap .main_menu_wrap .list .link .acc_wrap .acc_link a {
		font-size: 0.15rem;
	}
}

@media screen and (max-width: 330px) {
	header .glo_navi .menu_list_wrap .main_menu_wrap .list .link .acc_wrap .acc_link a {
		font-size: 0.14rem;
	}
}

header .glo_navi .menu_list_wrap .main_menu_wrap .list .link .acc_wrap .acc_link a:hover {
	padding-left: 0.20rem;
}

header .glo_navi .menu_list_wrap .main_menu_wrap .list .link .acc_wrap .acc_link a::after {
	content: "";
	width: 0.10rem;
	height: 0.06rem;
	background-image: url(../img/common/glo_navi_mini_arrow.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	right: 0.10rem;
}

/* サブナビゲーション */
header .glo_navi .menu_list_wrap .sub_menu_wrap {
	padding-top: 0.20rem;
}

@media screen and (max-width: 640px) {
	header .glo_navi .menu_list_wrap .sub_menu_wrap {
		padding: 0.15rem 0.20rem 0;
	}
	header .glo_navi .menu_list_wrap .sub_menu_wrap .list {
		display: flex;
		flex-wrap: wrap;
	}
	header .glo_navi .menu_list_wrap .sub_menu_wrap .list .link {
		width: 50%;
	}
}

header .glo_navi .menu_list_wrap .sub_menu_wrap .list .link a {
	display: block;
	border-bottom: 0;
	font-size: 0.14rem;
	padding: 0.10rem 0;
	color: #231815;
}

@media screen and (max-height: 800px) {
	header .glo_navi .menu_list_wrap .sub_menu_wrap .list .link a {
		font-size: 0.12rem;
	}
}

@media screen and (max-width: 640px) {
	header .glo_navi .menu_list_wrap .sub_menu_wrap .list .link a {
		font-size: 0.14rem;
		padding: 0.08rem 0;
	}
}

header .glo_navi .menu_list_wrap .sub_menu_wrap .list .link a::before {
	content: "";
	width: 0.20rem;
	height: 0.06rem;
	display: inline-block;
	background-image: url(../img/common/glo_navi_mini_arrow.svg);
	background-position: left center;
	background-repeat: no-repeat;
	background-size: contain;
	position: relative;
	top: -0.015rem;
	left: 0;
	transition: all 0.3s;
}

header .glo_navi .menu_list_wrap .sub_menu_wrap .list .link a:hover::before {
	left: 0.04rem;
}

/*============================
最新NEWS5件
============================*/
.news_list_wrap {
	position: relative;
	z-index: 1;
	margin: 0.60rem 0 1.30rem;
}

@media screen and (max-width: 640px) {
	.news_list_wrap {
		margin: 0.30rem 0 0;
	}
}

.news_list_wrap::before {
	content: "";
	width: calc(50% + 6.40rem);
	height: 100%;
	background-color: rgba(237, 245, 214, 0.5);
	border-radius: 0.20rem 0 0 0.20rem;
	position: absolute;
	right: 0;
	top: 0.20rem;
	z-index: 0;
}

@media screen and (max-width: 640px) {
	.news_list_wrap::before {
		width: 100%;
		height: calc(100% + 0.20rem);
		border-radius: 0;
		top: -0.20rem;
	}
}

.news_list_wrap .title_wrap {
	display: flex;
	align-items: end;
	padding-bottom: 0.30rem;
}

.news_list_wrap .title_wrap span {
	display: inline-block;
	font-size: 0.36rem;
	font-weight: 500;
	position: relative;
	font-family: 'Roboto', sans-serif;
}

@media screen and (max-width: 640px) {
	.news_list_wrap .title_wrap span {
		font-size: 0.26rem;
	}
}

.news_list_wrap .title_wrap span::before {
	content: "";
	width: 100%;
	height: 0.05rem;
	background-color: #00913A;
	position: absolute;
	left: 0;
	top: -0.20rem;
}

.news_list_wrap .title_wrap .jp_text {
	font-size: 0.18rem;
	font-weight: 600;
	padding-left: 0.20rem;
	position: relative;
	top: -0.05rem;
}

@media screen and (max-width: 640px) {
  .news_list_wrap .title_wrap .jp_text {
    font-size: 0.13rem;
    padding-left: 0.10rem;
    top: -0.04rem;
  }
}

.news_list_wrap .news_list {
	padding-left: 0.30rem;
}

@media screen and (max-width: 640px) {
	.news_list_wrap .news_list {
		padding-left: 0;
	}
}

.news_list_wrap .news_list .list .link {
	padding: 0.12rem 0;
}

.news_list_wrap .news_list .list .link a {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	color: #231815;
}

@media screen and (max-width: 640px) {
	.news_list_wrap .news_list .list .link a {
		justify-content: flex-start;
	}
}

.news_list_wrap .news_list .list .link a:hover {
	opacity: 0.7;
}

.news_list_wrap .news_list .list .link a .date {
	font-family: 'Roboto', sans-serif;
	width: 1.00rem;
	font-size: 0.16rem;
}

@media screen and (max-width: 640px) {
	.news_list_wrap .news_list .list .link a .date {
		width: 0.80rem;
		font-size: 0.13rem;
	}
}

.news_list_wrap .news_list .list .link a .cat {
	font-family: 'Roboto', sans-serif;
	width: 1.30rem;
	text-align: center;
}

@media screen and (max-width: 640px) {
	.news_list_wrap .news_list .list .link a .cat {
		font-family: 'Roboto', sans-serif;
		width: 0.80rem;
	}
}

.news_list_wrap .news_list .list .link a .cat .news {
	background-color: #00913A;
	color: #FFF;
	font-size: 0.15rem;
	line-height: 0;
	padding: 0.15rem 0;
	border-radius: 0.30rem;
	display: block;
}

@media screen and (max-width: 640px) {
	.news_list_wrap .news_list .list .link a .cat .news {
		font-size: 0.12rem;
		padding: 0.10rem 0;
	}
}

.news_list_wrap .news_list .list .link a .cat .blog {
	background-color: #F8DF09;
	color: #231815;
	font-size: 0.15rem;
	line-height: 0;
	padding: 0.15rem 0;
	border-radius: 0.30rem;
	display: block;
}

@media screen and (max-width: 640px) {
	.news_list_wrap .news_list .list .link a .cat .blog {
		font-size: 0.12rem;
		padding: 0.10rem 0;
	}
}

.news_list_wrap .news_list .list .link a .title {
	width: calc(100% - 2.90rem);
	font-size: 0.18rem;
}

@media screen and (max-width: 640px) {
	.news_list_wrap .news_list .list .link a .title {
		width: 100%;
		font-size: 0.15rem;
		font-weight: 500;
		line-height: 1.65;
		padding-top: 0.08rem;
	}
}

.news_list_wrap .btn_wrap {
	padding: 0.20rem 0 0.30rem;
}

.news_list_wrap .btn_wrap .list {
	display: flex;
	justify-content: flex-end;
}

@media screen and (max-width: 640px) {
	.news_list_wrap .btn_wrap .list {
		display: block;
		padding:0.10rem 0 0.20rem;
	}
}

.news_list_wrap .btn_wrap .list .btn {
	width: 100%;
	max-width: 3.00rem;
	padding-left: 0.20rem;
}

@media screen and (max-width: 640px) {
	.news_list_wrap .btn_wrap .list .btn {
		padding-left: 0;
		padding-bottom: 0.20rem;
		margin: auto;
	}
}

.news_list_wrap .btn_wrap .list .btn a {
	display: block;
	line-height: 0;
	padding: 0.29rem 0.30rem 0.31rem 0;
	border-radius: 0.60rem;
	background-color: #00913A;
	font-size: 0.18rem;
	font-weight: 600;
	color: #FFF;
	text-align: center;
	position: relative;
}

@media screen and (max-width: 640px) {
	.news_list_wrap .btn_wrap .list .btn a {
		padding: 0.25rem 0.20rem 0.27rem 0;
		font-size: 0.15rem;
	}
}

.news_list_wrap .btn_wrap .list .btn a:hover {
	opacity: 0.7;
}

.news_list_wrap .btn_wrap .list .btn:nth-child(2) a {
	background-color: #F8DF09;
	color: #231815;
}

.news_list_wrap .btn_wrap .list .btn a::before {
	content: "";
	width: 0.30rem;
	height: 0.30rem;
	border-radius: 0.25rem;
	background-color: #FFF;
	position: absolute;
	right: 0.15rem;
	top: 50%;
	transform: translateY(-50%);
}

@media screen and (max-width: 640px) {
	.news_list_wrap .btn_wrap .list .btn a::before {
		width: 0.26rem;
		height: 0.26rem;
	}
}

.news_list_wrap .btn_wrap .list .btn a::after {
	content: "";
	width: 0.14rem;
	height: 0.14rem;
	background-image: url(../img/common/link_arrow_green.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	right: 0.22rem;
	top: 50%;
	transform: translateY(-50%);
}

@media screen and (max-width: 640px) {
	.news_list_wrap .btn_wrap .list .btn a::after {
		width: 0.12rem;
		height: 0.12rem;
	}
}

.news_list_wrap .btn_wrap .list .btn:nth-child(2) a::after {
	background-image: url(../img/common/link_arrow_black.svg);
}

/*============================
共通タイトル
============================*/
.sec_title_wrap {
  text-align: center;
  position: relative;
  padding-bottom: 0.70rem;
}

@media screen and (max-width: 640px) {
	.sec_title_wrap {
		padding-bottom: 0.40rem;
	}
}

.sec_title_wrap .sec_title {
  font-family: 'Roboto', sans-serif;
  font-size: 0.36rem;
  font-weight: 500;
  letter-spacing: 0.10em;
  position: relative;
}

@media screen and (max-width: 640px) {
	.sec_title_wrap .sec_title {
		font-size: 0.26rem;
	}
}

.sec_title_wrap .sec_title span {
  display: inline-block;
  position: relative;
}

.sec_title_wrap .sec_title span::before {
  content: "";
  width: 100%;
  height: 0.05rem;
  display: block;
  margin-bottom: 0.20rem;
}

@media screen and (max-width: 640px) {
	.sec_title_wrap .sec_title span::before {
		margin-bottom: 0.17rem;
	}
}

.sec_title_wrap .sec_title .jp_text {
  padding-top: 0.10rem;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 0.18rem;
  font-weight: 500;
  letter-spacing: 0.06em;
}

@media screen and (max-width: 640px) {
  .sec_title_wrap .sec_title .jp_text {
    font-size: 0.13rem;
  }
}

/*============================
入塾の流れとよくある質問
============================*/
.footer_link_wrap {
	padding-bottom: 1.00rem;
	position: relative;
	z-index: 1;
}

@media screen and (max-width: 640px) {
	.footer_link_wrap {
		padding-bottom: 0.50rem;
	}
}

.footer_link_wrap .list {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.footer_link_wrap .list .detail {
	width: 49.9%;
	min-height: 3.90rem;
	max-height: 4.90rem;
	height: 27.08vw;
	position: relative;
}

@media screen and (max-width: 640px) {
	.footer_link_wrap .list .detail {
		width: 100%;
		min-height: auto;
		max-height: auto;
		height: 2.40rem;
		margin-top: 2px;
	}
}

.footer_link_wrap .list .detail::before {
	content: "";
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,0.6);
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
	transition: all 0.3s;
}

.footer_link_wrap .list .detail:hover::before {
	background-color: rgba(0,0,0,0.3);
}

.footer_link_wrap .list .detail a {
	display: block;
	padding-top: 16%;
	position: relative;
	height: 100%;
	box-sizing: border-box;
}

@media screen and (max-width: 640px) {
	.footer_link_wrap .list .detail a {
		padding-top: 0.60rem;
	}
}

.footer_link_wrap .list .detail a .sec_title_wrap {
	color: #FFF;
	padding-bottom: 0.60rem;
}

@media screen and (max-width: 640px) {
	.footer_link_wrap .list .detail a .sec_title_wrap {
		padding-bottom: 0.30rem;
	}
	.footer_link_wrap .list .detail a .sec_title_wrap .sec_title {
		font-size: 0.20rem;
	}
}

.footer_link_wrap .list .detail a .link {
	text-align: center;
	font-size: 0.20rem;
	font-weight: 500;
	color: #FFF;
	margin-right: 0.50rem;
}

@media screen and (max-width: 640px) {
	.footer_link_wrap .list .detail a .link {
		font-size: 0.16rem;
		margin-right: 0.40rem;
	}
}

.footer_link_wrap .list .detail a .link span {
	display: inline-block;
	line-height: 2;
	position: relative;
}

@media screen and (max-width: 640px) {
	.footer_link_wrap .list .detail a .link span {
		line-height: 1.85;
	}
}

.footer_link_wrap .list .detail a .link span::after {
	content: "";
	width: 0.36rem;
	height: 0.36rem;
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	right: -0.46rem;
	top: 50%;
	transform: translateY(-50%);
}

@media screen and (max-width: 640px) {
	.footer_link_wrap .list .detail a .link span::after {
		width: 0.26rem;
		height: 0.26rem;
		right: -0.36rem;
	}
}

.footer_link_wrap .list .detail.flow {
	background-image: url(../img/common/footer_link_ph01.jpg);
	background-position: center;
	background-size: cover;
}

.footer_link_wrap .list .detail.flow a .sec_title_wrap span::before {
	background-color: #E52D8A;
}

.footer_link_wrap .list .detail.flow a .link span {
	border-bottom: 2px solid #E52D8A;
}

.footer_link_wrap .list .detail.flow a .link span::after {
	background-image: url(../img/common/footer_link_icon_pink.svg);
}

.footer_link_wrap .list .detail.faq {
	background-image: url(../img/common/footer_link_ph02.jpg);
	background-position: center;
	background-size: cover;
}

.footer_link_wrap .list .detail.faq a .sec_title_wrap span::before {
	background-color: #044693;
}

.footer_link_wrap .list .detail.faq a .link span {
	border-bottom: 2px solid #044693;
}

.footer_link_wrap .list .detail.faq a .link span::after {
	background-image: url(../img/common/footer_link_icon_blue.svg);
}

/*============================
フッター
============================*/
footer {
	padding: 3.00rem 0;
	background-image: url(../img/common/footer_bg.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: auto 100%;
	margin-bottom: 0.04rem;
}

@media screen and (max-width: 640px) {
	footer {
		padding: 0;
		background-image: none;
		margin-bottom: 0;
		position: relative;
	}
	footer::before {
		content: "";
		width: 100%;
		height: 24.58vw;
		display: block;
		background-image: url(../img/common/sp_footer_ph_top.jpg);
		background-position: center;
		background-repeat: no-repeat;
		background-size: 110% auto;
	}
	footer::after {
		content: "";
		width: 100%;
		height: 24.58vw;
		display: block;
		background-image: url(../img/common/sp_footer_ph_bottom.jpg);
		background-position: center;
		background-repeat: no-repeat;
		background-size: 110% auto;
	}
}

footer .textbox {
	width: 5.00rem;
	margin: auto;
}

@media screen and (max-width: 640px) {
	footer .textbox {
		width: 100%;
		box-sizing: border-box;
		padding: 0.30rem 0.20rem;
	}
}

footer .textbox .catch {
	font-size: 0.20rem;
	font-weight: 600;
	text-align: center;
	letter-spacing: 0.40em;
	padding-bottom: 0.20rem;
}

@media screen and (max-width: 640px) {
	footer .textbox .catch {
		font-size: 0.15rem;
	}
}

footer .textbox .logo {
	width: 100%;
	max-width: 5.00rem;
	margin: auto;
	padding-bottom: 0.40rem;
}

@media screen and (max-width: 640px) {
	footer .textbox .logo {
		max-width: 3.00rem;
		padding-bottom: 0.10rem;
	}
}

footer .textbox .address {
	padding: 0.30rem 0;
	text-align: center;
	font-size: 0.16rem;
	line-height: 1.68;
}

footer .textbox .btn_wrap {
	padding-bottom: 0.30rem;
}

footer .textbox .btn_wrap .list {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

@media screen and (max-width: 640px) {
	footer .textbox .btn_wrap .list {
		display: block;
	}
}

footer .textbox .btn_wrap .list .btn {
	width: 48%;
}

@media screen and (max-width: 640px) {
	footer .textbox .btn_wrap .list .btn {
		width: calc(100% - 0.40rem);
		margin: auto;
		padding-top: 0.15rem;
	}
}

footer .textbox .btn_wrap .list .btn a {
	display: block;
	line-height: 0;
	background-color: #A40419;
	padding: 0.25rem 0.25rem 0.27rem 0;
	border-radius: 0.50rem;
	font-size: 0.16rem;
	font-weight: 700;
	color: #FFF;
	text-align: center;
	position: relative;
}

footer .textbox .btn_wrap .list .btn a:hover {
	opacity: 0.7;
}

footer .textbox .btn_wrap .list .btn:nth-child(2) a {
	background-color: #00913A;
}

footer .textbox .btn_wrap .list .btn a::before {
	content: "";
	width: 0.25rem;
	height: 0.25rem;
	background-color: #FFF;
	border-radius: 0.50rem;
	position: absolute;
	right: 0.15rem;
	top: 50%;
	transform: translateY(-50%);
}

footer .textbox .btn_wrap .list .btn a::after {
	content: "";
	width: 0.10rem;
	height: 0.10rem;
	background-image: url(../img/common/link_arrow_darkred.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	right: 0.22rem;
	top: 50%;
	transform: translateY(-50%);
}

footer .textbox .btn_wrap .list .btn:nth-child(2) a::after {
	background-image: url(../img/common/link_arrow_green.svg);
}

footer .textbox .copyright {
	border-top: 1px solid #CCC;
	text-align: center;
	padding-top: 0.25rem;
	font-family: 'Roboto', sans-serif;
	font-size: 0.12rem;
}

@media screen and (max-width: 640px) {
	footer .textbox .copyright {
		font-size: 0.10rem;
	}
}

/*============================
無料相談会・無料体験授業はお近くの教室へ
============================*/
.bottom_access {
	background: url(../img/common/access_bg.jpg) no-repeat center;
	background-size: cover;
	padding: 0.72rem 0 0.75rem;
	margin-top: 1.50rem;
	margin-bottom: 1.00rem;
	position: relative;
	z-index: 1;
}

@media screen and (max-width: 640px) {
	.bottom_access {
		padding: 0.40rem 0;
		margin-top: 0.70rem;
		margin-bottom: 0.70rem;
	}
}

.bottom_access .title {
	text-align: center;
	font-size: 0.30rem;
	font-weight: 700;
}

@media screen and (max-width: 640px) {
	.bottom_access .title {
		font-size: 0.20rem;
		line-height: 1.75;
	}
}

.bottom_access .title span{
	border-bottom: 0.03rem solid #00913A;
	padding-bottom: 0.05rem;
}

@media screen and (max-width: 640px) {
	.bottom_access .title span{
		border-bottom: 2px solid #00913A;
		padding-bottom: 0;
	}
}

.bottom_access .text {
	text-align: center;
	font-size: 0.16rem;
	line-height: 2;
	letter-spacing: 0.075em;
	margin-top: 0.35rem;
}

@media screen and (max-width: 640px) {
	.bottom_access .text {
		text-align: center;
		font-size: 0.13rem;
		line-height: 1.85;
		letter-spacing: 0.05em;
		margin-top: 0.20rem;
	}
}

.bottom_access .btn_common  {
	margin-top: 0.45rem;
}

@media screen and (max-width: 640px) {
	.bottom_access .btn_common  {
		margin-top: 0.25rem;
	}
}

.bottom_access .btn_common a {
	margin: auto;
}


/*============================
ボタン
============================*/
.btn_common a {
	display: block;
	line-height: 0;
	padding: 0.46rem 0.25rem 0.48rem 0;
	border-radius: 0.50rem;
	font-size: 0.24rem;
	font-weight: 700;
	color: #FFF;
	text-align: center;
	position: relative;
	background-color: #00913A;
	max-width: 4.60rem;
	width: 100%;
}

@media screen and (max-width: 640px) {
	.btn_common a {
		padding: 0.26rem 0.15rem 0.28rem 0;
		font-size: 0.18rem;
		box-sizing: border-box;
	}
}

.btn_common a:hover {
	opacity: 0.7;
}

.btn_common a::before {
	content: "";
	width: 0.36rem;
	height: 0.36rem;
	background-color: #FFF;
	border-radius: 0.50rem;
	position: absolute;
	right: 0.15rem;
	top: 50%;
	transform: translateY(-50%);
}

@media screen and (max-width: 640px) {
	.btn_common a::before {
		width: 0.26rem;
		height: 0.26rem;
	}
}

.btn_common a::after {
	content: "";
	width: 0.20rem;
	height: 0.20rem;
	background-image: url(../img/common/link_arrow_green.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	right: 0.22rem;
	top: 50%;
	transform: translateY(-50%);
}

@media screen and (max-width: 640px) {
	.btn_common a::after {
		width: 0.12rem;
		height: 0.12rem;
	}
}</pre></body></html>