@charset "utf-8";

/*============================================================

	BASE

==============================================================*/

/* ---------------------------------------------
	Noto Sans
------------------------------------------------ */
/* 
	[ Google Fonts에서 Noto Sans 폰트 패밀리를 한번에 가져오도록 import ]
	- Noto Sans KR: 한국어를 지원
	- Noto Sans: 라틴 문자 및 키릴 문자(영어, 러시아어, 말레이어 등)를 지원
	- Noto Sans JP: 일본어를 지원
	- Noto Sans SC: 중국어 간체(简体字)를 지원
	- Noto Sans TC: 중국어 번체(繁體字)를 지원
*/
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+KR&family=Noto+Sans&family=Noto+Sans+JP&family=Noto+Sans+SC&family=Noto+Sans+TC&display=swap');


/* ---------------------------------------------
	IBM Plex Sans
------------------------------------------------ */
@font-face {
	font-family: "IBM Plex Sans";
	font-style: normal;
	font-weight: 300;
	src: url(../fonts/IBM-Plex-Sans/IBMPlexSans-Light.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/IBMPlexSans-Light.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/IBMPlexSans-Light.otf) format("opentype");
}

@font-face {
	font-family: "IBM Plex Sans";
	font-style: normal;
	font-weight: 400;
	src: url(../fonts/IBM-Plex-Sans/IBMPlexSans-Regular.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/IBMPlexSans-Regular.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/IBMPlexSans-Regular.otf) format("opentype");
}

@font-face {
	font-family: "IBM Plex Sans";
	font-style: normal;
	font-weight: 500;
	src: url(../fonts/IBM-Plex-Sans/IBMPlexSans-Medium.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/IBMPlexSans-Medium.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/IBMPlexSans-Medium.otf) format("opentype");
}

@font-face {
	font-family: "IBM Plex Sans";
	font-style: normal;
	font-weight: 700;
	src: url(../fonts/IBM-Plex-Sans/IBMPlexSans-Bold.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/IBMPlexSans-Bold.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/IBMPlexSans-Bold.otf) format("opentype");
}

/* KR */
@font-face {
	font-family: "IBM Plex Sans KR";
	font-style: normal;
	font-weight: 300;
	src: url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Light.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Light.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Light.otf) format("opentype");
}

@font-face {
	font-family: "IBM Plex Sans KR";
	font-style: normal;
	font-weight: 400;
	src: url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Medium.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Medium.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Medium.otf) format("opentype");
}

@font-face {
	font-family: "IBM Plex Sans KR";
	font-style: normal;
	font-weight: 500;
	src: url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Medium.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Medium.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Medium.otf) format("opentype");
}

@font-face {
	font-family: "IBM Plex Sans KR";
	font-style: normal;
	font-weight: 700;
	src: url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Bold.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Bold.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/KR/IBMPlexSansKR-Bold.otf) format("opentype");
}

/* JP */
@font-face {
	font-family: "IBM Plex Sans JP";
	font-style: normal;
	font-weight: 300;
	src: url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Light.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Light.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Light.otf) format("opentype");
}

@font-face {
	font-family: "IBM Plex Sans JP";
	font-style: normal;
	font-weight: 400;
	src: url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Medium.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Medium.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Medium.otf) format("opentype");
}

@font-face {
	font-family: "IBM Plex Sans JP";
	font-style: normal;
	font-weight: 500;
	src: url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Medium.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Medium.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Medium.otf) format("opentype");
}

@font-face {
	font-family: "IBM Plex Sans JP";
	font-style: normal;
	font-weight: 700;
	src: url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Bold.woff) format("woff"),
		url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Bold.woff) format("woff2"),
		url(../fonts/IBM-Plex-Sans/JP/IBMPlexSansJP-Bold.otf) format("opentype");
}

/* ---------------------------------------------
	ZiTiQuanXinYiGuanHeiTi
------------------------------------------------ */
@font-face {
	font-family: "ZiTiQuanXinYiGuanHeiTi";
	font-weight: 800;
	font-style: normal;
	src: url("../fonts/ZiTiQuanXinYiGuanHeiTi/ZiTiQuanXinYiGuanHeiTi4.0-2.woff2") format("woff2"),
		url("../fonts/ZiTiQuanXinYiGuanHeiTi/ZiTiQuanXinYiGuanHeiTi4.0-2.woff") format("woff");
}

/* ---------------------------------------------
	SUIT-Variable
------------------------------------------------ */
/*
	[ 사용되는 font-weight ]
	- 300 : Light
	- 400 : Regular
	- 500 : Medium
	- 600 : SemiBold
	- 700 : Bold
*/
@font-face {
	font-family: 'SUIT Variable';
	font-weight: 100 900;
	src:
		url('../fonts/SUIT/SUIT-Variable.woff2') format('woff2'),
		url('../fonts/SUIT/SUIT-Variable.woff') format('woff'),
		url('../fonts/SUIT/SUIT-Variable.otf') format('opentype');
}

/* -------------------------------------------------------------------------------------------- */

/* 20240827//(Ina) 각 언어별로 최적의 Noto Sans 폰트가 적용되도록 수정(s) */
html body {
	font-family: 'Noto Sans KR', 'Noto Sans', 'Noto Sans JP', 'Noto Sans SC', 'Noto Sans TC', sans-serif;
	font-size: 13px;
	line-height: 1.5;
	font-weight: 300;
	color: #666;
}

html input[type="text"]::placeholder {
	font-family: 'Noto Sans KR', 'Noto Sans', 'Noto Sans JP', 'Noto Sans SC', 'Noto Sans TC', sans-serif;
	color: #707070 !important;
	font-weight: 400 !important;
}

/* 20240827//(Ina) 각 언어별로 최적의 Noto Sans 폰트가 적용되도록 수정(e) */

/* 20230802//(Ina)SUIT폰트 추가 : SUIT폰트 한자이슈로 국문,영문,말레이어(영문)만 지원한다. (s) */
html.ko .wrapper.main--renewal-2024,
html.en .wrapper.main--renewal-2024,
html.ms .wrapper.main--renewal-2024 {
	font-family: 'SUIT Variable', sans-serif;
	color: #666;
	font-size: 13px;
	line-height: 1.5;
	font-weight: 300;
}

/* ko */
html.ko input[type="text"]::placeholder {
	font-family: "SUIT Variable", sans-serif !important;
}

/* en */
html.en input[type="text"]::placeholder {
	font-family: "SUIT Variable", sans-serif !important;
}

/* ms */
html.ms input[type="text"]::placeholder {
	font-family: "SUIT Variable", sans-serif !important;
}

/* 20230802//(Ina)SUIT폰트 추가 : SUIT폰트 한자이슈로 국문,영문,말레이어(영문)만 지원한다. (e) */

body,
div,
dl,
dt,
dd,
th,
td,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
form,
fieldset,
p,
blockquote,
button,
input,
textarea {
	margin: 0;
	padding: 0;
}

article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
main {
	display: block;
	margin: 0;
	padding: 0;
}

hr,
table caption {
	display: block;
	width: 0;
	height: 0;
	position: absolute;
	overflow: hidden;
	text-indent: -9999999px;
}

/* legend, .hd-element {position:absolute; overflow:hidden; text-indent:-9999999px;background:none !important;font-size:0 } */
legend,
.hd-element {
	position: absolute;
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	clip-path: inset(0);
	border: 0;
}

/* 20211109//(Ina)웹접근성 수정 */

table {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	table-layout: fixed;
}

img,
fieldset,
button,
input {
	border: 0;
	vertical-align: middle;
}

ul,
ol,
li {
	list-style: none !important;
}

em,
address {
	font-style: normal;
}

button {
	cursor: pointer;
}

a {
	text-decoration: none;
	color: #666;
}

a:focus {
	outline: 5px auto -webkit-focus-ring-color;
	outline-offset: -2px;
}

a:hover {
	text-decoration: none;
}

button {
	vertical-align: top;
	background: transparent;
}

h1,
h2,
h3,
h4,
h5,
h6,
strong {
	font-size: 1em;
	font-weight: normal;
}

input,
select,
button,
textarea {
	font-family: inherit;
	font-size: inherit;
	line-height: inherit;
	font-weight: inherit;
	/* color: #555; */
	color: #2F2F2F;
}

.sub-contents img {
	max-width: 100%;
}

.paging-lst i::before,
.paging-lst i::after {
	display: inline-block !important;
	font-family: "Ionicons" !important;
	speak: none !important;
	font-style: normal !important;
	font-weight: normal !important;
	font-variant: normal !important;
	text-transform: none !important;
	/* text-rendering: auto; */
	line-height: 1 !important;
}

/* 20210625//(Ina)아이폰 input 그림자 제거
input {
	appearance: none;
}
*/

/* 20210730//(Ina)추가(s) */
input[type="checkbox"],
input[type="radio"] {
	margin-top: 0;
	margin-right: 1px;
}

/* 20210730//(Ina)추가(e) */

/* 접근성 메뉴 */
#accessibility {
	position: absolute;
	z-index: 999999999999999999;
	/* left: 5%;
	width: 90%; */
	top: 0;
	left: 0;
	width: 100%;
}

#accessibility a {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 0;
	overflow: hidden;
	background: #fff;
	color: #000;
}

#accessibility a:focus,
#accessibility a:active {
	height: 50px;
}

#accessibility a span {
	display: block;
	height: 50px;
	border: 1px solid #000;
	text-align: center;
	line-height: 50px;
}

/* margin */
.mt0 {
	margin-top: 0 !important;
}

.mt5 {
	margin-top: 5px !important;
}

.mt10 {
	margin-top: 10px !important;
}

.mt15 {
	margin-top: 15px !important;
}

.mt20 {
	margin-top: 20px !important;
}

.mt25 {
	margin-top: 25px !important;
}

.mt30 {
	margin-top: 30px !important;
}

.mt35 {
	margin-top: 35px !important;
}

.mt40 {
	margin-top: 40px !important;
}

.mt45 {
	margin-top: 45px !important;
}

.mt50 {
	margin-top: 50px !important;
}

.mt55 {
	margin-top: 55px !important;
}

.mt60 {
	margin-top: 60px !important;
}

.mt65 {
	margin-top: 65px !important;
}

.mt70 {
	margin-top: 70px !important;
}

.mt75 {
	margin-top: 75px !important;
}

.mt80 {
	margin-top: 80px !important;
}

.mt85 {
	margin-top: 85px !important;
}

.mt90 {
	margin-top: 90px !important;
}

.mt95 {
	margin-top: 95px !important;
}

.mt100 {
	margin-top: 100px !important;
}

.mr5 {
	margin-right: 5px !important;
}

.mr10 {
	margin-right: 10px !important;
}

.mr15 {
	margin-right: 15px !important;
}

.mr20 {
	margin-right: 20px !important;
}

.mr25 {
	margin-right: 25px !important;
}

.mr30 {
	margin-right: 30px !important;
}

.mr35 {
	margin-right: 35px !important;
}

.mr40 {
	margin-right: 40px !important;
}

.mr45 {
	margin-right: 45px !important;
}

.mr50 {
	margin-right: 50px !important;
}

.mr55 {
	margin-right: 55px !important;
}

.mr60 {
	margin-right: 60px !important;
}

.mr65 {
	margin-right: 65px !important;
}

.mr70 {
	margin-right: 70px !important;
}

.mr75 {
	margin-right: 75px !important;
}

.mr80 {
	margin-right: 80px !important;
}

.mr85 {
	margin-right: 85px !important;
}

.mr90 {
	margin-right: 90px !important;
}

.mr95 {
	margin-right: 95px !important;
}

.mr100 {
	margin-right: 100px !important;
}

.mb5 {
	margin-bottom: 5px !important;
}

.mb10 {
	margin-bottom: 10px !important;
}

.mb15 {
	margin-bottom: 15px !important;
}

.mb20 {
	margin-bottom: 20px !important;
}

.mb25 {
	margin-bottom: 25px !important;
}

.mb30 {
	margin-bottom: 30px !important;
}

.mb35 {
	margin-bottom: 35px !important;
}

.mb40 {
	margin-bottom: 40px !important;
}

.mb45 {
	margin-bottom: 45px !important;
}

.mb50 {
	margin-bottom: 50px !important;
}

.mb55 {
	margin-bottom: 55px !important;
}

.mb60 {
	margin-bottom: 60px !important;
}

.mb65 {
	margin-bottom: 65px !important;
}

.mb70 {
	margin-bottom: 70px !important;
}

.mb75 {
	margin-bottom: 75px !important;
}

.mb80 {
	margin-bottom: 80px !important;
}

.mb85 {
	margin-bottom: 85px !important;
}

.mb90 {
	margin-bottom: 90px !important;
}

.mb95 {
	margin-bottom: 95px !important;
}

.mb100 {
	margin-bottom: 100px !important;
}

.ml5 {
	margin-left: 5px !important;
}

.ml10 {
	margin-left: 10px !important;
}

.ml15 {
	margin-left: 15px !important;
}

.ml20 {
	margin-left: 20px !important;
}

.ml25 {
	margin-left: 25px !important;
}

.ml30 {
	margin-left: 30px !important;
}

.ml35 {
	margin-left: 35px !important;
}

.ml40 {
	margin-left: 40px !important;
}

.ml45 {
	margin-left: 45px !important;
}

.ml50 {
	margin-left: 50px !important;
}

.ml55 {
	margin-left: 55px !important;
}

.ml60 {
	margin-left: 60px !important;
}

.ml65 {
	margin-left: 65px !important;
}

.ml70 {
	margin-left: 70px !important;
}

.ml75 {
	margin-left: 75px !important;
}

.ml80 {
	margin-left: 80px !important;
}

.ml85 {
	margin-left: 85px !important;
}

.ml90 {
	margin-left: 90px !important;
}

.ml95 {
	margin-left: 95px !important;
}

.ml100 {
	margin-left: 100px !important;
}

/* clearfix */

.clearfix:before,
.clearfix:after {
	display: block;
	content: "";
	line-height: 0;
}

.clearfix:after {
	clear: both;
}

/* IR 효과 */
.ir_pm {
	display: block;
	overflow: hidden;
	font-size: 0;
	line-height: 0;
	text-indent: -9999px;
}

/* 의미있는 이미지의 대체 텍스트를 제공하는 경우(Phark Method) */
.ir_wa {
	display: block;
	overflow: hidden;
	position: relative;
	z-index: -1;
	width: 100%;
	height: 100%;
}

/* 의미있는 이미지의 대체 텍스트로 이미지가 없어도 대체 텍스트를 보여주고자 할 때(WA IR) */
.ir_so {
	overflow: hidden;
	position: absolute;
	width: 0;
	height: 0;
	line-height: 0;
	text-indent: -9999px;
}

/* 대체 텍스트가 아닌 접근성을 위한 숨김 텍스트를 제공할 때 */
.hidden-text {
	overflow: hidden;
	border: 0;
	margin: -1px;
	width: 1px;
	height: 1px;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	font-size: 0;
}

/* font */
[class*="textleft"] {
	text-align: left !important;
}

[class*="textcenter"] {
	text-align: center !important;
}

[class*="textright"] {
	text-align: right !important;
}

[class*="italic"] {
	font-style: italic;
}

.underline,
.underline:hover {
	text-decoration: underline !important;
	text-underline-offset: 3px;
}

.c-text-blue {
	color: #0b7dc3 !important;
}

.c-text-blue2 {
	color: #77d6ff !important;
}

.c-text-blue3 {
	color: #448def !important;
}

.c-text-blue4 {
	color: #0066eb !important;
}

.form-info-error {
	display: block;
	margin-top: 5px;
	color: #DA0606;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: -0.5px;
}

/* 202106//(Ina) .flex 추가(s) */
.flex-container {
	display: flex;
}

.flex-wrap {
	flex-wrap: wrap;
}

.flex-vertical-center {
	align-items: center;
}

.flex-vertical-end {
	align-items: flex-end;
}

.flex-align-center {
	justify-content: center;
}

.flex-space-between {
	justify-content: space-between;
}

.flex-end {
	justify-content: flex-end;
}

.flex-container .flex-1 {
	flex: 1;
}

.flex-container .flex-2 {
	flex: 2;
}

.flex-container .flex-3 {
	flex: 3;
}

.flex-container .flex-4 {
	flex: 4;
}

.flex-container .flex-5 {
	flex: 5;
}

.flex-container .flex-6 {
	flex: 6;
}

.flex-container .flex-7 {
	flex: 7;
}

.flex-container .flex-8 {
	flex: 8;
}

.flex-container .flex-9 {
	flex: 9;
}

.flex-container .flex-10 {
	flex: 10;
}

/* 202106//(Ina) .flex 추가(e) */

.swiper-notification {
	display: none;
}

/* 20210930//.swiper-notification 텍스트 안보이게 수정 */

.change-word-break {
	display: block !important;
}

.br--pc {
	display: block;
}
.br--tablet {
	display: none;
}
.br--mo {
	display: none;
}

@media (max-width: 1280px) {

	.br--pc {
		display: none;
	}
	.br--tablet {
		display: block;
	}
	.br--mo {
		display: none;
	}

}

@media (max-width: 768px) {
	.change-word-break {
		display: inline !important;
	}

	.br--pc {
		display: none;
	}
	.br--tablet {
		display: none;
	}
	.br--mo {
		display: block;
	}
	
}