@charset "utf-8";


/* fuwafuwaっていうアニメーションはこんなふうだよ！ */
@-webkit-keyframes fuwafuwa {
	0% {-webkit-transform:translate(0, 0);}
	25% {-webkit-transform:translate(0, -6px);}
	40% {-webkit-transform:translate(0, -12px);}
	50% {-webkit-transform:translate(0, -14px);}
	60% {-webkit-transform:translate(0, -12px);}
	75% {-webkit-transform:translate(0, -6px);}
	100% {-webkit-transform:translate(0, 0);}
}
@-moz-keyframes fuwafuwa {
	0% {-moz-transform:translate(0, 0);}
	25% {-moz-transform:translate(0, -6px);}
	40% {-moz-transform:translate(0, -12px);}
	50% {-moz-transform:translate(0, -14px);}
	60% {-moz-transform:translate(0, -12px);}
	75% {-moz-transform:translate(0, -6px);}
	100% {-moz-transform:translate(0, 0);}
}


.noto-serif {
  font-family: "Noto Serif JP", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-weight: normal;
}

#main {
  font-weight: 500;
}

.pt50 {
	padding-top: 50px;
}

.c-skyblue {
	color: #45bbc0 !important;
}

.c-fountainblue {
	color: #46B2B6;
}

.c-black {
	color: #333333;
}

.c-white {
	color: #ffffff;
}

.contact_box {
	margin-bottom: 20px;
	text-align: center;
}

.contact_box h3 {
	background-color: #221814;
	color: #fff;
	font-size: 24px;
	margin-bottom: 5px;
	padding: 3px 0;
}

.contact_box_img {
	padding: 6% 9% 9%;
}

.cnt-top {
	width: 100%;
	padding-top: 50px;
	padding-bottom: 30px;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
}
.cnt-top.bg-fountainblue, .cnt-top.bg-white {
	margin-bottom: 50px;
	padding-top: 20px;
}

@media screen and (max-width: 767px) {
	.cnt-top {
		padding-top: 10.6666666667vw;
		padding-bottom: 8vw;
	}
	.cnt-top.bg-fountainblue, .cnt-top.bg-white {
		margin-bottom: 8vw;
		padding-top: 6vw;
	}
}

.scr-anin .ttl01 .ttl01__main {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 1s 0.3s, transform 1s 0.3s;
}

.scr-anin .ttl01 .ttl01__sub {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 1s 0.6s, transform 1s 0.6s;
}

.scr-anin--on .ttl01 .ttl01__main {
	opacity: 1;
	transform: translateY(0);
}

.scr-anin--on .ttl01 .ttl01__sub {
	opacity: 1;
	transform: translateY(0);
}

.ttl01 {
	color: #fff;
	font-weight: bold;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
	flex-direction: column;
}

.ttl01 .ttl01__main {
	font-size: 38px;
	letter-spacing: 0.1em;
}

@media screen and (max-width: 767px) {
	.ttl01 .ttl01__main {
		font-size: 7.4666666667vw;
	}
}

.ttl01 .ttl01__sub {
	font-size: 16px;
}

@media screen and (max-width: 767px) {
	.ttl01 .ttl01__sub {
		font-size: 3.7333333333vw;
	}
}

.bg-white {
	background-color: #fff;
}

.bg-fountainblue {
	background-color: #46B2B6;
}

.bg-iceberg {
	background-color: #DAF0F0;
}


/*--------------------------------------------------------------
lcl-access
--------------------------------------------------------------*/
.lcl-access {
	padding: 75px 4% 120px;
	overflow: hidden;
}

.lcl-access .ttl {
	font-size: 30px;
	font-weight: bold;
	margin-bottom: 50px;
	text-align: center;
}

.lcl-access .txt01 {
	margin-top: 40px;
}

@media screen and (max-width: 767px) {
	.lcl-access {
		padding: 8vw 4vw 16vw;
	}
	.lcl-access .ttl {
		font-size: 20px;
		margin-bottom: 30px;
	}
	.lcl-access .txt01 {
		margin-top: 20px;
	}
}

.lcl-map {
	margin-top: 90px;
	width: 108.6%;
	height: 410px;
	position: relative;
	left: -4.3%;
	z-index: 2;
}

@media screen and (max-width: 767px) {
	.lcl-map {
		margin: 40px calc(50% - 50vw) 0;
		left: 0;
		width: 100vw;
	}
}


/*--------------------------------------------------------------
lcl-location
--------------------------------------------------------------*/
.lcl-location {
	padding: 120px 4% 130px;
}

.lcl-location .ttl {
	font-size: 30px;
	text-align: center;
	margin-bottom: 40px;
}

.lcl-location .txt01 {
	font-size: 18px;
	text-align: center;
	margin-bottom: 80px;
}

.location_point {
	border-bottom: 1px solid #333;
	padding: 60px 0;
}

.location_point h4 {
	font-size: 24px;
	margin-bottom: 20px;
	text-align: center;
}

.location_point h4 img {
	margin-bottom: 10px;
	width: 220px;
}

.location_point p {
	font-size: 18px;
	margin-bottom: 30px;
}

.location_point .imgs {
	margin: 0 auto;
	max-width: 750px;
	width: 81.5%;
}

.location_point .bx-wrapper {
	box-shadow: none;
	border: none;
	margin-bottom: 30px;
}

.location_point .bx-wrapper .bx-controls-direction a {
	height: 70px;
	width: 60px;
}

.location_point .bx-wrapper .bx-prev {
	background: url(../img/arrow_left.png) no-repeat 0 0;
	background-size: cover;
	left: -30px;
}

.location_point .bx-wrapper .bx-next {
	background: url(../img/arrow_right.png) no-repeat 0 0;
	background-size: cover;
	right: -30px;
}

.location_point .bx-wrapper .bx-pager.bx-default-pager a {
	background: #bbb;
	border-radius: 0;
	height: 5px;
	width: 20px;
}
.location_point .bx-wrapper .bx-pager.bx-default-pager a:hover,
.location_point .bx-wrapper .bx-pager.bx-default-pager a.active,
.location_point .bx-wrapper .bx-pager.bx-default-pager a:focus {
	background: #46B2B6;
}

@media screen and (max-width: 767px) {
	.lcl-location {
		padding: 16vw 4vw;
	}
	.lcl-location .ttl {
		font-size: 20px;
		margin-bottom: 20px;
	}
	.lcl-location .txt01 {
		font-size: 16px;
		margin-bottom: 40px;
	}
	.location_point h4 {
		font-size: 20px;
	}
	.location_point p {
		font-size: 16px;
	}
	.location_point .bx-wrapper .bx-controls-direction a {
		height: 35px;
		width: 30px;
	}

	.location_point .bx-wrapper .bx-prev {
		left: -16px;
	}

	.location_point .bx-wrapper .bx-next {
		right: -16px;
	}
}


/*--------------------------------------------------------------
lcl-concept
--------------------------------------------------------------*/
.lcl-concept {
	color: #fff;
	padding: 110px 4% 0;
	overflow: hidden;
}

.lcl-concept .ttl {
	font-size: 30px;
	font-weight: bold;
	margin-bottom: 40px;
	text-align: center;
}

.lcl-concept .txt01 {
	margin-bottom: 120px;
	text-align: center;
}

.lcl-concept .bg-img {
	background-size: cover !important;
	margin-bottom: 90px;
	padding: 50px 90px;
	width: 108.6%;
	position: relative;
	left: -4.3%;
}

.lcl-concept .bg-img .box {
	background-color: rgba(255, 255, 255, .75);
	font-size: 18px;
	padding: 30px;
	text-align: center;
}

.lcl-concept .bg-img .box h4 {
	font-size: 24px;
}

.concept_box {
	font-size: 18px;
	margin-bottom: 80px;
}

.concept_box h4 {
	font-size: 24px;
	margin-bottom: 20px;
	text-align: center;
}

.concept_box h4 small {
	font-size: 18px;
}

.concept_box .img01 {
	margin: 0 auto 30px;
	text-align: center;
	max-width: 70%;
}
.concept_box .img01.img07 {
	max-width: 51%;
}
.concept_box .img01.img08 {
	max-width: 81.5%;
}

@media screen and (max-width: 767px) {
	.lcl-concept {
		padding: 16vw 4vw 0;
	}
	.lcl-concept .ttl {
		font-size: 20px;
		margin-bottom: 20px;
	}
	.lcl-concept .txt01 {
		margin-bottom: 60px;
	}
	.lcl-concept .bg-img {
		margin: 0 calc(50% - 50vw) 40px;
		padding: 30px 40px;
		left: 0;
		width: 100vw;
	}
	.lcl-concept .bg-img .box {
		font-size: 14px;
		padding: 20px;
	}
	.lcl-concept .bg-img .box h4 {
		font-size: 20px;
	}
	.concept_box {
		font-size: 16px;
		margin-bottom: 40px;
	}
	.concept_box h4 {
		font-size: 20px;
	}

	.concept_box h4 small {
		font-size: 16px;
	}
	.concept_box .img01 {
		margin-bottom: 20px;
	}
}


/*--------------------------------------------------------------
lcl-description
--------------------------------------------------------------*/
.lcl-description {
	padding-bottom: 120px;
	/* ---- SP only ---- */
}

@media screen and (max-width: 767px) {
	.lcl-description {
		padding: 0 4vw 16vw;
	}
}

.lcl-description .lcl-description-list {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	align-items: stretch;
	justify-content: flex-start;
	width: 984px;
	margin: 0 auto;
	border-bottom: 1px solid #dddddd;
	border-right: 1px solid #dddddd;
	/* ---- SP only ---- */
}

@media screen and (max-width: 767px) {
	.lcl-description .lcl-description-list {
		width: 100%;
	}
}

.lcl-description .lcl-description-list__ttl, .lcl-description .lcl-description-list__cnt {
	padding: 15px;
	border-top: 1px solid #dddddd;
	border-left: 1px solid #dddddd;
	/* ---- SP only ---- */
}

@media screen and (max-width: 767px) {
	.lcl-description .lcl-description-list__ttl, .lcl-description .lcl-description-list__cnt {
		padding: 2.6666666667vw;
	}
}

.lcl-description .lcl-description-list__ttl {
	width: 250px;
	font-weight: bold;
	background-color: #f0f0f0;
	/* ---- SP only ---- */
}

@media screen and (max-width: 767px) {
	.lcl-description .lcl-description-list__ttl {
		width: 100%;
	}
}

.lcl-description .lcl-description-list__cnt {
	width: calc(100% - 250px);
	/* ---- SP only ---- */
}

@media screen and (max-width: 767px) {
	.lcl-description .lcl-description-list__cnt {
		width: 100%;
		padding-bottom: 4vw;
	}
}


.contact {
	display: none;
}

.contact a {
	position: fixed;
	bottom: 110px;
	right: 30px;
	width: 100px;
	height: 100px;
	z-index: 10;
	background-color: #46B2B6;
	transition: all .3s ease;
	transform: rotate(-45deg);
	text-decoration: none;
	color: #fff;
	font-size: 14px;
	text-align: center;
	font-weight: bold;
	padding-top: 20px;
	letter-spacing: 0.1em;
}

.contact a:hover {
	background-color: #1c52a3;
}

.contact a.fadein {
	right: 30px;
	transition: all .3s ease;
}

.contact a span {
	display: block;
	height: 60px;
	width: 100px;
	position: relative;
}

.contact a span::after {
	display: block;
	content: "";
	position: absolute;
	top: 5px;
	bottom: 0;
	right: 5px;
	left: 0;
	width: 10px;
	height: 10px;
	margin: auto;
	border-top: solid 4px #fff;
	border-right: solid 4px #fff;
	transform: rotate(0deg);
	transition: all .3s ease;
	height: 18px;
	width: 18px;
}

.pagetop a {
	display: block;
	background-color: #46B2B6;
}

.pagetop a span {
	display: block;
	width: 50px;
	height: 50px;
	position: relative;
	margin: 0 auto;
	top: 0;
	transition: all .3s ease;
	transform: rotate(-45deg);
	z-index: 2;
}

.pagetop a span::after {
	display: block;
	content: "";
	position: absolute;
	top: 5px;
	bottom: 0;
	right: 5px;
	left: 0;
	width: 10px;
	height: 10px;
	margin: auto;
	border-top: solid 4px #fff;
	border-right: solid 4px #fff;
	transform: rotate(0deg);
	transition: all .3s ease;
	height: 18px;
	width: 18px;
}

.pagetop a:hover span::after {
	top: -10px;
	right: -10px;
	transition: all .3s ease;
}


@media screen and (max-width: 767px){
	/* ---------------------------------------------------------------- SP Style ---- */
	.contact_box h3 {
		font-size: 18px;
	}
	.contact a {
		position: absolute;
		overflow: hidden;
		font-size: 10px;
		right: 20px;
		height: 50px;
		width: 50px;
		z-index: 11;
	}
	.contact a.fixed {
		position: fixed;
		bottom: 75px;
	}
	.contact a span {
		height: 10px;
		width: 50px;
	}
}
