@charset "UTF-8";

@import "./reset.css";
@import "./form.css";

:root{
	--width-default: 1360px;

	--color-primary-05:#f3faf6;
	--color-primary-10:#d9ede3;
	--color-primary-20:#acd8c1;
	--color-primary-30:#6fbc94;
	--color-primary-40:#389e69;
	--color-primary-50:#007739;
	--color-primary-60:#036331;
	--color-primary-70:#094e2a;
	--color-primary-80:#0b4024;
	--color-primary-90:#103120;
	--color-primary-95:#0f2118;

	--color-gray-00:#fff;
	--color-gray-05:#f8f8f8;
	--color-gray-10:#f1f1f1;
	--color-gray-20:#eee;
	--color-gray-30:#ddd;
	--color-gray-40:#ccc;
	--color-gray-50:#b3b3b3;
	--color-gray-60:#999;
	--color-gray-70:#7f7f7f;
	--color-gray-80:#666;
	--color-gray-90:#333;
	--color-gray-95:#111;


	--color-error-05:#fff2f2;
	--color-error-70:#da2a2a;
}


html{
	font-size: 62.5%;
	height: 100%;
	box-sizing: border-box
}

body{
	position: relative;
	display: flex;
	flex-direction: column;
	height: 100%;
	box-sizing: border-box;
	font-family: 'Pretendard GOV',sans-serif;
	background-color: var(--color-gray-00);
	color: var(--color-gray-95)
}

a, input, textarea, label{
	color: var(--color-gray-95)
}

a, button, label{
	cursor: pointer
}

img{
	max-width: 100%
}

.display-l{
	font-size: max(4rem, min(5.2vw, 6rem));
	font-weight: 700;
	line-height: 140%
}

.display-m{
	font-size: max(3.2rem, min(4.1vw, 4.4rem));
	font-weight: 700;
	line-height: 140%
}

.display-s{
	font-size: max(2.8rem, min(3.6vw, 3.6rem));
	font-weight: 700;
	line-height: 140%
}

h1, .tit-h1{
	font-size: max(2.8rem, min(3.6vw, 4rem));
	font-weight: 700;
	line-height: 140%
}

h2, .tit-h2{
	font-size: max(2.4rem, min(3.1vw, 3.2rem));
	font-weight: 700;
	line-height: 140%
}

h3, .tit-h3{
	font-size: max(2.2rem, min(2.8vw, 2.4rem));
	font-weight: 700;
	line-height: 140%
}

h4, .tit-h4{
	font-size: 2rem;
	font-weight: 700;
	line-height: 140%
}

h5, .tit-h5{
	font-size: 1.8rem;
	font-weight: 700;
	line-height: 140%
}

h6, .tit-h6{
	font-size: 1.6rem;
	font-weight: 700;
	line-height: 140%
}

.body-l{
	font-size: 1.8rem;
	line-height: 160%;
	letter-spacing: -0.02em
}

.body-m{
	font-size: 1.6rem;
	line-height: 160%;
	letter-spacing: -0.02em
}

.body-s{
	font-size: 1.4rem;
	line-height: 160%;
	letter-spacing: -0.02em
}

.body-xs{
	font-size: 1.3rem;
	line-height: 160%;
	letter-spacing: -0.02em
}

.body-b-l{
	font-size: 1.8rem;
	line-height: 160%;
	font-weight: 700
}

.body-b-m{
	font-size: 1.6rem;
	line-height: 160%;
	font-weight: 700
}

.body-b-s{
	font-size: 1.4rem;
	line-height: 160%;
	font-weight: 700
}

.body-b-xs{
	font-size: 1.3rem;
	line-height: 160%;
	font-weight: 700
}

.menu-gnb{
	font-size: 2rem;
	line-height: 160%;
	font-weight: 600
}

.menu-lnb{
	font-size: 1.6rem;
	line-height: 160%;
	font-weight: 400
}

.label{
	font-size: 1.3rem;
	line-height: 160%;
	font-weight: 400
}

.btn-s{
	font-size: 1.4rem;
	line-height: 160%;
	font-weight: 400
}

.btn-m{
	font-size: 1.6rem;
	line-height: 160%;
	font-weight: 700
}

.btn-l{
	font-size: 1.8rem;
	line-height: 160%;
	font-weight: 700
}

.bold{
	font-weight: 700
}

.primary{
	color: var(--color-primary-50)
}

.clear::after{
	content:'';
	display:block;
	clear:both
}

.layout{
	width: calc(100% - 32px);
	max-width: var(--width-default);
	margin:0 auto;
}


.common-pg{
	display: flex;
	align-items: center;
	justify-content: center;
	margin-top: 40px
}

.pg{
	display: flex;
	column-gap: 12px
}

.pg_page, .pg_current{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width:44px;
	height:44px;
	border-radius: 100px;
}

.pg_page{
	background-color: var(--color-gray-00);
	transition: 0.3s
}

.pg_current{
	background-color: var(--color-primary-50);
	color: var(--color-gray-00)
}

.pg_page:hover{
	color: var(--color-primary-50);
	background-color: var(--color-primary-05)
}

.pg_prev{
	width:44px;
	height:44px;
	background: url(../img/ico_prev.svg) no-repeat center;
}

.pg_next{
	width:44px;
	height:44px;
	background: url(../img/ico_next.svg) no-repeat center;
}

.container{
	position: relative;
	width: 100%;
	margin:0 auto;
	flex: 1;
	z-index: 10
}

.nav-margin{
	padding-top: 80px
}

/* datepicker */
.ui-datepicker{
	width: 100%;
	max-width: 320px;
	background-color: var(--color-gray-00);
	border-radius: 8px;
	box-shadow: inset 0 0 0 1px var(--color-gray-20);
	margin-top: 4px;
	padding:8px 8px 16px;
	box-sizing: border-box;
	font-family: 'Pretendard GOV',sans-serif;
	z-index: 20 !important;
}

.ui-datepicker-header{
	position: relative;
	height: 56px;
	margin-bottom: 12px;
}

.ui-datepicker-title{
	display: flex;
	justify-content: center;
	align-items: center;
	height: 56px;
	font-size: 2rem;
	font-weight: 700;
}

.ui-datepicker-prev, .ui-datepicker-next{
	position: absolute;
	top:50%;
	transform: translateY(-50%);
	overflow: hidden;
	transition: 0.3s;
}

.ui-datepicker-prev:hover, .ui-datepicker-next:hover{
	background-color: var(--color-gray-05);
	border-radius: 100px;
}

.ui-datepicker-prev{
	left: 0;
	width: 44px;
	height: 44px;
	background: url(../img/ico_prev.svg) no-repeat center;
}

.ui-datepicker-next{
	right: 0;
	width: 44px;
	height: 44px;
	background: url(../img/ico_next.svg) no-repeat center;
}

.ui-icon{
	position: absolute;
	text-indent: -9999px;
}

.ui-datepicker-calendar tr{
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	font-size: 1.4rem;
}

.ui-datepicker-calendar thead tr{
	width: 100%;
	height: 44px;
	aspect-ratio: 1/1;
	text-align: center;
	align-items: center;
	color: var(--color-gray-70);
}

.ui-state-default{
	display: inline-flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	aspect-ratio: 1/1;
	background-color: var(--color-gray-00);
}

.ui-state-default{
	transition:0.3s;
}

.ui-state-default:hover{
	border-radius: 12px;
	background-color: var(--color-gray-05);
}

.ui-state-active, .ui-state-active:hover{
	border: none;
	background: var(--color-primary-50);
	color: var(--color-gray-00);
	border-radius: 12px;
}



/* header */
.header__bg{
	position: fixed;
	left: 0;
	top: 0;
	width:100%;
	height: 80px;
	background-color: var(--color-gray-00);
	box-shadow: inset 0 -1px 0 0 var(--color-gray-10);
	z-index: 50
}

.header__wrap{
	padding:0 80px;
	box-sizing: border-box;
	transition: padding 0.3s;
}

.header__grid{
	display: flex;
	align-items: center;
	justify-content: space-between;
	height: 80px;
}

.header__logo {

}

.menu-pc__grid{
	display: flex;
	align-items: center;
	gap:40px;
}

.menu-pc__gnb{
	display: flex;
	gap:40px;
}

.menu-pc__gnb-li{
	position: relative;
}

.menu-pc__gnb-li{
	position: relative;
	transition: 0.3s
}

.menu-pc__gnb-li::before{
	content:'';
	position: absolute;
	top:16px;
	left: 50%;
	transform: translateX(-50%);
	width: 4px;
	height: 4px;
	border-radius: 100px;
	background-color: var(--color-primary-50);
	opacity: 0;
	transition: 0.3s
}

.menu-pc__gnb-li:hover::before{
	opacity: 1;
}

.menu-pc__gnb-li.cate::before{
	opacity: 1;
}

.menu-pc__gnb-li>a{
	display: flex;
	align-items: center;
	height: 80px;
	color: var(--color-gray-95);
}

.menu-pc__gnb-li>a:hover{
	color: var(--color-primary-50)
}

.menu-pc__gnb-li.hover>a{
	color: var(--color-primary-50)
}

.menu-pc__gnb-li.cate>a{
	color: var(--color-primary-50)
}

.menu-pc__lnb{
	position: absolute;
	top:88px;
	left: 50%;
	transform: translateX(-50%);
	width:160px;
	padding:12px;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	gap:4px;
	border-radius: 16px;
	background-color: var(--color-gray-00);
	box-shadow: 0 4px 12px rgba(0,0,0,0.05);
	display: none;
}

.menu-pc__lnb-li>a{
	display: flex;
	align-items: center;
	height: 40px;
	padding:0 12px;
	box-sizing: border-box;
	border-radius: 8px;
	transition: 0.3s;
}

.menu-pc__lnb-li>a:hover{
	background-color: var(--color-gray-05);
}


.header__menu-mo{
	display: none
}

/* footer */
.footer__bg{
	background-color: var(--color-gray-05);
	z-index: 12;
}

.footer__wrap{
	padding:40px 0 64px;
	box-sizing: border-box;
}

.footer__top{
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-bottom: 20px;
	padding-bottom: 20px;
	box-shadow: inset 0 -1px 0 0 var(--color-gray-20);
}

.footer__gnb{
	display: flex;
	align-items: center;
	gap: 20px;
}

.footer__site{
	position: relative;
}

.footer__site-btn{
	display: inline-flex;
	align-items: center;
	height: 40px;
	padding-right: 28px;
	box-sizing: border-box;
	background: url(../img/ico_off.svg) no-repeat right center;
	color: var(--color-gray-80);
	cursor: pointer;
}

.footer__site-btn.on{
	background: url(../img/ico_on.svg) no-repeat right center;
}

.footer__site-ul{
	position: absolute;
	bottom:40px;
	right: 0;
	width:160px;
	padding:12px;
	box-sizing: border-box;
	display: flex;
	flex-direction: column;
	gap:4px;
	border-radius: 16px;
	background-color: var(--color-gray-00);
	box-shadow: 0 4px 12px rgba(0,0,0,0.05);
	display: none;
	z-index: 11;
}

.footer__site-li>a{
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 100%;
	height: 40px;
	padding:0 12px;
	box-sizing: border-box;
	border-radius: 4px;
	transition: 0.3s;
}

.footer__site-li>a:hover{
	background-color: var(--color-gray-05);
}


.footer__bottom{
	display: flex;
	justify-content: space-between;
	margin-bottom: 40px;
	color: var(--color-gray-80)
}

.footer__info{
	display: flex;
	gap:20px;
}

.footer__textbox{
	display: flex;
	flex-direction: column;
	gap:12px;
}

.footer__text{
	display: inline-flex;
	gap:8px;
	align-items: center;
	flex-wrap: wrap;
}

.footer__text .line{
	width:1px;
	height: 8px;
	background-color: var(--color-gray-40);
}

.footer__sns-ul{
	display: flex;
	gap:8px;
}

.footer__sns-li>a{
	position: relative;
	width: 64px;
	height: 64px;
	background-color: var(--color-gray-00);
	border-radius: 100px;
	box-shadow: inset 0 0 0 1px var(--color-gray-20);
}

.footer__sns-li>a>img{
	position: absolute;
	top:50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 24px;
	height: 24px
}

.footer__copyright, .footer__copyright a{
	color: var(--color-gray-70)
}

.scroll-animation{
	opacity: 0;
	transform:translateY(80px);
	transition:opacity 0.8s, transform 0.8s ease
}

.scroll-animation02.active{
	opacity: 1;
	transform: translateY(0);
}

.scroll-animation02{
	opacity: 0;
	transform:translateY(-80px);
	transition:opacity 0.8s, transform 0.8s ease
}

.animation__flip{
	opacity: 0;
	transform:scaleX(0);
	transition:opacity 0.8s, transform 0.8s ease
}

.animation__flip.on{
	opacity: 1;
	transform: scaleX(1);
}

.section02-item.animation__flip:nth-child(2){
	opacity: 0;
	transform:scaleX(0);
	transition:opacity 0.8s, transform 0.8s ease
}

.section02-item.animation__flip.on:nth-child(2){
	opacity: 1;
	transform: scaleX(1) translateY(-40px);
}


@media all and (max-width:1320px) {

	.section02-item.animation__flip.on:nth-child(2){
		opacity: 1;
		transform: scaleX(1) translateY(0);
	}

}

@media all and (max-width:1024px) {

	.header__wrap{
		padding:0 20px;
	}

	.footer__bottom{
		flex-direction: column;
		gap:20px;
	}

	.footer__sns-ul{
		justify-content: flex-end;
	}

}

@media all and (max-width:840px) {
	.header__menu-pc{
		display: none
	}

	.header__menu-mo{
		display: block
	}

	.menu-mo__btn-open{
		width:44px;
		height:44px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		box-sizing: border-box;
		border-radius: 100px;
		cursor: pointer;
		transition: 0.3s
	}

	.menu-mo__btn-open:hover{
		background-color: var(--color-gray-05)
	}

	.menu-mo__wrap{
		position: fixed;
		top: 0;
		right: 0;
		width: 100%;
		max-width: 360px;
		height: 100%;
		box-sizing: border-box;
		background-color: var(--color-gray-00);
		transform:translateX(1000px);
		transition: 0.3s;
		z-index: 60
	}

	.menu-mo__top{
		display: flex;
		align-items: center;
		justify-content: space-between;
		height: 56px;
		padding:0 20px;
		box-sizing: border-box;
	}

	.menu-mo__top>img{
		height: 32px;
	}

	.menu-mo__btn-close{
		width:44px;
		height:44px;
		display: inline-flex;
		align-items: center;
		justify-content: center;
		box-sizing: border-box;
		border-radius: 100px;
		cursor: pointer;
		transition: 0.3s
	}

	.menu-mo__btn-close:hover{
		background-color: var(--color-gray-05)
	}

	.menu-mo__gnb{
		height: calc(100% - 56px);
		overflow-y: auto;
		scrollbar-width: none;
		-ms-overflow-style: none;
	}

	.menu-mo__gnb-li{
		padding:0 20px;
		box-sizing: border-box;
		user-select: none;
	}

	.menu-mo__gnb-tit, .menu-mo__gnb-tit>a{
		display: flex;
		align-items: center;
		width: 100%;
		height: 56px;
		background: url(../img/ico_off.svg) no-repeat right center;
		cursor: pointer;
		transition: 0.3s;
	}

	.menu-mo__gnb-tit.on{
		color: var(--color-primary-50);
		background: url(../img/ico_on.svg) no-repeat right center;
	}

	.menu-mo__gnb-tit:hover, .menu-mo__gnb-tit>a:hover{
		color: var(--color-primary-50)
	}

	.menu-mo__gnb-tit:last-child, .menu-mo__gnb-tit>a:last-child{
		background: none;
	}

	.menu-mo__gnb-tit.on:last-child{
		background: none;
	}

	.menu-mo__lnb-ul{
		border-radius: 8px;
		background-color: var(--color-gray-05);
	}

	.menu-mo__lnb-li>a{
		display: flex;
		align-items: center;
		height: 44px;
		padding:0 12px;
		box-sizing: border-box;
	}

	.menu-mo__bg{
		position: fixed;
		top: 0;
		right: 0;
		width: 100%;
		height: 100vh;
		background-color: rgba(0,0,0,0.7);
		z-index: 55
	}
}

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

	.footer__top{
		flex-direction: column;
		align-items: flex-start
	}

	.footer__sns-ul{
		justify-content: flex-start;
	}

}

@media all and (max-width:360px) {
	.footer__contact .line{
		display: none
	}

	.footer__contact{
		flex-direction: column;
		align-items:flex-start
	}
}