@charset "utf-8";

:root {
	--main_color: #007BE5;
}

/* 프로그램리스트 모바일 버전 */
.all_m_btn {
	padding: 10px;
	background: #323337;
}

.all_m_btn img {
	position: absolute;
	top: 28%;
	left: 15px;
	width: 10%;
	max-width: 40px;
	cursor: pointer;
}

.all_m_btn .mutit {
	text-align: center;
	font-weight: 900;
	font-size: 26px;
	color: #fff;
}

.pro_m_wrap {
	display: none;
	font-family: 'Nanum Gothic', sans-serif;
	transition: all 0.3s linear;
}

.pro_m_wrap .m_menu {
	width: 200px;
}

.pro_m_wrap .bg_black {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.7);
	z-index: -1;
}



.pro_m_wrap .subleftmenu {
	list-style: none;
	margin: 0;
	padding: 0;
}

.pro_m_wrap .subleftmenu li {
	border-bottom: 1px solid #515155;
	background: #323337;
}

.pro_m_wrap .subleftmenu a {
	display: block;
	color: #b5b2b2;
	font-size: 14px;
	padding: 11px 5px 11px 15px;
	font-family: 'Noto Sans KR';
}

.sub_title_m {
	font-size: 28px !important;
	font-weight: bold;
	color: #fff !important;
	padding: 12px 5px 12px 15px !important;
}

.pro_m_wrap .subleftmenu a:hover {
	background: #307dd4;
	color: #fff;
}

.sub_title_m:hover {
	background: #323337 !important;
	cursor: default;
}

@media all and (max-width:999px) {
	.pro_m_wrap {
		display: block;
		position: absolute;
		left: -100%;
		top: 0;
		z-index: 999;
	}

	.pro_m_wrap.view {
		left: 0;
	}
}


/* basic */
.inner {
	width: 100%;
	max-width: 1400px;
	margin: 0 auto;
	position: relative;
}

@media all and (max-width:1400px) {
	.inner {
		width: 93.75%
	}
}


/* 최근본 상품 퀵메뉴 */
/* .quick {overflow:hidden; z-index:110; position:fixed; right:20px; top:50%; width:141px;  -webkit-transform:translateY(-50%); -moz-transform:translateY(-50%); -ms-transform:translateY(-50%); -o-transform:translateY(-50%); transform:translateY(-50%) ;} */
.quick * {
	box-sizing: border-box;
}

.quick>ul {
	margin-bottom: 0;
	border: 1px solid #dcdcdc;
	box-sizing: border-box;
	background-color: #fff;
	border-radius: 10px;
	overflow: hidden;
}

.quick ul li.recent_prod {}

.quick ul li.recent_prod>p {
	height: 40px;
	font-size: 15px;
	color: #fff;
	letter-spacing: -0.025em;
	line-height: 40px;
	background-color: var(--color-primary01);
	text-align: center;
}


.prod_no_box {
	width: 114px;
	height: 114px;
	border-radius: 5px;
	background: #F5F5F5;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 15px;
	text-align: center;
}



.quick ul li.recent_prod ul {
	padding: 30px 10px;
	box-sizing: border-box;
	margin-bottom: 10px;
	background-color: #fff;
	border-radius: 0 0 6px 6px;
	position: relative;
}

.quick ul li.recent_prod ul li {
	border: unset;
	border-radius: 6px;
	aspect-ratio: 1/0.7333;
	overflow: hidden;
	margin-bottom: 10px;
	box-sizing: border-box;
}

.quick ul li.recent_prod ul li:last-of-type {
	margin-bottom: 0;
}

.quick ul li.recent_prod ul li img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.quick ul li.recent_prod .quick_pager {
	margin-top: 0;
	margin-bottom: 30px;
}

.quick ul li.recent_prod .quick_pager a {
	display: inline-block;
	vertical-align: middle;
	width: auto;
	height: auto;
	border: 0 none;
	margin: 0 3px;
	line-height: 14px;
	font-size: 14px;
	color: #b6b6b6;
}

.quick ul li.recent_prod .quick_pager a.active {
	color: #666666;
}

.quick ul li.recent_prod .quick_pager .page_prev,
.quick ul li.recent_prod .quick_pager .page_next {
	display: inline-block;
	vertical-align: middle;
	width: 9px;
	height: 11px;
	border: 0 none;
	text-indent: -9999px;
}

.quick ul li.recent_prod .quick_pager .page_prev {
	background: url('/img/theme/quick_prev_btn.png') no-repeat center center;
}

.quick ul li.recent_prod .quick_pager .page_next {
	background: url('/img/theme/quick_next_btn.png') no-repeat center center;
}

.quick ul.zzim {
	margin-top: 30px;
}

.quick ul li.top_btn {
	width: 100%;
	height: 40px;
	background-color: #000;
	box-sizing: border-box;
	line-height: 48px;
	text-align: center;
}

.quick ul li.top_btn a {
	display: block;
	color: #fff;
	line-height: 40px;
	font-size: 15px;
	letter-spacing: -0.025em;
}

.quick_top_btn {
	display: none;
	z-index: 999;
	position: fixed;
	right: 20px;
	bottom: -90px;
	/* width: 57px;
	height: 57px;
	background-color: #798ebb; */
	border-radius: 50%;
	text-align: center;
	cursor: pointer;
	transition: all 0.5s;
}

.quick_top_btn.on {
	bottom: 90px;
}

/* .quick_top_btn img {padding-top:12px; } */
.quick_top_btn p {
	font-size: 16px;
	color: #ffffff;
	letter-spacing: -0.025em;
}

.quick_step_btn_box01 {
	display: flex;
}

/* .quick_step_btn_box01 > a {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 1;
	border: 1px solid #DCDCDC;
	background-color: #F9F9F9;
	font-size: 12px;
	font-weight: 400;
	color: #333;
	padding: 5px;
}
.quick_step_btn_box01 > a + a {
	border-left: unset;
} */
.quick_step_btn_box01>a {
	position: absolute;
	z-index: 2;
}

.quick_step_btn_box01>a.btn-prev {
	top: 10px;
	left: 50%;
	transform: translateX(-50%);
}

.quick_step_btn_box01>a.btn-next {
	bottom: 10px;
	left: 50%;
	transform: translateX(-50%);
}

@media all and (max-width:1400px) {
	.quick {
		display: none;
	}

	.quick_top_btn {
		display: block;
	}
}

/* shop 퀵메뉴 */
#sideQuick {
	position: fixed;
	right: 10rem;
	bottom: 4rem;
	z-index: 101;
	max-width: 140px;
}

#sideQuick>ul {
	border-radius: 6px;
	margin-bottom: 20px;
}

#sideQuick ul li .side_quick_menu01 {
	width: 100%;
	aspect-ratio: 1/0.357;
	display: flex;
	align-items: center;
	gap: 5px;
	text-align: center;
	font-size: 14px;
	font-weight: 400;
	color: #222;
	background-color: #fff;
	box-shadow: 0px 0px 30px 0px rgba(0, 0, 0, 0.07);
	border-radius: 6px;
	padding: 0 20px;
}

#sideQuick ul li .side_quick_menu01+.side_quick_menu01 {
	margin-top: 10px;
}

#sideQuick ul li .side_quick_menu01 img {
	width: fit-content;
}

#top_btn {
	margin-top: 10px;
	display: none;
	opacity: 0;
	transition: opacity 0.3s ease-in-out, transform 0.3s ease-in-out;
	position: absolute;
	bottom: 0;
}

#top_btn.show {
	display: flex;
	opacity: 1;
	transform: translateY(0);
}

#sideQuickMoreBtn {
	position: absolute;
	cursor: pointer;
	bottom: 0;
	z-index: 2;
	transition: all 0.3s ease-in-out;
}

#top_btn,
#sideQuickMoreBtn {
	display: flex;
	justify-content: center;
}

.sideQuickBtn {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0px 0px 20px 0px rgba(0, 0, 0, 0.08);
	background-color: #fff;
}

#sideQuickMoreBtn .sideQuickBtn {
	background-color: var(--color-primary01);
}

#sideQuickMoreBtn .sideQuickBtn span {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background-color: #fff;
	transition: transform 0.3s, opacity 0.3s;
}

#sideQuickMoreBtn .sideQuickBtn span:nth-child(1) {
	width: 12px;
	height: 1px;
}

#sideQuickMoreBtn .sideQuickBtn span:nth-child(2) {
	width: 1px;
	height: 12px;
}

#sideQuickMoreBtn.scroll {
	bottom: 60px;
}

#sideQuickMoreBtn.active .sideQuickBtn span:nth-child(1) {
	transform: translate(-50%, -50%) rotate(45deg);
}

#sideQuickMoreBtn.active .sideQuickBtn span:nth-child(2) {
	transform: translate(-50%, -50%) rotate(45deg);
}

#sideQuickMoreBtn .quick {
	position: absolute;
	bottom: 100%;
	margin-bottom: 10px;
	min-width: 140px;
	display: none;
}

@media all and (max-width:1400px) {
	#sideQuick {
		display: none;
	}
}

/* END shop 퀵메뉴 */



/*------------------------------------
	/             모바일 Header              /
	/------------------------------------*/
.m_btn {
	cursor: pointer;
	font-size: 1.5rem;
	display: flex;
	align-items: center;
}

#m_menu {
	border: 1px solid #e9e9e9;
	display: flex;
	flex-direction: column;
}

.m_menu_bg {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.2);
	z-index: 98;
	opacity: 0;
	transition: opacity 0.3s ease;
}

.m_menu_bg.show {
	display: block;
	opacity: 1;
}

#m_menu {
	position: fixed;
	top: 0;
	left: -100%;
	width: 22.5rem;
	height: 100%;
	background: #fff;
	z-index: 9999;
	opacity: 0;
	transition: left 0.3s ease, opacity 0.3s ease;
}

#m_menu.on {
	left: 0;
	opacity: 1;
}

#m_menu .close_btn {
	position: absolute;
	top: 0.625rem;
	right: 0.625rem;
	font-size: 1.25rem;
	cursor: pointer;
	background: none;
	border: none;
}

#m_menu .gnb_box ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

#m_menu .gnb_box li {
	border-bottom: 1px solid #eee;
}

#m_menu .gnb_box li a {
	display: block;
	padding: 0.75rem 0.625rem;
	color: #333;
	text-decoration: none;
}

#m_menu .gnb_box li.on>a {
	color: var(--main_color);
	font-weight: bold;
}

#m_menu .depth02 {
	display: none;
	padding-left: 0.9375rem;
	background: #f9f9f9;
}

/*로고 탑과 화살표*/
.sidebar_top {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
	padding: 0.8125rem 1.25rem;
	box-shadow: 0 6px 15px -5px rgba(0, 0, 0, 0.1);
	height: 3.375rem;
}

.logo_top {
	height: 2.125rem;
}

/*검색창*/
.m_input_box {
	padding: 36px 18px
}

.m_search_box {
	display: flex;
	align-items: center;
	border: 2px solid var(--main_color);
	border-radius: 1.875rem;
	overflow: hidden;
	width: 100%;
	max-width: 31.25rem;
	height: 2.8125rem;
	padding: 0 1.125rem;
	box-sizing: border-box;
}

.m_search {
	flex: 1;
	border: none;
	outline: none;
	font-size: 0.875rem;
	color: #333;
}

.m_search::placeholder {
	color: #aaa;
}

.m_search_btn {
	background: none;
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 8px;
}

.m_search_btn img {
	width: 1.125rem;
	height: 1.125rem;
	display: block;
}

.m_search_box {
	display: flex;
	align-items: center;
	border: 2px solid var(--main_color);
	border-radius: 30px;
	overflow: hidden;
	width: 100%;
	max-width: 31.25rem;
	height: 2.8125em;
	;
	padding: 0 0.75rem;
	box-sizing: border-box;
}

/*로그인 박스*/
.m_login_box {
	max-width: 22.5rem;
	padding: 1rem;
	text-align: left;
}

.m_login_box p {
	font-size: 1.125rem;
	color: #222;
	line-height: 1.5;
	margin-bottom: 1.25rem;
	color: #222;
	font-family: "Noto Sans KR";
	font-style: normal;
	font-weight: 400;
	line-height: normal;
}

.m_btn_wrap {
	display: flex;
	justify-content: center;
	gap: 0.75rem;
	margin-bottom: 1.5rem;
}

.m_btn {
	flex: 1;
	padding: 0.625rem 0;
	border-radius: 1.5rem;
	font-size: 0.9375rem;
	font-weight: 500;
	cursor: pointer;
	transition: all 0.2s ease;
}

.m_btn.m_join {
	border: 0.0625rem solid var(--main_color);
	background: #fff;
	color: var(--main_color);
	display: flex;
	justify-content: center;
	align-items: center;
}

.m_btn.m_join:hover {
	background: #fff3f2;
}

.m_btn.m_login {
	border: none;
	background: var(--main_color);
	color: #fff;
	display: flex;
	justify-content: center;
	align-items: center;
}

.m_btn.m_login:hover {
	background: #d54c3c;
}

.m_menu_wrap {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0.5rem;
}

.m_menu {
	background: #fff;
	border: 0.0625rem solid #ddd;
	border-radius: 0.5rem;
	padding: 0.75rem 0;
	font-size: 0.875rem;
	cursor: pointer;
	transition: all 0.2s;
}

.m_menu:hover {
	background: #fafafa;
	border-color: var(--main_color);
	color: var(--main_color);
}

/*1뎁스*/
.gnb_box .m_btn {
	display: none;
}

.category {
	padding: 1.25rem 0.8125rem;
}

.category h3 {
	color: #222;
	font-family: "Noto Sans KR";
	font-size: 1.125rem;
	font-style: normal;
	font-weight: 700;
	line-height: normal;
	padding-bottom: 1.25rem;
}

.category .gnb_box ul {
	list-style: none;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
}

.category .gnb_box ul li {
	display: flex;
	justify-content: flex-start;
	width: 100%;
	color: #222;
	font-family: "Noto Sans KR";
	font-size: 0.75rem;
	font-style: normal;
	font-weight: 400;
	line-height: normal;
	padding: 0.75rem 1.125rem;
	height: 2.5rem;
	border: 1px solid #e9e9e9;
	border-bottom: none;
}

.category .gnb_box ul li:hover {
	background: var(--main_color);
}

.category .gnb_box ul li:hover a {
	color: #fff !important;
}

/*2뎁스*/
.category .gnb_box ul li .depth02 {
	all: unset
}

/*모바일 하단*/
/* 사이드바 안 전용 네비 */
#m_menu .bottom-nav {
	margin-top: auto;
	padding: 12px 0;
	border-top: 1px solid #eee;
}

#m_menu .bottom-nav ul {
	display: flex;
	justify-content: space-around;
	margin: 0;
	padding: 0;
	list-style: none;
}

#m_menu .bottom-nav li {
	display: flex;
	flex-direction: column;
	align-items: center;
	font-family: "Noto Sans KR";
	font-size: 12px;
	color: #aaa;
}

.bottom-nav li>a {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

#m_menu .bottom-nav li img {
	width: 24px;
	height: 24px;
	margin-bottom: 4px;
}

#m_menu .bottom-nav li.active span {
	color: var(--main_color);
	font-weight: 500;
}


/*------------------------------------
	/             PC Header              /
	/------------------------------------*/

/* 전체 초기화 */
* {
	margin: 0;
	padding: 0;
	list-style: none;
	box-sizing: border-box;
	font-family: Pretendard, sans-serif;
	text-decoration: none;
	word-break: keep-all;
}

.header_section {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 999;
	box-shadow: 0 0.5rem 0.9375rem rgba(0, 0, 0, 0.15);
}

/* 아래로 퍼지는 그림자 */

/*================ Header top ================*/
.header_inner__top {
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	padding: 1.125rem 0;
	background: #fff;
}

.header_top {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0 10rem;
}

.logo_box img {
	display: block;
	max-height: 2.5rem;
}

.header_top__right {
	display: flex;
	align-items: center;
	gap: 1.75rem;
}

.header_top__left {
	display: flex;
	gap: 36px;
	align-items: center;
}

/* 검색창 */
.search_wrap {
	display: flex;
	align-items: center;
	border: 0.15rem solid var(--main_color);
	overflow: hidden;
	height: 2.5rem;
	margin-left: 36px;
}

.search_box {
	border: none;
	outline: none;
	padding: 0 0.875rem;
	font-size: 0.875rem;
	color: #333;
	width: 25rem;
}

.search_box::placeholder {
	color: #aaa;
}

.search_btn {
	background: none;
	border: none;
	cursor: pointer;
	padding: 0 0.75rem;
	display: flex;
	align-items: center;
}

.search_btn img {
	width: 1.125rem;
	height: 1.125rem;
}

/* 메뉴 링크 */
.menu_links {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.menu_links a {
	font-size: 0.875rem;
	color: #666;
	position: relative;
}

.menu_links a:hover {
	color: var(--main_color);
}

.menu_links a:not(:last-child)::after {
	content: "";
	position: absolute;
	right: -0.625rem;
	top: 50%;
	transform: translateY(-50%);
	width: 0.0625rem;
	height: 0.875rem;
	background: #ccc;
}


/*모바일 아코디언 */
.accordion {
	width: 100%;
	border: 1px solid #eee;
}

.accordion-item {
	border-bottom: 1px solid #eee;
}

.accordion-header {
	width: 100%;
	text-align: left;
	padding: 15px 18px;
	font-size: 14px;
	font-weight: 500;
	background: #fff;
	color: #000;
	border: none;
	cursor: pointer;
	position: relative;
	leading-trim: both;
	text-edge: cap;
	font-family: "Noto Sans KR";
	font-style: normal;
	line-height: normal;
}

.accordion-header::after {
	content: "";
	position: absolute;
	right: 16px;
	top: 50%;
	transform: translateY(-50%);
	width: 16px;
	height: 16px;
	background-color: #888888;
	-webkit-mask: url("/img/category_arrow_icon.svg") no-repeat center/contain;
	mask: url("/img/category_arrow_icon.svg") no-repeat center/contain;
	transition: transform 0.3s, background-color 0.3s;
}

.accordion-header.active {
	background: var(--main_color);
	color: #fff;
}

.accordion-header.active::after {
	transform: translateY(-50%) rotate(180deg);
	background-color: #fff;
}

.accordion-content {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease;
	background: #fafafa;
}

.accordion-content ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.accordion-content a {
	text-decoration: none;
	color: #434343;
	font-size: 14px;
}

.accordion-content>.depth1 {
	padding: 18px;
	display: flex;
	flex-direction: column;
	gap: 30px;
}

.accordion-content>.depth1 li {
	display: flex;
	align-items: flex-start;
	gap: 18px;
	margin: 0;
}

.accordion-content>.depth1 li>span,
.accordion-content>.depth1 li>.depth2 {
	padding: 0;
	margin: 0;
}

.accordion-content .divider {
	color: #ccc;
}

.accordion-content .depth2 {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.accordion-content .depth2 li {
	margin: 0;
}

.depth1-title {
	color: #888;
	leading-trim: both;
	text-edge: cap;
	font-family: "Noto Sans KR";
	font-size: 12px;
	font-style: normal;
	font-weight: 400;
	line-height: normal;
}

.depth2>li>a {
	color: #222;
	leading-trim: both;
	text-edge: cap;
	font-family: "Noto Sans KR";
	font-size: 12px;
	font-style: normal;
	font-weight: 400;
	line-height: normal;
	text-decoration-style: solid;
	text-decoration-skip-ink: none;
	text-decoration-thickness: auto;
	text-underline-offset: auto;
	text-underline-position: from-font;
}

.depth2>li>a:hover {
	text-decoration-line: underline;
}

.accordion-content .depth04>li>a {
	color: #000;
}

.accordion-content .depth1 h4 {
	min-width: 60px;
}

.arrow_icon {
	cursor: pointer;
}

.accordion {
	max-height: 735px;
	overflow-y: auto;
	transition: max-height 0.3s ease;
	background-color: #fafafa;
}

.accordion::-webkit-scrollbar {
	display: none;
}

/*================ Header bottom ================*/
.header_inner__bottom {
	width: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	background: rgba(237, 237, 237, 0.80);
	backdrop-filter: blur(0.625rem);
	height: 3.25rem;
}

.header_bottom {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0 10rem;
}

.nav_menu {
	display: flex;
	gap: 2.25rem;
	align-items: center;
}

.nav_menu>li {
	display: flex;
	align-items: center;
	padding: 1.125rem 0;
	font-size: 1rem;
}

.nav_menu>li>a {
	color: #222;
	text-align: center;
	font-family: "Noto Sans KR";
	font-size: 1rem;
	font-weight: 400;
	line-height: 100%;
	letter-spacing: -0.01rem;
}

.icon_box>ul {
	display: flex;
	gap: 2.25rem;
	align-items: center;
}

.gnb {
	display: flex;
	gap: 9px;
	align-items: center;
}

.prod_meun {
	display: flex;
	gap: 42px;
	color: #222;
	text-align: center;
	font-family: "Noto Sans KR";
	font-size: 16px;
	font-style: normal;
	font-weight: 350;
	line-height: 100%;
	/* 16px */
	letter-spacing: -0.16px;
}

.nav_menu .depth1 h4 {
	min-width: 73px;
}

/*================ Navigation Menu ===============*/
.nav_menu {
	position: relative;
}

.nav_menu>li {
	position: relative;
}

.nav_menu>li>a {
	display: block;
	color: #222;
	white-space: nowrap;
}

/* ================= 2Depth ================= */
.depth02 {
	position: absolute;
	top: 100%;
	left: -50%;
	min-width: 6.25rem;
	background: #fff;
	border: 0.0625rem solid #ddd;
	z-index: 100;
	flex-direction: column;
	box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.1);
	opacity: 0;
	transform: translateY(0.625rem);
	visibility: hidden;
	transition: opacity 0.3s ease, transform 0.3s ease;
}

.nav_menu>li:hover>.depth02 {
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
}

.depth02>li {
	position: relative;
	padding: 0.875rem 1.125rem;
}

.depth02>li::after {
	content: "";
	position: absolute;
	bottom: 0;
	left: 10%;
	width: 80%;
	border-bottom: 0.0625rem solid #dedede;
}

.depth02>li:first-child {
	padding-top: 2rem;
}

.depth02>li:last-child {
	border: none;
	padding-bottom: 2rem;
}

.depth02>li>a {
	font-size: 1rem;
	color: #333;
	transition: 0.2s;
	white-space: nowrap;
	display: flex;
	justify-content: space-between;
	width: 10.25rem;
}

.depth02>li:hover>a {
	color: var(--main_color);
}

.depth02 .icon {
	opacity: 0;
	transform: translateX(-0.5rem);
	transition: opacity 0.3s ease, transform 0.3s ease;
	align-items: center;
	display: flex;
	justify-content: center;
}

.depth02>li:hover .icon {
	opacity: 1;
	transform: translateX(0);
}

/* ================= 3Depth ================= */
.depth03 {
	gap: 36px;
	display: flex;
	position: absolute;
	top: 0;
	left: 100%;
	min-width: 8.75rem;
	border: 0.0625rem solid #222;
	z-index: 200;
	flex-direction: column;
	padding: 2rem 0;
	background: rgba(34, 34, 34, 0.4);
	backdrop-filter: blur(10px);
	backdrop-filter: blur(0.625rem);
	opacity: 0;
	transform: translateX(0.625rem);
	visibility: hidden;
	transition: opacity 0.3s ease, transform 0.3s ease;
	justify-content: flex-start;
	align-items: flex-start;
}

.depth02>li:hover>.depth03 {
	opacity: 1;
	transform: translateX(0);
	visibility: visible;
}

.depth03>li {
	display: flex;
	align-items: flex-start;
	position: relative;
	padding: 0 18px;
	gap: 1rem;
}

.depth03>li>a {
	display: flex;
	font-size: 1rem;
	flex-direction: column;
	align-items: flex-start;
}

.depth03>li a {
	color: #fff;
}

.depth03>li h4 {
	color: #DEDEDE;
	text-align: center;
	font-family: "Noto Sans KR";
	font-size: 16px;
	font-style: normal;
	font-weight: 400;
	line-height: 100%;
	/* 16px */
	letter-spacing: -0.16px;
}

.depth03>li:last-child {
	border: none;
}

.depth03>li:first-child {
	padding-top: 0;
}

.depth04 li {
	width: 100%;
}

.depth03 li h4 {
	min-width: 73px;
	text-align: left;
	white-space: nowrap;
}

/* ================= 4Depth ================= */
.depth04 {
	display: flex;
	flex-direction: column;
	justify-content: flex-start;
	align-items: center;
	gap: 22px;
	white-space: nowrap;
}

.depth04>li>a {
	color: #FFF;
	text-align: center;
	font-family: "Noto Sans KR";
	font-size: 16px;
	font-style: normal;
	font-weight: 400;
	line-height: 100%;
	/* 16px */
	letter-spacing: -0.16px;
	text-decoration-style: solid;
	text-decoration-skip-ink: auto;
	text-decoration-thickness: auto;
	text-underline-offset: auto;
	text-underline-position: from-font;
	text-align: left;
}

.depth04>li:hover>a {
	text-decoration: underline;
}

/* 모바일 메뉴 3Depth: 옆으로 안 나오고 밑으로 나오게 */
#mmenu .depth03 {
	position: static;
	display: none;
	background: #f7f7f7;
	padding: 8px 12px;
}

#mmenu .depth03 li {
	padding: 6px 0;
}

#mmenu .depth03 li a {
	color: #333;
	font-size: 14px;
}

.header_block {
	height: 140px;
}

@media (max-width: 1000px) {
	.header_inner__bottom {
		display: none;
	}

	.header_top__right {
		display: none;
	}

	.gnb .nav_menu {
		display: none;
	}

	.header_top__left {
		width: 100%;
		justify-content: space-between;
	}

	.header_top {
		padding: 0 3rem
	}

	.header_block {
		height: 71px;
	}
}

body.no-scroll {
	overflow: hidden;
	/* ✅ 스크롤 잠금 */
	height: 100%;
}



/*------------------------------------

	/               Footer               /

	/------------------------------------*/
.footer_section {
	width: 100%;
	padding: 36px 0;
	background: #262626;
	overflow: hidden;
}

.footer_container {
	max-width: 1400px;
	margin: 0 auto;
	/* padding: 0 20px; */
	display: flex;
	gap: 56px;
}

.footer_logo {
	color: #EF4444;
	font-size: 36px;
	font-family: 'Pretendard', sans-serif;
	font-weight: 700;
	flex-shrink: 0;
}

.footer_content {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.footer_info {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.footer_info_item {
	color: white;
	font-size: 16px;
	font-family: 'Pretendard', sans-serif;
	font-weight: 400;
	margin: 0;
	line-height: 1.5;
}

.footer_disclaimer {
	color: rgba(161, 161, 170, 0.7);
	font-size: 14px;
	font-family: 'Pretendard', sans-serif;
	font-weight: 400;
	line-height: 20px;
	margin: 8px 0 0;
}

.footer_bottom {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.footer_links {
	display: flex;
	align-items: center;
	gap: 8px;
}

.footer_link {
	color: white !important;
	font-size: 16px;
	font-family: 'Pretendard', sans-serif;
	font-weight: 400;
	text-decoration: none;
	transition: color 0.3s;
}

.footer_link:hover {
	color: #EF4444;
}

.footer_divider {
	width: 1px;
	height: 14px;
	background: rgba(255, 255, 255, 0.2);
}

.footer_copyright {
	color: #737373;
	font-size: 16px;
	font-family: 'Pretendard', sans-serif;
	font-weight: 400;
	margin: 0;
}

@media (max-width: 1400px) {
	.footer_container {
		width: 93.75%;
	}
}

@media (max-width: 1200px) {
	.footer_container {
		gap: 40px;
	}

	.footer_logo {
		font-size: 32px;
	}

	.footer_info_item {
		font-size: 15px;
	}

	.footer_link {
		font-size: 15px;
	}

	.footer_copyright {
		font-size: 15px;
	}
}

@media (max-width: 968px) {
	.footer_section {
		padding: 30px 0;
	}

	.footer_container {
		flex-direction: column;
		gap: 30px;
	}

	.footer_logo {
		font-size: 28px;
	}

	.footer_content {
		gap: 30px;
	}

	.footer_bottom {
		flex-direction: column;
		align-items: flex-start;
		gap: 16px;
	}
}

@media (max-width: 768px) {
	.footer_section {
		padding: 25px 0;
	}

	.footer_container {
		/* padding: 0 15px; */
		gap: 25px;
	}

	.footer_logo {
		font-size: 24px;
	}

	.footer_info_item {
		font-size: 14px;
	}

	.footer_disclaimer {
		font-size: 13px;
		line-height: 18px;
	}

	.footer_links {
		flex-wrap: wrap;
		gap: 6px;
	}

	.footer_link {
		font-size: 14px;
	}

	.footer_copyright {
		font-size: 14px;
	}
}

@media (max-width: 480px) {
	.footer_section {
		padding: 20px 0;
	}

	.footer_logo {
		font-size: 20px;
	}

	.footer_info {
		gap: 6px;
	}

	.footer_info_item {
		font-size: 13px;
	}

	.footer_disclaimer {
		font-size: 12px;
		line-height: 16px;
	}

	.footer_links {
		width: 100%;
	}

	.footer_link {
		font-size: 13px;
	}

	.footer_copyright {
		font-size: 13px;
	}
}



/* 20251223 추가 */
.floating-banner {
	position: fixed;
	bottom: 30px;
	left: 30px;
	z-index: 9999;
}

.floating-banner a {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 12px 20px;
	background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
	border-radius: 50px;
	text-decoration: none;
	color: #fff;
	font-size: 14px;
	font-weight: 600;
	box-shadow: 0 4px 15px rgba(102, 126, 234, 0.4);
	transition: transform 0.2s, box-shadow 0.2s;
}

.floating-banner a:hover {
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(102, 126, 234, 0.5);
}

.icon {
	width: 32px;
	height: 32px;
	background: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 18px;
	animation: rotate 3s linear infinite;
}

.close-btn {
	position: absolute;
	top: -8px;
	right: -8px;
	width: 24px;
	height: 24px;
	background: #fff;
	border: 2px solid #667eea;
	border-radius: 50%;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	color: #667eea;
	font-weight: bold;
	transition: all 0.2s;
}

.close-btn:hover {
	background: #667eea;
	color: #fff;
	transform: rotate(90deg);
}


.floating-banner.hidden {
	display: none;
}