@charset "utf-8";
@import url('https://webfontworld.github.io/SCoreDream/SCoreDream.css');

/* ===================================================== */
/* 기본 스타일 ========================================== */
:root {
	--color-main: #ee3135;
	--color-main-a5: #ee313580;
	--color-main-a35: #ee313559;
	--color-main-dark: #e31d1a;
	--color-violet: #925da3;
	--color-blue: #65aadd;
	--color-green: #90c31f;
	--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);
	--grad-violet-red: linear-gradient(220deg, var(--color-main) 25%, var(--color-violet) 140%);
	--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), 50px);
	--content-padding: 20px;
	--inner-left-padding: max(var(--inner-padding), calc(var(--outer-padding) + var(--content-padding)));
	font-size: 10px;
}
html::-webkit-scrollbar {width: 8px; background-color: #eee;}
html::-webkit-scrollbar-thumb {background-color: #444;}
body {--header-height: 65px; font: 16px/1.2 'SCoreDream', Roboto, "Noto Sans KR", 'Malgun Gothic','돋움', dotum, sans-serif; color: #444;}
.is-open {overflow: hidden !important; padding-right: var(--scroll-width) !important;}
.inner {
	position: relative;
	margin-right: var(--inner-padding);
	margin-left: var(--inner-left-padding);
}

/* 왼쪽 빨간색 선 장식 */
.left-line {position: relative;}
.left-line::before { z-index: 105; position: absolute; top: 0; left: var(--outer-padding); width: 1px; height: 100%; background-color: var(--color-main-a35); content: '';}
.body-sub .footer.left-line::before {display: none;}

/* 글머리 기호 */
[class|="mark"] { display: flex; }
[class|="mark"] + [class|="mark"] { margin-top: 0.4em; }
[class|="mark"]::before { flex-shrink: 0; margin-right: 0.5em; content: "";}

@media (max-width: 1280px) {
	:root {font-size: 9px;}
	body, .is-fix {--header-height: 61px; }
}
@media (max-width: 768px) {
	:root {font-size: 8px;}
	body, .is-fix {--header-height: 57px; }
}
@media (max-width: 480px) {
	:root {font-size: 7px;}
	body, .is-fix {--header-height: 53px; }
}
@media (max-width: 360px) {
	:root {--inner-padding: 15px;	--content-padding: 15px;}
}
/* 기본 스타일 ========================================== */
/* ===================================================== */


/* ===================================================== */
/* HEADER ============================================== */
.header { z-index: 1000;position: absolute; inset: 0 0 auto;}
.header-inner { z-index: 1100; display: flex; justify-content: space-between; align-items: center; column-gap: 3%; position: fixed; inset: 0 0 auto; height: var(--header-height); padding: 0 var(--outer-padding); transition: .3s, padding 0s;}
.header-inner::before { position: absolute; inset: 0; border-bottom: 1px solid transparent; background-color: #fff; box-shadow: 0 0.3rem 0.3rem var(--color-black-a05); content: ''; transition: .3s; pointer-events: none;}
.is-open .header-inner { padding-right: calc(var(--outer-padding) + var(--scroll-width)); }
.is-open .header-inner::before { border-color: var(--color-main-a35);box-shadow: 0 0 0 transparent;}
.header-logo { position: relative; width: calc(35px + 7rem);}

/* GNB */
.gnb { flex-grow: 1; max-width: 46em; font-weight: 700; font-size: 18px;}
.gnb-wrap { display: flex; }
.depth1 { flex-grow: 1; position: relative;}
.depth1:nth-child(2) {width: 16%}
.depth1 > a { z-index: 50; overflow: hidden; position: relative; background-color: #fff; background-color: var(--color-main); text-align: center; }
.depth1 > a::before { position: absolute; inset: 0; background-color: var(--color-main);content: ''; transform: translateY(100%); transition: .4s;}
.depth1 > a span { display: flex; justify-content: center; align-items: center; position: relative; height: var(--header-height); background: linear-gradient(var(--color-white-a2), var(--color-white-a2)) no-repeat center bottom/0 1px; letter-spacing: 0.025em; color: #fff; white-space: nowrap; transition: .3s;}
.depth2 { opacity: 0; position: absolute; inset: 0 0 auto; padding: 1em 0 1.1em; background-color: var(--color-main); transform: translateY(calc(-100% - 1px)); transition: .5s, opacity 0s 0.5s; pointer-events: none;}
.depth2 ul { visibility: hidden; opacity: 0; transition: .2s;}
.depth2 a {padding: 0.7em 15%; font-weight: 600; font-size: 15px; letter-spacing: -0.025em; color: #fff;white-space: nowrap;}
.is-open .gnb { visibility: hidden; opacity: 0;}

.depth1:hover > a::before {transform: translateY(0);}
.depth1:hover > a span { background-size: 100% 1px; transition: .3s, background-size .3s .2s; }
.depth1:hover .depth2 { opacity: 1; transform: translateY(var(--header-height)); transition: .5s, opacity 0s; pointer-events: all; }
.depth1:hover .depth2 ul {visibility: visible; opacity: 1; transition: .3s .3s;}

/* 유틸 */
.header-util { display: flex; align-items: center; column-gap: 3rem; }

/* 로그인 */
.util-log a::before { display: block; width: 23px; height: 23px; background: #444 linear-gradient(var(--color-main), var(--color-main)) no-repeat center calc(100% + 5px)/100% 0; mask:  no-repeat center/contain; -webkit-mask: no-repeat center/contain; content: ''; transition: .3s; }
.util-log .login::before {mask-image: url(../images/common/ico_login.svg); -webkit-mask-image: url(../images/common/ico_login.svg);}
.util-log .logout::before {mask-image: url(../images/common/ico_logout.svg); -webkit-mask-image: url(../images/common/ico_logout.svg);}

/* SNS 버튼 */
.util-sns {position: relative;}
.util-sns-btn {display: none; width: 23px; height: 23px;}
.util-sns-btn::before { display: block; height: 100%; background: url(../images/common/sns_ico_open.svg) no-repeat center; content: ''; transition: .3s;}
.util-sns-list {display: flex; align-items: center; column-gap: 2.5rem;}
.util-sns-list a::before { display: block; width: 23px; height: 23px; background: #444 linear-gradient(var(--color-main), var(--color-main)) no-repeat center calc(100% + 5px)/100% 0; mask: no-repeat center/contain; -webkit-mask: no-repeat center/contain; content: ''; transition: .3s;}
.util-sns-list li:has(a[title="facebook"]) {margin: 0 -0.7rem;}
.util-sns-list a[title="kakao"]::before {mask-image: url(../images/common/sns_ico_kakao.png); -webkit-mask-image: url(../images/common/sns_ico_kakao.png);}
.util-sns-list a[title="facebook"]::before {mask-image: url(../images/common/sns_ico_fb.svg); -webkit-mask-image: url(../images/common/sns_ico_fb.svg);}
.util-sns-list a[title="instagram"]::before {mask-image: url(../images/common/sns_ico_insta.svg); -webkit-mask-image: url(../images/common/sns_ico_insta.svg);}
.util-sns-list a[title="youtube"]::before {mask-image: url(../images/common/sns_ico_ytb.svg); -webkit-mask-image: url(../images/common/sns_ico_ytb.svg);}
.util-sns-list a[title="linkedin"]::before {mask-image: url(../images/common/sns_ico_linkedin.svg); -webkit-mask-image: url(../images/common/sns_ico_linkedin.svg);}
.util-sns-list a[title="blog"]::before {mask-image: url(../images/common/sns_ico_blog.svg); -webkit-mask-image: url(../images/common/sns_ico_blog.svg);}

/* WhatsApp 팝업 버튼 */
.sns-whatsapp-item {position: relative;}
.sns-whatsapp-btn {display: block; width: 23px; height: 23px; padding: 0; border: none; cursor: pointer; background: #444 linear-gradient(var(--color-main), var(--color-main)) no-repeat center calc(100% + 5px)/100% 0; mask-image: url(../images/common/sns_ico_whatsapp.png); -webkit-mask-image: url(../images/common/sns_ico_whatsapp.png); mask-size: contain; mask-repeat: no-repeat; mask-position: center; -webkit-mask-size: contain; -webkit-mask-repeat: no-repeat; -webkit-mask-position: center; transition: .3s;}
.sns-whatsapp-btn:hover, .sns-whatsapp-btn.active {background-size: 100% calc(100% + 10px);}
.sns-whatsapp-popup {display: none; position: absolute; top: calc(100% + 10px); left: 50%; transform: translateX(-50%); background: #fff; border-radius: 8px; box-shadow: 0 0 20px rgba(0,0,0,.15); padding: 6px 0; white-space: nowrap; z-index: 200;}
.sns-whatsapp-popup.show {display: block;}
.sns-whatsapp-popup a {display: flex; align-items: center; gap: 10px; padding: 9px 16px; color: #333; font-size: 13px; text-decoration: none; transition: .2s;}
.sns-whatsapp-popup a:hover {background: #f5f5f5; color: var(--color-main);}
.sns-whatsapp-popup a::before {display: inline-block; width: auto; height: auto; background: #444; mask: none; -webkit-mask: none; content: attr(data-region); padding: 2px 7px; color: #fff; font-size: 11px; font-weight: 700; border-radius: 3px; flex-shrink: 0; transition: background .2s;}
.sns-whatsapp-popup a:hover::before {background: var(--color-main); background-size: auto;}
.footer .sns-whatsapp-btn {background-color: #aaa;}
.footer .sns-whatsapp-popup {top: auto; bottom: calc(100% + 10px);}

/* 전체메뉴 버튼 */
.util-allmenu-btn { position: relative; width: 23px; height: 23px; }
.util-allmenu-btn span { position: absolute; top: 10px; right: 0; width: 23px; height: 3px; background-color: #444; transition: .3s; }
.util-allmenu-btn span: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-open .util-allmenu-btn span:nth-child(2) { opacity: 0; }
.is-open .util-allmenu-btn span { width: 31px; transform: rotate(45deg) translate(3px, -3px); }
.is-open .util-allmenu-btn span:nth-child(3) { transform: rotate(-45deg) translate(3px, 3px); }

/* 전체메뉴 */
.allmenu { visibility: hidden; opacity: 0; position: fixed; width: calc(100% + var(--scroll-width)); height: 100%; background: url(../images/common/allmenu_bg03.jpg) no-repeat left bottom/cover; transition: .5s, width 0s; }
.allmenu-cont { visibility: hidden; overflow: hidden auto; opacity: 0; height: 100%; height: calc(100% - var(--header-height)); margin-top: var(--header-height); transition: .3s;}
.allmenu-cont::-webkit-scrollbar { width: 5px; background-color: #fff; }
.allmenu-cont::-webkit-scrollbar-thumb { background-color: var(--color-main); }
.allmenu-list { padding-bottom: calc(2rem + 4vh); }
.is-open .allmenu { visibility: visible; opacity: 1; width: 100%; transform: translateX(0);}
.is-open .allmenu-cont { visibility: visible; opacity: 1; transition: .6s ease-out .2s; }

.all-depth1 { position: relative; padding: 1.35em 4vw 1.35em calc(var(--outer-padding) + 4vw); border-bottom: 1px solid var(--color-main-a35); font-size: 30px;}
.all-depth1-btn { margin-bottom: 0.5em; font-weight: 700; text-align: left; white-space: nowrap; transition: color .3s , background-size .3s; cursor: default;}
.all-depth1-btn::before { position: absolute; inset: auto 0 -1px var(--outer-padding); width: 0; height: 4px; background-color: var(--color-main);content: ''; transition: .6s;}
.all-depth2 {font-size: 16px;}
.all-depth2 ul {display: flex; flex-wrap: wrap; column-gap: 2em;}
.all-depth2-btn { padding: 0.5em 0; font-weight: 600; color: #666; white-space: nowrap; transition: .3s;}

/* dim */
.gnb-dim { z-index: 1000; opacity: 0; position: fixed; width: 100%; height: 100%; background-color: var(--color-black-a6); transition: opacity .3s; pointer-events: none; }
:is(.is-dim):not(.is-open) .gnb-dim { opacity: 1; }

@media (max-width: 1440px) {
	.gnb {font-size: 17px;}
}
@media (max-width: 1280px) {
	.gnb {font-size: 16px;}
	.depth2 a {font-size: 14px;}
}
@media (max-width: 1024px) {
	.gnb { display: none; }
	.header .util-allmenu-btn {display: block;}
	.all-depth2 {font-size: 15px;}
}
@media (max-width: 768px) {
	.allmenu {--depth-padding: 4vw;}
	.allmenu-cont::-webkit-scrollbar {width: 0;}
	.all-depth1 { padding: 0; }
	.all-depth1:has(.all-depth1-btn.on)::before { inset: 100% 0 auto var(--outer-padding);width: 100%;}
	.all-depth1-btn { display: flex; justify-content: space-between; align-items: center; position: relative; width: 100%; padding: calc(0.7em + 2vh) var(--depth-padding) calc(0.7em + 2vh) calc(var(--depth-padding) + var(--content-padding)); margin: 0; color: #444; cursor: pointer;}
	.all-depth1-btn span {position: relative;}
	.all-depth1-btn::after { flex-shrink: 0; width: 19px; height: 12px; background-color: #444; mask-image: url(../images/common/chevron_v19.svg); -webkit-mask-image: url(../images/common/chevron_v19.svg); content: ''; transform: rotate(180deg); transition: .3s;}
	.all-depth1-btn.on { color: #222;}
	.all-depth1-btn.on::before { width: 100%;}
	.all-depth1-btn.on::after { background-color: var(--color-main); transform: rotate(0deg); }
	.all-depth2 { display: none; padding: calc(0.35em + 1vh) 0 calc(0.42em + 1.2vh); border-top: 1px solid var(--color-main-a35);}
	.all-depth2 ul {display: block; }
	.all-depth2-btn { padding: calc(0.35em + 1vh) var(--depth-padding) calc(0.35em + 1vh) calc(var(--depth-padding) + var(--content-padding)); font-weight: 700; color: #222; white-space: normal;}
}
@media (max-width: 640px) {
	.all-depth1 { font-size: 26px;}
}
@media (max-width: 576px) {
	/* sns 드롭다운 버튼 생성 */
	.util-sns-btn {display: block;}
	.util-sns-wrap {display: none; position: absolute; top: calc(100% + 15px); left: 50%; border-radius: 5px; background-color: #fff; box-shadow: 0 0 25px var(--color-black-a2); transform: translateX(-50%);}
	.util-sns-list {flex-direction: column; padding: 6px 0;}
	.util-sns-list a {padding: 6px 12px;}
	.util-sns-list a::before { background: #444; }
	.allmenu {--depth-padding: max(4.5vw, var(--content-padding));}
	.allmenu-cont::-webkit-scrollbar { width: 0; }
	.all-depth1 { font-size: 23px;}
}
@media (max-width: 480px) {
	.header-util { column-gap: calc(10px + 2.5vw);}
	.all-depth1 { font-size: 21px;}
}
@media (hover: hover) and (pointer: fine) {
	.depth2 a:hover {text-decoration: underline;}
	.util-log a:hover::before,
	.util-sns-list a:hover::before {background-size: 100% calc(100% + 10px);}
	.util-allmenu-btn {display: none;}
	.util-allmenu-btn:hover span:nth-child(2) { width: 23px; }
	.is-open .util-allmenu-btn:hover span { width: 31px; }
}
@media (hover: hover) and (pointer: fine) and (min-width: 769px) {
	.all-depth1:hover .all-depth1-btn {color: #222;}
	.all-depth1:hover .all-depth1-btn::before {width: 100%;}
	.all-depth2-btn:hover {color: var(--color-main);}
}
/* HEADER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* FOOTER ============================================== */
.footer { padding: 7.5rem 0 14rem; background: #444 url(../images/common/footer_bg.jpg) no-repeat right 40%/cover; color: #ddd;}



/* 푸터 주소 */
.footer-contact { display: flex; flex-wrap: wrap; gap: 0.9em 5rem; margin-bottom: 5.5rem; font-weight: 500;}
.footer-contact .item { display: flex; column-gap: 0.6em;}
.footer-contact .item.addr { width: 100%; padding-bottom: 0.3em;}
.footer-contact .item dt {font-weight: 700;}
.footer-contact .item dd {color: #aaa;}
/* 푸터 메뉴 + 카피라이트 */
.footer-policy { overflow: hidden; padding-top: 4.5rem; border-top: 1px solid var(--color-main-a5); font-size: calc(1em - 1px);}
.footer-policy .inner {display: flex; justify-content: space-between; align-items: center;}
.footer-policy .menu { display: flex; justify-content: end; align-items: center; transform: translateX(1.4em); }
.footer-policy .item { display: flex; align-items: center; }
.footer-policy .item a { position: relative; padding: 0.7em 1.4em; font-weight: 700;  color: #fff;}
.footer-policy .item + .item a::before { position: absolute; top: 50%; left: 0; width: 1px; height: 0.7em; background-color: var(--color-main); content: ''; transform: translateY(-50%); }
.footer-policy .copy { order: -5; line-height: 1.3; color: #888;}
.footer-policy .copy em { font-weight: 700;color: var(--color-main);}

@media (max-width: 1280px) {
	.footer {font-size: 15px;}
}
@media (max-width: 1024px) {
	.footer {text-align: center;}
	.footer-contact {justify-content: center;}
	.footer-contact .item.addr {justify-content: center;}
	.footer-policy  .inner {flex-direction: column-reverse; row-gap: 1.2rem;}
	.footer-policy .menu { transform: translateX(0); }
}
@media (max-width: 768px) {
	.footer {font-size: 14px;}
	.footer-policy {font-size: 1em;}
 }
@media (max-width: 576px) {
	.footer { padding: 8rem 0 12rem; background-blend-mode: soft-light; }
	.footer-policy .menu {flex-direction: column;}
	.footer-policy .item a {padding: 0.85em;}
	.footer-policy .item + .item a::before { top: 0; left: 50%; transform: translate(-50%, -50%); }
}



/*푸터 SNS 추가  20251001 */
.footer .util-sns-wrap {margin-bottom:3rem;}
.footer .util-sns-list a::before {background-color: #aaa;}
@media (max-width: 1024px) {
	.footer .util-sns-list {justify-content: center;}
}
@media (max-width: 576px) {
	.footer .util-sns-wrap {display: block !important; position: static; border-radius: 0; background-color: transparent; box-shadow: none; transform: translateX(0%);}
	.footer .util-sns-list {flex-direction: row; padding:0;}
	.footer .util-sns-list a {padding: 0;}
}
/* FOOTER ============================================== */
/* ===================================================== */


/* ===================================================== */
/* SUB-LAYOUT ========================================== */
.body-sub { --lnb-size: 60px; --lnb-padding: clamp(14px, 1.4vw, 25px);}
/* SUV-VISUAL */
.sub-visual { z-index: 100; position: absolute; inset: 0; pointer-events: none;}
.sub-visual-bg { overflow: hidden; position: relative; height: calc(30rem + 100px); }
.sub-visual-bg span { position: absolute; inset: 0; background: #444 no-repeat center/cover;  animation: fade-in 1.2s both; }
.sub-visual.nth-1 .sub-visual-bg span {background-position: 75% center;}
.sub-visual-txt { position: absolute; inset: 0; font-size: 1rem; }
.sub-visual-tit { position: absolute; right: 0; bottom: 20%; height: 7.5em;}
.sub-visual-tit::before { opacity: 0.8; position: absolute; right: 6em; bottom: 0; width: 16em; height: 16em; background: url(../images/common/sub_title_deco.png) no-repeat center/contain; content: ''; animation: fade-in 2s ease-out 1s both;}
.sub-visual-tit figure { overflow: hidden; position: relative; height: 100%;}
.sub-visual-tit img { height: 100%; object-fit: contain; animation: slide-up 0.9s ease-in-out 0.3s both;}

/* LNB */
.lnb { overflow: auto hidden; position: sticky; top: var(--header-height); background: #fff linear-gradient(var(--color-main-a35), var(--color-main-a35)) no-repeat left calc(var(--lnb-size) - 1px)/100% 1px; font-weight: 600; line-height: 1.15; color: #666; pointer-events: all;}
.lnb-inner {display: flex; position: relative; height: var(--lnb-size); padding-left: var(--content-padding); margin: 0 var(--inner-padding);}
.lnb::-webkit-scrollbar {height: 0;}
.lnb-home { flex-shrink: 0; position: relative; width: 21px; height: 100%; margin-right: var(--lnb-padding);}
.lnb-home::before { position: absolute; left: -4px; width: 30px; height: 100%; background: url(../images/common/lnb_home.svg) no-repeat center; content: ''; }
.lnb-btn { z-index: 5; display: none; position: relative; width: 100%; height: 100%; font-weight: 700; font-size: 18px; color: #444;  }
/* LNB 리스트 */
.lnb-wrap { height: 100%; padding-right: var(--content-padding); }
.lnb-list { display: grid; grid-auto-flow: column; position: relative; height: var(--lnb-size);}
.lnb-list::before { grid-column: 1 / calc(var(--lnb-on-index) + 1); align-self: end; position: absolute; right: var(--lnb-padding); width: calc(100% + var(--inner-padding) + 21px - var(--outer-padding) + var(--content-padding) );	height: 4px; background: linear-gradient(var(--color-main), var(--color-main)) no-repeat left/0 100%; content: ''; animation: lnb-deco calc(0.5s + 0.3s * var(--lnb-on-index)) 1s both;}
@keyframes lnb-deco { to {background-size: 100% 100%;} }
.lnb-item a { --c: #666; display: flex; justify-content: center; align-items: center; height: 100%; padding: 0 var(--lnb-padding); text-align: center; color: var(--c);  white-space: nowrap; transition: color .3s;}
.lnb-item a span {pointer-events: none;}/* lnb 좌우스크롤 때문에 이벤트 제거 */
.lnb-item a[title=MOVIE] span {display: flex; align-items: center;}
.lnb-item a[title=MOVIE] span::after { width: 1.2em; margin-left: 0.35em; background-color: var(--c); mask: url(../images/common/sns_ico_ytb.svg) no-repeat center/contain; -webkit-mask: url(../images/common/sns_ico_ytb.svg) no-repeat center/contain;content: ''; transition: background-color .3s;  aspect-ratio: 1 / 1;}
.lnb-item a:hover {--c: var(--color-main);}
.lnb-item.on a { --c: #222; font-weight: 800; }

/* CONTENT */
.sub-content {padding-top: calc(30rem + 100px + var(--lnb-size)); }
.content-wrap {padding-top: 8rem;}
.content-wrap::after {display: block; visibility: hidden; width: 100%; height: 1px; margin-bottom: -1px; content: '';}

@media (max-width: 1280px) {
	.body-sub { --lnb-size: 58px;}
	.lnb {font-size: 15px;}
}
@media (max-width: 1024px) {
	.lnb {font-size: 14px;}
	.lnb-list::before {height: 3px;}
}
@media (max-width: 768px) {
	.body-sub { --lnb-size: 56px;}
	.sub-visual-txt { font-size: calc(0.7vw + 3.5px); }
	.lnb { overflow: visible; font-size: 15px;}
	.lnb-home { z-index: 50;position: absolute;}
	.lnb-btn { display: block; padding: 0 calc(var(--content-padding) + 0.4em); transition: .3s; }
	.lnb-btn::before { position: absolute; top: 50%; right: 0; width: 0.95em; height: 0.7em; background-color: #444; mask: url(../images/common/chevron_v19.svg) no-repeat center/contain; content: ''; transform: translateY(-50%) rotate(180deg); transition: .3s;}
	.lnb.is-active .lnb-btn::before { transform: translateY(-50%); }
	.lnb-wrap { display: none; position: absolute; top: 100%; left: 0; width: calc(100% + var(--inner-padding)); height: auto; padding-right: 0; background-color: #fff;}
	.lnb-list { display: flex; flex-direction: column; height: auto;  }
	.lnb-list::before {display: none;}
	.lnb-item a { padding: 1.2em 1em; border-bottom: 1px solid var(--color-main-a35); }
	.lnb-item.on a { --c: #fff;background-color: var(--color-main);}
	.sub-content {position: relative;}
	.sub-content::before { z-index: 50; opacity: 0; position: absolute; inset: 0; background-color: var(--color-black-a4);content: ''; transition: .3s; pointer-events: none;}
	.sub-visual:has(.lnb.is-active) + .sub-content::before {opacity: 1;}
}
@media (max-width: 576px) {
	.sub-visual.nth-1 .sub-visual-bg span {background-position: 70% center;}
}
@media (max-width: 480px) {
	.body-sub { --lnb-size: 54px; }
	.sub-visual.nth-1 .sub-visual-bg span {background-position: 65% center;}
	.sub-visual-txt { font-size: 1.5vw; }
	.lnb {font-size: 14px;}
	.lnb-btn {font-size: 17px;}
}
@media (max-width: 420px) {
	.lnb-btn {font-size: 16px;}
}
@media (max-width: 360px) {
	.lnb-btn {font-size: 15px;}
}
/* SUB-LAYOUT ========================================== */
/* ===================================================== */
