@charset "utf-8";

/* 전역 word-break 설정 */
body {
    word-break: keep-all;
}

/* 기본프로그램 사용자모듈 메뉴 - PC */
.all_m_btn {padding:10px; background:#323337;}
.pro_m_wrap .m_menu {width:200px;}

@media all and (max-width:999px){
	.pro_m_wrap.view {left:0;}
}

/* basic */
.inner{width:100%; max-width:1560px; margin:0 auto; position:relative;}

@media all and (max-width:1560px){
	.inner{width:96%;}
}

/* 햄버거 메뉴 */
#header {display:none;} /* header.jsp의 헤더는 PC에서 숨김 - leftmenu.jsp의 navbar 사용 */
#header .m_header_text {display:none;} /* PC에서 숨김 */
#header .m_logo_img {display:none;} /* PC에서 숨김 */
#header .m_btn {display:none; width:24px; margin:0 auto; text-align:right; cursor:pointer; margin: 0;}
#header .m_btn i{display:inline-block; width:100%; height:2px; margin:3px 0; background:#fff; transition:all 0.5s;}
#header .m_btn i:nth-of-type(2){width:84%;}
#header .m_btn.on i:nth-of-type(1){margin:11px 0 -2px; transform:rotate(-45deg); -webkit-transform:rotate(-45deg); -moz-transform:rotate(-45deg); -ms-transform:rotate(-45deg);-o-transform:rotate(-45deg);}
#header .m_btn.on i:nth-of-type(2){width:0; margin:0;}
#header .m_btn.on i:nth-of-type(3){margin:0 0 11px; transform:rotate(45deg); -webkit-transform:rotate(45deg); -moz-transform:rotate(45deg); -ms-transform:rotate(45deg); -o-transform:rotate(45deg);}


@media all and (max-width:1440px){
	#header .inner{padding: 0 60px !important;}
}

@media all and (max-width:1024px){
	/* 모바일에서 헤더 표시 */
	#header {
		display: block !important;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		background: #000;
		z-index: 100;
		padding: 0;
        height: 50px !important;
	}
	#header .inner {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 12px 16px !important;
		max-width: 100%;
	}
	
	/* 왼쪽 텍스트 */
	#header .m_header_text {
		display: block;
		color: #fff;
		font-size: 11px;
		font-family: 'Pretendard', sans-serif;
		font-weight: 500;
		line-height: 1.3;
		white-space: nowrap;
	}
	
	/* 가운데 로고 */
	#header .logo_box {
		position: absolute;
		left: 50%;
		transform: translateX(-50%);
	}
	#header .logo_box .logo_img {
		display: none !important;
	}
	#header .logo_box .m_logo_img {
		display: block !important;
		height: 28px;
		width: auto;
	}
	
	/* 오른쪽 햄버거 */
	#header .m_btn {
		display: flex !important;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		width: 24px;
		height: 24px;
		cursor: pointer;
	}
	#header .m_btn i {
		background: #fff;
	}
	
	/* GNB 숨김 */
	#header .gnb_box {display: none !important;}
	
	/* leftmenu.jsp의 햄버거 버튼 - 모바일에서 숨김 (header.jsp 사용) */
	#toggle_nav_btn {
		display: none !important;
	}
}

.logo_box{cursor: pointer;}

/* 모바일 메뉴 */
.m_menu_bg {z-index:101; position:fixed; left:0; top:0; display:none; width:100%; height:100%; background:rgba(0,0,0,.5); cursor:pointer; }
#m_menu {z-index:102; position:fixed; left:-100%; top:0; width:100%; max-width:280px !important; height:100%; background-color:#fff; box-sizing:border-box; transition:all 0.3s; overflow-y:auto;}
#m_menu.on {left:0; }

/* 모바일 메뉴 헤더 */
#m_menu .m_menu_header {
	display:flex;
	justify-content:space-between;
	align-items:center;
	padding:20px 16px;
	border-bottom:1px solid #e5e7eb;
	background:#f9fafb;
}
#m_menu .m_logo {
	text-decoration:none;
}
#m_menu .m_logo .logo_text {
	font-family: 'Orbitron', sans-serif;
	font-size: 16px;
	font-weight: 900;
	color: #222;
	letter-spacing: -0.8px;
}
#m_menu .m_logo .logo_text em {
	color: #2563eb;
	font-style: normal;
}
#m_menu .close_btn {
	width:32px;
	height:32px;
	display:flex;
	justify-content:center;
	align-items:center;
	background:#fff;
	border-radius:8px;
	border:1px solid #e5e7eb;
}
#m_menu .close_btn i {
	display:block;
	width:16px;
	height:2px;
	background-color:#666;
	position:absolute;
}
#m_menu .close_btn i:first-of-type {
	transform:rotate(45deg);
}
#m_menu .close_btn i:last-of-type {
	transform:rotate(-45deg);
}
#m_menu .gnb_box {border-top:none;}
#m_menu .gnb_box > ul {list-style:none; margin:0; padding:0;}
#m_menu .gnb_box > ul > li {border-bottom:1px solid #e0e0e0;}
#m_menu .gnb_box > ul > li > a {display:flex !important; align-items:center; justify-content:space-between; padding:8px 10px !important; font-size:16px !important; font-weight:600; color:#222; text-decoration:none;}
#m_menu .gnb_box > ul > li > a .pull-left {display:flex; align-items:center;}
#m_menu .gnb_box > ul > li > a .pull-left i {font-size:18px; margin-right:8px; color:inherit; width:20px; text-align:center;}
#m_menu .gnb_box > ul > li > a .pull-left .right-nav-text {font-size:16px !important;}
#m_menu .gnb_box > ul > li > a .pull-right {display:flex; align-items:center; margin-left:auto;} /* 화살표 오른쪽 정렬 */
#m_menu .gnb_box > ul > li > a .pull-right i {font-size:14px; color:#999; transition:transform 0.3s;}
#m_menu .gnb_box > ul > li.on > a .pull-right i {transform:rotate(180deg);}
#m_menu .gnb_box > ul > li > a .clearfix {display:none;}
#m_menu .gnb_box > ul > li > ul,
#m_menu .gnb_box > ul > li > .depth02 {display:none; background:transparent; padding:3px 0; border-top:1px solid rgba(0,0,0,0.1); position:static; border:none; box-shadow:none; transform:none; border-radius:0;} /* 모바일용 스타일 오버라이드 */
#m_menu .gnb_box > ul > li > ul > li > a,
#m_menu .gnb_box > ul > li > .depth02 > li > a {display:block; padding:10px 10px 10px 30px !important; font-size:14px !important; color:#444 !important; text-decoration:none; font-weight:400 !important;}
#m_menu .gnb_box > ul > li > ul > li > a span,
#m_menu .gnb_box > ul > li > .depth02 > li > a span {font-size:14px !important;}
/* leftmenu.jsp의 .user_depth_custom 스타일 오버라이드 */
#m_menu .gnb_box .user_depth_custom > li > a {padding:8px 10px !important; font-size:16px !important;}
#m_menu .gnb_box .user_depth_custom > li > ul > li > a {padding:6px 10px 6px 38px !important; font-size:15px !important;}
#m_menu .gnb_box > ul > li > ul > li > a:hover,
#m_menu .gnb_box > ul > li > ul > li > a:active {color:#307dd4; background:#f5f5f5;} /* 호버 효과 */
/* 선택된 메뉴 배경색 */
#m_menu .gnb_box > ul > li > ul > li > a.current-menu,
#m_menu .gnb_box .user_depth_custom > li > ul > li > a.current-menu {background-color:rgba(48, 125, 212, 0.15) !important; color:#307dd4 !important;}
#m_menu .gnb_box > ul > li.on > ul,
#m_menu .gnb_box > ul > li.on > .depth02 {display:block !important;}
#m_menu .gnb_box > ul > li.navigation-header {display:none;}
/* 전체 펼침/닫힘 버튼 스타일 */
#m_menu .gnb_box > ul > li > .tree-controls {display:flex; justify-content:center; padding:6px; gap:0; background:#323337; border-bottom:1px solid rgba(255,255,255,0.1);}
#m_menu .gnb_box > ul > li > .tree-controls a {font-size:12px; padding:4px 10px; text-decoration:none;}
#m_menu .gnb_box > ul > li > .tree-controls a.btn-expand-all {color:#5bc0de;}
#m_menu .gnb_box > ul > li > .tree-controls a.btn-collapse-all {color:#d9534f;}
#m_menu .gnb_box > ul > li > .tree-controls a i {margin-right:4px;}
#m_menu .gnb_box > ul > li > .tree-controls .divider {display:inline-block; width:1px; height:14px; background:rgba(255,255,255,0.3); margin:0 4px;}

/* ========== 퀵메뉴 & TOP 버튼 ========== */
.quick_step_btn_box01 {
	display: flex;
}
.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%);
}

/* PC 퀵메뉴 */
#sideQuick {
	position: fixed;
	right: 30px;
	bottom: 30px;
	z-index: 9999;
	width: 60px;
}
#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, #307dd4);
}
#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;
}

/* 최근 본 상품 / 관심 상품 */
.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, #307dd4);
	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;
	text-align: center;
}
.prod_no_box > p {
	font-size: 11px;
	font-weight: 400;
	color: #999;
	margin-top: 5px;
}
.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;
}
.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.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; }

/* 모바일에서 퀵메뉴 위치 조정 */
@media all and (max-width:768px) {
	#sideQuick {
		right: 10px;
		bottom: 10px;
	}
	
	#sideQuickMoreBtn .quick {
		right: auto;
		left: auto;
		transform: translateX(-30px);
	}
}
/* ========== END 퀵메뉴 & TOP 버튼 ========== */


#header{background-color: #000; width: 100%; height: 70px; position: fixed; top: 0; left: 0; z-index: 100; display: flex; justify-content: space-between; align-items: center;}
#header .inner{max-width:1560px; margin:0 auto; display: flex; justify-content: space-between; align-items: center; width: 100%; box-sizing: border-box;}

/* 헤더 로고 */
#header .logo_box {
	text-decoration: none;
	display: flex;
	align-items: center;
}
#header .logo_img {
	width: 40px;
	height: 40px;
	object-fit: contain;
}

#header .gnb_box>ul{display: flex; align-items: center; gap: 36px;}


#header .gnb_box>ul>li{
	position: relative;
	height: 70px;
    align-items: center;
    display: flex;
}

#header .gnb_box>ul>li>a{
	color: #d1d5db;
	text-align: center;
	font-family: Pretendard;
	font-size: 14px;
	font-style: normal;
	font-weight: 500;
	line-height: normal;
	text-transform: uppercase;
	transition: color 0.2s ease;
    white-space: nowrap;
}

#header .gnb_box>ul>li.first>a {
	font-weight: 700;
}

#header .gnb_box>ul>li>a:hover,
#header .gnb_box>ul>li.active>a {
	color: #fff;
	font-weight: 700;
}

#header .gnb_box>ul>li a{
	color: #d1d5db;
	text-align: center;
	font-family: Pretendard;
	font-size: 14px;
	font-style: normal;
	font-weight: 500;
	line-height: normal;
	text-transform: uppercase;
    white-space: nowrap;
	transition: color 0.2s ease;
}

#header .gnb_box>ul>li:hover .depth02{display: flex;}

/* 2depth 메뉴 - 다크 테마 */
.depth02{
	display: none;
	width: auto;
    min-width: 100%;
	padding: 18px;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
	gap: 14px;
	border-radius: 9px;
	border: 1px solid rgba(255, 255, 255, 0.1);
	background: rgba(0, 0, 0, 0.9);
	backdrop-filter: blur(15px);
	-webkit-backdrop-filter: blur(15px);
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	z-index: 100;
}

.depth02 li a {
	color: #aaa !important;
	font-weight: 500 !important;
}
.depth02 li a:hover {
	color: #ef4444 !important;
}

.depth02 li:hover a {
	text-decoration: none !important;
	color: #2563eb !important;
}

/* ========== Footer ========== */
#footer {
    width: 100%;
    padding: 144px 0 72px;
    background: #000;
    overflow: hidden;
    box-sizing: border-box;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}
#footer .inner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 36px;
}

/* 상단 외부 링크 바 */
#footer .footer-external-bar {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: 19px 36px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 100px;
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
}
#footer .footer-external-bar a {
    color: #fff;
    font-size: 16px;
    font-family: 'Pretendard', sans-serif;
    font-weight: 500;
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: 1.225px;
    padding: 0 36px;
    text-align: center;
    transition: color 0.3s ease;
    white-space: nowrap;
}
#footer .footer-external-bar a:not(:last-child) {
    border-right: 1px solid rgba(255, 255, 255, 0.2);
}
#footer .footer-external-bar a:hover {
    color: #ef4444;
}

/* 콘텐츠 영역 */
#footer .footer-content {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

/* 좌측: 로고 & 설명 */
#footer .footer-info {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 18px;
}
#footer .footer-logo {
    width: 40px;
    height: 40px;
}
#footer .footer-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
#footer .footer-desc {
    color: #AAAAAA;
    font-size: 16px;
    font-family: 'Pretendard', sans-serif;
    font-weight: 400;
    line-height: 1.6;
    margin: 0;
}

/* 우측: 링크 & 연락처 */
#footer .footer-links {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 140px;
}
#footer .footer-col {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 18px;
}
#footer .footer-col-title {
    color: #fff;
    font-size: 18px;
    font-family: 'Pretendard', sans-serif;
    font-weight: 400;
    margin: 0;
}

/* Quick Links */
#footer .footer-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 18px;
}
#footer .footer-menu li a {
    color: #AAAAAA;
    font-size: 16px;
    font-family: 'Pretendard', sans-serif;
    font-weight: 400;
    line-height: 1.4;
    text-decoration: none;
    transition: color 0.3s ease;
}
#footer .footer-menu li a:hover {
    color: #ef4444;
}

/* Contact Us */
#footer .footer-contact {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 18px;
}
#footer .footer-contact li {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 9px;
}
#footer .contact-icon {
    width: 25px;
    height: 25px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
}
#footer .contact-icon img {
    width: 18px;
    height: 18px;
}
#footer .contact-text {
    color: #AAAAAA;
    font-size: 16px;
    font-family: 'Pretendard', sans-serif;
    font-weight: 400;
    line-height: 1.4;
}
#footer .contact-text a {
    color: #AAAAAA;
    text-decoration: none;
    transition: color 0.3s ease;
}
#footer .contact-text a:hover {
    color: #ef4444;
}

/* 구분선 */
#footer .footer-divider {
    width: 100%;
    height: 1px;
    background: rgba(255, 255, 255, 0.10);
}

/* 하단 영역 */
#footer .footer-bottom {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
#footer .copyright {
    color: rgba(170, 170, 170, 0.40);
    font-size: 16px;
    font-family: 'Pretendard', sans-serif;
    font-weight: 400;
    line-height: 1.4;
    margin: 0;
}
#footer .footer-policy {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 36px;
}
#footer .footer-policy a {
    color: rgba(170, 170, 170, 0.40);
    font-size: 16px;
    font-family: 'Pretendard', sans-serif;
    font-weight: 400;
    line-height: 1.4;
    text-decoration: none;
    transition: color 0.3s ease;
}
#footer .footer-policy a:hover {
    color: #AAAAAA;
}

/* ========== Footer 반응형 - 태블릿 ========== */
@media all and (max-width: 1400px) {
    #footer {
        padding: 100px 0 50px;
    }
    #footer .footer-links {
        gap: 60px;
    }
    #footer .footer-external-bar {
        padding: 15px 24px;
    }
    #footer .footer-external-bar a {
        font-size: 13px;
        padding: 0 24px;
    }
}

/* ========== Footer 반응형 - 모바일 ========== */
@media all and (max-width: 768px) {
    #footer {
        padding: 40px 0 30px;
    }
    #footer .inner {
        gap: 24px;
    }
    #footer .footer-external-bar {
        width: 93.75%;
        padding: 16px;
        gap: 12px;
        border-radius: 16px;
    }
    #footer .footer-external-bar a {
        padding: 8px 0;
        width: 100%;
        border-right: none !important;
        flex: 1 1 calc(100% / 3);
        white-space: normal;
        border-bottom: none !important;
    }
    #footer .footer-external-bar a:not(:last-child) {
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
    }
    #footer .footer-content {
        flex-direction: column;
        gap: 24px;
    }
    #footer .footer-links {
        width: 100%;
        flex-direction: column;
        gap: 20px;
    }
    #footer .footer-logo {
        width: 32px;
        height: 32px;
    }
    #footer .footer-desc {
        font-size: 13px;
        line-height: 1.5;
    }
    #footer .footer-desc br {
        display: none;
    }
    #footer .footer-col-title {
        font-size: 14px;
        margin-bottom: 10px;
    }
    #footer .footer-menu {
        gap: 12px;
    }
    #footer .footer-menu li a,
    #footer .contact-text {
        font-size: 13px;
    }
    #footer .footer-contact {
        gap: 12px;
    }
    #footer .contact-icon {
        width: 16px;
        height: 16px;
    }
    #footer .footer-divider {
        margin: 16px 0;
    }
    #footer .footer-bottom {
        flex-direction: column;
        gap: 12px;
        align-items: flex-start;
    }
    #footer .copyright {
        font-size: 11px;
    }
    #footer .footer-policy {
        gap: 16px;
    }
    #footer .footer-policy a {
        font-size: 11px;
    }
    #footer .social-icon {
        width: 28px;
        height: 28px;
    }
}

/* ========== 카톡 상담 퀵메뉴 ========== */
.quick-kakao {
    position: fixed;
    /* inner 영역 기준 정렬: (100vw - 1560px) / 2 = inner 바깥 여백 */
    right: calc((100vw - 1560px) / 2);
    bottom: 100px;
    z-index: 9999;
    width: 80px;
    height: 80px;
    background: #2563eb;
    border-radius: 60px;
    outline: 1px rgba(37, 99, 235, 0.15) solid;
    outline-offset: -1px;
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    transition: all 0.3s ease;
    cursor: pointer;
}
.quick-kakao:hover {
    background: #2563eb;
    transform: scale(1.05);
    box-shadow: 0 0 30px rgba(37, 99, 235, 0.30);
}
.quick-kakao .kakao-icon {
    display: flex;
    justify-content: center;
    align-items: center;
}
.quick-kakao .kakao-icon img {
    width: 30px;
    height: 28px;
}
.quick-kakao .kakao-text {
    color: #fff;
    font-size: 12px;
    font-family: 'Pretendard', sans-serif;
    font-weight: 700;
    text-align: center;
}

/* 1560px 이하: inner가 96% 너비 (2% 마진) */
@media all and (max-width: 1560px) {
    .quick-kakao {
        right: calc(2% + 20px);
    }
}

/* 모바일에서 퀵메뉴 크기 조정 */
@media all and (max-width: 768px) {
    .quick-kakao {
        right: calc(2% + 10px);
        bottom: 20px;
        width: 65px;
        height: 65px;
    }
    .quick-kakao .kakao-icon img {
        width: 24px;
        height: 22px;
    }
    .quick-kakao .kakao-text {
        font-size: 10px;
    }
}


    .br_custom{display: none;}
    @media(max-width:768px){
        .br_custom{display: block;}
    }

/* ========================================
   카톡 퀵메뉴 버튼 (전체 페이지 공통)
   ======================================== */

.quick-kakao-btn {
    position: fixed;
    right: 40px;
    bottom: 40px;
    z-index: 9999;
    width: 70px;
    height: 70px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s ease;
}

.quick-kakao-btn:hover {
    transform: scale(1.1);
}

.quick-kakao-btn img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    border-radius: 50%;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
}

/* index.jsp에서는 con01 안의 kakao-btn 사용하므로 중복 방지 */
body:has(.con01 .kakao-btn) .quick-kakao-btn {
    display: none;
}

@media all and (max-width: 768px) {
    .quick-kakao-btn {
        right: 16px;
        bottom: 16px;
        width: 56px;
        height: 56px;
    }
}