@charset "utf-8";

/* ==================================================
	H E A D E R
================================================== */
/* Header */
.header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	transition: transform .25s, box-shadow .25s;
	z-index: 1500;
}

/* Header bar */
.header-bar {
	position: relative;
	border-bottom: 1px solid rgba(255, 255, 255, 0);
	background-color: rgba(0, 0, 0, 0);
	transition: background-color .25s ease;
}

.mheader .header-bar {
	background-color: rgba(0, 0, 0, 0);
}

.megamenu-bg {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	bottom: 0;
	height: 0;
	background-color: rgba(255, 255, 255, .9);
	transition: height .25s ease;
}

.header-bar>.inner {
	max-width: 100%;
	width: 100%;
	/*max-width: 1840px;*/
}

.header-bar-wrap {
	display: flex;
	flex-wrap: nowrap;
	justify-content: space-between;
	align-items: center;
	align-content: center;
	height: 9.6rem;
}

.branding {
	margin-left: 3.5rem;
	z-index: 20;
}

.branding>a,
.branding>a>.logo {
	display: block;
	width: 100%;
	min-width: 17rem;
	max-width: 17rem;
}

.home .header-bar {
	border-bottom-width: 1px;
	background-color: rgba(0, 0, 0, .12);
}

/* Main Navi */
.main-navigation {
	display: flex;
	justify-content: center;
	width: 100%;
	height: 100%;
	/*padding: 0 0 0 8rem;*/
}

.main-nav {
	display: flex;
	justify-content: center;
	max-width: 120rem;
	width: 100%;
	height: 100%;
}

.main-nav>li {
	position: relative;
	width: 25%;
	height: 100%;
}

.main-nav>li>a {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	position: relative;
	min-width: 20rem;
	height: 100%;
	padding: 0;
	font-size: var(--rem-22);
	font-weight: var(--font-sb);
	/*text-transform: uppercase;*/
	color: var(--color-white);
	transition: background-color .25s, color .25s;
}

.main-nav>li>.sub-nav {
	position: absolute;
	top: 9.6rem;
	left: 0;
	right: 0;
	height: 0;
	overflow: hidden;
	visibility: hidden;
	opacity: 0;
	padding: 2rem 0;
	text-align: left;
	transition: visibility .25s, opacity .25s, height .25s, background-color .25s;
}

.main-nav .sub-nav li>a {
	position: relative;
	display: block;
	opacity: 1;
	padding: 0.4rem 0;
	font-size: var(--rem-16);
	font-weight: var(--font-md);
	letter-spacing: -0.2px;
	line-height: 1.5;
	color: var(--color-black);
	transition: color .25s;
}

.main-nav .sub-nav li>a:hover {
	color: var(--color-red);
}

.main-nav .sub-nav .sub-nav {
	display: none;
	padding-left: 0.8rem;
}

.main-nav .sub-nav .sub-nav li>a {
	padding: 0.1rem 0;
	font-size: 1.5rem;
	font-weight: 400;
	color: #787878;
}

.main-nav .sub-nav .sub-nav li>a:hover {
	color: var(--color-red);
}

.main-nav .sub-nav .sub-nav li:last-child {
	margin-bottom: 1rem;
}

.main-nav .child_button {
	display: none;
}

.main-nav .main_hide {
	display: none;
}

/* Hover */
.main-nav>li>a:hover {
	color: var(--color-red) !important;
}

/* Active */
.main-nav>li.act>a {
	color: var(--color-red) !important;
}

.main-nav .sub-nav li.act>a {
	color: var(--color-red);
	text-decoration: underline;
}

/* Quick Menu */
.header-quick {
	display: flex;
	align-items: center;
}

.header-quick .quick-act {
	position: relative;
	margin-right: 3.5rem;
	line-height: 1;
}

.header-quick .quick-act:last-child {
	margin-right: 0;
}

.language-switcher {
	position: relative;
}

.language-switcher .btn-select-language {
	display: block;
	position: relative;
	width: 5.4rem;
	height: 5.4rem;
	line-height: 5.4rem;
	border-radius: 50%;
	/*padding-left: 10px;*/
	font-family: var(--font-Poppins);
	font-size: var(--rem-16);
	font-weight: var(--font-sb);
	color: var(--color-white);
	text-align: center;
	border: 0;
	outline: none;
	border: 1px solid var(--color-white);
}

.mheader .language-switcher .btn-select-language {
	color: var(--color-white);
}

.header.floating .language-switcher .btn-select-language,
.header-bar.hover .language-switcher .btn-select-language,
.header-bar.full-open .language-switcher .btn-select-language {
	/*color: #000;*/
}

/*
.language-switcher .btn-select-language>.icon {
	font-size: 2rem;
	position: absolute;
	top: 10px;
	color: #b4b4b4;
}

.mheader .language-switcher .btn-select-language>.icon {
	color: var(--color-white);
}

.mheader .header.floating .language-switcher .btn-select-language>.icon,
.mheader .header-bar.hover .language-switcher .btn-select-language>.icon,
.mheader .header-bar.full-open .language-switcher .btn-select-language>.icon {
	color: #b4b4b4;
}*/

.language-switcher>.language-list {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	visibility: hidden;
	opacity: 0;
	margin-top: 5px;
	background-color: #fefefe;
	border: 1px solid #ededed;
	box-shadow: 2px 2px 6px rgba(0, 0, 0, 0.05);
	transition: visibility .25s ease, opacity .25s ease;
	z-index: 11;
}

.language-switcher>.language-list>li {
	text-align: left;
	border-bottom: 1px solid #eee;
}

.language-switcher>.language-list>li:last-child {
	border-bottom: 0;
}

.language-switcher>.language-list>li>a {
	display: block;
	font-family: var(--font-Poppins);
	font-size: var(--rem-15);
	color: var(--color-black);
	padding: 6px 0;
	text-align: center;
}

.language-switcher>.language-list>li>a:hover {
	background: var(--color-blue);
	color: var(--color-white);
}

.language-switcher>.language-list>li>a.act {
	background-color: var(--color-red);
	font-weight: var(--font-sb);
	color: var(--color-white);
}

/*
.language-switcher.open>.btn-select-language>.icon::before {
	content: "\e945"
}*/

.language-switcher.open>.language-list {
	visibility: visible;
	opacity: 1;
}

.btn-all-menu {
	display: flex;
	align-items: center;
	position: relative;
	width: 30px;
	height: 21px;
	border: 0;
	outline: none;
	background-color: transparent;
}

.btn-all-menu>.lines {
	display: inline-block;
	width: 100%;
	height: 3px;
	background-color: var(--color-white);
}

.btn-all-menu>.lines::after,
.btn-all-menu>.lines::before {
	content: "";
	display: inline-block;
	position: absolute;
	left: 0;
	right: 0;
	height: 3px;
	background-color: var(--color-white);
}

.btn-all-menu>.lines::before {
	top: 0;
}

.btn-all-menu>.lines::after {
	bottom: 0;
}

/* Header Hover & Floating */
.home .header.floating {
	box-shadow: 0 3px 9px rgba(0, 0, 0, .15);
}

.header.floating .header-bar,
.header-bar.hover,
.header-bar.full-open {
	background-color: rgba(255, 255, 255, 1);
}

.header.floating .header-bar {
	border-bottom: 1px solid rgba(0, 0, 0, .2);
}

.branding .logo.logo-floating {
	display: none;
}

.header.floating .branding .logo.logo-floating,
.header-bar.hover .branding .logo.logo-floating,
.header-bar.full-open .branding .logo.logo-floating {
	display: block;
}

.branding .logo-default {
	display: block !important;
}

.header.floating .branding .logo-default,
.header-bar.hover .branding .logo-default,
.header-bar.full-open .branding .logo-default {
	display: none !important;
}

.header.floating .header-bar .main-nav>li>a,
.header-bar.hover .main-nav>li>a,
.header-bar.full-open .main-nav>li>a {
	color: var(--color-black);
}

.header.floating .btn-select-language,
.header-bar.hover .btn-select-language,
.header-bar.full-open .btn-select-language {
	color: var(--color-black);
	border: 1px solid var(--color-black);
}

.header.floating .btn-all-menu>.lines,
.header.floating .btn-all-menu>.lines::after,
.header.floating .btn-all-menu>.lines::before,
.header-bar.hover .btn-all-menu>.lines,
.header-bar.hover .btn-all-menu>.lines::after,
.header-bar.hover .btn-all-menu>.lines::before,
.header-bar.full-open .btn-all-menu>.lines,
.header-bar.full-open .btn-all-menu>.lines::after,
.header-bar.full-open .btn-all-menu>.lines::before {
	background-color: var(--color-black);
}

.header-bar.full-open .main-nav>li>.sub-nav {
	visibility: visible;
	opacity: 1;
	height: 27rem;
	/* 내려오는 메뉴 높이 */
}

.header-bar.full-open .megamenu-bg {
	height: 27rem;
	/* 내려오는 메뉴 높이 */
	border-top: 1px solid #ddd;
	/*background-color: var(--color-white);*/
	background-color: var(--color-white);
	box-shadow: 0 0.3rem rgba(0, 0, 0, 0.08);
}

/* Full(Mobile) Nav */
.full-nav-mask {
	display: block;
	position: fixed;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
	visibility: hidden;
	opacity: 0;
	background-color: rgba(0, 0, 0, 0.6);
	cursor: pointer;
	transition: opacity .25s, visibility .25s;
	z-index: 1549;
	display: none;
}

.full-nav-mask.open {
	visibility: visible;
	opacity: 1
}

.full-nav {
	position: fixed;
	top: 50%;
	left: 50%;
	width: 120rem;
	overflow: hidden;
	visibility: hidden;
	opacity: 0;
	background-color: var(--color-white);
	border-radius: 1rem;
	transform: translate(-50%, -50%);
	transition: transform .5s, opacity .25s, visibility .25s;
	z-index: 1550;
	display: none;
}

.full-nav.open {
	visibility: visible;
	opacity: 1;
}

.full-nav .hd {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	height: 8rem;
	background-color: var(--color-red);
}

.full-nav .hd .close-full-nav {
	position: absolute;
	top: 50%;
	right: 3rem;
	font-size: 2.4rem;
	color: var(--color-white);
	border: 0;
	background-color: transparent;
	transform: translateY(-50%);
}

.full-nav .nav-all {
	padding: 5rem 6rem 6rem;
}

.full-navi {
	display: flex;
	justify-content: space-between;
}

.full-navi>li {
	position: relative;
	width: 100%;
	padding: 0 1.5rem;
	text-align: center
}

.full-navi>li>a {
	display: block;
	position: relative;
	padding-bottom: 1.4rem;
	font-size: 2rem;
	font-weight: 700;
	color: #222;
	border-bottom: 1px solid #ddd;
}

.full-navi>li.act>a,
.full-navi>li>a:hover {
	color: var(--color-red);
}

.full-navi .sub-nav {
	padding-top: 1.5rem;
}

.full-navi .sub-nav a {
	display: block;
	padding: 0.5rem 0.5rem;
	font-size: 1.6rem;
	color: #999;
}

.full-navi .sub-nav li.act a,
.full-navi .sub-nav li a:hover {
	color: var(--color-red);
}

.full-navi .child_button {
	display: none;
	top: 2rem;
	right: 3rem;
	font-family: xeicon !important;
	speak: none;
	font-size: 0;
	font-style: normal;
	font-weight: 400;
	font-variant: normal;
	text-transform: none;
	line-height: 1;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	border: 0;
	background-color: transparent;
	transition: transform .3s ease
}

.full-navi .child_button::before {
	content: "\e943";
	font-size: 2.4rem;
	color: #545454;
}

.full-navi li.open>.child_button {
	transform: rotate(180deg);
}

.full-navi .sub-nav .child_button {
	display: none !important;
}

/* mobile */
.full-nav .bth-bumace {
	display: none;
}

.header-quick .quick-nav {
	display: none;
}

/* 모바일CSS */
@media screen and (max-width:1400px) {

	/* Header bar */
	.header-bar-wrap {
		width: 96%;
		margin: 0 auto;
	}

	.branding {
		margin-left: 0;
	}

	/* Main Navi */
	.main-nav {
		max-width: 70rem;
	}

	/* Quick Menu */
	.full-nav .bth-bumace {
		display: block;
		color: #000 !important;
		width: 15rem;
		font-size: 16px;
	}

	.quick-nav {
		position: relative;
		top: -21px;
		padding-left: 20px;
	}

	.header-quick .quick-language {
		margin-right: 0;
	}
}

@media screen and (max-width:1280px) {

	/* Quick Menu */
	.header-quick .quick-language {
		margin-right: 2rem;
	}

	/* Full(Mobile) Nav */
	.full-nav {
		left: 4%;
		width: 92%;
		transform: translate(0, -50%);
	}

	.full-nav .nav-all {
		padding: 40px 45px 55px;
	}
}

@media screen and (max-width:1200px) {

	/* Header bar */
	.header-bar-wrap {
		width: 94%;
	}
}

@media screen and (max-width:1100px) {

	.full-nav-mask,
	.full-nav {
		display: block;
	}

	/* Main Navi */
	.main-navigation {
		display: none;
	}

	/* Quick Menu */
	.header-quick {
		padding-top: 0;
	}

	.quick-sitemap {
		display: none;
	}

	.quick-nav {
		top: 0;
		padding: 0;
	}

	.header-quick .quick-nav {
		display: block;
	}

	/* Full(Mobile) Nav */
	.full-nav {
		top: 0;
		bottom: 0;
		left: auto;
		right: 0;
		width: 480px;
		border-radius: 0;
		transform: translate(100%, 0);
	}

	.full-nav.open {
		transform: translate(0, 0);
	}

	.full-nav .hd {
		justify-content: flex-start;
		height: 79px;
		padding-left: 35px;
		border-bottom: 1px solid #e9e9e9;
		background-color: var(--color-white);
	}

	.full-nav .hd .close-full-nav {
		top: 0;
		right: 0;
		width: 78px;
		height: 100%;
		font-size: 2.8rem;
		color: var(--color-white);
		background-color: var(--color-red);
		transform: translateY(0);
	}

	.full-nav .nav-all {
		height: calc(100vh - 120px);
		overflow-y: auto;
		padding: 0;
		margin-top: 10px;
	}

	.full-nav .nav-all::-webkit-scrollbar {
		width: 6px;
		height: 6px
	}

	.full-nav .nav-all::-webkit-scrollbar-thumb {
		background-color: rgba(255, 150, 0, .45);
		border-radius: 3px;
	}

	.full-nav .nav-all::-webkit-scrollbar-track {
		background-color: rgba(255, 150, 0, .22);
	}

	.full-nav .mo-quick {
		display: block;
	}

	.full-navi {
		display: block;
	}

	.full-navi>li {
		padding: 4px 0;
	}

	.full-navi>li>a {
		padding: 11px 35px;
		font-size: 2.4rem;
		text-align: left;
		border-bottom: 0;
	}

	.full-navi .sub-nav {
		display: none;
		padding: 20px 0;
		background-color: #f5f5f5;
	}

	.full-navi .sub-nav a {
		font-size: 1.8rem;
		font-weight: 500;
		line-height: 1.5;
		text-align: left;
		padding: 5px 35px 5px 45px;
	}

	.full-navi .child_button {
		display: inline-block;
		position: absolute;
	}
}

@media screen and (max-width:640px) {

	/* Header bar */
	.header-bar-wrap {
		height: 68px;
	}

	/* Full(Mobile) Nav */
	.full-nav {
		width: 80%;
		min-width: none
	}

	.full-nav .hd {
		height: 69px;
	}

	.full-nav .hd .close-full-nav {
		width: 69px;
	}

	.full-nav .nav-all {
		height: calc(100vh - 175px);
	}
}

@media screen and (max-width:480px) {

	/* Header bar */
	.branding {
		position: relative;
		left: -5px;
	}

	/* Quick Menu */
	.btn-all-menu {
		width: 28px;
		height: 19px;
	}

	.btn-all-menu>.lines {
		height: 3px;
	}

	.btn-all-menu>.lines::after,
	.btn-all-menu>.lines::before {
		height: 3px;
	}

	/* Full(Mobile) Nav */
	.full-nav .hd {
		padding-left: 28px;
	}

	.language-switcher {
		margin-left: 0;
	}

	.full-nav .ft {
		display: block;
		border-top: 1px solid #ddd;
		padding-top: 16px;
		text-align: center;
	}

	.full-nav .ft .bth-bumace {
		display: inline-block;
		border-radius: 0
	}

	.full-nav .nav-all {
		height: calc(100vh - 165px);
		margin-top: 30px;
	}

	.full-navi>li>a {
		padding: 9px 28px;
		font-size: 20px;
	}

	.full-navi .sub-nav {
		padding: 16px 0;
	}

	.full-navi .sub-nav a {
		padding: 4px 30px 4px 30px;
		font-size: 16px;
	}

	.full-navi .child_button {
		right: 20px;
	}

	.full-navi .child_button::before {
		font-size: 20px;
	}

	.full-family-tt {
		font-size: 17px;
	}

	.full-nav .family-list .item-link {
		padding: 11px 26px;
		font-size: 17px;
	}

	.jp-page .full-nav .family-list .item-link {
		font-size: 16px;
	}

	.full-family .close-full-family {
		width: 68px;
	}
}

/* ==================================================
	스크롤 내렸을때 변화
================================================== */
#header.active {
	background: rgba(0, 0, 0, 1);
}

.mwarp #header.active {
	border-bottom: 0;
	background: rgba(0, 0, 0, 1);
}

/* ==================================================
	lnb
================================================== */
#lnb_con {
	position: absolute;
	left: 0;
	bottom: -4rem;
}

.lnb {
	width: var(--px-base);
	padding: 2.75rem 0;
	background: var(--color-red);
	padding-left: 26rem;
	border-radius: 0rem 0rem 3rem 0rem;
}

.lnb>ul {
	display: flex;
	flex-wrap: wrap;
}

.lnb>ul>li {
	position: relative;
	height: 100%;
}

.lnb>ul>li+li {
	margin-left: 7rem;
}

.lnb>ul>li a {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	font-size: 1.7rem;
	letter-spacing: -0.2px;
	color: rgba(255, 255, 255, 0.6);
	text-align: center;
	width: 100%;
	height: 100%;
	padding-bottom: 0.5rem;
}

.lnb>ul>li.on a,
.lnb>ul>li a:hover {
	color: var(--color-white);
}

/* 모바일CSS */
@media screen and (max-width:1600px) {
	#lnb_con {
		position: relative;
		bottom: 0;
		width: 100%;
	}

	.lnb {
		width: 100%;
		padding-left: 0;
		padding-left: 0;
		border-radius: 0;
	}

	.lnb>ul {
		justify-content: center;
	}
}

@media screen and (max-width:1400px) {
	.lnb>ul>li+li {
		margin-left: 5rem;
	}
}

@media screen and (max-width: 1023px) {
	#lnb_con {
		display: none;
	}
}

/* ==================================================
	컨텐츠 서브메뉴
================================================== */
.cnb2 {
	width: 100%;
	max-width: var(--px-base);
	margin-right: auto;
	margin-left: auto;
	margin-top: 6.8rem;
}

.cnb2 ul {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
}

.loc_cnb .cnb2 ul {
	display: -ms-grid;
	display: grid;
	-ms-grid-columns: (1fr)[3];
	grid-template-columns: repeat(3, 1fr);
	gap: 4.5rem;
	text-align: center;
}

.loc_cnb .cnb2 ul li {
	margin-right: 0;
}

.cnb2 ul li {
	position: relative;
	margin-right: 6.5rem;
}

.cnb2 ul li:last-child {
	margin-right: 0;
}

.cnb2 ul li.on:after {
	background-color: var(--color-red);
	content: "";
	bottom: -1.6rem;
	left: 0;
	position: absolute;
	height: 0.3rem;
	width: 100%;
}

.cnb2 ul li a {
	font-size: 1.9rem;
	letter-spacing: -0.2px;
	font-weight: var(--font-md);
	display: inline-block;
	position: relative;
	text-align: center;
}

.cnb2 ul li.on a {
	color: var(--color-red);
	font-weight: var(--font-sb);
}

.cnb2 ul li a:hover {
	color: var(--color-red);
}

/* 애니메이션 */
.cnb_ani {
	opacity: 0;
	transform: translateY(30px);
}

.cnb_ani.active {
	opacity: 1;
	transform: translateX(0px);
	transition: 0.7s 0.6s;
}

/* 모바일CSS */
@media screen and (max-width:1023px) {
	.cnb2 {
		margin-top: 4.5rem;
	}

	.cnb2 ul {
		display: -ms-grid;
		display: grid;
		-ms-grid-columns: (1fr)[3];
		grid-template-columns: repeat(3, 1fr);
		gap: 3.5rem;
		text-align: center;
	}

	.cnb2 ul.col2 {
		-ms-grid-columns: (1fr)[2];
		grid-template-columns: repeat(2, 1fr);
	}

	.cnb2 ul.col4 {
		-ms-grid-columns: (1fr)[2];
		grid-template-columns: repeat(2, 1fr);
	}

	.cnb2 ul li {
		margin-right: 0;
	}

	.cnb2 ul li.on:after {
		display: none;
	}

	.cnb2 ul li a {
		font-size: 2rem;
		letter-spacing: -0.05px;
	}
}

@media screen and (max-width:640px) {
	.cnb2 ul li a {
		font-size: 1.7rem;
	}

	.cnb2 ul li.on a:after {
		background-color: var(--color-red);
		content: "";
		bottom: -1.2rem;
		left: 0;
		position: absolute;
		height: 0.3rem;
		width: 100%;
	}
}

@media screen and (max-width:450px) {
	.cnb2 ul li a {
		font-size: 1.5rem;
		letter-spacing: -0.35px;
	}
}