@charset 'UTF-8';
/*----------------------------------------

	- content
		- .news-section
			- .news-ttl
		- .information-section
			- .information-ttl

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


@media screen and (max-width: 767px) {
	.kv {
		margin: 0 auto 50px;
	}
}

#contents {
	max-width: unset;
}

@media screen and (max-width: 768px) {
	#contents {
		width: 100%;
	}
}

.slider {
	position: relative;
	width: 100%;
	aspect-ratio: 2/1;
}

.slide {
	position: absolute;
	width: 100%;
	height: 100%;
	opacity: 0;
	transition: opacity 1.5s ease;
	overflow: hidden;

}

.slide .com-imgnote {
	position: absolute;
	right: 5px;
	bottom: 5px;
	color: #fff;
	text-shadow: 0 0 4px #000, 0 0 4px #000, 0 0 4px #000;
	font-weight: 600;
	font-size: 12px;
}

.slide .com-imgnote.blk {
	position: absolute;
	right: 5px;
	bottom: 5px;
	color: #000;
	text-shadow: 0 0 4px #ffffff;
}

.slide .cover {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	opacity: 0;
	scale: 1.1;
	transition: 1.5s ease;
}

.slide.active {
	opacity: 1;
}

.slide.active .cover {
	opacity: 1;
	scale: 1;
}

/* スライドごとの簡易アニメーション例 */
.fadeIn {
	animation: fadeIn 2s forwards;
}

.zoomIn {
	animation: zoomIn 2s forwards;
}

.slideIn {
	animation: slideIn 2s forwards;
}

@keyframes fadeIn {
	from {
		opacity: 0;
	}

	to {
		opacity: 1;
	}
}

@keyframes zoomIn {
	from {
		transform: scale(1.2);
		opacity: 0;
	}

	to {
		transform: scale(1);
		opacity: 1;
	}
}

@keyframes slideIn {
	from {
		transform: translateX(50%);
		opacity: 0;
	}

	to {
		transform: translateX(0);
		opacity: 1;
	}
}

@media screen and (max-width: 767px) {
	.slider {
		aspect-ratio: 39/37;
	}
}

.merit_wrap {
	position: relative;
	padding: 0;
}

.merit_wrap::before {
	content: "";
	position: absolute;
	width: 100%;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	height: 100%;
	background: transparent url("../img/mrt_bg.jpg") left top / cover no-repeat;
	z-index: 0;
}

.merit_wrap {
	position: relative;
	z-index: 1;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	padding-block: 1vw;
	flex-wrap: wrap;
}


.merit_wrap .mrtBox .mrt {
	font-size: 2.5rem;
	padding: 1vw 2vw;
	box-sizing: border-box;
}

.merit_wrap .mrtBox .mrt .sup {
	font-size: 1.1rem;
	vertical-align: super;
}

.merit_wrap .mrtBox .mrt .big_1 {
	font-size: 3.5rem;
}

.merit_wrap .mrtBox .mrt .small_1 {
	font-size: 1.5rem;
}

.merit_wrap .mrtBox .mrt .small_2 {
	font-size: 1.5rem;
}

.merit_wrap .mrtBox .mrt:nth-child(1) {
	border-left: 1px solid #fff;
}

.merit_wrap .mrtBox .mrt:nth-child(2) {
	box-sizing: border-box;
	border-right: 1px solid #fff;
	border-left: 1px solid #fff;
}

.merit_wrap .mrtBox .mrt:nth-child(3) {
	border-right: 1px solid #fff;
}

.merit_wrap::after {
	display: none;
}

.merit_wrap .mrtBox {
	position: relative;
	z-index: 1;
	justify-content: center;
}

@media screen and (max-width: 767px) {
	.merit_wrap::before {
		background: transparent url("../img/mrt_bg_sp.jpg") left top / cover no-repeat;
	}

	.merit_wrap {
		padding-block: 8vw;
	}

	.merit_wrap .mrtBox {
		position: relative;
		z-index: 1;
		padding-block: 1vw;
		flex-wrap: wrap;
		width: 90%;
		margin-inline: auto;
	}

	.merit_wrap .mrtBox .mrt {
		font-size: 2.5rem;
		padding: 5vw 0vw;
		width: 100%;
		text-align: center;
	}

	.merit_wrap .mrtBox .mrt .sup {
		font-size: 1.1rem;
		vertical-align: super;
	}

	.merit_wrap .mrtBox .mrt .big_1 {
		font-size: 3.5rem;
	}

	.merit_wrap .mrtBox .mrt .small_1 {
		font-size: 1.5rem;
	}

	.merit_wrap .mrtBox .mrt .small_2 {
		font-size: 1.5rem;
	}

	.merit_wrap .mrtBox .mrt:nth-child(1) {
		border-top: 1px solid #fff;
		border-left: none;
	}

	.merit_wrap .mrtBox .mrt:nth-child(2) {
		border-right: none;
		border-left: none;
		border-top: 1px solid #fff;
		border-bottom: 1px solid #fff;
	}

	.merit_wrap .mrtBox .mrt:nth-child(3) {
		border-bottom: 1px solid #fff;
		border-right: none;
	}

	.merit_wrap::after {
		display: none;
	}
}

.entry_wrap {
	position: relative;
	color: #ffffff;
}

.entry_wrap .con_inner {
	position: relative;
	z-index: 1;
}

.entry_wrap::before {
	content: "";
	width: 100%;
	height: 100%;
	left: 50%;
	top: 50%;
	position: absolute;
	transform: translate(-50%, -50%);
	background: linear-gradient(0deg, rgba(62, 67, 72, 0.75) 0%, rgba(62, 67, 72, 0.75) 100%), url(../img/gray_bg.jpg) lightgray 50% / cover no-repeat;
	z-index: 0;
}

.entry_wrap::after {
	display: none;
}

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

.entry_wrap .textBox .p1 {
	font-size: 3rem;
}

.entry_wrap .textBox .p2 {
	font-size: 2.2rem;
	line-height: 1.5;
	margin-block: 3vw;
}

.entry_wrap .imgBox {
	margin-bottom: 3vw;
	max-width: 1200px;
	width: 100%;
	margin-inline: auto;
}

.btn_area {
	max-width: 1200px;
	margin-inline: auto;
}

@media screen and (max-width: 767px) {
	.entry_wrap {
		padding-block: 15vw 10vw;
	}

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

	.entry_wrap .textBox .p1 {
		font-size: 2rem;
	}

	.entry_wrap .textBox .p2 {
		font-size: 1.5rem;
		margin-block: 5vw;
	}

	.entry_wrap .imgBox {
		margin-bottom: 0vw;
		width: 80%;
		margin-inline: auto;
	}

	.entry_wrap .btn_area {
		margin-block: 10vw;
	}

	.entry_wrap .btn_area .btn {
		width: 80%;
		margin-inline: auto;

	}

	.entry_wrap .btn_area .btn:last-child {
		margin-top: 5vw;
	}
}

.concept_wrap {
	width: 100%;
	left: 50%;
	position: relative;
	transform: translateX(-50%);
	background: transparent url("../img/con_bg.png") left top / cover no-repeat;
	padding-bottom: 13vw;
	padding-top: 0;
}

.concept_wrap::before,
.concept_wrap::after {
	display: none;
}

.concept_wrap .imgBox .imgNote {
	bottom: 15rem;
}

.concept_wrap .textBox {
	text-align: center;
	margin-top: -10vw;
}

.concept_wrap .textBox .p1 {
	font-size: 6rem;
	letter-spacing: .2em;
}

.concept_wrap .textBox .p2 {
	text-align: center;
	font-size: 1.8rem;
	line-height: 2.5;
	margin-top: 3vw;
}

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

	.concept_wrap .imgBox .imgNote {
		bottom: 3rem;
	}

	.concept_wrap .textBox {
		margin-top: 3vw;
	}

	.concept_wrap .textBox .p1 {
		font-size: 4rem;
		letter-spacing: .2em;
	}

	.concept_wrap .textBox .p2 {
		text-align: left;
		font-size: 1.3rem;
		line-height: 2.5;
		margin-top: 3vw;
		width: 90%;
		margin-inline: auto;
	}
}

.menu_wrap {
	position: relative;
	padding-block: 5vw;
}

.menu_wrap::before {
	width: 100%;
	height: 100%;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	background: transparent url("../img/gray_bg.jpg") left top / cover no-repeat;
}


.menu_wrap::after {
	display: none;
}

.menu_wrap .menu_flex {
	justify-content: space-between;
	align-items: center;
	position: relative;
	z-index: 1;
	max-width: 1200px;
	width: 100%;
	margin-inline: auto;
}

.menu_wrap .menu {
	display: inline-block;
	aspect-ratio: 1/1.4;
	width: calc(100%/3 - 15px);
	box-shadow: 4px 4px 8px 0 rgba(0, 0, 0, 0.25);
	transition: .5s;
	position: relative;
}

.menu_wrap .menu::before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background-color: rgba(0, 0, 0, 0.4);
	opacity: 1;
	pointer-events: none;
	transition: .5s;
}

.menu_wrap .menu .note {
	position: absolute;
	right: 5px;
	bottom: 5px;
	color: #fff;
	text-shadow: 0 0 4px #000;
	font-weight: 600;
	font-size: 1.2rem;
}

.menu_wrap .menu.acc_menu {
	background: transparent url("../img/acc_bg.jpg") left top / cover no-repeat;
}

.menu_wrap .menu.loc_menu {
	background: transparent url("../img/loc_bg.jpg") left top / cover no-repeat;
}

.menu_wrap .menu.plan_menu {
	background: transparent url("../img/plan_bg.jpg") left top / cover no-repeat;
}

.menu_wrap .menu a {
	display: block;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	text-decoration: none;
}

.menu_wrap .menu a .menu_inner {
	color: #fff;
	text-align: center;
	position: relative;
	z-index: 1;
	width: 100%;
}

.menu_wrap .menu a .menu_inner .textBox {
	margin-bottom: 2vw;
	width: 100%;
}


.menu_wrap .menu a .menu_inner .textBox .p1 {
	font-size: 3rem;
	letter-spacing: .15em;
	text-shadow: 0 0 4px #000, 0 0 4px #000;
}

.menu_wrap .menu a .menu_inner .textBox .p2 {
	font-size: 1.8rem;
	text-shadow: 0 0 4px #000, 0 0 4px #000;
}

.menu_wrap .menu a .menu_inner .text {
	font-size: 1.7rem;
	line-height: 2;
	aspect-ratio: 3/1;
	font-weight: 500;
	width: 100%;
	text-shadow: 0 0 4px #000, 0 0 4px #000;
}

.menu_wrap .menu a .menu_inner .text .sup {
	font-size: 1rem;
	vertical-align: super;
}

.menu_wrap .menu a .menu_inner .btn {
	max-width: 150px;
	width: 90%;
	background-color: #70564F;
	margin-inline: auto;
	padding-block: 1rem .6rem;
	margin-top: min(17vw, 200px);
	font-size: 1.3rem;
	position: relative;
	box-sizing: border-box;
	border: #70564F 1px solid;
	color: #fff;
	transition: .5s;
}

/* .menu_wrap .menu a .menu_inner .btn::before {
	content: "";
	width: 1px;
	height: 6vw;
	background-color: #fff;
	left: 50%;
	transform: translateX(-50%);
	top: -10vw;
	position: absolute;
} */

.menu_wrap .menu a:hover {
	outline: none;
}

.menu_wrap .menu:hover {
	box-shadow: none;
}

.menu_wrap .menu:hover::before {
	opacity: 0;
}

.menu_wrap .menu:hover a .menu_inner .btn {
	background-color: #ffffff;
	border: #70564F 1px solid;
	color: #70564F;
}

@media screen and (max-width: 767px) {
	.menu_wrap {
		position: relative;
		padding-block: 0vw;
	}

	.menu_wrap::before {
		display: none;
	}

	.menu_wrap .menu.acc_menu {
		background: transparent url("../img/acc_bg_sp.jpg") left 5% / cover no-repeat;
	}

	.menu_wrap .menu.loc_menu {
		background: transparent url("../img/loc_bg_sp.jpg") left 5% / cover no-repeat;
	}

	.menu_wrap .menu.plan_menu {
		background: transparent url("../img/plan_bg_sp.jpg") left 5% / cover no-repeat;
	}

	.menu_wrap .menu_flex {
		flex-direction: column;
	}

	.menu_wrap .menu {
		width: 100%;
		position: relative;
		left: 50%;
		transform: translateX(-50%);
		aspect-ratio: 1/1.05;
		box-shadow: none;
	}

	.menu_wrap .menu a .menu_inner .textBox {
		margin-bottom: 2vw;
		width: 100%;
	}

	.menu_wrap .menu a .menu_inner .textBox .p1 {
		font-size: 3rem;
		letter-spacing: .15em;
	}

	.menu_wrap .menu a .menu_inner .textBox .p2 {
		font-size: 1.8rem;
	}

	.menu_wrap .menu a .menu_inner .text {
		font-size: 1.5rem;
		line-height: 2;
		aspect-ratio: 2.2/1;
		font-weight: 500;
		width: 100%;
	}

	.menu_wrap .menu a .menu_inner .btn {
		padding-block: .8rem .5rem;
		margin-top: 19vw;
	}

	.menu_wrap .menu a .menu_inner .btn::before {
		height: 23vw;
		top: -30vw;
	}

}

/* .kvはダミーです */


.news-section {
	width: min(76%, 550px);
	margin: 0 auto 90px;
}

.news-ttl {
	color: #1a1816;
	font-weight: 500;
	font-size: 2.0rem;
	line-height: 1;
	font-family: 'Cormorant Garamond', '游明朝', YuMincho, 'Hiragino Mincho ProN W3', 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
}

.news-section dl {
	display: grid;
	gap: 8px;
	align-items: baseline;
	width: 100%;
	margin: 30px auto 0;

	grid-template: auto / 9.6em 1fr;
}

.news-section dl dt {
	grid-column: 1;
	font-size: 1.4rem;
}

.news-section dl dd {
	grid-column: 2;
	font-size: 1.6rem;
	line-height: 2;
}

.news-section dl dd a {
	color: var(--color_black_chocolate);
}

.news-section dl dd a:hover {
	text-decoration: underline;
}

@media screen and (max-width: 767px) {
	.news-section {
		margin: 0 auto 50px;
	}

	.news-ttl {
		font-size: 2.0rem;
	}

	.news-section dl {
		gap: 0;
		align-items: baseline;
		margin: 26px auto 0;

		grid-template: auto / 1fr;
	}

	.news-section dl dt {
		grid-column: unset;
		font-size: 1.2rem;
	}

	.news-section dl dd+dt {
		margin-top: 19px;
	}

	.news-section dl dd {
		grid-column: unset;
		font-size: 1.4rem;
	}
}


.information-section {
	padding-top: 90px;
	margin: 0 0 90px;
	text-align: center;
}

.information-section .btn_area {
	margin-top: 3vw;
}

.information-ttl {
	margin-bottom: 10px;
	color: #978d82;
	font-weight: 300;
	font-size: 2.0rem;
	line-height: 1;
	font-family: 'Cormorant Garamond', '游明朝', YuMincho, 'Hiragino Mincho ProN W3', 'ヒラギノ明朝 ProN W3', 'Hiragino Mincho ProN', 'HG明朝E', 'ＭＳ Ｐ明朝', 'ＭＳ 明朝', serif;
	letter-spacing: 0.1em;
}