@charset "UTF-8";



/* -------------------------------------------

header

------------------------------------------- */
header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: #fff;
}
header > div {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 0 1rem;
	height: 6rem;
}
@media screen and (max-width: 768px) {
	header > div {
		padding: 0 1rem 0 1.5rem;
		height: 5rem;
	}
}
/* ---- h1 ---- */
h1 {
	width: 20rem;
}
@media screen and (max-width: 768px) {
	h1 {
		width: 14rem;
		margin-bottom: 0.2rem;
	}
}
/* ---- wrap ---- */
header .wrap {
	display: flex;
	align-items: center;
	margin-top: 0.15rem;
}
@media screen and (max-width: 768px) {
	header .wrap {
		margin-top: 0;
	}
}
/* ---- tel ---- */
.header-tel  {
	display: flex;
	align-items: flex-start;
	margin-right: 1.5rem;
	margin-top: 0.2rem;
}
.header-tel img {
	width: 3.6rem;
	margin-right: 1rem;
}
.header-tel span {
	font-size: 2.4rem;
	font-weight: 900;
	line-height: 1;
	margin-top: -0.2rem;
}
.header-tel span i {
	display: block;
	font-weight: 500;
	font-size: 1rem;
	margin-top: 0.5rem;
}
/* ---- cv ---- */
.header-cv {
	display: flex;
}
.header-cv li:not(:last-child) {
	margin-right: 1rem;
}
.header-cv a {
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 0.8rem;
	background: #ccc;
	color: #fff;
	font-weight: bold;
	font-size: 1.5rem;
	height: 4rem;
	padding: 0 1.2rem 0 1.5rem;
	box-shadow: 0.2rem 0.2rem 0.2rem rgba(0,0,0,0.3);
}
.header-cv li:nth-child(1) a {
	background: linear-gradient(to right,#FF9929,#F2622B);
}
.header-cv li:nth-child(2) a {
	background: linear-gradient(to right,#4DBA00,#409B01);
}
.header-cv li:nth-child(3) a {
	background: linear-gradient(to right,#1A549F,#3FA6DF);
}
@media screen and (max-width: 768px) {
	.header-cv li:not(:last-child) {
		margin-right: 0.5rem;
	}
	.header-cv a {
		font-size: 1.2rem;
		height: 3.2rem;
		padding: 0 1rem 0.15rem 1.2rem;
		box-shadow: none;
	}
}



/* -------------------------------------------

kv

------------------------------------------- */
.kv p {
	padding: 5rem 0 8rem 0;
	text-align: center;
	color: #534741;
	font-family: var(--font);
	font-size: 2.9rem;
	letter-spacing: 0.5em;
	line-height: 1.7;
}
.kv p span {
	display: block;
	font-size: 1.5rem;
	margin-top: 1.5rem;
	letter-spacing: 0.2em;
}
@media screen and (max-width: 768px) {
	.kv p {
		font-size: 2.8rem;
		letter-spacing: 0.4em;
	}	
	.kv p span {
		margin-top: 3rem;
	}
}



/* -------------------------------------------

point

------------------------------------------- */
/* ---- h2 ---- */
.point .ttl-wrap {
	display: flex;
	justify-content: center;
}
.point h2 {
	color: var(--purple);
	text-align: center;
	letter-spacing: 0.1em;
	font-size: 2.2rem;
	border-bottom: dotted 2px var(--purple);
	padding-bottom: 0.5rem;
	margin-bottom: 4rem;
}
@media screen and (max-width: 768px) {
	.point h2 {
		font-size: 2.8rem;
	}
}
/* ul */
.point-menu {
	display: flex;
	justify-content: center;
	margin-bottom: 5rem;
}
.point-menu li {
	width: 15rem;
}
.point-menu li:not(:last-child) {
	margin-right: 1rem;
}
.point-menu li span {
	color: var(--pink);
	font-weight: bold;
	display: block;
	text-align: center;
	margin-bottom: 1rem;
	line-height: 1;
	font-size: 1.8rem;
}
.point-menu li span i {
	font-size: 2.4rem;
	margin-left: 0.4rem;
}
@media screen and (max-width: 768px) {
	.point-menu {
		flex-wrap: wrap;
	}
	.point-menu li {
		width: 16rem;
		margin-bottom: 2rem;
	}
	.point-menu li:not(:last-child) {
		margin-right: 1rem;
	}
	.point-menu li span {
		margin-bottom: 0.5rem;
		font-size: 1.8rem;
	}
	.point-menu li span i {
		font-size: 2.6rem;
		margin-bottom: -0.5rem;
	}
}
/* ---- wrap ---- */
.point .wrap {
	background: var(--bg-blue);
	padding: 4rem 0;
}
@media screen and (max-width: 768px) {
	.point .wrap {
		padding: 0 0 3rem 0;
	}
}
/* ul */
.point .wrap ul {
	background: #fff;
	border-radius: 1.5rem;
	padding: 3rem 4rem;
}
.point .wrap ul li:not(:last-child) {
	margin-bottom: 3rem;
}
.point .wrap ul .wrap-1,
.point .wrap ul .wrap-2 {
	position: relative;
}
.point .wrap ul .wrap-2 {
	margin-top: -6rem;
}
.point .wrap ul .wrap-2 figure {
	position: relative;
	z-index: 0;
}
.point .wrap ul .wrap-1 .box,
.point .wrap ul .wrap-2 .box {
	width: 51.5%;
	position: absolute;
	top: 50%;
	transform: translate(0,-50%);
	background: #fff;
	border-radius: 1.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 4rem 3rem 6rem 3rem;
	box-shadow: 0.35rem 0.35rem 0.7rem var(--purple);
	z-index: 2;
}
.point .wrap ul .wrap-2 .box {
	z-index: 1;
	padding: 10rem 3rem 6rem 3rem;
	align-items: flex-start;
	margin-top: -2rem;
}
.point .wrap ul li:nth-child(odd) .wrap-1 .box,
.point .wrap ul li .wrap-2 .box {
	right: 0;
}
.point .wrap ul li:nth-child(even) .wrap-1 .box {
	left: 0;
}
@media screen and (max-width: 768px) {
	.point .wrap ul {
		background: none;
		border-radius: 0;
		padding: 3rem 0;
	}
	.point .wrap ul li:not(:last-child) {
		margin-bottom: 3rem;
	}
	.point .wrap ul .wrap-2 {
		margin-top: 0;
	}
	.point .wrap ul .wrap-1 .box,
	.point .wrap ul .wrap-2 .box {
		width: 80%;
		position: relative;
		top: auto;
		transform: none;
		padding: 2rem 3rem 3rem 3rem;
		margin: -4rem auto 0 auto;
	}
	.point .wrap ul .wrap-2 .box {
		padding: 2rem 3rem 3rem 3rem;
		margin-top: 0;
	}
	.point .wrap ul li:nth-child(odd) .wrap-1 .box,
	.point .wrap ul li .wrap-2 .box {
		right: auto;
	}
	.point .wrap ul li:nth-child(even) .wrap-1 .box {
		left: auto;
	}
}
/* h3 */
.point h3 {
	display: flex;
	flex-direction: column;
	align-items: center;
	color: var(--purple);
	line-height: 1;
	font-size: 2.6rem;
	margin-bottom: 1rem;
}
.point h3 img {
	width: auto;
	height: 8rem;
	margin-bottom: 3rem;
}
@media screen and (max-width: 768px) {
	.point h3 {
		font-size: 2.3rem;
	}
	.point h3 img {
		height: 10rem;
		margin-bottom: 1.2rem;
	}
}
/* h4 */
.point h4 {
	color: var(--blue);
	line-height: 1.4;
	font-size: 2.6rem;
	margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
	.point h4 {
		margin-top: 4rem;
		font-size: 2.2rem;
	}
}



/* -------------------------------------------

blog

------------------------------------------- */
.blog {
	padding-top: 5rem;
}
.blog a {
	display: flex;
	justify-content: center;
	align-items: center;
}
.blog p {
	margin-right: 4rem;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.5;
	letter-spacing: 0.1em;
	background: url(../img/arrow-blue.png) no-repeat center right;
	background-size: auto 1.5rem;
	padding-right: 5rem;
}
.blog p span {
	border-bottom: solid 1px #000;
}
.blog img {
	width: 24rem;
}
@media screen and (max-width: 768px) {
	.blog a {
		flex-direction: column;
	}
	.blog p {
		margin-right: 0;
		margin-bottom: 1rem;
		font-size: 2rem;
		text-align: center;
		background: url(../img/arrow-blue-2.png) no-repeat center bottom;
		background-size: 2rem auto;
		padding-right: 0;
		padding-bottom: 5rem;
	}
}



/* -------------------------------------------

cv

------------------------------------------- */
.cv {
	background: var(--purple);
	padding: 3rem 0;
	color: #fff;
	display: flex;
	flex-direction: column;
	align-items: center;
}
.cv.adjust {
	padding: 3rem 0 0 0;
}
.cv a {
	color: #fff
}
/* ---- h2 ---- */
.cv h2 {
	font-size: 1.8rem;
	letter-spacing: 0.15em;
}
@media screen and (max-width: 768px) {
	.cv h2 {
		font-size: 1.8rem;
	}
}
/* ---- ul ---- */
.cv ul {
	margin: 2.5rem 0;
	display: flex;
	align-items: center;
	justify-content: center;
}
.cv ul li:not(:last-child) {
	margin-right: 2rem;
}
.cv ul li:not(:last-child) a {
	padding-bottom: 0.35rem;
}
.cv ul a {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	width: 30rem;
	height: 7.6rem;
	border-radius: 0.5rem;
	border: solid 1px #fff;
	font-weight: bold;
	font-size: 2.2rem;
	position: relative;
}
.cv ul a::before {
	content: "";
	width: 1.5rem;
	height: 1.5rem;
	background: url(../img/arrow-wh.png) no-repeat;
	background-size: 100% auto;
	position: absolute;
	right: 1rem;
	top: calc(50% - 0.75rem)
}
.cv ul a span {
	font-size: 1.2rem;
	color: #534741;
	background: #f9dc53;
	border-radius: 10rem;
	padding: 0 2rem;
	letter-spacing: 0.2em;
	margin-top: 0.2rem;
	margin-bottom: 0.3rem;
}
.cv li:nth-child(1) a {
	background: linear-gradient(to right,#FF9929,#F2622B);
}
.cv li:nth-child(2) a {
	background: linear-gradient(to right,#4DBA00,#409B01);
}
@media screen and (max-width: 768px) {
	.cv ul {
		margin: 2.5rem 0;
		display: block;
	}
	.cv ul li:not(:last-child) {
		margin-right: 0;
		margin-bottom: 1.5rem;
	}
	.cv ul a {
		width: 30rem;
		height: 8rem;
		font-size: 2.2rem;
	}
	.cv ul a span {
		font-size: 1.2rem;
		padding: 0 2rem 0.1rem 2rem;
	}
}
/* ---- tel ---- */
.cv-tel a {
	display: flex;
	align-items: flex-start;
}
.cv-tel img {
	width: 4rem;
	margin-top: 0.6rem;
	margin-right: 1.5rem;
}
.cv-tel span {
	font-weight: 900;
	font-size: 3.6rem;
	line-height: 1;
}
.cv-tel span i {
	font-size: 1rem;
	font-weight: 500;
	display: block;
	margin-top: 0.8rem;
}
@media screen and (max-width: 768px) {
	.cv-tel a {
		text-decoration: none;
	}
	.cv-tel img {
		width: 5rem;
	}
}
/* ---- wrap ---- */
.cv .wrap {
	display: flex;
	align-items: center;
	justify-content: center;
}
.cv .wrap > a {
	width: 27rem;
	display: block;
}
@media screen and (max-width: 768px) {
	.cv .wrap {
		flex-direction: column;
	}
	.cv .wrap > a {
		margin-top: 3rem;
		width: 28rem;
	}
}



/* -------------------------------------------

plan

------------------------------------------- */
.plan {
	padding: 6rem 0;
}
@media screen and (max-width: 768px) {
	.plan {
		padding: 6rem 3rem;
	}
}
/* table */
table {
	width: 48rem;
	margin: 0 auto;
}
table thead {
	background: var(--orange);
	color: #fff;
	border-bottom: solid 0.6rem #fff;
	font-size: 1.8rem;
}
table thead th {
	padding: 1rem 0;
	border-radius: 1rem 1rem 0 0;
}
table tbody tr {
	background: var(--bg-yellow);
}
table tbody tr:nth-of-type(1) {
	border-bottom: solid 2rem #fff;
}
table tbody th {
	width: 30%;
	text-align: center;
	padding: 1.5rem 0;
	font-size: 1.8rem;
	vertical-align: middle;
}
table tbody td {
	padding: 1.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
}
table tbody td span {
	font-family: var(--font);
	font-weight: bold;
	font-style: italic;
	line-height: 1;
	font-size: 2.8rem;
}
table tbody td span strong {
	font-size: 4rem;
	margin-right: 0.5rem;
}
table tbody td span i {
	font-size: 1.6rem;
	font-family: 'Noto Sans JP', sans-serif;
}
table tbody td > i {
	letter-spacing: 0.1em;
	margin-top: 1rem;
}
@media screen and (max-width: 768px) {
	table {
		width: 100%;
		margin: 0 auto;
	}
	table tbody tr {
		background: var(--bg-yellow);
	}
	table tbody tr:nth-of-type(1) {
		border-bottom: solid 2rem #fff;
	}
	table tbody th {
		font-size: 1.6rem;
	}
	table tbody td {
		padding: 1.5rem 0;
	}
	table tbody td span {
		font-size: 2.4rem;
	}
	table tbody td span strong {
		font-size: 3.6rem;
	}
	table tbody td span i {
		font-size: 1.2rem;
	}
	table tbody td > i {
		margin-top: 0.5rem;
		font-size: 1.2rem;
	}
}



/* -------------------------------------------

amount

------------------------------------------- */
.amount {
	padding: 3rem 0 6rem 0;
}
@media screen and (max-width: 768px) {
	.amount {
		padding: 3rem 3rem 6rem 3rem;
	}
}
/* ---- h2 ---- */
.amount h2 {
	margin-bottom: 2rem;
}
/* ---- p ---- */
.amount h2 + p {
	letter-spacing: 0.2em;
	font-size: 1.8rem;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 2.5rem;
}
.amount h2 + p i {
	font-size: 1.2rem;
}
@media screen and (max-width: 768px) {
	.amount h2 + p {
		flex-direction: column;
		font-size: 1.6rem;
		margin-top: -1rem;
		margin-bottom: 3rem;
	}
	.amount h2 + p i {
		font-size: 1.2rem;
		text-align: center;
		line-height: 1.4;
	}
}
/* ---- ul ---- */
.amount ul {
	display: flex;
	justify-content: space-between;
}
.amount ul li {
	width: 13.7%;
}
@media screen and (max-width: 768px) {
	.amount ul {
		flex-wrap: wrap;
	}
	.amount ul li {
		width: 24.5%;
	}
	.amount ul li:nth-child(n + 5) {
		margin-top: 0.5rem;
	}
	.amount ul li:last-child {
		display: flex;
		align-items: center;
		justify-content: center;
		font-size: 1.2rem;
	} 
}
/* ---- dl ---- */
.amount dt {
	background-color: var(--orange);
	color: #fff;
	text-align: center;
	letter-spacing: 0.2em;
	padding: 0.8rem 0 0.9rem 0;
	margin-bottom: 0.5rem;
}
.amount dd {
	background: var(--bg-yellow);
	text-align: center;
	font-family: var(--font);
	font-weight: bold;
	font-size: 1.6rem;
	padding: 0.8rem 0 0.9rem 0;
}
.amount ul + div {
	text-align: right;
}
@media screen and (max-width: 768px) {
	.amount dt {
		font-size: 1.3rem;
		padding: 0.5rem 0 0.6rem 0;
		margin-bottom: 0.3rem;
	}
	.amount dd {
		font-size: 1.5rem;
		padding: 0.6rem 0 0.5rem 0;
	}
}
/* ---- p ---- */
.amount > p {
	font-size: 1.2rem;
	margin-top: 2rem;
}



/* -------------------------------------------

facility

------------------------------------------- */
.facility {
	padding: 6rem 0;
	background: var(--bg-yellow);
}
/* ---- movie ---- */
.facility > .movie {
	width: 56rem;
	margin: 0 auto;
}
.facility video {
	width: 100%;
}
.movie iframe {
	width: 100%;
	height: 25.63vw;
}
@media screen and (max-width: 768px) {
	.facility > .movie {
		width: 100%;
		margin: 0 auto;
	}
	.movie iframe {
		width: 100%;
		height: 54.93vw;
	}
}
/* ---- h3 ---- */
.facility h3 {
	text-align: center;
	margin: 4rem 0 2rem 0;
	font-size: 2rem;
}

/* ---- slider ---- */
#loopslider,
#loopslider ul,
#loopslider ul li,
#loopslider img {
	height: 150px;
}
#loopslider ul li {
	width: 240px;
}
#loopslider img {
	object-fit: cover;
	padding: 0 1rem;
}
#loopslider {
	margin: 0 auto;
	width: 100%;
	text-align: left;
	position: relative;
	overflow: hidden;
}
#loopslider ul {
	float: left;
	display: inline;
	overflow: hidden;
	margin: 0;
	padding: 0;
}
#loopslider ul li {
	float: left;
	display: inline;
	overflow: hidden;
}
#loopslider ul:after {
	content: ".";
	height: 0;
	clear: both;
	display: block;
	visibility: hidden;
}
#loopslider ul {
	display: inline-block;
	overflow: hidden;
}
@media screen and (max-width: 768px) {
	#loopslider,
	#loopslider ul,
	#loopslider ul li,
	#loopslider img {
		height: 120px;
	}
	#loopslider ul li {
		width: 200px;
	}
}



/* -------------------------------------------

access

------------------------------------------- */
.access {
	padding: 6rem 0;
}
@media screen and (max-width: 768px) {
	.access {
		padding: 6rem 3rem;
	}
}
/* ---- dl ---- */
.access h2 + dl {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.6rem;
	font-weight: 500;
}
.access h2 + dl dt {
	color: #fff;
	background: linear-gradient(to right, #8589ce,#51afcf);
	padding: 0.2rem 1.5rem 0.35rem 1.5rem;
	margin-right: 1.5rem;
}
/* ---- figure ---- */
.access > figure {
	width: 68rem;
	margin: 2rem auto 4rem auto;
}
@media screen and (max-width: 768px) {
	.access > figure {
		width: auto;
		margin: 2rem auto 3rem auto;
	}
}
/* ---- dl ---- */
.access > figure + dl {
	width: 56rem;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	font-size: 1.6rem;
	font-weight: 500;
}
.access > figure + dl dt {
	width: 8rem;
	background: var(--purple);
	color: #fff;
	text-align: center;
}
.access > figure + dl dd {
	width: 48rem;
	padding-left: 3rem;
}
.access > figure + dl dd:not(:last-of-type) {
	margin-bottom: 3rem
}
.access > figure + dl dd img {
	width: 8rem;
	margin-bottom: 1rem;
	display: block;
}
@media screen and (max-width: 768px) {
	.access > figure + dl {
		width: auto;
	}
	.access > figure + dl dt {
		margin-bottom: 1rem;
	}
	.access > figure + dl dd {
		width: 100%;
		padding-left: 0;
	}
}



/* -------------------------------------------

area

------------------------------------------- */
.area {
	padding: 3rem 0 6rem 0;
}
/* ---- h2 ---- */
.area h3 {
	font-family: var(--font);
	color: #534741;
	font-weight: normal;
	letter-spacing: 1.3rem;
	text-align: center;
	font-size: 3.2rem;
	white-space: nowrap;
	margin-bottom: 1rem;
}
.area h3 + p {
	margin-bottom: 2rem;
}
@media screen and (max-width: 768px) {
	.area h3 {
		font-size: 2.7rem;
		white-space: normal;
		line-height: 2
	}
	.area h3 + p {
		padding: 0 4rem;
		margin-bottom: 2.5rem;
	}
}
/* ---- figure ---- */
.area figure {
	margin-bottom: 4rem;
	padding-bottom: 4rem;
	border-bottom: solid 1px #ccc;
}
.area figure + p {
	font-size: 1.2rem;
	margin-bottom: 3rem;
}
@media screen and (max-width: 768px) {
	.area figure {
		margin-bottom: 4rem;
		padding-bottom: 4rem;
		border-bottom: solid 1px #ccc;
	}
	.area figure + p {
		padding: 0 4rem;
		font-size: 1.2rem;
		margin-bottom: 3rem;
	}
}
.area section {
	width: 68rem;
	margin: 0 auto;
}
@media screen and (max-width: 768px) {
	.area section {
		width: auto;
	}
}



/* -------------------------------------------

area

------------------------------------------- */


@media screen and (max-width: 768px) {

}



/* -------------------------------------------

fooer

------------------------------------------- */
footer {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 5rem 0 10rem 0;
}
footer .logo {
	width: 20rem;
	margin-bottom: 2.5rem;
}
footer p {
	font-size: 1rem;
	text-align: center;
}
@media screen and (max-width: 768px) {
	footer {
		padding: 7rem 0;
	}
	footer .logo {
		width: 24rem;
		margin-bottom: 2.5rem;
	}
	footer p {
		padding: 0 3rem;
		font-size: 1.2rem;
	}
}



/* -------------------------------------------

anchor

------------------------------------------- */
.anchor {
	display: block;
	padding-top: 6rem;
	margin-top: -6rem;
}
@media screen and (max-width: 768px) {
	.anchor {
		padding-top: 5rem;
		margin-top: -5rem;
	}
}