@charset "utf-8";

/*
	** MAIN CSS
*/



.main-wrapper {
	position: relative;
	overflow: hidden auto;
}
.main-section {
	padding: 90px 0;
}
.main-section-title {
	font-size: 3em;
	font-weight: 600;
}
.main-sub-title {
	font-size: var(--font-size-28);
}
.main-bg {
	background: #f5f7ef;
}
.main-more {
	position: absolute;
	top: 0;
	right: 0;
}
.main-more::after {
	content: "\2b";
	font-weight: 900;
	font-family: "Font Awesome 6 Pro";
	font-size: var(--font-size-22);
}
@media all and (max-width: 1023px) {
	.main-section-title {
		font-size: 2.75em;
	}
	.main-sub-title {
		font-size: var(--font-size-24);
	}
}
@media all and (max-width: 767px) {
	.main-section {
		padding: 60px 0;
	}
	.main-section-title {
		font-size: 2em;
	}
	.main-sub-title {
		font-size: var(--font-size-22);
	}
	.main-more::after {
		font-size: var(--font-size-20);
	}
}



.main-visual {
	position: relative;
}
.main-visual-slide {
	max-width: 90%;
	height: calc(100vh - 158px);
	position: relative;
}
.main-visual-slide .text-box {
	position: absolute;
	z-index: 5;
	top: 20%;
    width: 100%;
	text-align: center;
	color: #fff;
}
.main-visual-slide .text-box .title {
	font-size: 3.25em;
	font-weight: 600;
	font-family: 'S-CoreDream';
	word-break: keep-all;
}
.main-visual-slide .text-box .desc {
	font-size: 2.25em;
	margin-bottom: 10px;
	font-family: 'S-CoreDream';
}
.main-visual-slide .swiper-slide img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.main-visual-slide .slide-control {
	position: absolute;
	z-index: 5;
	top: 48%;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	color: #fff;
}
.main-visual-slide .swiper-pagination {
	position: unset;
	width: auto;
	text-align: left;
}
.main-visual-slide .swiper-pagination-bullet {
	display: inline-flex;
	align-items: center;
	width: auto;
	height: auto;
	background: none;
	opacity: 0.5;
}
.main-visual-slide .swiper-pagination-bullet-active {
	opacity: 1;
}
.main-visual-slide .swiper-pagination-num {
	margin-right: 15px;
}
.main-visual-slide .swiper-progress-bar {
	position: relative;
	display: none;
	width: 180px;
	height: 1px;
	margin-right: 15px;
	background: rgba(225,225,225,0.5);
}
.main-visual-slide .swiper-progress-bar::after {
	content: "";
	position: absolute;
	background: #fff;
	width: 100%;
	height: 100%;
}
.main-visual-slide .swiper-pagination-bullet-active .swiper-progress-bar {
	display: block;
}
.main-visual-slide .swiper-pagination-bullet-active .swiper-progress-bar::after {
	transition-delay: unset;
	animation: 5s progress linear;
}
@keyframes progress {
    0% {width: 0%;}
    100% {width: 100%;}
}
.main-visual-slide .swiper-pause .swiper-progress-bar::after {
	animation-play-state: paused;
}
.main-visual-slide :is(.swiper-button-play, .swiper-button-pause) {
	display: none;
	align-items: center;
	justify-content: center;
	width: 20px;
	color: #fff;
	font-size: var(--font-size-15);
}
.main-visual-slide :is(.swiper-button-play, .swiper-button-pause).active {
	display: inline-flex;
}
.main-visual-slide .swiper-button-play::after,
.main-visual-slide .swiper-button-pause::after {
	display: inline-flex;
	font-family: "Font Awesome 6 Pro";
	font-weight: 900;
}
.main-visual-slide .swiper-button-play::after {
	content:"\f04b";
}
.main-visual-slide .swiper-button-pause::after {
	content:"\f04c";
}
@media all and (max-width: 1023px) {
	.main-visual-slide {
		height: calc(100vh - 132px);
	}
	.main-visual-slide .text-box .title {
		font-size: 2.75em;
	}
	.main-visual-slide .text-box .desc {
		font-size: var(--font-size-26);
	}
}
@media all and (max-width: 767px) {
	.main-visual-slide {
		height: 550px;
	}
	.main-visual-slide .text-box {
		padding: 0 10px;
	}
	.main-visual-slide .text-box .title {
		font-size: 2em;
	}
	.main-visual-slide .text-box .desc {
		font-size: var(--font-size-20);
	}
	.main-visual-slide .swiper-progress-bar {
		width: 80px;
	}
	.main-visual-slide .slide-control {
		top: 42%;
		padding: 0 10px;
	}
	.main-visual-slide .swiper-pagination-num {
		margin-right: 10px;
	}
}


.scroll-down {
	position: absolute;
	bottom: 60px;
	width: 5%;
	display: flex;
	align-items: center;
	color: var(--primary-color);
	writing-mode: vertical-lr;
	white-space: nowrap;
	animation: scrollDown 1s ease-in-out 0.5s infinite alternate both;
}
@keyframes scrollDown {
	0% {transform:translateY(0);}
	100% {transform:translateY(10px);}
}
.scroll-down::before {
	content: "";
	display: block;
	width: 1px;
	height: 85px;
	margin-bottom: 20px;
	background: var(--primary-color);
}
@media all and (max-width: 1023px) {
	.scroll-down {
		display: none;
	}
}


.main-visual .sns-list {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 5%;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 10px;
}
.main-visual .sns-list .lnk {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	color: #d7d7d7;
	font-size: var(--font-size-22);
}
.main-visual .sns-list .blog img {
	width: 26px;
}
@media all and (max-width: 1023px) {
	.main-visual .sns-list .lnk {
		font-size: var(--font-size-20);
	}
	.main-visual .sns-list .blog img {
		width: 24px;
	}
}
@media all and (max-width: 767px) {
	.main-visual .sns-list {
		position: initial;
		transform: none;
		flex-direction: row;
		width: auto;
		margin-top: 20px;
	}
}


.main-guide .list-box {
	display: flex;
	align-items: center;
	gap: 0 3%;
	margin-top: 200px;
	position: relative;
}
.main-guide .list-box::after {
	content: "";
	position: absolute;
	bottom: 100%;
	right: 0;
	width: 200px;
	height: 200px;
	margin-bottom: 15px;
	background: url("../img/layout/logo-square.png") no-repeat center / cover;
}
.main-guide .list-box li {
	flex: 0 0 31.33%;
}
.main-guide .list-box li:nth-child(1) {
	transform: translateY(-65px);
}
.main-guide .list-box li:nth-child(2) {
	transform: translateY(-140px);
}
.main-guide .list-box .img-box {
	border: 2px solid transparent;
	transition: var(--transition);
}
.main-guide .list-box .img-box img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.main-guide .list-box .text {
	margin-top: 25px;
	font-weight: 600;
	font-size: var(--font-size-26);
	transition: var(--transition);
}
.main-guide .list-box a:hover .img-box {
	transform: translateY(-2px);
	border-color: var(--primary-color);
	box-shadow: 9px 9px 15px rgba(0,0,0,0.25);
}
.main-guide .list-box a:hover .text {
	color: var(--primary-color);
}
@media all and (max-width: 1023px) {
	.main-guide .list-box {
		margin-top: 100px;
	}
	.main-guide .list-box::after {
		width: 120px;
		height: 120px;
	}
	.main-guide .list-box li:nth-child(1) {
		transform: translateY(-30px);
	}
	.main-guide .list-box li:nth-child(2) {
		transform: translateY(-80px);
	}
	.main-guide .list-box .text {
		font-size: var(--font-size-22);
	}
}
@media all and (max-width: 767px) {
	.main-guide .list-box {
		margin-top: 0;
		flex-wrap: wrap;
		gap: 10px;
	}
	.main-guide .list-box::after {
		margin-bottom: 0;
		bottom: 10px;
		right: 10px;
	}
	.main-guide .list-box li {
		position: relative;
		flex: 0 0 48%;
		transform: translateY(0) !important;
	}
	.main-guide .list-box .img-box {
		height: 200px;
		position: relative;
	}
	.main-guide .list-box .img-box::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: linear-gradient(to top, rgba(0,0,0,0.4), transparent 60%);
	}
	.main-guide .list-box .text {
		margin-top: 0;
		position: absolute;
		bottom: 15px;
		left: 12px;
		font-size: var(--font-size-18);
		color: #fff !important;
	}
	.main-guide .list-box li:hover .img-box {
		box-shadow: 3px 3px 10px rgba(0,0,0,0.25);
	}
}


.main-way {
	background: url("../img/main/way-bg.jpg") no-repeat center;
	background-attachment: fixed;
	text-align: center;
	color: #fff;
}
.main-way .list-box {
	margin-top: 80px;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0 60px;
}
.main-way .list-box li {
	flex: 0 0 230px;
	height: 230px;
	border-radius: 50%;
	font-size: var(--font-size-22);
	overflow: hidden;
}
.main-way .list-box a {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 20px 0;
	width: 100%;
	height: 100%;
	color: #fff;
	background-color: rgba(0,0,0,0.5);
	transition: var(--transition);
}
.main-way .list-box a:hover {
	background: rgb(12,90,73,0.8);
}
.main-way .list-box a::before {
	content: "";
	display: block;
	width: 70px;
	height: 70px;
}
.main-way .list-box li:nth-child(1) a::before {background: url("../img/main/way-img01.png") no-repeat center / cover;}
.main-way .list-box li:nth-child(2) a::before {background: url("../img/main/way-img02.png") no-repeat center / cover;}
.main-way .list-box li:nth-child(3) a::before {background: url("../img/main/way-img03.png") no-repeat center / cover;}
@media all and (max-width: 1023px) {
	.main-way .list-box {
		margin-top: 60px;
		gap: 0 40px;
	}
	.main-way .list-box li {
		flex: 0 0 200px;
		height: 200px;
		font-size: var(--font-size-20);
	}
	.main-way .list-box a::before {
		width: 60px;
		height: 60px;
	}
}
@media all and (max-width: 767px) {
	.main-way {
		background-attachment: initial;
	}
	.main-way .list-box {
		margin-top: 50px;
		gap: 0 10px;
		width: 100%;
	}
	.main-way .list-box li {
		flex: 0 0 30%;
		height: auto;
		font-size: var(--font-size-16);
		border-radius: 15px;
	}
	.main-way .list-box a {
		gap: 15px 0;
		padding: 20px 0;
	}
	.main-way .list-box a::before {
		width: 40px;
		height: 40px;
	}
}


.main-board .main-sub-title {
	padding-right: 50px;
	margin-bottom: 40px;
	word-break: keep-all;
}
@media all and (max-width: 767px) {
	.main-board .main-sub-title {
		margin-bottom: 30px;
	}
}

.main-news {
	position: relative;
}
.main-news .list-box {
	display: flex;
	gap: 20px 3%;
}
.main-news .list-box li {
	flex: 0 0 calc(25% - 2.3%);
}
.main-news .list-box a {
	display: block;
	padding: 40px 35px;
	border: 1px solid #d4d8c9;
	border-radius: 8px;
	transition: var(--transition);
}
.main-news .list-box .title {
	font-size: var(--font-size-22);
	font-weight: 600;
	margin-bottom: 25px;
	min-height: 58px;
	transition: var(--transition);
}
.main-news .list-box .desc {
	line-height: 1.5;
	color: #494949;
	min-height: 72px;
}
.main-news .list-box .date {
	margin-top: 30px;
	font-size: var(--font-size-14);
	color: #494949;
}
.main-news .list-box a:hover {
	border-color: var(--primary-color);
}
.main-news .list-box a:hover .title {
	color: var(--primary-color);
}
.main-wrapper .board-empty {
	padding-top:40px;
	padding-bottom: 40px;
}
.main-wrapper .board-empty::before {
	background: #fbfcf8;
}
@media all and (max-width: 1023px) {
	.main-news .list-box {
		flex-wrap: wrap;
	}
	.main-news .list-box li {
		flex: 0 0 48.5%;
	}
	.main-news .list-box a {
		padding: 30px;
	}
}
@media all and (max-width: 767px) {
	.main-news .list-box {
		gap: 15px 0;
	}
	.main-news .list-box li {
		flex: 0 0 100%;
	}
	.main-news .list-box a {
		padding: 20px 18px;
	}
	.main-news .list-box .title {
		font-size: var(--font-size-18);
		margin-bottom: 10px;
		min-height: auto;
	}
	.main-news .list-box .desc {
		font-size: var(--font-size-15);
		min-height: auto;
	}
	.main-news .list-box .date {
		margin-top: 10px;
	}
}


.main-gallery {
	position: relative;
	margin-top: 100px;
	overflow: hidden;
}
.main-gallery .list-box {
	display: flex;
	gap: 0 35px;
}
.main-gallery .list-box li {
	flex: 0 0 calc(33.3333% - 23px);
}
.main-gallery .list-box .img-box {
	aspect-ratio: 3 / 2;
	overflow: hidden;
}
.main-gallery .list-box .img-box img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: var(--transition);
}
.main-gallery .list-box .text-box {
	margin-top: 25px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0 20px;
}
.main-gallery .list-box .text-box .title {
	font-size: var(--font-size-20);
	font-weight: 600;
	transition: var(--transition);
}
.main-gallery .list-box .text-box .date {
	font-size: var(--font-size-14);
	color: #494949;
}
.main-gallery .list-box a:hover img {
	transform: scale(1.1);
}
.main-gallery .list-box a:hover .title {
	color: var(--primary-color);
}
@media all and (max-width: 1023px) {
	.main-gallery .list-box {
		overflow: auto hidden;
	}
	.main-gallery .list-box li {
		flex: 0 0 400px;
	}
}
@media all and (max-width: 767px) {
	.main-gallery {
		margin-top: 60px;
	}
	.main-gallery .list-box {
		gap: 0 20px;
	}
	.main-gallery .list-box li {
		flex: 0 0 300px;
	}
	.main-gallery .list-box .text-box {
		margin-top: 15px;
	}
	.main-gallery .list-box .text-box .title {
		font-size: var(--font-size-18);
	}
}


.main-popup {
	position: absolute;
	right:calc(var(--popup-width) * -1);
	top:200px;
	z-index: 50;
	display: flex;
	--popup-width: 389px;
	transition: 0.3s ease-in-out;
}
.main-popup.active {
	right:0;
}
.main-popup .btn-item {
	display: flex;
	writing-mode: vertical-rl;
	text-orientation: mixed;
	width: 40px;
	background: #3c3c3c;
	color: #fff;
	border-radius: 0;
}
.main-popup .btn-item.close {
	display: none;
}
.main-popup.active .btn-item.close {
	display: flex;
}
.main-popup.active .btn-item.open {
	display: none;
}
.main-popup .btn-item .text {
	align-self: center;
	padding:15px 0;
	letter-spacing: 1px;
	font-size: var(--font-size-15);
}
.main-popup .btn-item .checkbox-label {
	gap:5px;
}
.main-popup .checkbox-text {
	margin:0;
}
.main-popup .btn-item .btn {
	display: flex;
	align-items: center;
	justify-content: center;
	flex:0 0 40px;
	width: 100%;
	height: 40px;
	background:#000;
	color: #fff;
	border-radius: 0;
	font-size: var(--font-size-18);
}
.main-popup-slide {
	width: var(--popup-width);
	position: relative;
}
.main-popup-slide .swiper-control {
	position: absolute;
	right:20px;
	top:15px;
	display: flex;
	align-items: center;
	justify-content: flex-end;
	z-index: 5;
	gap:0 10px;
}
.main-popup-slide .swiper-pagination {
	position: relative;
	bottom: auto;
	left: auto;
	top:auto;
	display: flex;
	align-items: center;
}
.main-popup-slide .swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	border-radius: 0;
	border:1px solid #fff;
	background: none;
	opacity: 1;
	vertical-align: top;
}
.main-popup-slide .swiper-pagination-bullet.swiper-pagination-bullet-active {
	background:#fff;
}
.main-popup-slide .swiper-control .btn {
	display: none;
	align-items: center;
	justify-content: center;
	width: 10px;
	font-size: var(--font-size-14);
	color: #fff;
	line-height: 1;
}
.main-popup-slide .swiper-control .btn.active {
	display: flex;
}
@media all and (max-width: 767px) {
	.main-popup {
		--popup-width: 280px;
	}
	.main-popup .btn-item {
		width: 35px;
	}
	.main-popup .btn-item .text {
		font-size: var(--font-size-14);
		padding:10px 0;
	}
	.main-popup .btn-item .btn {
		flex:0 0 35px;
		height: 35px;
	}
}


.main-menu {
	position: absolute;
	z-index: 5;
	top: 60%;
	left: 0;
	right: 0;
	max-width: 660px;
	margin: 0 auto;
	padding: 0 20px;
	display: flex;
	justify-content: space-between;
	gap: 0 4%;
}
.main-menu .menu-btn {
	position: relative;
	flex: 1 1 0;
	padding: 30px 0;
	text-align: center;
	border-radius: 20px;
	background: rgba(255,255,255,0.8);
	box-shadow: 3px 0 8px rgba(0,0,0,0.08);
	transition: var(--transition);
}
.main-menu .menu-btn .desc {
	align-content: center;
	min-height: 48px;
	margin-top: 15px;
	font-weight: 600;
	line-height: 1.2;
	font-size: var(--font-size-20);
	transition: var(--transition);
}
.main-menu .menu-btn:hover {
	background: rgba(255,255,255,0.9);
}
.main-menu .menu-btn:hover .img {
	animation: menuImg 0.9s both;
}
.main-menu .menu-btn:hover .desc {
	color: var(--primary-color);
}
@keyframes menuImg {
	15% {transform: rotateZ(5deg);}
	30% {transform: rotateZ(-5deg);}
	45% {transform: rotateZ(2deg);}
	60% {transform: rotateZ(-2deg);}
	75% {transform: rotateZ(1deg);}
}
@media all and (max-width: 1023px) {
	.main-menu .menu-btn .img {
		width: 50px;
		margin: 0 auto;
	}
	.main-menu .menu-btn .desc {
		font-size: var(--font-size-18);
	}
}
@media all and (max-width: 767px) {
	.main-menu .menu-btn {
		padding: 18px 0;
	}
	.main-menu .menu-btn .img {
		width: 38px;
	}
	.main-menu .menu-btn .desc {
		min-height: 39px;
		margin-top: 10px;
		font-size: var(--font-size-16);
	}
}

:has(.main-wrapper) .quick-menu {
	display: none;
}