select::-ms-expand { display: none; }
select { 
    -webkit-appearance: none; 
    -moz-appearance: none; 
    appearance: none;
	outline: none;
}
input{ outline: none; border: none; }
input[type="submit"],input[type="button"], input[type="file"],
input[type="text"], button { appearance: none; -moz-appearance: none; -webkit-appearance: none; border-radius: 0;-webkit-border-radius: 0; -moz-border-radius: 0; }
input[type="checkbox"]{ padding: 0 !important; }


/* paging */
.paging,
.paging .arr,
.paging ul{ display: flex; justify-content: center; align-items: center; }

.paging{ margin-top: 120px; }
.paging a{ width: 40px; height: 40px; display: inline-flex; justify-content: center; align-items: center; background: none !important; border: none !important; font-family: var(--engFont); font-size: 15px; font-weight: 500; color: #999; }
.paging ul{ margin: 0 20px; }
.paging ul li.on a{ background: var(--mainColor) !important; color: #FFF; }
.paging .arr i::before{ content: ""; width: 8px; height: 13px; display: inline-flex; background: url("/img/board/icon_paging.svg") no-repeat center center / contain; }
.paging .arr i.xi-angle-right-min::before{ transform: scaleX(-1); }


/* flex-title */
.flex-title{ display: flex; justify-content: space-between; margin-bottom: 60px; }


/* tab-menu */
.tab-menu ul{ display: flex; }
.tab-menu ul li a{ min-height: 60px; display: flex; justify-content: center; align-items: center; font-family: var(--engFont); font-size: 19px; font-weight: 400; color: #777; padding: 10px 30px; }
.tab-menu ul li.on a{ background: var(--mainColor); font-weight: 600; color: #FFF; }


/* 검색창 */
.search-box{
	--bg: #F5F5F5;

	--height: 60px;
	--select: 200px;
	--input: 300px;
	--padding: 25px;
}
.search-box{ display: flex; }
.search-box *{ font-family: var(--baseFont); font-size: 18px; font-weight: 500; color: #333; letter-spacing: -0.03em; } 
.search-box > *:not(:last-child){ margin-right: 10px; }
.search-box select,
.search-box input{ height: var(--height); border: none; border-radius: 0; -webkit-border-radius: 0; padding: 0 var(--padding); }
.search-box select{ width: var(--select); background: var(--bg) url("/img/board/icon_search_arrow.svg") no-repeat center right var(--padding) / auto; padding-right: calc((var(--padding) * 2) + 14px); }
.search-box input{ background: var(--bg); }
.search-box button{ width: var(--height); height: var(--height); background: var(--mainColor); border: none; padding: 0; }
.search-box button i{ height: 30px; display: block; background: url("/img/board/icon_search.svg") no-repeat center center / contain; }

@media screen and (max-width: 1700px){
	/* paging */
	.paging{ margin-top: 90px; }

	/* tab-menu */
	.tab-menu ul li a{ min-height: 55px; }

	/* 검색창 */
	.search-box{
		--height: 55px;
		--select: 150px;
		--input: 200px;
	}
}

@media screen and (max-width: 1280px){
	/* paging */
	.paging{ margin-top: 60px; }
	.paging a{ width: 37px; height: 37px; }
	.paging ul{ margin: 0 10px; }
	.paging .arr i{ transform: translateY(-2px); }
	.paging .arr i::before{ width: 6px; height: 10px; }

	/* tab-menu */
	.tab-menu ul li a{ min-height: 50px; font-size: 18px; padding-inline: 25px; }

	/* 검색창 */
	.search-box{
		--height: 50px;
		--padding: 20px;
	}
	.search-box *{ font-size: 17px; }
	.search-box button i{ height: 27px; }
}

@media screen and (max-width: 1000px){
	/* paging */
	.paging a{ width: 34px; height: 34px; }
	.paging ul{ margin: 0; }
	.paging .arr a{ width: 30px; height: 30px; }

	/* flex-title */
	.flex-title{ flex-direction: column; margin-top: -25px; margin-bottom: 40px; }
	.flex-title .tab-menu{ margin-bottom: 50px; }
	.flex-title .tab-menu ul{ justify-content: center; }
	.flex-title .search-box{ justify-content: center; }
}

@media screen and (max-width: 550px){
	/* 검색창 */
	.search-box{ flex-wrap: wrap; }
	.search-box select{ width: 100%; margin-right: 0 !important; margin-bottom: 10px; }
	.search-box input{ width: calc(100% - var(--height) - 10px); }
}


/* 이미지 게시판 */
.img-board{ 
	--gapB: 100px; 
	--gapR: 50px; 
	--line: 3;
}

.img-board{ display: flex; flex-wrap: wrap; margin-bottom: calc(var(--gapB) * -1); }
.img-board .item{ width: calc((100% - calc(var(--gapR) * (var(--line) - 1))) / var(--line)); margin-right: var(--gapR); margin-bottom: var(--gapB); }
.img-board .item:nth-of-type(3n){ margin-right: 0; }
.img-board .img{ position: relative; }
.img-board .img figure{ display: block; padding-bottom: 56.1%; position: relative; overflow: hidden; }
.img-board .img figure img{ width: 100%; height: 100%; object-fit: cover; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); }
.img-board .img span{ background: var(--mainColor); font-family: var(--engFont); font-size: 16px; font-weight: 600; color: #FFF; line-height: 1; padding: 12px 15px; position: absolute; bottom: 20px; right: 20px; }
.img-board .txt{ margin-top: 20px; }
.img-board .txt h6,
.img-board .txt p{ display: -webkit-box; text-overflow: ellipsis; word-break: break-all; overflow: hidden; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.img-board .txt h6{ height: 3em; font-size: 24px; font-weight: 500; color: #000; letter-spacing: -0.02em; line-height: 1.5; }
.img-board .txt p{ height: 3.4em; font-size: 17px; font-weight: 300; color: #777; letter-spacing: -0.03em; line-height: 1.7; margin-top: 10px; }
.img-board .txt span{ display: block; font-size: 17px; font-weight: 400; color: #999; letter-spacing: -0.03em; margin-top: 30px; }  

@media screen and (max-width: 1700px){
	.img-board{ 
		--gapB: 70px; 
		--gapR: 30px; 
	}
	.img-board .img span{ font-size: 16px; padding: 9px 12px; bottom: 15px; right: 15px; }
	.img-board .txt h6{ font-size: 22px; }
	.img-board .txt span{ margin-top: 20px; }
}

@media screen and (max-width: 1280px){
	.img-board{ 
		--gapB: 50px; 
		--gapR: 20px; 
	}
	.img-board .img span{ font-size: 15px; padding: 8px 10px; bottom: 10px; right: 10px; }
	.img-board .txt{ margin-top: 15px; }
	.img-board .txt h6{ font-size: 20px; }
	.img-board .txt p{ font-size: 16px; }
	.img-board .txt span{ font-size: 16px; margin-top: 15px; }
}

@media screen and (max-width: 1000px){
	.img-board{
		--line: 2;
	}
	.img-board .item:nth-of-type(3n){ margin-right: var(--gapR); }
	.img-board .item:nth-of-type(2n){ margin-right: 0; }
}

@media screen and (max-width: 900px){
	.img-board .txt h6{ height: 2.8em; font-size: 19px; line-height: 1.4; }
	.img-board .txt p{ height: 3em; line-height: 1.5; }
}


/* 상세 페이지 */
.view-ctn{
	--border: #DDD;
}

.view-ctn{ max-width: 1000px; margin: 0 auto; }
.view-ctn .title{ border-top: 1px solid var(--border); text-align: center; padding: 60px 0; }
.view-ctn .title span{ display: inline-block; background: var(--mainColor); font-family: var(--engFont); font-size: 16px; font-weight: 600; color: #FFF; line-height: 1; padding: 12px 15px; margin-bottom: 30px; }
.view-ctn .title h2{ font-size: 4.2rem; font-weight: 500; color: #111; line-height: 1.5; letter-spacing: -0.02em; margin-bottom: 30px; }
.view-ctn .title p{ font-family: var(--IBMFont); font-size: 16px; font-weight: 400; color: #CCC; letter-spacing: -0.02em; }

.view-ctn .edit-content{ border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); font-size: 18px; padding: 60px 0 80px; }

.view-ctn .files{ border-bottom: 1px solid var(--border); padding: 40px 0; }
.view-ctn .files ul{ margin: -12px 0; }
.view-ctn .files ul li a{ display: block; font-size: 17px; font-weight: 300; color: #111; letter-spacing: -0.02em; line-height: 1.3; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; padding: 12px 0; padding-left: 45px; position: relative; }
.view-ctn .files ul li a::before{ content: ""; width: 23px; height: 23px; background: url("/img/board/icon_view_file.svg") no-repeat center center / contain; position: absolute; top: 50%; left: 0; transform: translateY(-50%); }

.view-ctn .pages{ background: #F5F5F5; display: grid; grid-template-columns: repeat(2, 50%); padding: 0 40px; margin-top: 20px; }
.view-ctn .pages dl{ display: flex; align-items: center; }
.view-ctn .pages dl *{ font-size: 18px; letter-spacing: -0.02em; }
.view-ctn .pages dl dt{ flex-shrink: 0; width: 80px; display: flex; justify-content: space-between; align-items: center; font-family: var(--engFont); font-weight: 500; color: #111; }
.view-ctn .pages dl dt i{ width: 7px; height: 13px; display: inline-block; background: url("/img/board/icon_view_page.svg") no-repeat center center / contain; }
.view-ctn .pages dl dd{ flex: 1 1 auto; min-width: 0; }
.view-ctn .pages dl dd a{ display: block; font-weight: 300; color: #111; white-space: nowrap; text-overflow: ellipsis; overflow: hidden; padding: 40px; }

.view-ctn .pages dl:last-of-type,
.view-ctn .pages dl:last-of-type dt{ flex-direction: row-reverse; }
.view-ctn .pages dl:last-of-type dt i{ transform: scaleX(-1); }
.view-ctn .pages dl:last-of-type dd a{ text-align: right; }

.view-ctn .buttons{ text-align: center; margin-top: 80px; }
.view-ctn .buttons > *{ width: 300px; height: 85px; display: inline-flex; justify-content: center; align-items: center; background: var(--mainColor); font-family: var(--engFont); font-size: 19px; font-weight: 600; color: #FFF; letter-spacing: -0.02em; }

@media screen and (max-width: 1700px){
	.view-ctn .title{ padding: 40px 0; }
	.view-ctn .title span{ font-size: 16px; padding: 9px 12px; }

	.view-ctn .edit-content{ padding: 40px 0 60px; }

	.view-ctn .files{ padding: 30px 0; }
	.view-ctn .files ul{ margin: -10px 0; }
	.view-ctn .files ul li a{ padding: 10px 0; padding-left: 35px; }
	.view-ctn .files ul li a::before{ width: 20px; height: 20px; }

	.view-ctn .pages{ padding: 0 30px; }
	.view-ctn .pages dl dd a{ padding: 30px; }

	.view-ctn .pages dl:last-of-type,
	.view-ctn .pages dl:last-of-type dt{ flex-direction: row-reverse; }
	.view-ctn .pages dl:last-of-type dt i{ transform: scaleX(-1); }
	.view-ctn .pages dl:last-of-type dd a{ text-align: right; }

	.view-ctn .buttons > *{ width: 240px; height: 75px; }
}

@media screen and (max-width: 1280px){
	.view-ctn .title{ padding: 30px 0; }
	.view-ctn .title span{ font-size: 15px; padding: 8px 10px; margin-bottom: 20px; }
	.view-ctn .title h2{ margin-bottom: 20px; }

	.view-ctn .edit-content{ font-size: 17px; padding: 40px 0; }

	.view-ctn .files{ padding: 20px 0; }
	.view-ctn .files ul{ margin: -7px 0; }
	.view-ctn .files ul li a{ padding: 7px 0; padding-left: 30px; }
	.view-ctn .files ul li a::before{ width: 17px; height: 17px; }

	.view-ctn .pages{ padding: 0 25px; margin-top: 15px; }
	.view-ctn .pages dl *{ font-size: 17px; }
	.view-ctn .pages dl dt{ width: 70px; }
	.view-ctn .pages dl dt i{ width: 7px; height: 13px; }
	.view-ctn .pages dl dd a{ padding: 25px; }

	.view-ctn .buttons{ margin-top: 50px; }
	.view-ctn .buttons > *{ width: 200px; height: 65px; font-size: 18px; }
}

@media screen and (max-width: 900px){
	.view-ctn .title h2{ font-size: 4.5rem; }
}

@media screen and (max-width: 750px){
	.view-ctn .pages{ background: transparent; grid-template-columns: repeat(1, 100%); padding: 0; }
	.view-ctn .pages dl,
	.view-ctn .pages dl dt{ flex-direction: row !important; }
	.view-ctn .pages dl{ background: #F5F5F5; }
	.view-ctn .pages dl:not(:last-of-type){ margin-bottom: 10px; }
	.view-ctn .pages dl dt{ width: 90px; padding-left: 25px; }
	.view-ctn .pages dl dd a{ text-align: left !important; }

	.view-ctn .pages dl:first-of-type dt i{ transform: rotate(90deg); }
	.view-ctn .pages dl:last-of-type dt i{ transform: rotate(-90deg); }

	.view-ctn .buttons > *{ width: 170px; height: 60px; }
}


/* grid-form */
.grid-form{
	--height: 80px;
	--padding: 25px;

	--bg: #F8F8F8;
	--red: #FF0004;
}
.grid-form{ font-family: var(--baseFont); font-size: 17px; font-weight: 300; color: #999; letter-spacing: -0.02em; }
.grid-form *{ font-family: inherit; font-size: inherit; font-weight: inherit; color: inherit; }

.grid-form .tit{ display: flex; flex-wrap: wrap; justify-content: space-between; align-items: baseline; margin-bottom: 40px; }
.grid-form .tit h4{ font-family: var(--engFont); font-size: 34px; font-weight: 500; color: #111; }
.grid-form .tit p{ font-size: 18px; font-weight: 400; color: #555; }
.grid-form .tit p i{ font-style: normal; color: var(--red); }

.grid-form .scroll-y{ background: var(--bg); overflow-x: clip; overflow-y: auto; }
.grid-form .scroll-y::-webkit-scrollbar{ width: calc((var(--padding) * 2) + 7px); height: calc((var(--padding) * 2) + 5px); }
.grid-form .scroll-y::-webkit-scrollbar-thumb{ min-height: 100px; background: #DDD; background-clip: padding-box; border: var(--padding) solid transparent; cursor: pointer; }
.grid-form .scroll-y::-webkit-scrollbar-track{ background: transparent; background-clip: padding-box; border: var(--padding) solid transparent; }

.grid-form .form .grid{ display: grid; grid-template-columns: repeat(2, 50%); margin: -10px; }
.grid-form .form .grid > *{ margin: 10px; }
.grid-form .form .block{ grid-column: auto / span 2; }
.grid-form .form .flex{ display: flex; }  

.grid-form .form dl{ display: grid; grid-template-columns: 150px calc(100% - 150px); align-items: center; background: var(--bg); }
.grid-form .form dl dt{ font-size: 19px; font-weight: 500; color: #111; padding-left: var(--padding); }
.grid-form .form dl dt.block{ padding: var(--padding); }
.grid-form .form dl dt i{ font-style: normal; color: var(--red); }

.grid-form .form input,
.grid-form .form select,
.grid-form .form textarea{ width: 100%; background: var(--bg); border: none; border-radius: 0; -webkit-border-radius: 0; outline: none; }
.grid-form .form input,
.grid-form .form select{ height: var(--height); padding: 0 var(--padding); }
.grid-form .form input,
.grid-form .form textarea{ color: #111; }

.grid-form .form select{ background: url("/img/board/icon_select.svg") no-repeat center right var(--padding) / auto; padding-right: calc((var(--padding) * 2) + 24px); }
.grid-form .form select.selected{ color: #111; }
.grid-form .form textarea{ resize: none; height: 200px; padding: var(--padding); padding-top: 0; }

.grid-form .form input::placeholder, 
.grid-form .form textaree::placeholder{ color: #999; }

.grid-form .form .calendar{
	--icon: 30px;
}
.grid-form .form .calendar{ position: relative; }
.grid-form .form .calendar::after{ content: ""; width: var(--icon); height: var(--icon); background: url("/img/board/icon_calendar.svg") no-repeat center center / contain; position: absolute; top: 50%; right: var(--padding); transform: translateY(-50%); }
.grid-form .form .calendar input{ padding-right: calc((var(--padding) * 2) + var(--icon)); }

.grid-form .form .file{
	--width: 180px;
	--gap: 10px;
}
.grid-form .form .file > input{ width: calc(100% - var(--width) - var(--gap)); }
.grid-form .form .file .fileBtn{ width: var(--width); margin-left: var(--gap); position: relative; }
.grid-form .form .file .fileBtn::before{ content: ""; width: var(--gap); height: calc(100% + 6px); background: #FFF; position: absolute; top: 50%; left: 0; transform: translate(-100%, -50%); }
.grid-form .form .file .fileBtn input{ display: none; }
.grid-form .form .file .fileBtn label{ width: 100%; height: 100%; display: flex; justify-content: center; align-items: center; background: #333; font-size: 19px; font-weight: 500; color: #FFF; cursor: pointer; }
.grid-form .form .file .fileBtn label i{ display: inline-block; width: 17px; height: 17px; background: url("/img/board/icon_fileBtn.svg") no-repeat center center / contain; margin-left: 10px; } 

.grid-form .captcha{
	--width: 229px;
}
.grid-form .captcha figure img{ height: var(--height) !important; }
.grid-form .captcha button{ width: var(--height); height: var(--height); background: #333; padding: 0; border: none; }
.grid-form .captcha button i{ display: block; height: 21px; background: url("/img/board/icon_reset.svg") no-repeat center center / contain; }
.grid-form .captcha input{ width: calc(100% - var(--height) - var(--width)); }


.grid-form .policy .scroll-y{
	--padding: 20px;
}
.grid-form .policy .scroll-y{ height: 240px; padding: var(--padding); }
.grid-form .policy .pBox p:not(:last-of-type){ margin-bottom: 15px; }
.grid-form .policy .sec-box > *{ padding-top: 50px; }
.grid-form .policy .sec-box .column > *:not(:last-child){ margin-bottom: 20px; }
.grid-form .policy .sec-box .column.gap15 > *:not(:last-child){ margin-bottom: 10px; }
.grid-form .policy .sec-box .lineH170{ line-height: 1.7; }
.grid-form .policy .sec-box h6{ font-size: 18px; font-weight: 500; margin-bottom: 15px; }
.grid-form .policy .sec-box dl dt{ font-weight: 400; }
.grid-form .policy .sec-box dl dd{ margin-top: 10px; }
.grid-form .policy .sec-box ul li:not(:last-of-type){ margin-bottom: 10px; }
.grid-form .policy .sec-box ul li strong{ font-weight: 400; }

.grid-form .agree{ margin-top: 20px; }
.grid-form .agree input{ display: none; }
.grid-form .agree label{ display: inline-block; font-size: 18px; font-weight: 500; color: #333; padding-block: 10px; padding-left: 40px; margin: -10px 0; position: relative; cursor: pointer; }
.grid-form .agree label{
	-webkit-tap-highlight-color: transparent;   /* 사파리 & 크롬용 */
	-webkit-touch-callout: none;                    /* iOS 오래 누를 때 메뉴 제거 */
	user-select: none;    
}
.grid-form .agree label::before,
.grid-form .agree label::after{ content: ""; width: 20px; height: 20px; position: absolute; top: calc((1.3em + 20px) / 2); left: 0; transform: translateY(-50%); box-sizing: border-box; }
.grid-form .agree label::before{ background: #F5F5F5; border: 2px solid transparent; }
.grid-form .agree label::after{ background: url("/img/board/icon_check.svg") no-repeat center center / contain; opacity: 0; }
.grid-form .agree input:checked + label::before{ background: #FFF; border-color: var(--mainColor); }
.grid-form .agree input:checked + label::after{ opacity: 1; }

.grid-form .submit{
	--icon: 24px;
	--iconL: 10px;
}
.grid-form .submit{ display: flex; justify-content: space-between; }
.grid-form .submit > *{ width: calc((100% - 20px) / 2); height: var(--height); display: inline-flex; justify-content: center; align-items: center; padding: 10px; }
.grid-form .submit > * i{ flex-shrink: 0; width: var(--icon); height: var(--icon); display: inline-block; margin-left: var(--iconL); }
.grid-form .submit a{ background: #EEE; font-size: 20px; font-weight: 500; color: #555; text-align: center; }
.grid-form .submit a i{ background: url("/img/board/icon_download.svg") no-repeat center center / contain; }
.grid-form .submit button{ background: var(--mainColor); border: none; font-family: var(--engFont); font-size: 24px; font-weight: 500; color: #FFF; }
.grid-form .submit button i{ background: url("/img/board/icon_arrow.svg") no-repeat center center / contain; }

@media screen and (hover: hover) and (pointer: fine){
	.grid-form .submit button{ transition: background 0.4s; }
	.grid-form .submit button i{ margin-left: calc(var(--icon) * -1); opacity: 0; transition: margin 0.4s, opacity 0.4s; }

	.grid-form .submit button:hover{ background: #13357A; }
	.grid-form .submit button:hover i{ margin-left: var(--iconL); opacity: 1; }
}

@media screen and (max-width: 1700px){
	.grid-form{
		--height: 70px;
		--padding: 20px;
	}
	.grid-form .tit{ margin-bottom: 30px; }
	.grid-form .tit h4{ font-size: 30px; }

	.grid-form .form .file{
		--width: 160px;
	}

	.grid-form .captcha{
		--width: 200px;
	}

	.grid-form .submit a{ font-size: 19px; }
	.grid-form .submit button{ font-size: 22px; }
}

@media screen and (max-width: 1280px){
	.grid-form{
		--height: 60px;
		--padding: 17px;
	}
	.grid-form .tit{ margin-bottom: 20px; }
	.grid-form .tit h4{ font-size: 26px; }
	.grid-form .tit p{ font-size: 17px; }

	.grid-form .form dl{ grid-template-columns: 140px calc(100% - 140px); }
	.grid-form .form dl dt{ font-size: 18px; }

	.grid-form .form .file{
		--width: 140px;
	}
	.grid-form .form .file .fileBtn label{ font-size: 18px; } 

	.grid-form .captcha{
		--width: 172px;
	}

	.grid-form .policy .scroll-y *{ font-size: 16px; }
	.grid-form .policy .sec-box h6{ font-size: 17px; margin-bottom: 10px; }
	.grid-form .agree{ margin-top: 15px; }
	.grid-form .agree label{ font-size: 17px; padding-left: 35px; }

	.grid-form .submit{
		--icon: 22px;
	}
	.grid-form .submit > *{ width: calc((100% - 10px) / 2); height: 65px; } 
	.grid-form .submit a{ font-size: 18px; }
	.grid-form .submit button{ font-size: 20px; }
}

@media screen and (max-width: 1200px){
	.grid-form .form .grid{ grid-template-columns: repeat(1, 100%); }
	.grid-form .form .block{ grid-column: unset; }
	.grid-form .form dl dt.block{ grid-column: auto  / span 2; }
}

@media screen and (max-width: 900px){
	.grid-form .tit h4{ font-size: 22px; }
	.grid-form .tit p{ font-size: 16px; }

	.grid-form .submit a{ font-size: 17px; }
	.grid-form .submit button{ font-size: 19px; }
}

@media screen and (max-width: 700px){
	.grid-form .form .grid{ margin: -12px 0; }
	.grid-form .form .grid > *{ margin: 12px 0; }
	.grid-form .form dl{  grid-template-columns: repeat(1, 100%); background: transparent; }
	.grid-form .form dl dt{ padding: 0 0 10px !important; position: relative; }
	.grid-form .form dl dt.block{ grid-column: unset; }
	.grid-form .form dl dd{ background: var(--bg); }

	.grid-form .form textarea{ padding: var(--padding); }

	.grid-form .form .file .fileBtn{
		--gap: 5px;
	}

	.grid-form .submit{ flex-direction: column; }
	.grid-form .submit > *{ width: 100%; }
	.grid-form .submit > *:not(:last-child){ margin-bottom: 10px; }
}