@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Noto+Sans+KR:100,300,400,500,700,900');
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css");


/* ===================================================== */
/* 기본 스타일 ========================================== */
:root {
	--color-main: #a72e2f;
	--color-sub: ;
	--color-white-a05: rgba(255, 255, 255, 0.05);
	--color-white-a1: rgba(255, 255, 255, 0.1);
	--color-white-a2: rgba(255, 255, 255, 0.2);
	--color-white-a4: rgba(255, 255, 255, 0.4);
	--color-white-a6: rgba(255, 255, 255, 0.6);
	--color-white-a8: rgba(255, 255, 255, 0.8);
	--color-white-a9: rgba(255, 255, 255, 0.9);
	--color-black-a05: rgba(0, 0, 0, 0.05);
	--color-black-a1: rgba(0, 0, 0, 0.1);
	--color-black-a2: rgba(0, 0, 0, 0.2);
	--color-black-a4: rgba(0, 0, 0, 0.4);
	--color-black-a6: rgba(0, 0, 0, 0.6);
	--color-black-a8: rgba(0, 0, 0, 0.8);
	--color-black-a9: rgba(0, 0, 0, 0.9);
	--scroll-width: 0px;
	--inner-width: calc(100vw - var(--scroll-width));
	--inner-padding: max(20px, calc(((var(--inner-width)) - 1400px) / 2));
	--outer-padding: min(var(--inner-padding), 45px);
	--font-noto: 'Noto Sans KR', Roboto,'Malgun Gothic','돋움', dotum, sans-serif;
	--font-pretendard: Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif;
	--font-montserrat: 'Montserrat', Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif;
	font-size: 10px;
}
html::-webkit-scrollbar {width: 8px; background-color: #eee;}
html::-webkit-scrollbar-thumb {background-color: #444;}
body {--header-height: auto; font: 16px/1.2 'Montserrat', Pretendard, Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif; letter-spacing: -0.025em; color: #666;}
/*body:where(.is-fix) {--header-height: 80px;}*/
#wrap { overflow: hidden;}
.is-open {overflow: hidden !important; padding-right: var(--scroll-width) !important;}
.inner {position: relative; margin: 0 var(--inner-padding);}


@media (max-width: 1280px) {
	:root {font-size: 9px;}
}
@media (max-width: 768px) {
	:root {font-size: 8px;}
}
@media (max-width: 480px) {	:root {font-size: 7px;} }
@media (max-width: 360px) {	:root {--inner-padding: 15px;} }
/* 기본 스타일 ========================================== */
/* ===================================================== */


/* ===================================================== */
/* HEADER ============================================== */
.header {--allmenu-gap: 0%; --allmenu-img-width: 0%; position: relative; inset: 0 0 auto; z-index: 1000; border-bottom:1px solid #e1e1e1;}
.header-inner { display: flex; flex-direction: column; justify-content: end; align-items: center; position:relative ; z-index: 1100; transition: .3s, padding 0s; background-color: #fff; }

.header-logo {width:100%; transition:all 0.3s ease-in-out; padding:1.5rem var(--outer-padding); border-bottom:1px solid #f3f3f3; display: flex; justify-content: center;}



/* 상단 2번째 Row */
.header-box.nth-1 {display: flex; align-items: center; background-image: linear-gradient(to bottom, #ffff, #f3f3f3); width:100%; padding:2rem var(--inner-padding); z-index: 2; transition: all 0.3s ease-in-out;}


/* 유틸 */
.header-util {display: flex; align-items: center;}
.header__cate {position: relative;}
.header__cate-btn {display: flex; align-items: center;}
.header__cate-btn em {width:2.2rem; height:2px; display: block; background-color: var(--color-main); position: relative; font-size:0;transition: all 0.3s ease-in-out;}
.header__cate-btn em::before,
.header__cate-btn em::after {content:''; display: block; width:100%; height:100%; background-color: var(--color-main); position: absolute;top:0; left:50%; transition: all 0.3s ease-in-out;}
.header__cate-btn em::before {transform:translate(-50%, -7px);}
.header__cate-btn em::after {transform:translate(-50%, 7px);}
.header__cate-btn span {font-size:1.5rem; font-weight: 700; color:var(--color-main); margin-left:1.2rem;}

.header__cate-btn.is-on em {background-color: transparent;}
.header__cate-btn.is-on em::before {transform:translate(-50%, -50%) rotate(45deg);}
.header__cate-btn.is-on em::after {transform:translate(-50%, -50%) rotate(-45deg);}


.header__cate-list { position: absolute;background-color: #fff; border-radius: 1rem; border:1px solid #dfdfdf;box-shadow: 0 0 1.5em var(--color-black-a1); left:0; top:calc(100% + 2rem); display: none;}
.header__cate-list .list { padding:1rem 0;}
.header__cate-list .depth1 {position: relative;}
.header__cate-list .depth1 > a { font-size:1.4rem; font-weight: 600; padding:1.2rem 3rem;  transition: all 0.3s ease-in-out; white-space: nowrap;color:#4b4b4b;}
.header__cate-list .depth1 > a::before {content:''; display: block; width:1rem; height:1rem; background-color: #fff; position: absolute; top:50%; right:0; transform:translate(calc(50% + 2px), -50%) rotate(45deg); z-index: 1; opacity: 0;}


.header__cate-list .depth1.is-on > a,
.header__cate-list .depth1 > a:hover{background-color: var(--color-main); color: #fff !important;}


.header__cate-list .depth2 {display: none; position: absolute; right:0; top:-1rem; transform: translate(100%, 0);}
.header__cate-list .depth2::before {content:''; display: block; width:1rem; height:1rem; background-color: #fff; position: absolute; top:3rem; left:0; transform:translate(calc(2px - 50%), -50%) rotate(45deg); z-index: 1; opacity: 0;}
.header__cate-list .depth1.is-on .depth2::before,
.header__cate-list .depth1 > a:hover + .depth2::before {opacity: 1;}

.header__cate-list .depth2 ul {background-color: #fff;border-radius: 1rem; border:2px solid var(--color-main);box-shadow: 0 0 1.5em var(--color-black-a1); padding:1rem 0;}
.header__cate-list .depth2 li {padding: 0.8rem 2rem; }
.header__cate-list .depth2 li > a {font-size:1.4rem; font-weight: 600; color:#4b4b4b;text-underline-offset: 0.25em;}
.header__cate-list .depth2 li > a:hover {color:var(--color-main); text-decoration: underline;}


/*상단검색폼*/
.header__search {width:35rem; margin-left:3rem; transition: all 0.3s ease-in-out;}
.header__search-wrap { position:relative; width:100%;transition: all 0.3s ease-in-out;}
.header__search .input-search {border:2px solid #3a3c3e; border-radius: 2.5rem; width:100%; height:4rem; line-height: 4rem; padding:0 4rem 0 2rem;font-weight: 700; color:var(--color-main);}
.header__search .input-search::placeholder{color:#ccc}
.header__search .input-search:focus {border:2px solid var(--color-main);}
.header__search .search-btn {width:4rem; height:4rem; font-size:0; text-indent:-99999px; overflow: hidden; background:url('../images/common/ico_search01.png') 50% 50% no-repeat; position: absolute; right:0; top:50%; transform: translate(0, -50%);}

.header__search .search-open {width:4rem; height:4rem; font-size:0; text-indent:-99999px; overflow: hidden; background:url('../images/common/ico_search01.png') 50% 50% no-repeat; display: none;}
.header__search .search-close {display: none;}

@media (max-width: 1280px){
	.header__search {width:32rem; margin-left:2rem;}
}


/* GNB */
.gnb{ transition: opacity .3s;  margin-left:auto;}
.gnb-wrap { display: flex; margin-right: 0; }
.gnb .depth1 { position: relative; }
.gnb .depth1 > a { padding: 0 2.5rem;  font-size:1.4rem; font-weight: 500;}
.gnb .depth1:first-child > a {padding:0 2.5rem 0 0;}
.gnb .depth1:last-child > a {padding:0 0 0 2.5rem;}
.gnb .depth1 > a span { letter-spacing: normal; color: #707070; white-space: nowrap;}
.gnb .depth1:hover > a span { color: var(--color-main); }


@media (max-width: 1280px){
	.gnb .depth1 > a { padding: 0 2rem;}
	.gnb .depth1:first-child > a {padding:0 2rem 0 0;}
	.gnb .depth1:last-child > a {padding:0 0 0 2rem;}
}



/*상단 제품라인 슬라이드*/
.header-box.nth-2 {background-color: #fff; z-index: 1; width:100%; transition: all 0.3s ease-in-out;}

.top__cate-wrap {overflow: hidden;}
.top__cate .swiper-wrapper {align-items: center !important; height:100%;}
.top__cate .depth1 {width: auto; flex-shrink: 0; line-height:8rem; height:8rem;}
.top__cate .depth1 a { color:#4b4b4b; font-size:1.5rem; font-weight: 600; padding:0 2.5rem;}
.top__cate .depth1 a::after {content:''; display: block; width:0; height:3px; background-color: var(--color-main); transition: all 0.3s ease-in-out; position: absolute; bottom:0; left:50%; transform: translate(-50%, 0);}
.top__cate .depth1 a:hover {color:var(--color-main);}

.body-sub .top__cate .depth1 a.on {color:var(--color-main);}
.body-sub .top__cate .depth1 a.on::after {width:100%;}


.top__cate-btn {width:2rem; height:2rem; cursor: pointer; position: absolute; top:50%; transform: translate(0, -50%); left:-5rem; z-index: 2;}
.top__cate-btn.next {left:auto; right: -5rem;transform: translate(0, -50%) rotate(180deg);}
.top__cate-btn::before,
.top__cate-btn::after {content:''; display: block; width:1.2rem; height:4px; background-color: rgba(0, 0, 0, 1); border-radius: 4px; position: absolute; top:50%; left:0;}
.top__cate-btn::before{transform: translate(0, -150%) rotate(-45deg);}
.top__cate-btn::after{transform: translate(0, 50%) rotate(45deg);}

.top__cate-btn span {display: block; height:4px; width:100%; border-radius: 4px; background-color: rgba(0, 0, 0, 1); position: absolute; top:50%; left:0; transform: translate(0, -50%);}
.top__cate-btn.swiper-button-disabled {opacity: 0.3; pointer-events: none;}

.top__cate-btn:hover::before,
.top__cate-btn:hover::after,
.top__cate-btn:hover span {background-color: var(--color-main);}

@media (max-width: 1580px) {
	.top__cate-wrap {margin:0 auto; width:calc(100% - 4rem)}
	.top__cate-btn {left:-1rem;}
	.top__cate-btn.next {left:auto; right: -1rem;}
}









/* 전체메뉴 버튼 */
.util-allmenu-btn { position: relative; width: 23px; height: 23px; }
.util-allmenu-btn span { position: absolute; top: 10px; left: 0; width: 23px; height: 3px; border-radius: 3px; background-color: #fff; transition: .3s; }
.util-allmenu-btn:hover span:not(:nth-child(2)) { width: 18px; }
.util-allmenu-btn span:nth-child(1) { transform: translateY(-8px); }
.util-allmenu-btn span:nth-child(3) { transform: translateY(8px); }
:is(.is-hover, .is-fix, .is-menu) .util-allmenu-btn span { background-color: #222; }
.is-menu .util-allmenu-btn span { width: 31px; transform: rotate(45deg) translate(-3px, 3px); }
.is-menu .util-allmenu-btn span:nth-child(2) { opacity: 0; }
.is-menu .util-allmenu-btn span:nth-child(3) { transform: rotate(-45deg) translate(-3px, -3px); }




/* 전체메뉴 / 모바일메뉴 */
.allmenu { display: flex; visibility: hidden; opacity: 0; position: fixed; width: 100%; height: 100%;  background:#fff;  transition: all 0.5s ease-in-out; z-index: 1200; inset: 0; transform: translateX(-10%);}
.allmenu-wrap {flex-grow: 1; padding:0 var(--inner-padding);}
.allmenu-cont { visibility: hidden; overflow: hidden auto; opacity: 0; height: calc(100% - var(--header-height)); transition: .3s;}
.allmenu-cont::-webkit-scrollbar { width: 6px; }
.allmenu-cont::-webkit-scrollbar-thumb { background-color: var(--color-main); }
.allmenu-list { display:none; flex-wrap: wrap; padding: 0 0 calc(3rem + 6vh); }




/* dim */
.gnb-dim { opacity: 0; position: fixed; inset: 0; z-index: 1000; background-color: var(--color-black-a6); transition: opacity .3s; pointer-events: none; }
/*:is(.is-hover):not(.is-menu) .gnb-dim { opacity: 1; }  */

@media (hover: hover) and (pointer: fine) {
}

@media (max-width: 1024px) {

	.header-inner {flex-direction: row; flex-wrap: wrap; justify-content: flex-start; padding:0 var(--inner-padding);}
	.header-logo {width:19rem; border:0; padding:0; flex-shrink: 0;}
	.header-box.nth-1 {width:calc(100% - 19rem); background: transparent; padding:0; flex-grow: 1; justify-content: flex-end; height:7rem;}
	.header-util {gap: 2rem;}
	.header__cate {order:2;}
	.header__cate-btn span {display: none;}
	.header__search {order:1;}

	.header-box.nth-2 {width:100%; position: relative;}
	.header-box.nth-2::before {content: ''; display: block; height:1px; width:200%; position: absolute; top:0; left:-50%; background-color: #e1e1e1; }
	.header-box.nth-2 .inner{margin:0;}

	.top__cate .depth1 {line-height:7rem; height:7rem;}


	.gnb { display: none; }
	.is-menu .allmenu { visibility: visible; opacity: 1; width: 100%; transform: translateX(0);}

	.is-menu .allmenu-cont { visibility: visible; opacity: 1; transition: .6s ease-out .2s; height:100%;}

	.allmenu-cont::-webkit-scrollbar { width: 0; }
	.allmenu-list.is-on { display: block; }

	.all-depth1 { padding: 0; }
	.all-depth1-btn { display: flex; justify-content: space-between; align-items: center; width: 100%; padding: 2.2rem 2rem; margin: 0; border-bottom: 1px solid #d9d9d9; cursor: pointer; font-weight: 600; color:#000; font-size:2rem; }
	.all-depth1-btn::after { flex-shrink: 0; width: 18px; height: 10px; background-image: url(../images/common/chevron_w18.svg); content: ''; transition: .3s; }
	.all-depth1-btn.on { color: var(--color-main); border-bottom: 2px solid var(--color-main); }
	.all-depth1-btn.on::after { transform: rotate(180deg); }
	.all-depth1-btn.is-only::after { transform: rotate(270deg); }
	.all-depth2 { display: none; padding: 0.8em 0; background-color: var(--color-black-a05); }
	.all-depth2-btn { padding: 1rem 3rem; font-size:1.8rem; font-weight: 500;}


	.allmenu-close {width:3rem; height:3rem; position: relative; display: block; margin-left:auto; margin:1rem 0 1rem auto; text-indent: -99999px; overflow: hidden; }
	.allmenu-close::before,
	.allmenu-close::after {content:''; display: block; width:100%; height:2px; background-color: #000; border-radius: 4px; position: absolute; top:50%; left:50%; transform: translate(-50%, -50%);}

	.allmenu-close::before {transform: translate(-50%, -50%) rotate(45deg);}
	.allmenu-close::after {transform: translate(-50%, -50%) rotate(-45deg);}

	/*모바일 메뉴 탭*/
	.allmenu-tab {display: flex; border-bottom: 1px solid var(--color-main);}
	.all-tab-btn {flex:1 1 50%; text-align: left; padding:0 2rem; height:6rem; color:#565656; background-color: #e7e7e7; font-weight: 700; font-size:1.8rem;}
	.all-tab-btn.is-on {background-color: var(--color-main); color:#fff;}
}
@media (max-width: 768px) {

	.header__search {width:auto; margin:0;}
	.header__search-wrap {position: fixed; z-index: 2; width:100%; height:7rem; top:-10rem; left:0; background-color: #fff; display: flex; align-items: center; padding: 0 10px; gap:1rem;}
	.header__search-wrap.is-on {top:0;}

	.header__search .input-search {width:calc(100% - 4rem);}
	.header__search .search-btn {right:6rem; background-size:2.5rem auto;}

	.header__search .search-close {width:3rem; height:3rem; position: relative; display: block; margin-left:auto; margin:1rem 0 1rem auto; text-indent: -99999px; overflow: hidden; display: block; }
	.header__search .search-close::before,
	.header__search .search-close::after {content:''; display: block; width:100%; height:2px; background-color: var(--color-main); border-radius: 4px; position: absolute; top:50%; left:50%; transform: translate(-50%, -50%);}

	.header__search .search-close::before {transform: translate(-50%, -50%) rotate(45deg);}
	.header__search .search-close::after {transform: translate(-50%, -50%) rotate(-45deg);}

	.header__search .search-open {display: block;}



	.top__cate-btn::before,
	.top__cate-btn::after {width:1.1rem; height:3px;}

	.top__cate-btn span {height:3px; border-radius: 3px;}



}
@media (max-width: 480px) {
	.top__cate-btn::before{transform: translate(0, -125%) rotate(-45deg);}
	.top__cate-btn::after{transform: translate(0, 25%) rotate(45deg);}
}
/* HEADER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* FOOTER ============================================== */
.footer { padding: 9rem 0; background-color: #181818; color: #fff; letter-spacing: 0.025em; position: relative; z-index: 1;}

/*우측퀵*/
.quick {position: fixed; top:50%; right:0; transform:translate(0, -50%); z-index: 2000; transition: all 0.3s ease-in-out;}
.is-menu .quick {z-index:999;}
.quick-btn {display: block; width:5rem; height:5rem; background-color: var(--color-main); border-radius: 50%; position: absolute; font-size:0; transition: all 0.3s ease-in-out; z-index: 1; top:0; right:0rem;  transform: translate(100%, 0);box-shadow: 0 0 2rem var(--color-black-a2); z-index: 1;}
.quick-btn::after {content:''; display: block; width:1.2rem; height:1.2rem; background-color: var(--color-main); position: absolute; bottom:3px; right:3px; transform:skew(30deg); z-index: -1; transition: all 0.3s ease-in-out;}

.quick-btn span::before,
.quick-btn span::after {content:'';}
.quick-btn span::before,
.quick-btn span::after,
.quick-btn span {display: block; width:0.6rem; height:0.6rem; background-color: #fff; border-radius: 50%; position: absolute; top:50%; left:50%; transform:translate(-50%, -50%); transition: all 0.3s ease-in-out;}
.quick-btn span::before {transform:translate(calc(-50% - 1rem), -50%);}
.quick-btn span::after {transform:translate(calc(-50% + 1rem), -50%);}

.quick-wrap {border-radius: 1rem 0 0 1rem; overflow: hidden;  transition: all 0.3s ease-in-out; position: absolute; top:50%; right:0%; transform:translate(0, -50%);box-shadow: 0 0 1.5em var(--color-black-a2);}
.quick-wrap .item a {display: flex;  width:10rem; height:10rem; align-items: center; justify-content: center; color:#fff; font-size: 1.4rem; font-weight: 600; transition: all 0.3s ease-in-out;}
.quick-wrap .item a span {padding:0; display: flex; flex-direction: column; align-items: center; gap:1rem;}
.quick-wrap .item a span::before {content:''; display: block; width:3rem; height:3rem; background-position: 50% 0; background-repeat: no-repeat; background-size: contain; transition: all 0.3s ease-in-out;}

.quick-wrap .item:nth-of-type(1) a{background-color: #fff; color:#3a3c3e;}
.quick-wrap .item:nth-of-type(1) a span::before {background-image: url('../images/common/ico_quick01.png');}

.quick-wrap .item:nth-of-type(2) a{background-color: #3a3c3e;}
.quick-wrap .item:nth-of-type(2) a span::before {background-image: url('../images/common/ico_quick02.png');}
.quick-wrap .item:nth-of-type(3) a{background-color: #da2725;}
.quick-wrap .item:nth-of-type(3) a span::before {background-image: url('../images/common/ico_quick03.png');}

.quick-wrap .item a:hover {background-color: var(--color-main); color:#fff;}
.quick-wrap .item:nth-of-type(1) a:hover span::before {background-image: url('../images/common/ico_quick01_on.png');}


/* .is-fixed .quick {top:auto; bottom:7rem; transform: translate(0);}
.is-fixed .quick-wrap {transform: translate(100%, 0); display: flex; border-radius: 1rem; opacity: 0;}
.is-fixed .quick-btn {transform: translate(0); right:var(--outer-padding);}

.is-fixed .quick-wrap .item {flex:1 1 auto;}
.is-fixed .quick-wrap .item a {width:16rem; height:5rem; padding:0 1rem;}
.is-fixed .quick-wrap .item a span {flex-direction: row; gap:0.5rem; letter-spacing: -0.025em; white-space: nowrap;}
.is-fixed .quick-wrap .item a span::before {width:2.4rem; height:2.4rem;} */






/* .quick.is-on {position:absolute; top:-12rem; bottom:auto;} */

@media (max-width: 1600px) {
	.quick {top:auto; bottom:7rem;}
	.quick-btn {transform: translate(0); right:var(--outer-padding);}

	.quick-wrap {border-radius: 1rem; display: flex; transform: translate(100%, 0); opacity: 0;}
	.quick.is-active .quick-wrap {transform: translate(0, 0); right:calc(var(--outer-padding) + 6rem); opacity: 1;}
	.quick-wrap .item {flex:1 1 auto;}
	.quick-wrap .item a {width:16rem; height:5rem; padding:0 1rem;}
	.quick-wrap .item a span {flex-direction: row; gap:0.5rem; letter-spacing: -0.025em; white-space: nowrap;}
	.quick-wrap .item a span::before {width:2.4rem; height:2.4rem;}


}

.quick.is-active .quick-btn,
.quick.is-active .quick-btn::after {background-color: #000;}
.quick.is-active .quick-btn span {background-color: transparent;}
.quick.is-active .quick-btn span::before,
.quick.is-active .quick-btn span::after {width:2rem; height:2px; transform:translate(-50%, -50%);}
.quick.is-active .quick-btn span::before {transform:translate(-50%, -50%) rotate(45deg);}
.quick.is-active .quick-btn span::after {transform:translate(-50%, -50%) rotate(-45deg);}
/* .is-fixed .quick.is-active .quick-wrap {transform: translate(0, 0); right:calc(var(--outer-padding) + 6rem); opacity: 1;} */

@media (max-width: 480px) {
	.quick-wrap .item a,
	.is-fixed .quick-wrap .item a {width:12rem;}
}




.footer-wrap {display: flex; gap:1rem; }
.footer-box:nth-of-type(1) {flex-shrink: 0; width:25%;}
.footer-box:nth-of-type(2) {flex-grow: 1; width:100%;}
.footer-box:nth-of-type(3) {flex-shrink: 0; width:25rem;}

.footer-logo img{margin:0 auto;}

.footer-info {display: flex; flex-direction: column; font-size:1.5rem; line-height:1.3;}
.footer-info .item { display: flex; flex-direction: column;}
.footer-info .item + .item {margin-top:2rem;}
.footer-info .item dt {font-weight: 700;}
.footer-info .item dd {font-weight: 500;}
.footer-info .item a {display: inline;}

.footer-menu { display: flex; align-items: center; margin-top:6rem; position: relative; font-size:1.4rem;}
.footer-menu::before,
.footer-menu::after {content:''; display: block; width:500%; height:1px; background-color: #2d2d2d; position: absolute; left:0;}
.footer-menu::before{top:0;}
.footer-menu::after {top:100%;}
.footer-menu .item { display: flex; align-items: center; }
.footer-menu .item a { padding: 3rem 0rem; color:#696969; font-weight: 600;}
.footer-menu .item a:hover {color:var(--color-main);}
.footer-menu .item + .item {margin-left:2.5rem;}
.footer-menu .item + .item::before { width: 5px; height: 5px; border-radius: 50%; background-color: var(--color-main); content: '';  margin-right:2.5rem;}


.footer-contact { display: flex; flex-direction: column; padding:2rem; background-color: #fff; border-radius: 1rem; color:#3a3c3e;}
.footer-contact .item { display: flex; flex-direction: column; padding-left: 3rem; }
.footer-contact .item + .item {margin-top:2rem;}
.footer-contact .item dt {position: relative; text-decoration: underline;text-underline-offset: 0.25em; color:#222; font-weight: 700; font-size:1.5rem;}
.footer-contact .item dt::before {content:''; display: block; width:2.4rem; height:2.4rem; background-color: #231f20; border-radius: 50%; background-repeat: no-repeat; background-position: 50% 50%; background-size: contain; position: absolute; top:50%; left:0; transform:translate(-120%, -50%)}
.footer-contact .item:nth-of-type(1) dt::before {background-image: url('../images/common/ico_tel.png');}
.footer-contact .item:nth-of-type(2) dt::before {background-image: url('../images/common/ico_fax.png');}
.footer-contact .item dd {font-weight: 700; font-size:1.8rem; margin-top:0.5rem;}
.footer-contact .item.tel dd {color:var(--color-main);}


.footer-copy { line-height: 1.3; font-size: 1.4rem; color:#676767; margin-top:5rem; text-transform: uppercase; font-weight: 600;}

/* 탑버튼 */
.top-btn { display: flex; width: 5rem; height: 5rem; background-color: #fff; border-radius: 50%;  position: absolute; top:9rem; right:var(--outer-padding); box-shadow: 0 0 1.5em var(--color-black-a2);}
.top-btn::before { width: 16px; height: 22px; margin: auto; background: url(../images/common/ico_top.svg) no-repeat center/contain; content: ''; }
@keyframes top-btn {
	33% { transform: translateY(2px); }
	66% { transform: translateY(-4px); }
}
.top-btn.is-on {top:-6rem; }

@media (hover: hover) and (pointer: fine) {
	.top-btn:hover::before { animation: top-btn 1.5s infinite linear; }
}
@media (max-width: 1280px) {
	.footer-box:nth-of-type(1) {width:20%;}
}
@media (max-width: 960px) {
	.footer-box:nth-of-type(1) {display: none;}
}
@media (max-width: 768px) {
	.footer {padding:7rem 0;}
	.footer-wrap {flex-direction: column; row-gap: 3rem;}
	.footer-box:nth-of-type(1) {display: block; margin:0 auto; width:25%;}
	.footer-box:nth-of-type(2) {order:2;}
	.footer-box:nth-of-type(3) {order:1; width:100%;}

	.footer-menu {font-size:1.6rem;}
	.footer-menu::before,
	.footer-menu::after {left:-3rem;}



	.footer-contact { flex-direction: row; gap:2rem;}
	.footer-contact .item { flex-grow: 1; padding-left:2rem;}
	.footer-contact .item + .item {margin-top:0rem;}
	.footer-contact .item dd {white-space: nowrap;}

}
@media (max-width: 480px) { }
/* FOOTER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* SUB-LAYOUT ========================================== */

/* SUV-VISUAL */
.sub-visual {position: relative;  }
.sub-visual-bg { overflow: hidden; position: absolute; inset: 0; width:100%; height:41rem; z-index: -1; background-color: var(--color-black-a1);}
.sub-visual-bg span { position: absolute; inset: 0; background: #f5f5f5 no-repeat top/cover; transform: scale(1.1); animation: sub-visual 5s linear both; }
@keyframes sub-visual { to { transform: scale(1); } }

.sub-visual.nth-1 .sub-visual-bg span {background-image: url('../images/common/sub_visual01.jpg');}
.sub-visual.nth-2 .sub-visual-bg span {background-image: url('../images/common/sub_visual02.jpg');}
.sub-visual.nth-3 .sub-visual-bg span {background-image: url('../images/common/sub_visual03.jpg');}
.sub-visual.nth-4 .sub-visual-bg span {background-image: url('../images/common/sub_visual04.jpg');}
.sub-visual.nth-5 .sub-visual-bg span {background-image: url('../images/common/sub_visual05.jpg');}
.sub-visual.nth-6 .sub-visual-bg span {background-image: url('../images/common/sub_visual06.jpg');}


.sub-visual-txt { display: flex; flex-direction: column; margin-top:4rem;}
.sub-visual-tit { margin-bottom: 1rem; font-weight: 700; font-size: 3rem; letter-spacing: 0em; color:var(--color-main)}
.sub-visual-tit span {text-decoration: underline;text-underline-offset: 0.25em;}


/* SUB-TAB */
.sub-tab { position: relative; z-index: 10;  background: linear-gradient(var(--color-white-a1), var(--color-white-a1)) no-repeat top/100% 1px;  font-weight: 600; font-size: 1.4rem;}
.sub-tab-wrap { display: flex; align-items: center; margin:0 var(--inner-padding); padding:2.5rem 0; border-bottom:1px solid #e1e1e1;}

.sub-tab-home { width: 2.2rem; height:2.2rem; background: #231f20 url(../images/common/ico_home.svg) no-repeat center; border-radius: 50%;}
.sub-tab-item { position: relative;}
.sub-tab-item + .sub-tab-item {padding-left:1rem;}
.sub-tab-item + .sub-tab-item::before {content:''; width:0.8rem; height:0.8rem; border:1px solid #777; border-width: 1px 1px 0 0; position: absolute; top:50%; left:0; transform: translate(0, -50%) rotate(45deg); }
.sub-tab-btn { overflow: hidden; display: block; position: relative; z-index: 5; width: 100%; padding: 0 1rem; text-align: left; white-space: nowrap; /*text-overflow: ellipsis;*/ transition: .2s; color:#8a8a8a; pointer-events: none;}
/*
.sub-tab-btn::before { position: absolute; top: 50%; right: 8%; width: 13px; height: 8px; background-color: #fff; mask-image: url(../images/common/chevron_w13.svg); -webkit-mask-image: url(../images/common/chevron_w13.svg); content: ''; transform: translateY(-50%); transition: .2s;}
*/
.sub-tab-item.is-active .sub-tab-btn {background-color: #fff; color: var(--color-main);}
.sub-tab-item.is-active .sub-tab-btn::before { background-color: var(--color-main); transform: translateY(-50%) rotate(180deg); }
/* 리스트 */
.sub-tab-list { display: none; position: absolute; top: 100%; width: 100%; border-top: 1px solid #eee; background-color: #fff; box-shadow: 0 0 2em var(--color-black-a1); font-size: var(--font-16);}
.sub-tab-list a { padding: 0.85em 10%; }
.sub-tab-list li.on a { background-color: #f5f5f5; font-weight: 800; color: var(--color-main);}


/* SUB-CONTENT */
.sub-content {margin-top:3rem;}
.sub-content-tit h3 { padding: 6rem 0; font-weight: 700; font-size: 4rem; text-align: center; color: #222; }
.sub-content-wrap::after {display: block; visibility: hidden; width: 100%; height: 1px; content: ''; margin-bottom: -1px;}
/* SUB-CONTENT-TAB */
.sub-content-tab { overflow-x: auto; padding: 0 var(--inner-padding); margin-bottom: 7rem; text-align: center;}
.sub-content-tab:not(:has(li)) { display: none; }
.sub-content-tab::-webkit-scrollbar {height: 6px; background-color: #fff;}
.sub-content-tab::-webkit-scrollbar-thumb {border: 1px solid transparent; background-color: var(--color-main); background-clip: content-box;}
.sub-content-tab ul {display: flex; gap: 1px; width: fit-content; padding: 1px; margin: 0 auto;}
.sub-content-tab li {outline: 1px solid #eee;}
.sub-content-tab li.on {z-index: 5; outline-color: var(--color-main);}
.sub-content-tab li a { min-width: 12em; padding: 1em 2em; font-size: calc(1rem + 8px); transition: .3s;}
.sub-content-tab li.on a { background-color: var(--color-main); font-weight: 600;color: #fff; }

@media (hover: hover) and (pointer: fine) {
	.sub-tab-list li a:hover { background-color: #fff; color: var(--color-main); }
	.sub-content-tab li:not(.on) a:hover {color: var(--color-main); text-shadow: 0 0 0.04em var(--color-main);}
}
@media (max-width: 1280px) {
	.body-sub { --sub-tab-height: 66px; }
	.sub-visual-txt {padding: var(--header-height) 0 var(--sub-tab-height);}
}
@media (max-width: 768px) {
	.body-sub {--sub-tab-height: 62px;}
}
@media (max-width: 480px) {
	.body-sub { --sub-tab-height: 58px; }
	.sub-content-tab ul { flex-direction: column; width: 100%;}
}
/* SUB-LAYOUT ========================================== */
/* ===================================================== */


/* ===================================================== */
/* MODAL =============================================== */
#modal { z-index: 9999; position: relative; letter-spacing: -0.02em;}
.modal-item { display: flex;visibility: hidden; opacity: 0; position: fixed; inset: 0; background-color: var(--color-black-a4); transition: .3s, margin 0s;}
.is-open .modal-item {margin-right: var(--scroll-width);}
.modal-item.on {visibility: visible; opacity: 1;}
.modal-inner {display: grid; grid-template-rows: auto 1fr; width: 90%; padding: 2.5rem; margin: auto; background-color: #fff; max-width: 700px;}
.modal-top {display: flex; justify-content: space-between; padding-bottom: 0.8em; margin-bottom: 1em; border-bottom: 2px solid #333; font-size: 2.4rem; line-height: 1; align-items: center; column-gap: 0.5em;}
.modal-tit { font-weight: 700; color: #333;white-space: nowrap;}
.modal-close { flex-shrink: 0; width: 2rem; aspect-ratio: 1 / 1; }
.modal-close::before { display: block; height: 100%; background: url(../images/common/ico_close.svg) no-repeat center/contain;content: '';}
.modal-cont { overflow: hidden auto; max-height: 50vh; padding: 4%; border: 1px solid #eee; overscroll-behavior: contain;}
.modal-cont::-webkit-scrollbar {width: calc(1rem - 3px); background-color: #eee;}
.modal-cont::-webkit-scrollbar-thumb { min-height: 30%; background-color: var(--color-main);}

/* 개인정보처리방침 */
.privacy {font-size: calc(9px + 0.6rem); line-height: 1.6; padding: 1.5em 0 2em;}
.privacy a {display: inline;}
.privacy h4 { padding-top: 1em;font-weight: 500; font-size: calc(1em + 1px); color: #444;}
.privacy-header { margin-bottom: 1em; font-weight: 600; font-size: calc(1em + 1px);color: #333;}
.privacy-inner {padding: 0.6em 0.6em 0.8em;}
.privacy-comment {padding-top: 1em;}

/* 이메일무단수집거부 */
.refusal-mail {font-size: calc(10px + 0.6rem); padding: 1.8em 0 2em; text-align: center; font-weight: 500;}
.refusal-mail h4 {font-size: 1.75em; color: #333; margin-bottom: 0.4em; font-weight: 700;}
.refusal-mail h5 {font-size: 1.25em; color: #444;}
.refusal-mail h5::after {display: block; width: 1em; height: 2px; background-color: #333; content: ''; margin: 1em auto;}
.refusal-mail p { line-height: 1.7;}
@media (max-width: 576px) {
	.refusal-mail h4 {font-size: calc(2.2vw + 12px);}
	.refusal-mail h5 {font-size: 1.2em;}
	.refusal-mail p br {display: none;}
}
/* MODAL =============================================== */
