@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@300..800&display=swap');
* {
	box-sizing: border-box;
}
body {
	background: #fff;
	margin: 0;
	padding: 0;
	line-height: 1.8;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 16px;
	font-weight: 500;
	color: #333;
}
a {
	overflow: hidden;
	vertical-align: bottom;
	text-decoration: none;
}
a:link, a:visited,a:hover {
	color:#333;
}
input,textarea {
	border: 1px solid #ccc;
	padding: 5px;
	font-size: 16px;
	color: #333;
}
figure {
	margin: 0;
}
ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
img {
	vertical-align: bottom;
}
.inner {
	width: 1000px;
	margin: 0 auto;
}
.flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.align-center {
	text-align: center;
}
.sp-block,
.sp-inline {
	display: none;
}
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}
.morebtn a {
	display: block;
	position: relative;
	background: #90CC66;
	width: 200px;
	padding: 13px 0;
	border-radius: 20px;
	text-align: center;
	line-height: 1;
	letter-spacing: 0.1em;
	font-family: 'Open Sans', sans-serif;
	font-weight: 700;
	color: #fff;
}
.morebtn a:after,
.morebtn span:after {
	content: "";
	position: absolute;
	top: 50%;
	right: 20px;
	transform: translate(0, -50%) rotate(135deg);
	width: 6px;
	height: 6px;
	border-top: solid 1px #fff;
	border-left: solid 1px #fff;
}
.morebtn a:hover {
	opacity: 0.8;
}
.returnbtn a {
	display: block;
	margin: 0 auto;
	border: 1px solid #333;
	width: 180px;
	height: 40px;
	line-height: 40px;
	text-align: center;
	text-decoration: none !important;
	letter-spacing: 0.1em;
	font-size: 15px;
	font-weight: 700;
	color: #333 !important;
}
.returnbtn a:hover {
	background: #F0F7EB;
}
#pagescroll {
	margin: 0;
}
#pagescroll a {
	position: fixed;
	bottom: 20px;
	right: 20px;
	z-index: 200;
	background: #333;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	opacity: 0.3;
}
#pagescroll a:before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) rotate(45deg);
	width: 8px;
	height: 8px;
	border-left: solid 3px #fff;
	border-top: solid 3px #fff;
	margin: 2px 0 0;
}
#pagescroll a:hover {
	opacity: 0.7;
}

/* スクロールフェードイン */
.scroll-fade {
	opacity: 0.1;
	transition: all 500ms;
}
.scroll-fade.up {
	transform: translate(0, 50px);
}
.scroll-fade.scrollin {
	opacity: 1;
	transform: translate(0, 0);
}
@media screen and (max-width:1024px) {
	.inner {
		width: 100%;
		padding: 0 5%;
	}
}
@media screen and (max-width:767px) {
	body {
		font-size: 15px;
	}
	input,textarea {
		font-size: 15px;
	}
	.pc-block {
		display: none !important;
	}
	.sp-block {
		display: block !important;
	}
	.sp-inline {
		display: inline !important;
	}
	.morebtn a {
		padding: 10px 0;
	}
	.wrap_box {
		position: relative;
		height: 0;
		padding-top: 56.25%;
	}
	.wrap_box iframe,
	.wrap_box object,
	.wrap_box embed {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}
}
/* main
------------------------------------------------*/
#main {
	display: block;
}
.flex #main {
	width: 69.5%;
}
#main img {
	max-width: 100%;
	height: auto;
}
#main p {
	margin: 0 0 1.87em;
}
#main figure + p {
	margin-top: 1em;
}
@media screen and (max-width:767px) {
	.flex #main {
		width: 100%;
	}
}
/* side
------------------------------------------------*/
#side {
	width: 25%;
}
#side h3 {
	background: #90CC66;
	border-radius: 5px;
	margin: 0;
	padding: 5px 10px;
	font-size: 16px;
	font-weight: 700;
	color: #fff;
}
#side ul {
	margin: 0 0 40px;
}
#side li a {
	display: block;
	position: relative;
	padding: 10px 10px 10px 30px;
	border-bottom: 1px solid #ccc;
}
#side li a:hover {
	background: #F0F7EB;
}
#side li a:before {
	content: "";
	position: absolute;
	top: 50%;
	left: 10px;
	transform: translate(0, -50%) rotate(135deg);
	width: 5px;
	height: 5px;
	border-top: 1px solid #555;
	border-left: 1px solid #555;
}
#side .archive {
	position: relative;
	border-bottom: 1px solid #ccc;
}
#side .archive:after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	left: 12px;
	transform: translate(0, -50%) rotate(135deg);
	width: 5px;
	height: 5px;
	border-left: 1px solid #555;
	border-top: 1px solid #555;
}
#side .archive select::-ms-expand {
	display: none;
}
#side .archive select {
	-webkit-appearance: none;
	appearance: none;
	cursor: pointer;
	border: 0;
	width: 100%;
	padding: 10px 10px 10px 35px;
	line-height: 1.8;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 16px;
	font-weight: 500;
	color: #333;
	outline: none;
}
@media screen and (max-width:767px) {
	#side {
		width: 100%;
	}
	#side h3 {
		margin: 40px 0 0;
	}
	#side ul {
		margin: 0;
	}
	#side .archive select {
		font-size: 15px;
	}
}
/* common
------------------------------------------------*/
ul.bnrlist {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 40px 0 0;
}
.home ul.bnrlist {
	margin: 0;
}
ul.bnrlist li {
	width: 24%;
	max-width: 240px;
	margin: 0 0 10px;
	border-radius: 10px;
	box-shadow: 0 3px 3px rgba(0,0,0,0.1);
}
ul.bnrlist li img,
.widebnr img {
	max-width: 100%;
	height: auto;
	border-radius: 10px;
}
ul.bnrlist li a {
	display: block;
}
ul.bnrlist li a:hover img,
.widebnr a:hover img {
	opacity: 0.8;
}
.widebnr {
	border-radius: 10px;
	box-shadow: 0 3px 3px rgba(0,0,0,0.1);
	margin: 20px 0 !important;
} 
#path {
	margin: 20px auto 80px;
	font-size: 14px;
}
#path a {
	color: #888;
}
#title {
	background: #F0F7EB;
	padding: 30px 0;
}
#title .page-title {
	margin: 0;
	line-height: 1.5;
	letter-spacing: 0.1em;
	font-size: 35px;
	font-weight: 700;
	color: #11A661;
}
#archivelist li {
	border-bottom: 1px solid #ccc;
	margin: 0 0 30px;
	padding: 0 0 30px;
}
#archivelist a {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	color: #555;
}
#archivelist a:hover {
	background: #F0F7EB;
}
#archivelist p {
	width: 43%;
	margin: 0;
}
#archivelist dl {
	width: 52.5%;
	margin: 0;
}
#archivelist dt {
	font-size: 15px;
	color: #888;
}
#archivelist dd {
	margin: 0;
	line-height: 1.6;
	font-size: 14px;
}
#archivelist dt + dd {
	margin: 5px 0;
	font-size: 18px;
}
@media screen and (max-width:767px) {
	ul.bnrlist {
		justify-content: center;
	}
	ul.bnrlist li {
		width: calc(50% - 10px);
	}
	ul.bnrlist li:nth-child(2n) {
		margin-left: 10px;
	}
	#path {
		margin: 20px auto 40px;
		font-size: 13px;
	}
	#title .page-title {
		letter-spacing: 0.04em;
		font-size: 24px;
	}
	#archivelist dt {
		font-size: 14px;
	}
	#archivelist dd {
		font-size: 13px;
	}
	#archivelist dt + dd {
		font-size: 16px;
	}
}
@media screen and (max-width:480px) {
	#archivelist a {
		align-items: flex-start;
	}
	#archivelist dt + dd {
		font-size: 15px;
	}
}
/* post
------------------------------------------------*/
#post .post-meta {
	display: flex;
	justify-content: space-between;
	margin: 0 0 40px;
	font-size: 15px;
	color: #888;
}
#post .post-meta p {
	margin: 0;
}
#post .post-meta a {
	color: #888;
}
#post .post-meta a:hover {
	text-decoration: underline;
}
#post .post-body {
	overflow: hidden;
}
#post .post-body:after {
	content: "";
	display: block;
	clear: both;
}
#post .post-body h2 {
	position: relative;
	margin: 80px 0 40px;
	padding: 0 0 20px;
	line-height: 1.5;
	letter-spacing: 0.06em;
	font-size: 30px;
	font-weight: 700;
}
#post .post-body h2:after {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	background: #90CC66;
	width: 50px;
	height: 5px;
}
#post .post-body h2:first-child {
	margin-top: 0;
}
#post .post-body h3 {
	display: flex;
	background: #90CC66;
	border-radius: 5px;
	margin: 60px 0 25px;
	padding: 15px 20px;
	line-height: 1.5;
	font-size: 25px;
	font-weight: 700;
	color: #fff;
}
#post .post-body h3:before {
	content: "";
	display: block;
	background: #fff;
	width: 4px;
	margin: 0 15px 0 0;
}
#post .post-body h2 + h3 {
	margin-top: 40px;
}
#post .post-body h4 {
	display: flex;
	margin: 40px 0 25px;
	line-height: 1.5;
	font-size: 20px;
	font-weight: 700;
}
#post .post-body h4:before {
	content: "";
	display: block;
	background: #ccc;
	width: 4px;
	margin: 0 15px 0 0;
}
#post .post-body h3 + h4 {
	margin-top: 30px;
}
#post .post-body ul {
	list-style: disc;
	margin: 0 0 1.87em;
	padding: 0 0 0 1.5em;
}
#post .post-body ol {
	list-style: decimal;
	margin: 0 0 1.87em;
	padding: 0 0 0 1.5em;
}
#post .post-body li {
	margin: 0 0 7px;
}
#post .post-body table {
	width: 100%;
	border-collapse: collapse;
	margin: 0 0 1.87em;
}
#post .post-body table th,
#post .post-body table td {
	border: 1px solid #ccc;
	padding: 10px 20px;
	line-height: 1.6;
}
#post .post-body table th {
	background: #F0F7EB;
	text-align: left;
}
#post .post-body thead th,
#post .post-body tfoot th {
	background: #D5ECC5;
}
#post .post-body tfoot tr:first-child th,
#post .post-body tfoot tr:first-child td {
	border-top: double 3px #ccc;
}
#post .post-body a {
	text-decoration: underline;
	color: #005481;
}
#post .post-body .wp-block-button a,
#post .post-body .wp-block-file__button {
	background: #11A661;
	text-decoration: none;
	font-size: 1em;
	color: #fff;
	position: relative;
}
#post .post-body .wp-block-button a:hover,
#post .post-body .wp-block-file__button:hover {
	opacity: 0.7;
}
#post .post-body .wp-block-button.exlink a {
	padding-right: 40px;
}
#post .post-body .wp-block-button.exlink a::after {
	content: "";
	display: block;
	background: url(img/icon-exlink.svg) no-repeat 0 0 / contain;
	width: 15px;
	height: 15px;
	position: absolute;
	top: 50%;
	right: 15px;
	transform: translate(0,-50%);
}
#post .post-body a:hover {
	text-decoration: none;
}
#post .post-body .addtoany_content {
	margin: 50px 0 0;
}
#page-nav {
	border-top: 1px solid #ccc;
	margin: 50px 0 0;
	padding: 40px 0 0;
	font-size: 14px;
}
#page-nav .prev_post,
#page-nav .next_post {
	width: calc(50% - 90px);
}
#page-nav .prev_post {
	padding: 7px 0 0 0;
}
#page-nav .next_post {
	padding: 7px 0 0 0;
	text-align: right;
}
#page-nav .prev_post a {
	position: relative;
	padding: 0 0 0 20px;
}
#page-nav .next_post a {
	position: relative;
	padding: 0 20px 0 0;
}
#page-nav .prev_post a:hover,
#page-nav .next_post a:hover {
	color: #888;
}
#page-nav .prev_post a:after,
#page-nav .next_post a:after {
	content: "";
	position: absolute;
	top: 50%;
	width: 6px;
	height: 6px;
	border-top: solid 1px #888;
	border-left: solid 1px #888;
}
#page-nav .prev_post a:after {
	left: 0;
	transform: translate(0, -50%) rotate(-45deg);
}
#page-nav .next_post a:after {
	right: 0;
	transform: translate(0, -50%) rotate(135deg);
}
#page-nav .all_post a {
	display: block;
	width: 180px;
	height: 40px;
	border: 1px solid #ccc;
	text-align: center;
	line-height: 40px;
	letter-spacing: 0.1em;
	font-family: 'Open Sans', sans-serif;
	font-size: 15px;
	font-weight: 700;
}
#page-nav .all_post a:hover {
	background: #F0F7EB;
}
.wp-pagenavi {
	margin: 50px 0 0;
}
.wp-pagenavi span {
	display: inline-block;
	background: #fff;
	margin: 0 5px 10px;
	padding: 5px 7px;
	line-height: 1;
	vertical-align: middle;
}
.wp-pagenavi span.current {
	background: #90CC66;
	border: 1px solid #ccc;
	color: #fff;
}
.wp-pagenavi a {
	display: inline-block;
	background: #fff;
	border: 1px solid #ccc;
	margin: 0 5px 10px;
	padding: 5px 7px;
	vertical-align: middle;
	text-decoration: none;
	line-height: 1;
	color: #333;
}
.wp-pagenavi a:hover {
	background: #90CC66;
	text-decoration: none !important;
	color: #fff;
}
.search .post-body form,
.error404 .post-body form {
	display: flex;
	align-items: center;
	border: 2px solid #11A661;
	border-radius: 5px;
	margin: 0 0 50px;
	padding: 10px 15px;
}
.search .post-body form input,
.error404 .post-body form input {
	border: 0;
	padding: 0;
	outline: none;
}
.search .post-body form .s,
.error404 .post-body form .s {
	width: calc(100% - 22px);
}
.search .post-body form .searchbtn,
.error404 .post-body form .searchbtn {
	width: 22px;
}
@media screen and (max-width:767px) {
	#post .post-meta {
		margin: 0 0 30px;
	}
	#post .post-body h2 {
		margin: 60px 0 20px;
		letter-spacing: 0.04em;
		font-size: 22px;
	}
	#post .post-body h2:after {
		width: 50px;
	}
	.page #post .post-body h2 {
		font-size: 24px;
	}
	.page #post .post-body h2:after {
		width: 50px;
		margin: 0 0 0 -25px;
	}
	#post .post-body h3 {
		margin: 40px 0 15px;
		padding: 15px;
		font-size: 20px;
	}
	#post .post-body h3:before {
		margin: 0 10px 0 0;
	}
	#post .post-body h2 + h3 {
		margin-top: 30px;
	}
	#post .post-body h4 {
		margin: 30px 0 15px;
		font-size: 18px;
	}
	#post .post-body h3 + h4 {
		margin-top: 20px;
	}
	#post .post-body table th,
	#post .post-body table td {
		padding: 7px 15px;
	}
	#page-nav {
		margin: 40px 0 0;
		font-size: 13px;
	}
	#page-nav .prev_post,
	#page-nav .next_post {
		width: calc(50% - 50px);
	}
	#page-nav .all_post a {
		width: 100px;
		font-size: 14px;
	}
}
/* home
------------------------------------------------*/
.home #title {
	background: none;
	padding: 20px 0 0;
}
.home #title .splide {
	margin: 0 0 60px;
}
.home #title .splide__slide img {
	height: auto;
	width: 100%;
}
.home #title .splide__pagination {
	bottom: -30px;
}
.home #title .splide__pagination__page {
	width: 13px;
	height: 13px;
	margin: 0 6px;
}
.home #title .splide__pagination__page.is-active {
	background: #90CC66;
	transform: none;
}
#main #lead {
	text-align: center;
}
#main #lead h2 {
	margin: 40px 0 15px;
	line-height: 1.5;
	letter-spacing: 0.06em;
	font-size: 25px;
}
#main #lead h2 span {
	color: #11A661;
}
#main #lead h3 {
	background: #11A661;
	border-radius: 10px;
	margin: 20px 0;
	padding: 5px;
	letter-spacing: 0.06em;
	font-size: 20px;
	color: #fff;
}
#main #lead h3 span {
	background: url("img/icon-bus.svg") no-repeat left center;
	background-size: auto 25px;
	padding: 0 0 0 45px;
}
#main #lead h3 strong {
	font-weight: bold;
	color: #FFFF69;
}
/* #main #lead h2 + h3 {
    background: #D5ECC5;
    border-radius: 0;
    margin: 0 0 10px;
    padding: 0;
    letter-spacing: 0.2em;
    font-size: 1.1em;
    color: #11A661;
}
#main #lead p {
	margin: 0;
	font-size: 18px;
	color: #777;
} */
#main #lead ul {
	margin-bottom: 30px;
}
#main #news-area {
	background: #DFEFD3;
	padding: 40px 0;
}
#main #plans-area,
#main #access-area {
	padding-top: 60px;
}
#main #insta-area {
	background: #FCF5F5;
	padding: 60px 0;
}
#main #reason-area {
	background: #F0F7EB;
	padding: 60px 0;
}
#main #news-area h2 {
	margin: 0 0 20px;
	line-height: 1;
	letter-spacing: 0.2em;
	font-family: 'Open Sans', sans-serif;
	font-size: 34px;
	font-weight: 700;
	color: #90CC66;
}
#main #plans-area h2,
#main #insta-area h2,
#main #reason-area h2,
#main #access-area h2 {
	position: relative;
	margin: 0 0 30px;
	padding: 30px 0 0;
	letter-spacing: 0.2em;
	font-size: 31px;
	color: #11A661;
}
#main #plans-area h2:before,
#main #insta-area h2:before,
#main #reason-area h2:before,
#main #access-area h2:before {
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0.3;
	line-height: 1;
	letter-spacing: 0.09em;
	font-family: 'Open Sans', sans-serif;
	font-size: 65px;
	font-weight: 700;
	color: #90CC66;
}
#main #plans-area h2:before {
	content: 'Training Plans';
}
#main #insta-area h2 {
	text-align: center;
	color: #F26666;
}
#main #insta-area h2:before {
	content: 'Follow Me';
	width: 100%;
	text-align: center;
	color: #F26666;
}
#main #reason-area h2:before {
	content: 'Reason';
}
#main #access-area h2:before {
	content: 'Access';
}
#main #news-area .box {
	width: 130px;
}
#main #news-area .morebtn a {
	width: 130px;
}
#main #news-area ul {
	width: calc(100% - 155px);
	border-top: 1px dotted #777;
}
#main #news-area ul li a {
	display: flex;
	padding: 20px 0;
	border-bottom: 1px dotted #777;
	color: #888;
}
#main #news-area ul li a:hover {
	background: #D5ECC5;
}
#main #news-area ul li div:first-child {
	width: 130px;
}
#main #news-area ul li div:last-child {
	font-size: 14px;
}
#main #news-area ul li strong {
	display: block;
	font-size: 16px;
	color: #555;
}
#main #plans-area ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	margin: 0 0 60px;
}
#main #plans-area ul:after {
	content: "";
	display: block;
	width: 32%;
}
#main #plans-area ul li {
	width: 32%;
	margin: 0 0 20px;
}
#main #plans-area ul li a {
	position: relative;
	display: block;
	height: 200px;
	border-radius: 10px;
	line-height: 1.5;
	letter-spacing: 0.06em;
	font-size: 20px;
	font-weight: 700;
	color: #fff;
}
#main #plans-area ul li:nth-child(1) a {
	background: url("img/plans-img01.jpg") no-repeat center;
	background-size: cover;
}
#main #plans-area ul li:nth-child(2) a {
	background: url("img/plans-img02.jpg") no-repeat center;
	background-size: cover;
}
#main #plans-area ul li:nth-child(3) a {
	background: url("img/plans-img03.jpg") no-repeat center;
	background-size: cover;
}
#main #plans-area ul li:nth-child(4) a {
	background: url("img/plans-img04.jpg") no-repeat center;
	background-size: cover;
}
#main #plans-area ul li:nth-child(5) a {
	background: url("img/plans-img05.jpg") no-repeat center;
	background-size: cover;
}
#main #plans-area ul li:nth-child(6) a {
	background: url("img/plans-img06.jpg") no-repeat center;
	background-size: cover;
}
#main #plans-area ul li:nth-child(7) a {
	background: url("img/plans-img07.jpg") no-repeat center;
	background-size: cover;
}
#main #plans-area ul li:nth-child(8) a {
	background: url("img/plans-img08.jpg") no-repeat center;
	background-size: cover;
}
#main #plans-area ul li:nth-child(9) a {
	background: url("img/plans-img09.jpg") no-repeat center;
	background-size: cover;
}
#main #plans-area ul li a:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	background: rgba(0,0,0,0.3);
	width: 100%;
	height: 100%;
}
#main #plans-area ul li a:hover {
	opacity: 0.8;
}
#main #plans-area ul li span {
	display: block;
	position: absolute;
	left: 20px;
	bottom: 20px;
	z-index: 2;
	width: calc(100% - 60px);
}
#main #plans-area ul li span:before,
#main #plans-area ul li span:after {
	content: '';
	position: absolute;
}
#main #plans-area ul li span:before {
	right: -20px;
	bottom: 0;
	width: 26px;
	height: 26px;
	border: 1px solid #fff;
	border-radius: 50%;
}
#main #plans-area ul li span:after {
	right: -8px;
	bottom: 11px;
	transform: rotate(135deg);
	width: 5px;
	height: 5px;
	border-top: solid 1px #fff;
	border-left: solid 1px #fff;
}
#main #insta-area h2 + p {
	text-align: center;
}
#main #insta-area .view {
	background: #fff;
	border: 1px solid #F26666;
	border-radius: 10px;
	padding: 30px;
}
#main #reason-area h3 {
	background: url("img/icon-heart.svg") no-repeat left 30px top;
	background-size: 100px auto;
	margin: 20px 0;
	padding: 10px 0 0;
	line-height: 1.8;
	letter-spacing: 0.06em;
	font-size: 35px;
	font-weight: 700;
	color: #888;
}
#main #reason-area .flex .txt {
	width: 46%;
	color: #777;
}
#main #reason-area .flex .txt p {
	margin: 0;
	font-size: 18px;
}
#main #reason-area .flex .img {
	width: 50%
}
#main #reason-area .flex .img img {
	border-radius: 20px;
}
#main #reason-area ol {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	list-style: none;
	margin: 20px 0 0;
	padding: 0;
}
#main #reason-area ol li {
	width: 31.8%;
	margin: 20px 0 0;
}
#main #reason-area ol li a {
	display: block;
	position: relative;
	background: #fff;
	height: 100%;
	border: 1px solid #90CC66;
	border-radius: 20px;
	padding: 0 20px 20px;
	text-align: center;
	line-height: 1.6;
	font-size: 18px;
	color: #777;
}
#main #reason-area ol li a:hover {
	background: #F0F7EB;
}
#main #reason-area ol li a:before,
#main #reason-area ol li a:after {
	content: '';
	position: absolute;
}
#main #reason-area ol li a:before {
	right: 10px;
	bottom: 10px;
	background: #F0F7EB;
	width: 26px;
	height: 26px;
	border-radius: 50%;
}
#main #reason-area ol li a:after {
	right: 20px;
	bottom: 20px;
	transform: rotate(135deg);
	width: 5px;
	height: 5px;
	border-top: solid 2px #90CC66;
	border-left: solid 2px #90CC66;
}
#main #reason-area ol li .img {
	overflow: hidden;
	margin: 0 -22px;
	height: 200px;
}
#main #reason-area ol li img {
	border-top-left-radius: 20px;
	border-top-right-radius: 20px;
}
#main #reason-area ol li strong {
	position: relative;
	display: block;
	padding: 30px 0 0;
	font-size: 21px;
	font-weight: 700;
	color: #11A661;
}
#main #reason-area ol li strong:before {
	position: absolute;
	top: -25px;
	left: 50%;
	display: block;
	background: #90CC66;
	width: 50px;
	height: 50px;
	border: 2px solid #fff;
	border-radius: 50%;
	margin: 0 0 0 -25px;
	text-align: center;
	line-height: 50px;
	letter-spacing: 0.05em;
	font-family: 'Open Sans', sans-serif;
	font-size: 28px;
	font-weight: 700;
	color: #fff;
}
#main #reason-area ol li:nth-child(1) strong:before {
	content: "1";
}
#main #reason-area ol li:nth-child(2) strong:before {
	content: "2";
}
#main #reason-area ol li:nth-child(3) strong:before {
	content: "3";
}
#main #reason-area ol li:nth-child(4) strong:before {
	content: "4";
}
#main #reason-area ol li:nth-child(5) strong:before {
	content: "5";
}
#main #reason-area ol li:nth-child(6) strong:before {
	content: "6";
}
#main #reason-area ol li span {
	display: block;
}
#main #access-area .flex + h2 {
	margin-top: 50px;
}
#main #access-area .flex .img {
	width: 50%
}
#main #access-area .flex .img p {
	margin: 0;
}
#main #access-area .flex .txt {
	width: 46%;
}
#main #access-area .flex .txt p {
	margin: 0 0 15px;
	font-size: 1.1em;
}
#main #access-area .morebtn a {
	margin: 15px 0 0 auto;
}
#main #access-area .support-tit {
    background: #e1f5f9;
    border-radius: 20px;
    margin: 0 0 30px;
    padding: 30px 20px 20px;
	text-align: center;
}
#main #access-area .support-tit img {
	width: 650px;
}
#main #access-area .txt p strong {
	color: #F26666;
}
#main #access-area .flex .txt .note {
	font-size: 15px;
}
#main #access-area h4 {
	display: flex;
    margin: 40px 0 25px;
    line-height: 1.5;
    font-size: 20px;
    font-weight: 700;
}
#main #access-area h4:before {
	content: "";
	display: block;
	background: #ccc;
	width: 4px;
	margin: 0 15px 0 0;
}
#main #access-area ul {
	list-style: disc;
    margin: 0 0 1.87em;
    padding: 0 0 0 1.5em;
}
@media screen and (max-width:1024px) {
	#main #news-area ul li a {
		display: block;
	}
	#main #news-area ul li div:first-child {
		width: auto;
	}
	#main #plans-area ul:after {
		content: none;
	}
	#main #plans-area ul li {
			width: 48.5%;
	}
	#main #reason-area ol {
		margin: 0;
	}
	#main #reason-area ol li {
		width: 48.5%;
	}
	#main #reason-area h3 {
		font-size: 33px;
	}
}
@media screen and (max-width:767px) {
	.home #title .splide {
		margin: 0 0 30px;
	}
	.home #title .splide__pagination {
		bottom: -20px;
	}
	.home #title .splide__pagination__page {
		width: 10px;
		height: 10px;
	}
	#main #lead h2 {
		margin: 30px 0 10px;
		font-size: 19px;
	}
	#main #lead h3 {
		margin: 10px 0;
		font-size: 19px;
	}
	#main #lead h2 + h3 {
		font-size: 15px;
	}
	#main #lead h3 span {
		background-size: auto 20px;
        line-height: 1.5;
		text-align: left;
        padding: 0 0 0 40px;
        display: block;
        background-position: 5px center;
	}
	#main #lead p {
		text-align: left;
		font-size: 16px;
	}
	#main #lead ul {
		margin-bottom: 20px;
	}
	#main #news-area .inner {
		padding: 0 8%;
	}
	#main #insta-area,
	#main #reason-area {
		padding: 40px 0;
	}
	#main #plans-area,
	#main #access-area {
		padding-top: 40px;
	}
	#main #plans-area h2,
	#main #insta-area h2,
	#main #reason-area h2,
	#main #access-area h2 {
		margin: 0;
		padding: 15px 0 0;
		letter-spacing: 0.1em;
		font-size: 26px;
	}
	#main #plans-area h2:before,
	#main #insta-area h2:before,
	#main #reason-area h2:before,
	#main #access-area h2:before {
		font-size: 44px;
	}
	#main #news-area h2 {
		font-size: 28px;
	}
	#main #news-area .box {
		position: relative;
		width: 100%;
	}
	#main #news-area ul {
		width: 100%;
	}
	#main #news-area .morebtn {
		position: absolute;
		top: -3px;
		right: 0;
		margin: 0;
	}
	#main #plans-area ul {
		margin: 0 0 20px;
	}
	#main #plans-area ul li {
			width: 100%;
	}
	#main #plans-area ul li a {
		height: 150px;
	}
	#main #insta-area .view {
		padding: 20px;
	}
	#main #reason-area .flex,
	#main #access-area .flex.reverse {
		flex-direction: column-reverse;
	}
	#main #reason-area .flex .txt,
	#main #reason-area .flex .img,
	#main #access-area .flex .img,
	#main #access-area .flex .txt {
		width: 100%;
	}
	#main #reason-area h3 {
		background-position: left 15px top 5px;
		background-size: 60px auto;
		font-size: 22px;
	}
	#main #reason-area .flex .txt p {
		font-size: 15px;
	}
	#main #reason-area ol li a {
		border-radius: 10px;
		padding: 0 10px 20px;
		font-size: 16px;
	}
	#main #reason-area ol li a:before {
		width: 16px;
		height: 16px;
	}
	#main #reason-area ol li a:after {
		right: 15px;
		bottom: 15px;
		width: 4px;
		height: 4px;
	}
	#main #reason-area ol li img {
		border-top-left-radius: 9px;
		border-top-right-radius: 9px;
	}
	#main #reason-area ol li .img {
		height: 140px;
		margin: 0 -10px;
	}
	#main #reason-area ol li strong {
		margin: 0 0 5px;
		padding: 20px 0 0;
		line-height: 1.3;
		font-size: 15px;
	}
	#main #reason-area ol li strong:before {
		top: -15px;
		width: 30px;
		height: 30px;
		margin: 0 0 0 -15px;
		line-height: 30px;
		font-size: 18px;
	}
	#main #access-area h4 {
		margin: 30px 0 15px;
		font-size: 18px;
	}
}
@media screen and (max-width:480px) {
	#main #lead h2 {
		font-size: 16px;
	}
	#main #lead h3 {
		font-size: 15px;
	}
	#main #lead p {
		font-size: 14px;
	}
	#main #reason-area ol li a {
		font-size: 12px;
	}
	#main #reason-area ol li .img {
		height: 100px;
	}
	#main #access-area .flex .txt p img {
		max-width: 90%;
	}
	#main #access-area .flex .txt .max img {
		max-width: 100%;
	}
}

/* contact-area
------------------------------------------------*/
#contact-area {
	background: url("img/bg-contactarea.jpg") no-repeat center;
	background-size: cover;
	margin: 60px 0 0;
	padding: 40px 0;
}
#contact-area .inner {
	background: #fff;
	border-radius: 20px;
	padding: 40px 0;
	text-align: center;
}
#contact-area h3 {
	display: inline-block;
	position: relative;
	margin: 0;
	padding: 0 30px;
	line-height: 1.4;
	letter-spacing: 0.1em;
	font-size: 26px;
	color: #11A661;
}
#contact-area h3:before,
#contact-area h3:after {
	content: "";
	position: absolute;
	top: 10px;
	background: #11A661;
	width: 3px;
	height: 30px;
}
#contact-area h3:before {
	left: 10px;
	transform: rotate(-30deg);
}
#contact-area h3:after {
	right: 10px;
	transform: rotate(30deg);
}
#contact-area ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
#contact-area ul li {
	width: 27%;
	margin: 0 20px 0 0;
}
#contact-area ul li:last-child {
	margin: 0;
}
#contact-area ul li a {
	display: block;
	box-shadow: 0 3px 3px rgba(0,0,0,0.1);
	border-radius: 30px;
	padding: 20px 0;
	line-height: 1.3;
	letter-spacing: 0.04em;
	font-size: 17px;
	color: #fff;
}
#contact-area ul li:nth-child(1) a {
	background: #F26666;
}
#contact-area ul li:nth-child(1) a:before {
	content: 'おすすめ';
	background: #FFFF69;
	margin: 0 10px 0 0;
	padding: 0 5px;
	border-radius: 5px;
	letter-spacing: normal;
	font-size: 14px;
	font-weight: 700;
	color: #F26666;
}
#contact-area ul li:nth-child(2) a {
	background: #11A661;
}
#contact-area ul li:nth-child(3) a {
	background: #90CC66;
}
#contact-area ul li a:hover {
	box-shadow: none;
	opacity: 0.8;
}
#contact-area dl {
	display: inline-block;
	margin: 20px 0 0;
}
#contact-area dl dt {
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 1;
	font-family: 'Open Sans', sans-serif;
	font-weight: 500;
	color: #11A661;
}
#contact-area dl dt span {
	margin: 0 5px 0 0;
	letter-spacing: 0.09em;
	font-size: 16px;
}
#contact-area dl dt a {
	letter-spacing: 0.04em;
	font-size: 25px;
	color: #11A661;
}
#contact-area dl dd {
	margin: 5px 0 0 5px;
	font-size: 13px;
}
#contact-area dl dd a {
	background: #eee;
	border-radius: 20px;
	display: inline-block;
	padding: 5px 25px 5px 20px;
	font-size: 0.9em;
	color: #333;
	position: relative;
}
#contact-area dl dd a::after {
	content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: 10px;
    transform: rotate(135deg);
    width: 6px;
    height: 6px;
    border-left: solid 1px #888;
    border-top: solid 1px #888;
    margin: -3px 0 0;
}
#contact-area dl dd a:hover {
	opacity: 0.8;
}
@media screen and (max-width:1024px) {
	#contact-area {
		padding: 40px 20px;
	}
	#contact-area ul li {
		width: 29%;
	}
	#contact-area ul li a {
		font-size: 16px;
	}
	#contact-area ul li:nth-child(1) a:before {
		font-size: 13px;
	}
}
@media screen and (max-width:767px) {
	#contact-area .inner {
		padding: 20px;
	}
	#contact-area h3 {
		font-size: 20px;
	}
	#contact-area h3:before,
	#contact-area h3:after {
		top: 5px;
		width: 2px;
		height: 25px;
	}
	#contact-area ul li {
		width: 31%;
		margin: 0 10px 0 0;
	}
	#contact-area ul li a {
		padding: 16px;
		font-size: 15px;
	}
	#contact-area ul li a span {
		display: block;
	}
	#contact-area ul li:nth-child(1) a:before {
		display: block;
		width: 60px;
		margin: 0 auto 4px;
		font-size: 12px;
	}
}
@media screen and (max-width:480px) {
	#contact-area h3 span {
		display: block;
	}
	#contact-area h3:before,
	#contact-area h3:after {
		top: 5px;
		height: 50px;
	}
	#contact-area ul li {
		width: 100%;
		margin: 0 0 10px;
	}
	#contact-area ul li a {
		padding: 20px;
	}
	#contact-area ul li a span,
	#contact-area ul li:nth-child(1) a:before {
		display: inline;
	}
	#contact-area ul li:nth-child(1) a:before {
		margin: 0 10px 0 0;
	}
}
/* header
------------------------------------------------*/
body {
	padding-top: 135px; /* header + nav 高さ */
}
#header {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10;
	background: #fff;
	width: 100%;
}
#logo {
	height: 32px;
	margin: 0;
	line-height: 1;
	font-size: 10px;
}
#logo img {
	display: block;
}
#logo a {
	display: inline-block;
}
#logo a:hover img {
	opacity: 0.8;
}
#header .flex {
	align-items: center;
}
#header > .flex {
	height: 85px;
	padding: 0 30px;
}
#header dl {
	margin: 0 10px 0 0;
}
#header dl dt {
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 1;
	font-family: 'Open Sans', sans-serif;
	font-weight: 500;
	color: #11A661;
}
#header dl dt span {
	margin: 0 5px 0 0;
	letter-spacing: 0.09em;
	font-size: 16px;
}
#header dl dt a {
	letter-spacing: 0.04em;
	font-size: 25px;
	color: #11A661;
}
#header dl dd {
	margin: 0 -5px 0 0;
	text-align: center;
	font-size: 12px;
}
#header dl dd a {
	position: relative;
}
#header dl dd a::after {
	content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: -10px;
    transform: rotate(135deg);
    width: 6px;
    height: 6px;
    border-left: solid 1px #888;
    border-top: solid 1px #888;
    margin: -3px 0 0;
}
#header dl dd a:hover {
	opacity: 0.8;
}
#header ul.btn {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
}
#header ul.btn li {
	width: 210px;
	margin: 0 5px 0 0;
}
#header ul.btn li:last-child {
	margin: 0;
}
#header ul.btn li a {
	display: block;
	box-shadow: 0 3px 3px rgba(0,0,0,0.1);
	border-radius: 30px;
	padding: 13px 0;
	text-align: center;
	line-height: 1.3;
	letter-spacing: 0.04em;
	font-size: 15px;
	color: #fff;
}
#header .flex ul.btn li:first-child a {
	background: #11A661;
}
#header .flex ul.btn li:last-child a {
	background: #F26666;
}
#header .flex ul.btn li:last-child a:before {
	content: 'おすすめ';
	background: #FFFF69;
	margin: 0 10px 0 0;
	padding: 0 5px;
	border-radius: 5px;
	letter-spacing: normal;
	font-size: 14px;
	font-weight: 700;
	color: #F26666;
}
#header ul.btn li a:hover {
	box-shadow: none;
	opacity: 0.8;
}
#nav {
	background: #90CC66;
}
#nav .pc-block > ul {
	display: flex;
	height: 50px;
	padding: 0 60px 0 0;
}
#nav .pc-block > ul > li {
	position: relative;
	width: calc(100% / 6);
	border-right: 1px solid #9DEABD;
}
#nav .pc-block > ul li:last-child {
	border: 0;
}
#nav .pc-block > ul > li > a {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	text-align: center;
	letter-spacing: 0.04em;
	font-size: 15px;
	font-weight: 700;
	color: #fff;
}
#nav .pc-block > ul > li > a:hover {
	background: #8BD955;
}
#nav .pc-block ul .has-children span {
	position: relative;
}
#nav .pc-block ul .has-children span:before {
	content: '';
	position: absolute;
	top: 50%;
	right: -20px;
	transform: translate(0, -50%) rotate(-135deg);
	width: 7px;
	height: 7px;
	border-top: solid 1px #fff;
	border-left: solid 1px #fff;
}
#nav .pc-block ul .dropmenu {
	display: none;
	position: absolute;
	top: 40px;
	left: 0;
	z-index: 15;
	background: #fff;
	width: 100%;
	box-shadow: 0 3px 6px rgba(0,0,0,0.15);
}
#nav .pc-block ul .dropmenu li {
	border-bottom: 1px solid #ccc;
}
#nav .pc-block ul .dropmenu li a {
	display: block;
	padding: 10px;
	text-align: center;
	line-height: 1.5;
	letter-spacing: 0.04em;
	font-size: 15px;
	color: #555;
}
#nav .pc-block ul .dropmenu li a:hover {
	background: #F0F7EB;
}
.menu-trigger {
	display: block;
	position: absolute;
	top: 92px;
	right: 10px;
	z-index: 5;
	background: #fff;
	width: 36px;
	height: 36px;
	border-radius: 5px;
	cursor: pointer;
}
.menu-trigger .toggle-bar,
.menu-trigger .toggle-bar::before,
.menu-trigger .toggle-bar::after {
	position: absolute;
	width: 16px;
	height: 2px;
	background: #90CC66;
	transition: all 0.2s;
	content: "";
}
.menu-trigger .toggle-bar {
	top: 17px;
	left: 10px;
}
.menu-trigger .toggle-bar::before {
	top: 6px;
}
.menu-trigger .toggle-bar::after {
	top: -6px;
}
body.js-menu-open {
	width: 100%;
	height: 100%;
	position: fixed;
}
.header-back {
	display: block;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	visibility: hidden;
	background: rgba(0, 0, 0, 0.4);
	opacity: 0;
	transition: 0.4s;
}
.js-menu-open .header-back {
	visibility: visible;
	opacity: 1;
}
#nav .slide {
	position: fixed;
	top: 0;
	right: -506px;
	z-index: 10;
	background: #fff;
	width: 506px;
	max-width: 100%;
	max-height: 100%;
	padding: 45px 80px 20px 20px;
	overflow: auto;
	color: #555;
	transition: right 0.4s, top 0.4s;
}
.js-menu-open #nav .slide {
	right: 0;
	box-shadow: -5px 3px 6px -4px rgba(0, 0, 0, 0.3);
}
#nav .slide .closebtn {
	display: none;
	position: fixed;
	top: 20px;
	right: 20px;
	z-index: 1002;
	background: #90CC66;
	width: 36px;
	height: 36px;
	border-radius: 5px;
	cursor: pointer;
}
.js-menu-open #nav .slide .closebtn {
	display: block;
}
#nav .slide .closebtn:hover {
	opacity: 0.8;
}
#nav .slide .closebtn .toggle-bar::before,
#nav .slide .closebtn .toggle-bar::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 10px;
	width: 16px;
	height: 2px;
	background: #fff;
}
#nav .slide .closebtn .toggle-bar::before {
	transform: rotate(45deg);
}
#nav .slide .closebtn .toggle-bar::after {
	transform: rotate(-45deg);
}
#nav .slide form {
	display: flex;
	align-items: center;
	border: 2px solid #11A661;
	border-radius: 5px;
	margin: 0 0 10px;
	padding: 10px 15px;
}
#nav .slide form input {
	border: 0;
	padding: 0;
	outline: none;
}
#nav .slide form .s {
	width: calc(100% - 22px);
}
#nav .slide form .searchbtn {
	width: 22px;
}
#nav .slide ul.btn li {
	width: calc(50% - 5px);
}
#nav .slide ul.btn li a {
	padding: 8px 0;
}
#nav .slide ul.btn li:first-child a {
	background: #F26666;
}
#nav .slide ul.btn li:first-child a:before {
	content: 'おすすめ';
	display: block;
	background: #FFFF69;
	width: 60px;
	margin: 0 auto 2px;
	padding: 0 5px;
	border-radius: 5px;
	letter-spacing: normal;
	font-size: 14px;
	font-weight: 700;
	color: #F26666;
}
#nav .slide ul.btn li:last-child a {
	background: #11A661;
}
#nav .slide dl {
	margin: 20px 0;
}
#nav .slide dl dt {
	position: relative;
}
#nav .slide dl dt:after {
	content: '';
	position: absolute;
	right: 75px;
	top: 12px;
	transform: rotate(135deg);
	width: 5px;
	height: 5px;
	border-top: solid 1px #90CC66;
	border-left: solid 1px #90CC66;
}
#nav .slide dl + ul li a {
	display: block;
	position: relative;
	background: #90CC66;
	padding: 10px 20px;
	border-bottom: 2px solid #fff;
	color: #fff;
}
#nav .slide dl + ul li a:hover {
	background: #8BD955;
}
#nav .slide dl + ul li a:before {
	position: absolute;
	top: 50%;
	right: 17px;
	width: 5px;
	height: 5px;
	content: "";
	border-top: 2px solid #fff;
	border-left: 2px solid #fff;
	transform: translate(0, -50%) rotate(135deg);
}
#nav .slide dl + ul li li a {
	background: #F7F7F7;
	padding: 10px 20px 10px 40px;
	font-size: 14px;
	color: #555;
}
#nav .slide dl + ul li li a:hover {
	background: #F0F7EB;
}
#nav .slide dl + ul li li a:before {
	position: absolute;
	top: 50%;
	right: auto;
	left: 20px;
	background: #90CC66;
	width: 10px;
	height: 2px;
	content: "";
	border: 0;
	transform: translate(0, -50%);
}
@media screen and (max-width:1024px) {
	body {
		padding-top: 145px; /* header + nav 高さ */
	}
	#logo {
		margin: 10px auto 0;
		height: 24px;
	}
	#logo img {
		height: 24px;
	}
	#header > .flex {
		height: 95px;
	}
	#header .flex .flex {
		justify-content: center;
		width: 100%;
		margin: 10px 0;
	}
	#header dl dt span {
		font-size: 14px;
	}
	#header dl dt a {
		font-size: 23px;
	}
	#header dl dd {
		margin: 0 -3px 0 0;
		font-size: 11px;
	}
	#header .flex ul li {
		width: 190px;
	}
	#header .flex ul li a {
		padding: 11px 0;
		font-size: 14px;
	}
	#header .flex ul li:last-child a:before {
		font-size: 13px;
	}
	.menu-trigger {
		top: 102px;
	}
	#nav .pc-block > ul > li > a {
		font-size: 13px;
	}
	#nav .pc-block ul .has-children span:before {
		right: -15px;
		width: 5px;
		height: 5px;
	}
	#nav .pc-block ul .dropmenu li a {
		font-size: 12px;
	}
}
@media screen and (max-width:767px) {
	body {
		padding-top: 60px; /* header 高さ */
	}
	#header {
		box-shadow: 0 3px 6px rgba(0,0,0,0.2);
	}
	#logo {
		height: 28px;
		margin: 0;
	}
	#logo img {
		height: 28px;
	}
	#header > .flex {
		height: 60px;
		padding: 0 20px;
	}
	#header .flex .flex {
		display: none;
	}
	#nav .slide .closebtn,
	.js-menu-open #nav .slide .closebtn {
		display: none;
	}
	.menu-trigger {
		top: 10px;
		right: 15px;
		z-index: 15;
		background: #90CC66;
	}
	.menu-trigger .toggle-bar,
	.menu-trigger .toggle-bar::before,
	.menu-trigger .toggle-bar::after {
		background: #fff;
	}
	.js-menu-open .menu-trigger .toggle-bar {
		background: transparent;
	}
	.js-menu-open .menu-trigger .toggle-bar::before {
		top: 50%;
		transform: rotate(45deg);
	}
	.js-menu-open .menu-trigger .toggle-bar::after {
		top: 50%;
		transform: rotate(-45deg);
	}
	#nav .slide {
		top: 60px;
		right: -100vw;
		width: 100vw;
		max-width: 100%;
		max-height: calc(100% - 60px);
		padding: 20px 20px 0;
		-webkit-overflow-scrolling: touch;
	}
	#nav .slide ul {
		width: calc(100% + 40px);
		margin: 0 -20px;
	}
	#nav .slide ul ul {
		width: 100%;
		margin: 0;
	}
	#header #nav .slide ul.btn {
		justify-content: center;
		width: 100%;
		margin: 0;
	}
}
/* footer
------------------------------------------------*/
#footer {
	position: relative;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding: 60px 30px;
}
#footer dl {
	display: flex;
	align-items: center;
	margin: 0;
	line-height: 1.5;
}
#footer dt {
	margin: 5px.0 0;
	width: 170px;
}
#footer dt a {
	display: block;
}
#footer dt a:hover img {
	opacity: 0.7;
}
#footer dt img {
	max-width: 100%;
	height: auto;
}
#footer dd strong {
	letter-spacing: 0.1em;
	font-size: 23px;
	font-weight: 500;
}
#footer dd {
	margin: 0 0 0 40px;
	font-size: 14px;
}
#footer ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
	font-size: 14px;
}
#footer ul li.sns a {
	display: inline-block;
}
#footer ul li.sns img {
	width: 46px;
	height: auto;
}
#footer ul li.sns {
	margin: 0 0 0 20px;
}
#footer ul li.subnav {
	margin: 0 0 0 30px;
}
#footer ul li:first-child {
	margin: 0;
}
#footer ul li.sns a:hover img,
#footer ul li.subnav a:hover {
	opacity: 0.8;
}
#footer small {
	display: block;
	position: absolute;
	bottom: 60px;
	right: 30px;
	font-size: 12px;
	color: #888;
}
@media screen and (max-width:1024px) {
	#footer {
		justify-content: center;
		padding: 35px;
	}
	#footer ul {
		justify-content: center;
		width: 100%;
		margin: 20px 0;
	}
	#footer small {
		position: relative;
		right: auto;
		bottom: auto;
		text-align: center;
	}
}
@media screen and (max-width:767px) {
	#footer {
		display: block;
		padding: 30px 20px 15px;
	}
	#footer dl {
		flex-direction: column;
		text-align: center;
	}
	#footer dt {
		width: 150px;
		font-size: 18px;
	}
	#footer dd {
		margin: 10px 0 0;
		font-size: 12px;
	}
	#footer ul li.sns {
		width: calc(52% / 3);
		margin: 0 0 20px;
	}
	#footer ul li.subnav {
		width: 50%;
		margin: 0;
	}
	#footer ul li:first-child,
	#footer ul li:nth-child(4) {
		text-align: right;
	}
	#footer ul li:nth-child(2) {
		text-align: center;
	}
	#footer ul li:last-child {
		padding: 0 0 0 20px;
	}
	#footer ul li.sns img {
		width: 36px;
	}
}
@media screen and (max-width:480px) {
	#footer ul li.sns {
		width: calc(70% / 3);
	}
	
}
