@charset "utf-8";

* { box-sizing: border-box; }

/* ----- S : layout ----- */
#wrap, header, #header, #container, gnb, #gnb, main, #main, aside, #aside, footer, #footer { box-sizing: border-box; }

section { position: relative; }

h1 { color: #111; font-size: 24px; font-weight: 600; }
h2 { color: #333; font-size: 21px; }
h3 { color: #444; font-size: 19px; font-weight: 500; }


/* 헤더 */
#header { position: fixed; width: 100%; display: flex; justify-content: space-between; align-items: center; padding: 26px 30px; background: #3d8e70; z-index: 99999; }
logo a, #logo a { display: inline-block; color: #fff; vertical-align: middle; transition: background 0.1s; font-size: 20px; font-weight: 800; }
logo a img, #logo a img { height: 36px; }

#header #logo { width: auto; }

.member_info .fa-circle-user { margin-right: 5px; }
.member_info .fa-angle-down { margin-left: 2px; padding: 0 2px; font-size: 14px; }
.member_info { display: flex; align-items: center; color: rgba(255, 255, 255, .9); font-size: 18px; font-weight: 500; }
.member_info:hover { color: rgba(255, 255, 255, 1); }

.header_left { display: flex; gap: 16px; align-items: center; }

/* 레프트 메뉴 */
.user { position: relative; }
.list_util { display: none; position: absolute; top: 36px; right: 0; width: 140px; z-index:99999; background: #fff; line-height: 20px; border: 1px solid #eee; border-radius: 10px; overflow: hidden; box-shadow: 0 0 8px 0 rgba(0, 0, 0, .08); }
.list_util > li { border-top: 1px solid #eee; }
.list_util > li:first-of-type { border-top: 0; }
.list_util a { font-size: 16px; display: block; line-height: 46px; padding: 0 24px; color: #555; }
.list_util a:hover { color: #333; background: rgba(177,177,177,.1); }

/* 메인 탑 메뉴 */
.top_menu_inner { display: flex; justify-content: space-between; align-items: center; width: 100%; }

.menu_list { position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%); display: flex; width: 800px; justify-content: center; }
.menu_list li { position: relative; flex: 1; text-align: center; }
.menu_list li a { display: inline-block; width: 100%; padding: 28px; font-weight: 500; color: #fff; font-size: 18px; }
.menu_list li a:hover { color: #8fffd5; }

.menu_box { flex: 1; text-align: center; }
.submenu_column { display: block; }
.submenu_column .menu_title { font-weight: 600; margin-bottom: 10px; }
.submenu_wrap { position: absolute; top: 100%; left: 0; width: 100vw; background: #fff; display: flex; justify-content: center; padding: 20px 0; border-top: 1px solid #ddd; transform: scaleY(0); transform-origin: top; opacity: 0; transition: transform 0.4s cubic-bezier(0.25, 1, 0.5, 1), opacity 0.3s ease; will-change: transform, opacity;  overflow: hidden; z-index: 10; box-shadow: 0 0 8px 0 rgba(0, 0, 0, .08); }
.submenu_wrap > div { display: flex; width: 800px; justify-content: center; }

.menu_nav:hover .submenu_wrap { transform: scaleY(1); opacity: 1; }

.menu_title { display: none; font-size: 18px; font-weight: 500; color: #555; }
.smenu_title a { color: #666; line-height: 36px; }
.smenu_title:hover a { color: #333; text-decoration: underline; }
.menu_title.open, .menu_title:hover { color: #333; font-weight: 600; }


/* 푸터 */
.simple.footer { padding: 16px 0; background: #ececec; }
.simple.footer p { color: #999; text-align: center; font-size: 14px; line-height: 18px; }

/* 햄버거메뉴 */
.util { display: flex; align-items: center; }
.ico_bar { display: none; }
.ico_bar span { display: block; background-color: #fff; border-radius: 1px; transition: .2s; opacity: 0.8; width: 20px; height: 3px; margin-bottom: 4px; }
.ico_bar span:nth-child(3) { margin-bottom: 0; }

/* 사이드 메뉴 */
#snb { position: fixed; height: 100%; width: 260px; margin-top: 77px; overflow: hidden; background: #fff; box-shadow: 0 0 8px 0 rgba(0,0,0,.08); transition: .1s; opacity: 1; z-index: 9999; }
#gnb nav { padding-top: 10px; }
#gnb nav ul { width: 100%; }
#gnb nav ul li { width: 100%; }
#gnb nav ul li a { position: relative; display: block; width: 100%; padding-left: 30px; line-height: 58px; color: #666; font-size: 19px; font-weight: 500; }

#gnb nav > ul > li > a:hover,
#gnb nav .sidemenu li.on > a { color: #0a237f; }
#gnb nav > ul > li.on > a,
#gnb nav > ul > li.active > a,
#gnb nav > ul > li.on > a { font-weight: 600; }
#gnb nav ul li .sidemenu li a { padding-left: 36px; font-size: 18px; line-height: 50px; }
#gnb nav ul li .sidemenu li a:hover { background: rgba(228,230,235,.9); color: #192d79; }
#gnb nav ul .fa-angle-down { position: absolute; top: 50%; right: 24px; transform: translateY(-50%); margin: 0; font-size: 17px; }
#gnb nav ul .dropdown.on > a, .dropdown.on > a i { color: #0a237f !important; }
#gnb nav ul .dropdown.on .fa-angle-down { transform: translateY(-10px) rotate(180deg); transition: .3s;}
#gnb nav ul .dropdown.on .sidemenu { display: block; }
.sidemenu { background: #f2f4f7; }

.btn_hide { position: absolute; top: 50%; left: 260px; transform: translateY(-50%); color: #fff; background: #9ea3af; padding: 12px 6px; border-top-right-radius: 4px; border-bottom-right-radius: 4px; box-shadow: 1px 0px 3px 0px rgba(0, 0, 0, 0.1); z-index: 999; }
.btn_hide i { font-size: 15px; }
.hide #snb { width: 0; opacity: 0; transition: width .3s;}
.hide #snb  + .btn_hide,
.hide #container { left: 0; }
.hide #snb  + .btn_hide i { transform: rotate(180deg); }
.sidemenu { display: none; }

.empty_text { font-size: 17px; color: #666; }

.button_area { display: flex; margin-top: 20px; align-items: center; justify-content: center; gap: 10px; }

/* 레이아웃 */
#wrap { position: relative; width: 100%; height: 100%; background: #f8f8f8; font-family: 'Pretendard'; }
#container { position: absolute; height: calc(100dvh - 77px); left: 260px; right: 0; overflow: auto; margin-top: 77px; transition: .2s; }
.contents { position: relative; width: 100%; min-height: calc(100dvh - 127px); height: auto; overflow: auto; background: #f8f8f8; padding: 40px 0 50px; }
.wrapper { max-width: 1400px; margin: 0 auto; padding: 0 40px; }

/* tit */
.tit_wrap { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 10px; margin-bottom: 12px; }
.tit_wrap.border { padding-bottom: 10px; border-bottom: 1px solid #ddd; }
.tit_wrap span { color: #777; font-size: 17px; }
.tit_wrap02 { display: flex; justify-content: space-between; align-items: flex-end; padding-bottom: 16px; border-bottom: 1px solid #333; }
.stit_wrap { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-end; gap: 12px; margin-bottom: 16px; }

.stit_wrap > span { color: #999; }
.stit_wrap > p { color: #777; font-size: 16px; }
.stit_wrap > em { color: #333; font-size: 16px; }
.stit_wrap > em b { color: #5456bb; font-size: 18px; }
.stit_wrap h3 b { color: #5456bb; }

/* box */
.wh_box { padding: 24px; background: #fff; border-radius: 5px; box-shadow: 0px 0px 10px 2px rgb(225 225 225 / 0.65); }
.wh_box.column01 { padding: 24px 30px 30px; }
.wh_box.column02 { display: grid; grid-template-columns: 2fr 1.5fr; padding: 0; }
.wh_box.column02 > div { padding: 24px 30px 24px; }

/* form */
.top_select,
.top_date { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; color: #777; }
.top_date span { margin-right: 3px; color: #444; }
.top_date button { height: 36px; }
.top_select select { min-width: 150px; }

.checkbox_area input[type="checkbox"] { margin-right: 6px; }
.checkbox_area span { margin-top: 3px; color: #777; cursor: pointer; font-size: 17px; }
.checkbox_area input[type="text"] { margin-top: 8px; }
.checkbox_wrap { display: flex; flex-wrap: wrap; gap: 10px 20px; }
.checkbox_wrap label { width: auto; }

.btn_date_wrap { display: flex; gap: 10px; justify-content: flex-end; align-items: center; margin-bottom: 14px; }
.btn_date_wrap > label { color: #555; font-size: 17px; }
.btn_date { display: inline-flex; border: 1px solid #ddd; border-radius: 5px; overflow: hidden; color: #666; background: #fff; }
.btn_date label { padding: 5px 9px; transition: .1s;  font-size: 16px; }
.btn_date label:first-of-type { border-right: 1px solid #ddd; }
.btn_date label:hover { background: #eaecef; }
.btn_date label.on { background: #667489; color: #fff; }

/* search */
.search_wrap { display: inline-block; position: relative; width: 240px; box-shadow: 0px 0px 8px 1px rgba(85,85,85,0.1); }
.search_wrap a { position: absolute; top: 50%; right: 0; transform: translateY(-50%); width: 40px; text-align: center; }
.search_wrap input { width: 100%; padding: 0 40px 0 18px; border: none; border-radius: 6px; color: #000; }

.search_select { display: flex; gap: 6px; }
.set_search { display: flex; gap: 6px; }

.search_input {	position: relative;	width: 100%; max-width: 340px; }
.search_input input { width: 100%; padding-right: 40px; border: 1px solid #ddd; }
.search_btn { position: absolute; right: 8px; top: 50%; transform: translateY(-50%); border: none; background: none; padding: 4px; cursor: pointer;	color: #999; font-size: 16px; }
.search_btn:hover { color: #555; }

/* table */
table { cursor: default; }
.tbl_box { overflow-x: auto; }
.tbl_box table td a { display: -webkit-box; text-overflow: ellipsis; overflow: hidden; -webkit-box-orient: vertical; -webkit-line-clamp: 1; word-break: break-all; font-weight: 500; text-align: left; padding-left: 5%; }
.thover tbody tr:hover { cursor: pointer; }
.thover tbody tr:hover a { text-decoration: underline; }

.tbl01.max { min-width: 2000px; }
.tbl01 { width: 100%; min-width: 700px; text-align: center; }
.tbl01 th { padding: 12px 0; border-top: 1px solid #bbb; font-size: 17px; font-weight: 500; background: #f1f1f1; }
.tbl01 td { padding: 14px 0; border-bottom: 1px solid #ddd; font-size: 16px; line-height: 20px; color: #444; }
.tbl01 td a { color: #444; font-weight: 400 }
.tbl01.thover tbody tr:hover { background: #fcfcfc; }

.tbl02 { width: 100%; min-width: 700px; text-align: center; }
.tbl02 th { padding-bottom: 16px; border-bottom: 2px solid #333; font-size: 17px; font-weight: 600; }
.tbl02 td { padding: 16px 5px; border-bottom: 1px solid #ddd; font-size: 16px; line-height: 20px; color: #444; }
.tbl02 td a { color: #444; }
.tbl02.thover tbody tr:hover { background: #fafafa; }

.tbl03 { width: 100%;  min-width: 700px; text-align: center; }
.tbl03 thead th { background: #687280; color: #fff; font-weight: 600; padding: 14px 12px; text-align: center; border-bottom: 1px solid #ddd; }
.tbl03 tbody td { padding: 13px 12px; border-bottom: 1px solid #e5e5e5; color: #555; text-align: center; }
.tbl03 td a { color: #555; }
.tbl03.thover tbody tr:hover { background: #fafafa; }

.tbl04 { width: 100%; border-collapse: collapse; font-size: 16px; }
.tbl04 { min-width: 700px; }
.tbl04 th,
.tbl04 td { border: 1px solid #ddd; padding: 12px 10px; color: #444; }
.tbl01 td a { color: #444; }
.tbl04 thead th { background: #f1f1f1; font-weight: 600; color: #333; text-align: center; }
.tbl04 tbody td { color: #444; background: #fff; text-align: center; }
.tbl04.thover tbody tr:hover td { background: #f8f8f8; }

/* 팝업 전용 테이블 */
.tbl_popup { width: 100%; border-collapse: collapse; font-size: 15px; background: #fff; overflow: hidden; font-size: 16px; }
.tbl_popup thead th { background: #f5f5f7; color: #333; font-weight: 600; padding: 10px 16px; text-align: left; border-bottom: 1px solid #e2e2e2; }
.tbl_popup tbody td { padding: 10px 16px; color: #444; border-bottom: 1px solid #e8e8e8; vertical-align: middle; }
.tbl_popup tbody td { color: #444; }
.tbl_popup tbody tr:last-child td { border-bottom: none; }
.tbl_popup tbody td:first-child { color: #555; background: #fafafa; font-weight: 500; border-right: 1px solid #e8e8e8; }
.tbl_popup.thover tbody tr:hover td:last-of-type { background: #fcfcfc; }

/* paging */
.wh_box + .paging { margin-top: 20px; }
.paging { text-align: center; }
.paging .num { display: flex; gap: 10px; align-items: center; }
.paging a { float: left; color: #777; font-size: 15px; line-height: 32px; }
.paging a i { line-height: 30px; }
.paging span.num > a { font-size: 16px; }
.paging .num > .num { gap: 4px; }
.paging .num > .pageNoClass,
.paging .num > .num a { padding: 0 13px; }
.paging a:hover,
.paging strong:hover,
.paging span.num > a:hover { color: #111; text-decoration: underline; }
.paging span.num > a.on { color: #3958a4; background: #ebedf2; font-weight: 500; border-radius: 8px; }
.paging .first:hover,
.paging .last:hover,
.paging .pre:hover,
.paging .next:hover { color: #7c5df5; }
.paging .disable,
.paging .disable:hover { opacity: .5; }

/* tab */
.tab_wrap { display: flex; justify-content: center; }
.tab01 { display: flex; border-radius: 5px; overflow: hidden; }
.tab01 li { flex: 1; }
.tab01 li button { width: 100%; padding: 12px 0; font-size: 20px; font-weight: 500; border: none; background: #e2e3e6; color: #777; border-right: 1px solid #cccccc; }
.tab01 li:last-of-type button { border-right: none; }
.tab01 li button:hover { background: #d1d4dd; color: #444; }
.tab01 li.on button { background: #75819f; color: #fff; font-weight: 600; }

.tab02 { border-bottom: 1px solid #ddd; margin-bottom: 16px; }
.tab02 ul { display: flex; gap: 14px; align-items: center; }
.tab02 li { position: relative; padding: 10px 14px; }
.tab02 li a { font-size: 19px; font-weight: 500; color: #777; }
.tab02 li:hover a { color: #666; font-weight: 600; }
.tab02 li.on a { color: #333; font-weight: 600; }
.tab02 li.on::after { content: ""; position: absolute; bottom: 0; left: 0; width: 100%; height: 3px; font-weight: 600; background: #577097; }

.tab03 { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.tab03 li a { padding: 6px 12px; color: #888; border-radius: 16px; font-weight: 500; cursor: pointer; }
.tab03 li a:hover { background: #f3f3f3; }
.tab03 li.on a { background: #eaeaea; color: #666; font-weight: 600; }

.tab04 { display: inline-flex; background: #e6e6e6; border-radius: 8px; padding: 2px; }
.tab04 button { padding: 8px 20px; background: transparent; border: none; font-size: 16px; color: #666; cursor: pointer; }
.tab04 button.on { background: #fff !important; color: #555; font-weight: 600; box-shadow: 0 0 3px rgba(0,0,0,0.08); border-radius: 5px; }
.tab04 button:hover { background: #ddd; }

/* btn */
.button_area { display: flex; margin-top: 20px; align-items: center; justify-content: center; gap: 10px; }

.btn { display: inline-block; border-radius: 5px; color: #fff; background: #6478af; align-content: center; }
.line.btn:hover { opacity: 0.7; }
.btn:hover { opacity: 0.8; }
.btn.sm { height: 34px; padding: 0 12px; color: #fff; font-size: 15px; font-weight: 500; }
.btn.mid { height: 40px; padding: 0 15px; font-size: 17px; font-weight: 500; border-radius: 6px; }
.btn.lg { height: 47px; padding: 0 26px; font-size: 18px; font-weight: 500; border-radius: 7px; }
.btn.disable { color: #999; background: #f0f0f0; cursor: default; opacity: 1 !important; }

.line.btn { background: #fff; color: #555; border: 1px solid #a6a6a6; }
.line.btn.blue { background: #fff; color: #3455a6; border: 1px solid #8091c0; }
.line.btn.red { border: 1px solid #c27b7b; background: #fff; color: #992a2a; }

.btn.blue { color: #fff; background: #6c7fb1; }
.btn.navy { color: #fff; background: #4f5789; }
/* .btn.mcolor { color: #fff; background: #6478af; } */
.btn.scolor { background: #bb6b6b; color: #fff; }

.btn.dgrey { background: #676767; color: #fff; }
.btn.grey { background: #8c8c8c; color:#fff; }
.btn.lgrey { background: #aaa; color: #fff; }

.btn_icon, .btn_link { opacity: 0.9; }
.btn_icon:hover, .btn_link:hover { opacity: 0.9; font-weight: 500; }
.btn_icon { color: #555; font-size: 16px; }
.btn_icon i { margin-left: 6px; color: #999; }

.btn_link { color: #555; text-decoration: underline; font-size: 16px; }
.btn_link i { margin-left: 6px; color: #777; font-size: 15px; }
.btn_link:hover, .btn_link:hover i { color: #1c69a7; }

.tag_btn_wrap { display: flex; gap: 12px; flex-wrap: wrap; }
.tag_btn { display: inline-block; padding: 6px 14px; background: #eaeaea; border-radius: 30px; cursor: pointer; color: #555; font-weight: 500; }
.tag_btn i { margin-left: 6px; color: #777; font-size: 15px; }
.tag_btn:hover { background: #e2e2e2; }


/* 로그인, 아이디 비밀번호 찾기 */
#container.noside_cont { height: calc(100dvh - 77px); overflow-y: auto; left: 0; }
#container .login logo { text-align: center; margin-bottom: 24px; }
#container .login logo a{ color: #333; }

.member_wrap { display: flex; justify-content: center; align-items: center; }
.member_wrap .wh_box { width: 540px; padding: 30px; }
.member_wrap h2 { margin-bottom: 26px; color: #333; font-size: 22px; }
.check_tab { display: flex; width: 100%; margin-bottom: 26px; }
.check_tab li { padding: 13px 0; flex: 1; text-align: center; color: #a9a9a9; font-size: 17px; background: #f5f5f5; border: 1px solid #ddd; transition: .2s; }
.check_tab li:hover { cursor: pointer; }
.check_tab li.on { font-weight: 500; }
.check_tab li:last-of-type { border-radius: 0 8px 8px 0; }
.check_tab li:first-of-type { border-radius: 8px 0 0 8px; }

.member_wrap.contents section { display: flex; flex-direction: column; padding: 0 30px; }
.login .wh_box { padding: 40px 60px 50px; }
.login strong { display: inline-block; margin-bottom: 20px; color: #333; font-size: 20px; font-weight: 600; }
.login input[type="text"],
.login input[type="password"] { height: 50px; padding: 0 16px; font-size: 17px; }
.login .pass_input { width: 100%; margin-top: 12px; } 

.pass_input { position: relative; border-radius: 8px; }
.pass_input input { padding: 0 50px 0 16px; }
.pass_input .icon_view i { position: absolute; right: 16px; top: 50%; transform: translateY(-50%); color: #999; vertical-align: middle; font-size: 17px; cursor: pointer; }
.pass_input .icon_view i.fa-eye-slash { color: #b4b4b4; }
.login .check_area { display: flex; justify-content: space-between; align-items: center; margin-top: 20px; color: #777; font-size: 17px; }
.login .check_area label { margin-bottom: 0; }
.login .check_area a { color: #666; }
.login .check_area a:hover { color: #555; font-weight: 500; }
.login button { width: 100%; margin-top: 24px; padding: 16px 0; border-radius: 8px; font-size: 20px; font-weight: 500; }
.login .join_area { display: flex; justify-content: center; gap: 10px; margin-top: 40px; color: #666; font-size: 19px; }
.login .join_area a { color: #333; font-weight: 500; border-bottom: 1px solid #333; }
.login .join_area a:hover { font-weight: 600; }


/* 회원가입 */
.member_wrap .input_group { display: flex; flex-direction: column; margin-bottom: 18px; }
.member_wrap .input_group:last-of-type { margin-bottom: 0; }
.member_wrap input[type="text"],
.member_wrap input[type="password"] { width: 100%; }
.member_wrap input::placeholder { color: #999; }
.member_wrap label { margin-bottom: 10px; color: #777; font-size: 17px; font-weight: 500; }
.member_wrap .form_btnarea { width: 100%; margin-top: 30px; display: flex; gap: 14px; }
.member_wrap .form_btnarea a,
.member_wrap .form_btnarea button { flex: 1; text-align: center; }
.member_wrap .id_check { display: flex; gap: 10px; }
.member_wrap .id_check > div { flex: 1; }
.member_wrap .id_check button { white-space: nowrap; }
.member_wrap .alert_error { color: #d05050; font-size: 16px; margin-top: 10px; }
.member_wrap .point { margin-top: 4px; color: #d06969; font-size: 16px; }
.member_wrap .email input[type="text"] { width: calc(50% - 15px); }
.member_wrap .email select { width: 100%; }
.member_wrap .email > div { width: 100%; }
.member_wrap .personal_info_box { margin-bottom: 20px; }
.member_wrap .personal_info_box:last-of-type { margin-bottom: 0; }
.member_wrap .agree_box { width: 100%; max-height: 220px; padding: 12px; border: 1px solid #ddd; border-radius: 6px; font-size: 16px; line-height: 22px; color: #555; overflow: auto; }
.member_wrap .agree_checkarea { text-align: right; font-size: 18px; }
.member_wrap .agree_checkarea label { margin-bottom: 0; color: #555; }
.member_wrap .join_finish { display: flex; flex-direction: column; align-items: center; padding-top: 20px; }
.member_wrap .join_finish span { display: flex; justify-content: center; align-items: center; width: 54px; height: 54px; border: 1px solid #ddd; border-radius: 100%; }
.member_wrap .join_finish span i { color: #6c7fb1; font-size: 29px; }
.member_wrap .join_finish b { margin-top: 20px; color: #555; font-size: 20px; }
.member_wrap .join_finish p { margin: 6px 0 20px; color: #777; font-size: 17px; }
.email span { margin: 0 3px; color: #555; }
.email { display: flex; flex-wrap: wrap; gap: 8px; }


/* 공지사항 */
table .fa-file i { color: #777; }
table .fa-bullhorn { color: #cd5454; }
table .fa-bullhorn + span { display: none; }
.bbs_cate { padding: 8px 12px; color: #4e5681; font-size: 16px; font-weight: 600; border-radius: 30px; white-space: nowrap; transition: none; }

.board_view .wh_box { margin-bottom: 20px; }
.board_view .fa-bullhorn { color: #cd5454 }
.board_view h3 { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; padding-bottom: 16px; margin-bottom: 16px; border-bottom: 1px solid #d3d4d5; color: #333; font-size: 19px; }
.board_view dl { display:flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.board_view dl dt { color: #666; font-size: 17px; font-weight: 500; }
.board_view dl dt::after { content: ''; display: inline-block; width: 1px; height: 10px; margin-left: 10px; background: #ccc; }
.board_view dl dd { font-size: 16px; color: #555;}
.board_view_head dl dd::after { content: ''; display: inline-block; width: 3px; height: 3px; margin: 0 0 4px 10px; border-radius: 2px; background: #b4b6b7; }
.board_view_head dl dd:last-of-type::after { display: none; }
.board_view_head { padding: 20px; background: #f4f6f8; border-radius: 8px; }
.board_view_head .board_cate { display: inline-block; padding: 10px 12px; color: #45537c; background: #dce1eb; font-size: 15px; font-weight: 600; border-radius: 30px; white-space: nowrap; }
.board_content { min-height: 400px; padding: 20px; color: #444; font-size: 16px; line-height: 1.6; }
.board_content img { max-width: 100%; }

.file_detail { padding: 16px 0 6px; border-top: 1px solid #ddd; }
.file_detail dt { padding-left: 12px; }
.file_detail p { line-height: 28px; }
.file_detail a { color: #464e8f; font-size: 16px; font-weight: 500; }
.file_detail a:hover { text-decoration: underline; }
.file_detail .fa-paperclip { color: #999; margin-right: 4px; }


/* 회원수정 */
.member_update dl { display: flex; margin-bottom: 16px; }
.member_update dl:last-of-type { margin-bottom: 0; }
.member_update dl dt { display: flex; align-items: center; }
.member_update label { width: 200px; color: #555; font-size: 17px; font-weight: 500; cursor: auto; }
.member_update input { width: 300px; }
.member_update select { padding: 0 78px 0 14px; }
.member_update .email input { width: 180px; }
/* .member_update i { margin-right: 6px; color: #c26767; vertical-align: text-bottom; }
.member_update p { margin-top: 8px; color: #c54646; } */




/* Tablet */
@media screen and (max-width: 1023px){
	
	/*  사이드메뉴 */
	.btn_hide { display: none; }
	.ico_bar { display: block; }
	#snb { width: 0; }
	#snb.open { display: block; width: 100%; }
	#gnb nav { padding-top: 10px; }
	
	/* 레이아웃 */
	#container { left: 0; }
	
	/* 헤더*/
	.list_util { top: 34px; right: -20px; width: 130px; }
	.list_util a { line-height: 46px; padding: 0 20px; }
	.member_info .fa-angle-down { display: none; }
	.user_box .user > a > span { display: none; }
	
	/* 기본 탑메뉴 */
	.menu_list { display: none; }
	.menu_title { position: relative; display: block; padding: 16px 30px; }
	.menu_title::after { content: "\f078"; font-family: "FontAwesome"; position: absolute; right: 30px; top: 50%; transform: translateY(-50%); font-size: 16px; transition: transform 0.3s ease; color: #666; }
	.smenu_title { padding: 4px 34px; }

	.submenu_wrap.open { transform: scaleY(1); opacity: 1; }
	.submenu_wrap { height: 100dvh; padding: 10px 0; }
	.submenu_wrap > div { width: 100%; flex-direction: column; justify-content: flex-start; }
	.submenu_column { width: 100%; background: #f2f2f2; height: 0; transition: height .25s ease; overflow: hidden; }
	.menu_box.open .submenu_column { height: auto; }

	.menu_box { flex: unset; text-align: left; }
	.menu_box.open .menu_title::after { transform: translateY(-50%) rotate(180deg); }

}
/* Tablet */
@media screen and (max-width: 839px){
	
	h1 { font-size: 19px; }
	h2 { font-size: 17px; }
	h3 { font-size: 16px; }
	
	.wh_box { padding: 20px; }
	.wh_box.column01, .wh_box.column02 > div { padding: 16px 20px 20px; }

	.h_wrap { height: 64px; }
	.h_wrap,
	.wrapper,
	.h_link { padding: 0 24px; }
	
	.grey_box { padding: 18px; }
	
	.guide { font-size: 14px; }
	
	.tit_wrap { flex-direction: column; align-items: flex-start; margin-bottom: 14px; }
	.stit_wrap { margin-bottom: 10px; }
	.stit_wrap > em { font-size: 14px; }
	.stit_wrap > em b { font-size: 16px; }
	
	/* 버튼 */
	.btn.sm { height: 29px; padding: 0 9px; font-size: 15px; }
	.btn.mid { height: 34px; padding: 0 13px; font-size: 15px; border-radius: 5px; }
	.btn.lg { height: 40px; padding: 0 20px; font-size: 16px; border-radius: 6px; }
	.btn.link i { font-size: 14px; }
	
	/* 페이징 */
	.paging { margin-top: 14px; }
	.paging a { line-height: 28px; }
	.paging span.num > a { font-size: 14px; }
	.paging span.num > a.on { border-radius: 5px; }
	.paging .num > .num { gap: 2px; }
	.paging .num > .pageNoClass,
	.paging .num > .num a { padding: 0 10px; }
	.paging a i { line-height: 25px; }
	
	/* 테이블 */
	.tbl01 th { padding: 10px 0; }
	.tbl01 td { padding: 12px 0; }
	.tbl02 th { padding-bottom: 12px; }
	.tbl02 td { padding: 8px 3px; }
	.tbl01 th, .tbl02 th, .tbl03 th, .tbl04 th { font-size: 16px; }
	.tbl01 td, .tbl02 td, .tbl03 td, .tbl04 td { font-size: 15px; }
	.tbl_popup { font-size: 15px; }
	
	/* 탭 */
	.tab01 li button { font-size: 18px; }
    .tab02 { margin-bottom: 12px; }
    .tab02 li { padding: 8px 12px; }
    .tab02 li a { font-size: 17px; }
	.tab03 { gap: 6px; margin-bottom: 10px; }
	.tab03 li a { font-size: 16px; }
	
	/* 헤더 */
	.header_left { gap: 12px; }
	#header { padding: 20px 24px; }
	logo a img, #logo a img { height: 32px; }
	logo a, #logo a { font-size: 17px; }
	.member_info { font-size: 16px; }
	.ico_bar { margin-top: 2px; }
	.ico_bar span { width: 18px; height: 3px; margin-bottom: 3px; }
	
	/* 기본 탑메뉴 */
	.menu_title { padding: 14px 24px; }
	.menu_title::after { right: 24px; }
	.smenu_title { padding: 2px 28px; }
	
	/* 사이드메뉴 */
    #snb { margin-top: 62px; }
    #gnb nav ul li a { padding-left: 20px; font-size: 17px; line-height: 42px; }
    #gnb nav ul li .sidemenu li a { padding-left: 26px; font-size: 17px; line-height: 40px; }
    #gnb nav ul .fa-angle-down { right: 20px; }
    
    /* 검색 */
	.search_input { max-width: 100%; }
	
	/* 레이아웃 */
	#container { margin-top: 54px; height: calc(100dvh - 54px) !important; }
	#container .contents { min-height: calc(100dvh - 105px); padding: 30px 0 40px; }
	
	/* 회원수정 */
	.member_update .email > div { width: 100%; }
	.member_update .email input { min-width: auto; width: calc(50% - 15px); }
	.member_update dd,
	.member_update #memberEmail,
	.member_update input,
	.member_update select { width: 100%; }
	.member_update label { width: 140px; }
	.member_update label:first-of-type { margin-top: 0; }
	
	/* 공지사항 */
	.search_select { flex-direction: column; width: 100%; }
	.search_select input { flex: 1; }
	.board_list.notice .stit_wrap { flex-direction: column; align-items: flex-start; margin-top: 10px; }
	.board_list td span { padding: 5px 12px; }
	.board_view h3 { padding-bottom: 12px; margin-bottom: 12px; font-size: 16px; }
	.board_view dl dt, 
	.board_view dl dd, 
	.file_detail a { font-size: 15px; }
	.board_view_head { padding: 16px; }
    .board_view_head .board_cate { padding: 8px 10px; font-size: 14px; }
    .board_view dl { gap: 6px; }
    .board_view dl dt::after { margin-left: 6px; }
    .board_content { padding: 10px; font-size: 15px; }
    .file_detail dt { padding-left: 0; }
	
	/* 팝업 */
	.pop_head > span,
	.pop_head .popup_close i { font-size: 18px; }
	.pop_body .pop_alert p { font-size: 17px; line-height: 22px; }
	.pop_body { padding: 14px 16px; }
	.pop_body dl { flex-direction: column; }
	.pop_body dt { margin-top: 0; margin-bottom: 8px; }
	.pop_body label { font-size: 16px; }
	.pop_footer { margin-top: 16px; }
	

}

/* small Tablet */
@media screen and (max-width: 768px){
	
	/* 회원가입 */
	.member_wrap label { font-size: 16px; }
	.member_wrap h2 { margin-bottom: 16px; font-size: 19px; }
	.member_wrap .agree_box { font-size: 15px; }
	
	/* 회원수정 */
	.member_update dl { flex-direction: column; gap: 8px; }

	/* 로그인 */
	.member_wrap .wh_box,
	.member_wrap form { width: 100%; } 
	.login .wh_box { padding: 30px 36px; }
	.login .wh_box span { margin-bottom: 14px; font-size: 17px; }
	.login input_group { height: 40px; padding: 0 14px; font-size: 15px; }
	#container.login logo { margin-bottom: 18px; }
	.check_area { margin-top: 14px; font-size: 14px; }
	
	
	

}

/* Mobile */
@media screen and (max-width: 480px){
    	
	.wh_box { padding: 16px; }
	
	.pass_input input { padding: 0 40px 0 12px; }
	
	/* 사이드메뉴 */
	#snb { margin-top: 50px; }
	
	/* 헤더 */
	#header { padding: 14px 20px; }
	.list_util { top: 30px; width: 120px; font-size: 15px; }
	.list_util a { line-height: 40px; padding: 0 16px; font-size: 15px; }
	
	/* 기본 탑메뉴 */
	.menu_title { padding: 12px 20px; font-size: 17px; }
	.smenu_title { padding: 1px 24px; font-size: 16px; }
	.menu_title::after { right: 20px; font-size: 13px; }
	
	/* 푸터 */
	.simple.footer { padding: 12px 0; }
    .simple.footer p { font-size: 12px; line-height: 16px; }

    /* 래아어윳 */
    .tit_wrap,
    .stit_wrap { margin-bottom: 16px; }
    #container { margin-top: 48px; height: calc(100dvh - 48px) !important; }
    #container .contents { padding: 20px 0 30px; }
	
	/* 로그인 */
	.login strong { margin-bottom: 12px; font-size: 17px; }
	#container.login { height: calc(100dvh - 221px); }
	.login .wh_box { padding: 26px 30px; }
	.login .wh_box span { margin-bottom: 12px; font-size: 16px; }
    .login button { margin-top: 16px; padding: 12px 0; font-size: 17px; }
    .login input[type="text"],
    .login input[type="password"] { height: 40px; padding: 0 12px; font-size: 15px; }
    .login .pass_input { margin-top: 10px; }
    .login input { font-size: 16px; }
    .login .check_area { margin-top: 14px; font-size: 15px; }
    .login .join_area { margin-top: 30px; font-size: 17px; }
    .pass_input .icon_view i { right: 14px; font-size: 15px; }
    
    /* 회원가입 */
    .member_wrap.contents section  { padding: 0 20px; }
    .member_wrap label { font-size: 15px; }
    .member_wrap .wh_box { padding: 20px; }
	.member_wrap .point { margin-top: 2px; font-size: 15px; }
	.member_wrap .input_group { margin-bottom: 12px; }
	.email span { font-size: 15px; }
	.member_wrap .form_btnarea { margin-top: 20px; gap: 8px; }
	.member_wrap .join_finish b { margin-top: 16px; color: #555; font-size: 17px; }
	.member_wrap .join_finish p { margin: 6px 0 10px; font-size: 16px;}
	.member_wrap .join_finish span { width: 48px; height: 48px; }
	.member_wrap .join_finish span i { font-size: 24px; }
	.member_wrap .alert_error { font-size: 14px; }
	
	/* 아이디 비밀번호 찾기 */
	.check_tab li { padding: 10px 0; font-size: 16px; }

	/* 회원수정 */
    .member_update input { min-width: 100%; }
    .member_update label { font-size: 15px; }
    
}