@charset "utf-8";

.dark-mode #wrapper { background:#333; }
body.dark-mode #wrapper h1, h2 , h3, p { color:#fff; }
body.dark-mode p,
body.dark-mode h1,
body.dark-mode h2,
body.dark-mode h3,
body.dark-mode a { color:#fff; }
body.dark-mode button {
    background-color:#c71526;
    color:#fff;
}
body.light-mode h1, h2, h3, p, a { color:#333; }
body.light-mode button {
    background-color:#c71526;
    color:#eee
}
button { background:#c71526; }
#darkLight {
    width:70px; height:90px; 
    font-size:3em;
    padding-left:0.5%;
    position:fixed;
    right:0; bottom:3%;
    border-radius:100px 0 0 100px;
    transition:all .3s;
    z-index:99999;
}
#darkLight:hover {
    width:130px;
    padding-left:1%;
    background-color:#111;
}
/* 초기화 */
html {overflow-y:scroll}
body {margin:0;padding:0;font-size:0.75em;font-family: 'Noto Sans KR', sans-serif;background:#e7e7e7}
html, h1, h2, h3, h4, h5, h6, form, fieldset, img {margin:0;padding:0;border:0}
h1, h2, h3, h4, h5, h6 {font-size:1em;font-family: 'Noto Sans KR', sans-serif;}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {display:block}
ul, dl,dt,dd {margin:0;padding:0;list-style:none}
legend {position:absolute;margin:0;padding:0;font-size:0;line-height:0;text-indent:-9999em;overflow:hidden}
label, input, button, select, img {vertical-align:middle;font-size:1em}
input, button {margin:0;padding:0;font-family:'Noto Sans KR', sans-serif;font-size:1em}
input[type="submit"]{cursor:pointer}
button {cursor:pointer}
textarea, select {font-family:'Noto Sans KR', sans-serif;font-size:1em}
select {margin:0}
p {margin:0;padding:0;word-break:keep-all}
hr {display:none}
pre {overflow-x:scroll;font-size:1.1em}
a {color:#000;text-decoration:none}
*, :after, :before {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}
input[type=text],input[type=password], textarea {
-webkit-transition: all 0.30s ease-in-out;
-moz-transition: all 0.30s ease-in-out;
-ms-transition: all 0.30s ease-in-out;
-o-transition: all 0.30s ease-in-out;
outline: none;
}
/*
input[type=text]:focus,input[type=password]:focus,  textarea:focus,select:focus {
-webkit-box-shadow:  0 0 5px #9ed4ff;
box-shadow: 0 0 5px #9ed4ff;
border: 1px solid #558ab7 !important;
}
*/
.placeholdersjs { color: #aaa !important; }

/* 레이아웃 크기 지정 */
#hd, #wrapper, #ft{/*min-width:1200px*/}

#hd_pop,
#hd_wrapper,
#tnb ul,
#gnb .gnb_wrap,
#container_wr,
#ft_wr{width:1200px}

/* 팝업레이어 */
#hd_pop {z-index:1000;position:relative;margin:0 auto;height:0}
#hd_pop h2 {position:absolute;font-size:0;line-height:0;overflow:hidden}
.hd_pops {position:absolute;border:1px solid #e9e9e9;background:#fff;}
.hd_pops img{max-width:100%;width: 100%;}
.hd_pops_con {}
.hd_pops_footer {padding: 0;background:#000;color:#fff;text-align:left;position:relative;}
.hd_pops_footer:after {display:block;visibility:hidden;clear:both;content:""}
.hd_pops_footer button {padding: 10px;border:0;color:#fff}
.hd_pops_footer .hd_pops_reject{background:#000;text-align:left}
.hd_pops_footer .hd_pops_close{background:#393939;position:absolute;top:0;right:0}
#hd_pops_3{
    top: 80px !important;
    left: 50% !important;
    transform: translateX(-50%);
}
.mo-img{display: none;}
.pc-img{display: block;}
@media screen and (max-width: 768px) {
    .hd_pops {position:absolute;border:1px solid #e9e9e9;background:#fff;width: 95%;left: 0!important;top: 50px!important}
    .hd_pops_con {width: auto!important;height: auto!important}
    .hd_pops_con img {width: 100%;height: auto}
    .pc-img{display: none;}
    .mo-img{display: block;}
    .hd_pops_footer .hd_pops_close{
        height: 100%;
    }
    }

/* 상단 레이아웃 */
#hd {border-top:2px solid #d13f4a}
#hd_h1 {position:absolute;font-size:0;line-height:0;overflow:hidden}

#hd_wrapper {position:relative;margin:0 auto;padding:10px 0;height:115px;zoom:1}
#hd_wrapper:after {display:block;visibility:hidden;clear:both;content:""}

#logo {float:left;padding:30px 0 0}

.hd_sch_wr{position:absolute;top:25px;left:50%;width:430px;margin-left:-215px;}
#hd_sch h3 {position:absolute;font-size:0;line-height:0;overflow:hidden}
#hd_sch{border:2px solid #556ada;background:#fff;border-radius:5px;overflow:hidden}
#hd_sch #sch_stx {padding-left:10px;height:40px;width:376px;border:0;border-right:0;float:left;font-size:1.25em}
#hd_sch #sch_submit {height:40px;border:0;background:#fff;color:#d13f4a;width:50px;float:left;cursor:pointer;font-size:18px}

#sbn_side{position:absolute;top:20px;right:0}

#tnb {border-bottom:1px solid #ddd;background:#fff}
#tnb h3 {position:absolute;font-size:0;line-height:0;overflow:hidden}
#tnb ul {margin:0 auto;zoom:1}
#tnb ul:after {display:block;visibility:hidden;clear:both;content:""}
#tnb li {float:right;border-left:1px solid #ddd;margin-bottom:-1px;font-size:0.92em}
#tnb a {display:inline-block;padding:0 10px;color:#646464;line-height:35px}
#tnb a:focus, #tnb a:hover {color:#d13f4a;background:#fafafa}
#tnb .tnb_admin a{color:#ff0000;}
#tnb .tnb_left{float:left}
#tnb .tnb_left a{padding:0 14px}
#tnb .tnb_cart{border-right:1px solid #ddd;}
#tnb .tnb_community{border-right:1px solid #ddd}
#tnb .tnb_community i{font-size:15px}
#tnb .tnb_community{background:#e7e7e7;font-weight:bold;}
#tnb .tnb_community:focus, #tnb .tnb_community:hover {color:#333;border-bottom:0}
#tnb .tnb_community a{color:#d13f4a;border-bottom:1px solid #e7e7e7}

#hd_qnb{float:right;margin-top:20px}
#hd_qnb:after {display:block;visibility:hidden;clear:both;content:""}
#hd_qnb li{float:left;font-size:1.083em;line-height:15px;position:relative;text-align:center;margin:0 10px}
#hd_qnb li span {display:block;margin-top:5px;font-size:0.92em}
#hd_qnb li a{display:block}
#hd_qnb li i{display:inline-block;width:40px;line-height:40px;border-radius:25px;background:#fff;text-align:center;margin:0;color:#fff}
#hd_qnb .visit .visit-num{display:inline-block;line-height:18px;padding:0 5px;border-radius:10px;background:#f04e00;color:#fff;font-size:10px;position:absolute;top:0;right:0}
#hd_qnb li .fa-question{background:#e83a5f;font-size:20px}
#hd_qnb li .fa-question:hover{background:#e41b45}
#hd_qnb li .fa-comments{background:#82c13f;font-size:16px}
#hd_qnb li .fa-comments:hover{background:#5aa708}
#hd_qnb li .fa-users{background:#f0ba00;font-size:15px}
#hd_qnb li .fa-users:hover{background:#f06f00}
#hd_qnb li .fa-history{background:#8522c4;font-size:15px}
#hd_qnb li .fa-history:hover{background:#6700a9}

/* 메인메뉴 */
#gnb{position:relative}
#gnb h2{position:absolute;font-size:0;line-height:0;overflow:hidden}
#gnb .gnb_wrap{margin:0 auto;position:relative}
#gnb #gnb_1dul {font-size:1.083em;padding: 0;background:#d13f4a;zoom:1;
-webkit-box-shadow: 0 1px 3px rgba(0,0,0,0.3);
box-shadow: 0 1px 3px rgba(0,0,0,0.3)}
#gnb ul:after {display:block;visibility:hidden;clear:both;content:""}
#gnb .gnb_1dli{float:left;line-height:50px;padding:0 15px;position:relative;}
#gnb .gnb_1dli:hover{background:#1a30a7;
-webkit-transition: background-color 2s ease-out;
-webkit-transition: background-color 0.3s ease-out;
transition: background-color 0.3s ease-out;}

.gnb_1dli .bg{display:inline-block;width:10px;height:10px;overflow:hidden;background:url(../img/gnb_bg2.gif) no-repeat 50% 50%;text-indent:-999px}
.gnb_1da {display:inline-block;font-weight:bold;color:#fff;text-decoration:none;}
.gnb_2dli{border-top:1px solid #d13f4a}
.gnb_2dli:first-child{border:0}
.gnb_2dul {display:none;position:absolute;top:50px;min-width:140px;background:#1a30a7;padding: 0;
-webkit-box-shadow: 0 1px 5px rgba(0,0,0,0.1);
box-shadow: 0 1px 5px rgba(0,0,0,0.1);}
.gnb_2da {display:block;padding:0 10px;line-height:40px;color:#c3cbf7;text-align:left;text-decoration:none}
a.gnb_2da:hover{background:#0e2080;
-webkit-transition: all 0.3s ease-out;
transition: all 0.3s ease-out;}

.gnb_1dli_air .gnb_2da {}
.gnb_1dli_on .gnb_2da {}
.gnb_2da:focus, .gnb_2da:hover {color:#fff}
.gnb_1dli_over .gnb_2dul {display:block;left:0}
.gnb_1dli_over2 .gnb_2dul {display:block;right:0}
.gnb_wrap .gnb_empty {padding:10px 0;width:100%;text-align:center;line-height:2em;color:#fff}
.gnb_wrap .gnb_empty a{color:#fff;text-decoration:underline}
.gnb_wrap .gnb_al_ul .gnb_empty, .gnb_wrap .gnb_al_ul .gnb_empty a{color:#555}

#gnb .gnb_menu_btn{background:#4158d1;color:#fff;width:50px;height:50px;border:0;vertical-align:top;font-size:18px}
#gnb .gnb_close_btn{background:#4158d1;color:#fff;width:50px;height:50px;border:0;vertical-align:top;font-size:18px;position:absolute;top:-50px;left:0}
#gnb .gnb_mnal{padding:0}

#gnb_all{display:none;position:absolute;width:100%;z-index:99;}
#gnb_all .gnb_al_ul:after {display:block;visibility:hidden;clear:both;content:""}
#gnb_all .gnb_al_ul{background:#fff;border:1px solid #4158d1;padding:20px;
-webkit-box-shadow: 0 2px 5px rgba(0,0,0,0.2);
box-shadow: 0 2px 5px rgba(0,0,0,0.2);}
#gnb_all .gnb_al_li{background:#fff;float:left;min-width:20%;padding:5px }
#gnb_all .gnb_al_li .gnb_al_a{font-size:1.083em;padding:10px;display:block;position:relative;margin-bottom:10px;background: #eff1f9;border-bottom: 1px solid #dee2f1;font-weight: bold;color:#243071}
#gnb_all .gnb_al_li li {padding-left:10px;line-height:2em}
#gnb_all .gnb_al_li li i{color:#9ca6cc}
#gnb_all .gnb_al_li li a{color:#555}

/* 중간 레이아웃 */
#wrapper{}
#container_wr:after {display:block;visibility:hidden;clear:both;content:""}
#container_wr {z-index:5;margin:0 auto;height:100%;zoom:1}
#aside {float:right;width:305px;padding:0;background: #e7ebf3;height: 100%;border: 1px solid #adbfd2;margin:20px 0 20px 20px}

#container {z-index:4;position:relative;float:left;min-height:1600px;height:auto !important;margin:20px  0;height:500px;font-size:1em;width:875px;zoom:1}
#container:after {display:block;visibility:hidden;clear:both;content:""}
#container_title {font-size:1.333em;margin:0 auto;font-weight:bold;}
#container_title span{margin:0 auto 10px;display:block;line-height:30px;}
/*.latest_wr:after {display:block;visibility:hidden;clear:both;content:""}*/
.lt_wr{width:49%}
.lt_wr:nth-child(2n+1){clear:both}
.latest_wr:after {display:block;visibility:hidden;clear:both;content:""}
/* 하단 레이아웃 */
#ft {border-top:1px solid #d5d5d5;background:#fff;padding-bottom:30px;margin:0 auto;text-align:center}
#ft h1 {position:absolute;font-size:0;line-height:0;overflow:hidden}
#ft_wr {margin:0 auto;position:relative;}
#ft_link{padding:15px 0;border-bottom:1px solid #eee}
#ft_link a{display:inline-block;padding:0 8px;line-height:1.083em;font-weight:bold}
#ft_catch{margin:20px 0 10px}
#ft_copy{color:#555;font-size:0.92em}
#top_btn {position:fixed;bottom:20px;right:20px;width:50px;height:50px;line-height:46px;border:2px solid #333;color:#333;text-align:center;font-size:15px;z-index:90;background:rgba(255,255,255,0.5)}
#top_btn:hover{border-color:#3059c7;background:#3059c7;color:#fff}

/* 게시물 선택복사 선택이동 */
#copymove {}
#copymove  .win_desc {text-align:center;display:block}
#copymove  .tbl_wrap{margin:20px }
#copymove  .win_btn{padding:0 20px 20px}
.copymove_current {float:right;background:#ff3061;padding:5px;color:#fff;border-radius:3px}
.copymove_currentbg {background:#f4f4f4}

/* 화면낭독기 사용자용 */
#hd_login_msg {position:absolute;top:0;left:0;font-size:0;line-height:0;overflow:hidden}
.msg_sound_only, .sound_only {display:inline-block !important;position:absolute;top:0;left:0;margin:0 !important;padding:0 !important;font-size:0;line-height:0;border:0 !important;overflow:hidden !important}
/* 본문 바로가기 */
#skip_to_container a {z-index:100000;position:absolute;top:0;left:0;width:1px;height:1px;font-size:0;line-height:0;overflow:hidden}
#skip_to_container a:focus, #skip_to_container a:active {width:100%;height:75px;background:#21272e;color:#fff;font-size:2em;font-weight:bold;text-align:center;text-decoration:none;line-height:3.3em}

/* ie6 이미지 너비 지정 */
.img_fix {width:100%;height:auto}

/* 캡챠 자동등록(입력)방지 기본 -pc */
#captcha {display:inline-block;position:relative}
#captcha legend {position:absolute;margin:0;padding:0;font-size:0;line-height:0;text-indent:-9999em;overflow:hidden;}
#captcha #captcha_img {height:40px;border:1px solid #898989;vertical-align:top;padding:0;margin:0}
#captcha #captcha_mp3 {margin:0;padding:0;width:40px;height:40px;border:0;background:transparent;vertical-align:middle;overflow:hidden;cursor:pointer;background:url('../../../img/captcha2.png') no-repeat;text-indent:-999px;border-radius:3px}
#captcha #captcha_reload {margin:0;padding:0;width:40px;height:40px;border:0;background:transparent;vertical-align:middle;overflow:hidden;cursor:pointer;background:url('../../../img/captcha2.png') no-repeat  0 -40px;text-indent:-999px;border-radius:3px}
#captcha #captcha_key {margin:0 0 0 3px;padding:0 5px;width:90px;height:40px;border:1px solid #ccc;background:#fff;font-size:1.333em;font-weight:bold;text-align:center;border-radius:3px;vertical-align:top}
#captcha #captcha_info {display:block;margin:5px 0 0;font-size:0.95em;letter-spacing:-0.1em}

/* 캡챠 자동등록(입력)방지 기본 - mobile */
#captcha.m_captcha audio {display:block;margin:0 0 5px;width:187px}
#captcha.m_captcha #captcha_img {width:160px;height:60px;border:1px solid #e9e9e9;margin-bottom:3px;margin-top:5px;display:block;}
#captcha.m_captcha #captcha_reload {position:static;margin:0;padding:0;width:40px;height:40px;border:0;background:transparent;vertical-align:middle;overflow:hidden;cursor:pointer;background:url('../../../img/captcha2.png') no-repeat  0 -40px;text-indent:-999px}
#captcha.m_captcha #captcha_reload span{display:none;}
#captcha.m_captcha #captcha_key {margin:0;padding:0 5px;width:115px;height:29px;border:1px solid #b8c9c2;background:#f7f7f7;font-size:1.333em;font-weight:bold;text-align:center;line-height:29px;margin-left:3px}
#captcha.m_captcha #captcha_info {display:block;margin:5px 0 0;font-size:0.95em;letter-spacing:-0.1em}
#captcha.m_captcha #captcha_mp3 {width:31px;height:31px;background:url('../../../img/captcha2.png') no-repeat 0 0 ;  vertical-align:top;overflow:hidden;cursor:pointer;text-indent:-9999px;border:none}

/* ckeditor 단축키 */
.cke_sc {margin:0 0 5px;text-align:right}
.btn_cke_sc{display:inline-block;padding:0 10px;height:23px;border:1px solid #ccc;background:#fafafa;color:#000;text-decoration:none;line-height:1.9em;vertical-align:middle;cursor:pointer}
.cke_sc_def {margin:0 0 5px;padding:10px;border:1px solid #ccc;background:#f7f7f7;text-align:center}
.cke_sc_def dl{margin:0 0 5px;text-align:left;zoom:1}
.cke_sc_def dl:after {display:block;visibility:hidden;clear:both;content:""}
.cke_sc_def dt, .cke_sc_def dd {float:left;margin:0;padding:5px 0;border-bottom:1px solid #e9e9e9}
.cke_sc_def dt {width:20%;font-weight:bold}
.cke_sc_def dd {width:30%}

/* ckeditor 태그 기본값 */
#bo_v_con ul{display: block;list-style-type: disc;margin-top: 1em;margin-bottom: 1em;margin-left: 0;margin-right: 0;padding-left: 40px;}
#bo_v_con ol{display: block;list-style-type: decimal;margin-top: 1em;margin-bottom: 1em;margin-left: 0;margin-right: 0;padding-left: 40px;}
#bo_v_con li{display: list-item;}

/* 버튼 */
a.btn,.btn{line-height:35px;height:35px;padding:0 10px;text-align:center;font-weight:bold;border:0;
-webkit-transition: background-color 0.3s ease-out;
transition: background-color 0.3s ease-out;}

a.btn01 {display:inline-block;padding:7px;border:1px solid #ccc;background:#fafafa;color:#000;text-decoration:none;vertical-align:middle}
a.btn01:focus, a.btn01:hover {text-decoration:none}
button.btn01 {display:inline-block;margin:0;padding:7px;border:1px solid #ccc;background:#fafafa;color:#000;text-decoration:none}
a.btn02 {display:inline-block;padding:7px;border:1px solid #3b3c3f;background:#4b545e;color:#fff;text-decoration:none;vertical-align:middle;}
a.btn02:focus, .btn02:hover {text-decoration:none}
button.btn02 {display:inline-block;margin:0;padding:7px;border:1px solid #3b3c3f;background:#4b545e;color:#fff;text-decoration:none}

.btn_confirm {text-align:right} /* 서식단계 진행 */

.btn_submit {border:0;background:#d13f4a;color:#fff;cursor:pointer;border:0}
.btn_submit:hover {background:#0025eb}

a.btn_cancel {display:inline-block;background:#969696;color:#fff;text-decoration:none;vertical-align:middle;}
button.btn_cancel {display:inline-block;background:#969696;color:#fff;text-decoration:none;vertical-align:middle}
.btn_cancel:hover {background:#aaa;
}
a.btn_frmline, button.btn_frmline {display:inline-block;padding:0 5px;height:40px;border:0;background:#3c3c3c;border-radius:5px;color:#fff;text-decoration:none;vertical-align:top} /* 우편번호검색버튼 등 */
a.btn_frmline {}
button.btn_frmline {font-size:1em}

/* 게시판용 버튼 */
a.btn_b01,.btn_b01 {display:inline-block;background:#4c4f6f;color:#fff;text-decoration:none;vertical-align:middle}
.btn_b01:hover, .btn_b01:hover {background:#54598c}
a.btn_b02,.btn_b02 {display:inline-block;background:#d13f4a;padding:0 10px;color:#fff;text-decoration:none;border:0;vertical-align:middle;}
a.btn_b02:hover, .btn_b02:hover {background:#0025eb}
a.btn_b03, .btn_b03 {display:inline-block;background:#fff;border:1px solid #b9bdd3;color:#646982;text-decoration:none;vertical-align:middle}
a.btn_b03:hover, .btn_b03:hover {background:#ebedf6}
a.btn_b04, .btn_b04 {display:inline-block;background:#fff;border:1px solid #ccc;color:#707070;text-decoration:none;vertical-align:middle}
a.btn_b04:hover, .btn_b04:hover {color:#333;background:#f9f9f9}
a.btn_admin,.btn_admin {display:inline-block;background:#d13f4a;color:#fff;text-decoration:none;vertical-align:middle} /* 관리자 전용 버튼 */
.btn_admin:hover, a.btn_admin:hover {background:#ff3746}


/*컬러*/
.color_1 {background:#169dd6}
.color_2 {background:#14d53d}
.color_3 {background:#3814ff}
.color_4 {background:#7520c5}

/* 기본테이블 */
.tbl_wrap table {width:100%;border-collapse:collapse;border-spacing: 0 5px;border:1px solid #ccc;} 
.tbl_wrap caption {padding:10px 0;font-weight:bold;text-align:left}
.tbl_head01 {margin:0;}
.tbl_head01 caption {padding:0;font-size:0;line-height:0;overflow:hidden}
.tbl_head01 thead th {padding:10px 0;font-weight:normal;text-align:center;border-bottom:1px solid #ddd;background:#fafafa;height:40px}
.tbl_head01 thead th input {vertical-align:top; margin:10% 0; width:15px; height:15px; } /* middle 로 하면 게시판 읽기에서 목록 사용시 체크박스 라인 깨짐 */
.tbl_head01 tfoot th, .tbl_head01 tfoot td {padding:10px 0;border-top:1px solid #c1d1d5;border-bottom:1px solid #c1d1d5;background:#d7e0e2;text-align:center}
.tbl_head01 tbody th {padding:8px 0;border-bottom:1px solid #e8e8e8}
.tbl_head01 td {color:#666;background:#fff;padding:10px 5px;border-top:1px solid #ecf0f1;line-height:1.4em;height:70px;word-break:break-all}
.tbl_head01 tbody tr:hover td{background:#fafafa;}
.tbl_head01 a:hover {text-decoration:underline}
.tbl_head02 {margin:0 0 10px}
.tbl_head02 caption {padding:0;font-size:0;line-height:0;overflow:hidden}
.tbl_head02 thead th {padding:5px 0;border-top:1px solid #d1dee2;border-bottom:1px solid #d1dee2;background:#e5ecef;color:#383838;font-size:0.95em;text-align:center;letter-spacing:-0.1em}
.tbl_head02 thead a {color:#383838}
.tbl_head02 thead th input {vertical-align:top} /* middle 로 하면 게시판 읽기에서 목록 사용시 체크박스 라인 깨짐 */
.tbl_head02 tfoot th, .tbl_head02 tfoot td {padding:10px 0;border-top:1px solid #c1d1d5;border-bottom:1px solid #c1d1d5;background:#d7e0e2;text-align:center}
.tbl_head02 tbody th {padding:5px 0;border-top:1px solid #e9e9e9;border-bottom:1px solid #e9e9e9;background:#fff}
.tbl_head02 td {padding:5px 3px;border-top:1px solid #e9e9e9;border-bottom:1px solid #e9e9e9;background:#fff;line-height:1.4em;word-break:break-all}
.tbl_head02 a {}

/* 폼 테이블 */
.tbl_frm01 {margin:0 0 20px}
.tbl_frm01 table {width:100%;border-collapse:collapse;border-spacing:0}
.tbl_frm01 th {width:70px;padding:7px 13px;border:1px solid #e9e9e9;border-left:0;background:#f5f8f9;text-align:left}
.tbl_frm01 td {padding:7px 10px;border-top:1px solid #e9e9e9;border-bottom:1px solid #e9e9e9;background:transparent}
.wr_content textarea,.tbl_frm01 textarea,.form_01 textarea, .frm_input {border:1px solid #ccc;background:#fff;color:#000;vertical-align:middle;border-radius:3px;padding:5px;
-webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);
}
.tbl_frm01 textarea {padding:2px 2px 3px}
.frm_input {height:40px;}

.full_input{width:100%}
.half_input{width:49.5%}
.tbl_frm01 textarea, .write_div textarea {width:100%;height:100px}
.tbl_frm01 a {text-decoration:none}
.tbl_frm01 .frm_file {display:block;margin-bottom:5px}
.tbl_frm01 .frm_info {display:block;padding:0 0 5px;line-height:1.4em}

/*기본 리스트*/
.list_01 li{border:1px solid #dbdbdb;background:#fff;border-radius:3px;margin:3px 0;padding:10px 15px;list-style:none;position:relative;}
.list_01 li:after {display:block;visibility:hidden;clear:both;content:""}
.list_01 li:hover{background:#f9f9f9}
.list_01 li.empty_li{text-align:center;padding:20px 0;color:#666}
/*폼 리스트*/
.form_01 h2{margin:0 0 10px;font-size:1.167em}
.form_01 li{margin:10px 0}
.form_01 li:after {display:block;visibility:hidden;clear:both;content:""}
.form_01 li .right_input{float:right}
.form_01 textarea{height:100px;width:100%}
.form_01 .frm_label{display:inline-block;width:130px}

/* 자료 없는 목록 */
.empty_table {padding:50px 0 !important;text-align:center}
.empty_list {padding:20px 0 !important;color:#666;text-align:center}

/* 필수입력 */
.required, textarea.required {background-image:url('../img/require.png')  !important;background-repeat:no-repeat   !important;background-position:right top  !important;}

/* 테이블 항목별 정의 */
.td_board {width:80px;text-align:center}
.td_category {width:80px;text-align:center}
.td_chk {width:30px;text-align:center}
.td_date {width:60px;text-align:center}
.td_datetime {width:110px;text-align:center}
.td_group {width:80px;text-align:center}
.td_mb_id {width:100px;text-align:center}
.td_mng {width:80px;text-align:center}
.td_name {width:100px;text-align:left}
.td_nick {width:100px;text-align:center}
.td_num {width:50px;text-align:center}
.td_numbig {width:80px;text-align:center}
.td_stat {width:60px;text-align:center}

.txt_active {color:#5d910b}
.txt_done {color:#e8180c}
.txt_expired {color:#ccc}
.txt_rdy {color:#8abc2a}

/* 새창 기본 스타일 */
.new_win {position:relative;}
.new_win .tbl_wrap {margin:0 20px}
.new_win #win_title {font-size:1.25em;height:50px;line-height:30px;padding:10px 20px;background:#333;color:#fff;}
.new_win #win_title .sv {font-size:0.75em;line-height:1.2em}
.new_win .win_ul {border-right:1px solid #dfe6e7;}
.new_win .win_ul:after {display:block;visibility:hidden;clear:both;content:""}
.new_win .win_ul li{float:left;background:#fff;width:33.333%;text-align:center;border:1px solid #ccc;margin-left:-1px}
.new_win .win_ul li a{display:block;padding:10px 0}
.new_win .win_ul .selected{background:#fff;border-color:#d13f4a;position:relative;z-index:5}
.new_win .win_ul .selected a{color:#d13f4a;font-weight:bold}
.new_win .win_desc {margin:5px 0;font-size:0.92em;color:#3598db;}
.new_win .frm_info{font-size:0.92em;color:#3598db}
.new_win .win_total{text-align:right;margin:10px 0}
.new_win .win_total span{display:inline-block;line-height:30px;font-size:0.92em;color:#4e546f;background:#d4d4d4;padding:0 10px;border-radius:5px;}
.new_win .new_win_con{margin:20px;}
.new_win .new_win_con:after {display:block;visibility:hidden;clear:both;content:""}
.new_win .btn_confirm:after {display:block;visibility:hidden;clear:both;content:""}
.new_win .win_btn{text-align:right}
.new_win .btn_close {position:absolute;top:0;right:0;height:50px;width:50px;background:url(../img/close_btn.gif) no-repeat 50% 50%;border:0;text-indent:-999px;overflow:hidden;cursor:pointer}
.new_win .btn_submit {padding:0 20px;height:40px;font-weight:bold;font-size:1.083em;float:right}

/* 검색결과 색상 */
.sch_word {color:#00c4ac}

/* 자바스크립트 alert 대안 */
#validation_check {margin:100px auto;width:500px}
#validation_check h1 {margin-bottom:20px;font-size:1.3em}
#validation_check p {margin-bottom:20px;padding:30px 20px;border:1px solid #e9e9e9;background:#fff}

/* 사이드뷰 */
.sv_wrap {position:relative;font-weight:normal}
.sv_wrap .sv {z-index:1000;display:none;margin:5px 0 0;font-size:0.92em;background:#333;
-webkit-box-shadow: 2px 2px 3px 0px rgba(0,0,0,0.2);
box-shadow: 2px 2px 3px 0px rgba(0,0,0,0.2);}
.sv_wrap .sv:before{content: "";position: absolute;top: -6px;left: 15px;width: 0;height: 0;border-style: solid;border-width: 0 6px 6px 6px;border-color: transparent transparent #333 transparent;}
.sv_wrap .sv a {display:inline-block;margin:0;padding:0  10px;line-height:30px;width:100px;font-weight:normal;color:#bbb }
.sv_wrap .sv a:hover{background:#000;color:#fff}
.sv_member{color:#333}
.sv_on {display:block !important;position:absolute;top:23px;left:0px;width:auto;height:auto}
.sv_nojs .sv {display:block}

/* 페이징 */
.pg_wrap {clear:both;margin:30px 0 ;text-align:center}
.pg_wrap:after {display:block;visibility:hidden;clear:both;content:""} 
.pg {}
.pg_page, .pg_current {display:inline-block;vertical-align:middle;background:#f3f3f3;border:1px solid #bbbcc3}
.pg a:focus, .pg a:hover {text-decoration:none}
.pg_page {color:#555;font-size:1.083em;height:30px;line-height:28px;padding:0 5px;min-width:30px;text-decoration:none;border-radius:3px;}
.pg_page:hover{background-color:#ddd}
.pg_start {text-indent:-999px;overflow:hidden;background:url('../img/btn_first.gif') no-repeat 50% 50% #fff;padding:0;border:1px solid #bbb;}
.pg_prev {text-indent:-999px;overflow:hidden;background:url('../img/btn_prev.gif') no-repeat 50% 50% #fff;padding:0;border:1px solid #bbb}
.pg_end {text-indent:-999px;overflow:hidden;background:url('../img/btn_end.gif') no-repeat 50% 50% #fff;padding:0;border:1px solid #bbb}
.pg_next {text-indent:-999px;overflow:hidden;background:url('../img/btn_next.gif') no-repeat 50% 50% #fff;padding:0;border:1px solid #bbb}
.pg_start:hover,.pg_prev:hover,.pg_end:hover,.pg_next:hover{background-color:#fafafa}

.pg_current {display:inline-block;background:#4c4f6f;color:#fff;font-weight:bold;height:30px;line-height:30px;padding:0 10px;min-width:30px;border-radius:3px;
-webkit-box-shadow: inset 1px 1px 2px #222542;
box-shadow: inset 1px 1px 2px #222542;
}

/* cheditor 이슈 */
.cheditor-popup-window *, .cheditor-popup-window :after, .cheditor-popup-window :before {
-webkit-box-sizing: content-box;
box-sizing: content-box;
}

/* Mobile화면으로 */
#device_change {display:block;margin:0.3em;padding:0.5em 0;border:1px solid #eee;border-radius:2em;background:#fff;color:#000;font-size:2em;text-decoration:none;text-align:center}

.pcdisplay{display:block;}
.mdisplay{display:none;}
@media screen and (max-width: 768px) {
    .pcdisplay{display:none;}
    .mdisplay{display:block;}
    .main_home{display:none;}
    .mainVisual,
.visualSlider .slick-slide{
    position:relative;
    height:60vh;
    opacity:1;
}
.bgWrap{
    position: absolute;
    width:100%;
    height:100%;
    overflow:hidden;
    background-position:center;
    background-size:cover;
}
.visualSlider .slick-slide.slick-active .bgWrap{
    animation: subbg 10s forwards;
}

.visualTxt{
-ms-display: flex;
display: flex;
flex-wrap: wrap;
flex-direction: column;
height: 100%;
position: absolute;
top: 0;
width: 100%;
z-index: 999;
text-align: center;
opacity:0;
}
.visualTxt.main {justify-content:flex-start; padding-top:40vw;}

.visualTxt .vtxt,
.visualTxt span{
    color:#fff;
    display:block;
}

.visualSlider .slick-active .visualTxt {
    opacity:1;
    background: rgba(0, 0, 0, 0.25) !important;
}

.visualSlider .slick-active  .visualTxt p {
    overflow:hidden;
}
.visualSlider .slick-active  .visualTxt .vtxt span, .visualSlider .slick-active .visualTxt .imgSmall{
    animation: maintxtani 1s;
    animation-fill-mode: forwards;
    transform: translateY(-100%);
    opacity: 0;
    display:block;

}
.visualSlider .slick-active .visualTxt .imgSmall{
    animation-delay: 1s;
    font-size:18px;
    text-align:center;
    margin:0 auto 2.7vw;
}
.visualSlider .slick-active .visualTxt .imgSmall img {max-width:4vw;}
.visualSlider .slick-active .visualTxt  b {font-weight:600 !important;}

.visualSlider .slick-active .visualTxt .delay01 span{
    animation-delay: 1.2s;	
    font-size:6.7vw; line-height:8.7vw; letter-spacing:-0.08em; font-weight:200;
    padding-bottom:5.4vw;
    font-family: 'Noto Serif KR', serif;
}

.visualSlider .slick-active .visualTxt .delay02 span{
    animation-delay: 1.4s;	
    font-size:4vw; line-height:6vw; letter-spacing:-0.08em; font-weight:400;
}

.visualSlider .color1 {color:#d961ff;}
.visualSlider .color2 {color:#ffc560;}
.visualSlider .eng {font-family: "Plantagenet Cherokee";}

@keyframes maintxtani {
form { transform: translateY(100px); opacity: 0;}
to { transform: translateY(0); opacity: 1;}
}

@-webkit-keyframes maintxtani {
form { transform: translateY(100px); opacity: 0;}
to { transform: translateY(0); opacity: 1;}
}


.visualControl{
position:absolute;
top:50%;
left:50%; 
transform:translate(-50%, -50%);
z-index:99;
display:flex;
align-items:center;
margin-top:-10vw;
}
.visualControl .slick-dots{
    margin-top:0;
    margin-left:0;
    display:flex;
    justify-content:center;
}

.visualControl .ico{
    filter:brightness(0) invert(1);
}

.visualControl > button{
    margin-left:12px;
    width:20px;
    text-align:center;
}

.visualControl .slick-dots{
    background:transparent;
}

.visualControl .slick-dots li{
width:30px;
height:30px;
background:transparent;
position:relative;
margin:0 !important;
}
.circle_wrap {margin-left:2.7vw; display: none;}


.mainVisual, .visualSlider .slick-slide {overflow:hidden;}
.mainVisual .main_fixed {width:100%; height:100%; position:fixed; top:0; left:0;}

.circle_wrap {
overflow: hidden;
position: relative;
width: 20px;
height: 20px;
border-radius: 20px;
background-color: transparent;
}

.circle_wrap .circle {
overflow: hidden;
position: absolute;
left: 0;
top: 0;
width: 20px;
height: 20px;
border-radius: 20px;
clip: rect(0px, 20px, 20px, 10px);
}

.circle_wrap .circle-line {
width: 20px;
height: 20px;
border-radius: 100%;
border: 3px solid #c7c4c3;
}

.circle_wrap .circle-inner {
overflow: hidden;
position: absolute;
left: 0;
top: 0;
width: 20px;
height: 20px;
border-radius: 20px;
border:3px solid #81719b;
clip: rect(0px, 10px, 20px, 0px)
}

.circle_wrap .circle2 {
-webkit-transform: rotate(180deg);
transform: rotate(180deg)
}

.slick-active .circle1 .circle-inner {
-webkit-animation-name: circle_round;
-webkit-animation-duration: 3s;
-webkit-animation-iteration-count: 1;
-webkit-animation-timing-function: linear;
-webkit-animation-fill-mode: forwards
}

.slick-active .circle2 .circle-inner {
-webkit-animation-name: circle_round;
-webkit-animation-duration: 3s;
-webkit-animation-delay: 3s;
-webkit-animation-iteration-count: 1;
-webkit-animation-timing-function: linear;
-webkit-animation-fill-mode: forwards
}

@-webkit-keyframes circle_round {
0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg)
}

100% {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg)
}
}

.visualControl .txt_wrap {width:160px; position:absolute; left:45px; top:0; cursor:pointer;}
.visualControl .txt_wrap span {color:#fff; font-size:12px; line-height:30px;}
.visualControl .txt_wrap span.num {color:rgba(255,255,255,0.5); font-family: 'SpoqaHanSansNeo-Regular';}
.visualControl .txt_wrap span.txt {display:none;}
.slick-active .txt_wrap span.txt {display:block;}
.slick-active .txt_wrap span.num {display:none;}

.mainVisual .scroll {position:absolute; bottom:4vw; left:50%; transform:translateX(-50%);}
.mainVisual .scroll img {max-width:3.4vw;}

}
  /* =========================
    공통 스타일
    ========================= */
    * {
        margin: 0;
        padding: 0;
        box-sizing: border-box;
    }

    .main_container {
        max-width: 1600px;
        margin: 0 auto;
        padding: 20px;
    }

    h2 {
        font-size: 24px;
        font-weight: bold;
        text-align: center;
    }

    .divider {
        width: 50px;
        height: 2px;
        background: black;
        margin: 10px auto;
    }

    .description {
        text-align: center;
        font-size: 16px;
        color: #555;
        margin-bottom: 20px;
    }

    /* =========================
    INTRODUCTION 섹션 스타일
    ========================= */
    .introduction {
        padding: 180px 0 0;
        text-align: center;
    }

    .intro-text {
        text-align: left;
        margin: 0 auto 40px;
    }

    .intro-text h2 {
        text-align: left;
        font-size: 22px;
        font-weight: 400;
        margin-bottom: 10px;
    }

    .intro-text h2 strong {
        font-size: 36px;
        font-weight: 700;
    }

    .intro-text p {
        font-size: 16px;
        color: #666;
        line-height: 1.6;
    }

    /* =========================
    이미지 그리드 (CSS Grid 적용)
    ========================= */
    .grid {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: auto;
        gap: 10px;
        position: relative;
    }

    /* ✅ 그룹 단위로 묶어서 배치 */
    .grid-group {
        display: flex;
        flex-direction: row;
        justify-content: space-between; /* ✅ 그룹 내부 아이템 간격 조정 */
        align-items: center;
        width: 100%;
    }

    /* ✅ 각 grid-item 스타일 유지 */
    .grid-item {
        flex: 1; /* ✅ 가득 차도록 설정 */
        height: 100%; /* ✅ 부모 컨테이너 높이와 맞춤 */
        max-width: calc(50% - 10px); /* ✅ 한 그룹 안에서 균등 분배 */
        background-size: cover;
        background-position: center;
        position: relative;
        display: flex;
        align-items: center;
        justify-content: center;
        color: white;
        font-size: 18px;
        font-weight: bold;
        text-align: center;
        overflow: hidden; /* 확대될 때 영역 밖으로 넘치는 부분을 숨김 */
        transition: transform 0.3s ease-in-out; /* 부드러운 확대 애니메이션 */
        cursor: pointer;
    }
     /* ✅ 그룹 단위로 적용 */
    .grid-group:nth-child(1) .grid-item:nth-child(1),
    .grid-group:nth-child(1) .grid-item:nth-child(2) {
        grid-row: 1 / 2;
    }

    /* ✅ 1,2번 그룹을 작게 만들기 */
    .grid-group:nth-child(1) {
        height: 300px; /* 1,2번 그룹 높이를 작게 조정 */
    }
    /* ✅ 1,2번 그룹 내 개별 아이템 크기 조정 */
    .grid-group:nth-child(1) .grid-item {
        flex: 1;
        max-width: calc(50% - 10px);
        height: 100%; /* 그룹 높이에 맞춤 */
    }
    .grid-group:nth-child(2) .grid-item:nth-child(1),
    .grid-group:nth-child(2) .grid-item:nth-child(2) {
        grid-row: 1 / 3;
        height: 500px; /* 높이를 키움 */
        position: relative;
        top: -230px; /* 위로 올림 */
    }
    /* ✅ 3, 4번 그룹 (ULTHERA, THERMAGE) 높이 키우기 */
    .grid-group:nth-child(2) .grid-item {
        height: 500px;  /* ✅ 높이 증가 */
    }


    /* ✅ 오버레이 추가 (어둡게 만들기) */
    .grid-item::after {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba(0, 0, 0, 0.5); /* 검은색 반투명 레이어 */
        z-index: 1;
        pointer-events: none; /* ✅ 호버 이벤트 방해 안 하도록 설정 */
        opacity: 1;
        transition: opacity 0.3s ease-in-out; /* 부드러운 투명도 변화 */
    }

    /* ✅ 호버 시 `::after` 투명하게 변경 */
    .grid-item:hover::after {
        opacity: 0.2;
    }

    /* ✅ hover 시 grid-item 자체 확대 */
    .grid-item:hover {
        transform: scale(1.05);
    }

    /* ✅ 텍스트 가독성을 위해 레이어 위에 위치하도록 */
    .grid-item span {
        position: relative;
        z-index: 2;
        text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.8);
    }

   

    /* 배경 이미지 설정 */
    .doctor {
        background-image: url('/img/doctor.png');
    }
    .reservation {
        background-image: url('/img/reservation.png');
    }
    .ulthera {
        background-image: url('/img/ulthera.png');
    }
    .thermage {
        background-image: url('/img/thermage.png');
    }

    /* ✅ 텍스트 크기 및 가독성 개선 */
    .overlay span {
        font-size: 24px; /* 기존보다 크게 조정 */
        font-weight: 600; /* 더 두껍게 */
        letter-spacing: 1px;
    }

    .overlay strong {
        font-size: 28px;
        font-weight: 700;
    }


    /* =========================
    CLINIC 섹션 스타일
    ========================= */
    .clinic-section {
        background: #f8f8f8;
        padding: 100px 0;
        text-align: center;
    }

    .image-grid {
        display: flex;
        justify-content: center;
        gap: 10px;
        margin-top: 30px;
    }

    .image-grid .grid-item {
        position: relative;
        overflow: hidden;
        width: 32%;
        height: 350px;
    }

    .image-grid .grid-item img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 0.5s ease-in-out;
    }

    .image-grid .grid-item:hover img {
        transform: scale(1.1);
    }

    /* =========================
    BRAND KEYWORD 섹션 스타일
    ========================= */
    .brand-keyword {
        background: #ffffff;
        padding: 150px 0;
        text-align: center;
    }

    .keyword-grid {
        display: flex;
        justify-content: space-around;
        gap: 40px;
        margin-top: 30px;
    }

    .keyword-item {
        text-align: center;
        opacity: 0;
        transform: translateY(30px);
    }

    .image-wrapper {
        width: 290px;
        height: auto;
        border-radius: 50%;
        overflow: hidden;
        filter: grayscale(90%);
        transition: .5s;
    }

    .image-wrapper:hover {
        filter: grayscale(0%);
        transition: .5s;
    }

    .image-wrapper img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 0.4s ease-in-out;
    }

    .image-wrapper:hover img {
        transform: scale(1.1);
    }

    .en {
        font-size: 14px;
        color: #777;
        margin-top: 10px;
    }

    .ko {
        font-size: 18px;
        font-weight: 700;
        color: #000;
    }

    /* =========================
    반응형 스타일 (기존 코드)
    ========================= */
    @media screen and (max-width: 1024px) {
        /* 1, 2번째 이미지 → 40%, 3, 4번째 이미지 → 55% */
        .grid-item:nth-child(1),
        .grid-item:nth-child(2) {
            width: 40%;
        }

        .grid-item:nth-child(3),
        .grid-item:nth-child(4) {
            width: 55%;
        }

        .image-grid .grid-item {
            width: 48%;
            height: 250px;
        }

        .keyword-grid {
            flex-wrap: wrap;
            gap: 20px;
        }

        .keyword-item {
            width: 45%;
        }
    }

    @media screen and (max-width: 768px) {
        .grid {
            flex-direction: column;
        }

        .grid-item {
            width: 100%;
            height: 200px;
        }

        .image-grid {
            flex-direction: column;
            align-items: center;
        }

        .image-grid .grid-item {
            width: 100%;
            height: 100%;
            max-width: 100%;
        }

        .keyword-grid {
            align-items: center;
        }

        .keyword-item {
            width: 50%;
        }

        .main_container {
            max-width: 100%;
            padding: 0 15px;
        }
        .clinic-section{
            padding: 50px 0;
        }
    }
    

/* =========================
INTRO 모바일 레이아웃 (<=768px)
========================= */
@media screen and (max-width: 768px) {
    .grid-group{
        display: flex;
        flex-wrap: wrap;
    }
    .overlay strong{
        font-size: 21px;
    }
    /* 1) 그룹 래퍼를 풀어서 .grid-item 을 직접 배치하도록 */
  .introduction .grid-group {
    gap: 12px;
   
  }

  /* 2) 2열 CSS Grid 재정의 */
  .introduction .grid {
    display: flex !important;
    grid-template-columns: repeat(2, 1fr) !important;
    grid-auto-rows: auto    !important;
    gap: 10px               !important;
    position: static        !important;
  }

  /* 3) 각 카드 높이, 비율 조정 */
  .introduction .grid-item {
    width: 100%         !important;
    max-width: 100%     !important;
    height: 300px       !important; /* 필요에 따라 조절 가능 */
    position: relative  !important;
    top: auto           !important;
    transform: none     !important;
    margin: 0           !important;
  }

  /* 4) 오버레이·텍스트 크기 약간 조정(Optional) */
  .introduction .grid-item::after {
    background: rgba(0, 0, 0, 0.4) !important;
  }
  .introduction .grid-item span {
    font-size: 16px !important;
  }
  
  /* 5) 섹션 패딩 축소 */
  .introduction {
    padding: 100px 0 20px !important;
  }
  }
  
  /* =========================
   BRAND KEYWORD 반응형 (≤768px) – Flex 사용
   ========================= */
@media screen and (max-width: 768px) {
    .brand-keyword {
      padding: 50px 15px;
    }
  
    .keyword-grid {
      display: flex;
      flex-wrap: wrap;           /* 줄바꿈 허용 */
      justify-content: space-between; /* 좌우 균등 분배 */
      gap: 20px;                 /* 아이템 간격 */
      margin-top: 20px;
    }
  
    .keyword-item {
      flex: 0 0 calc(50% - 10px); /* 2열로 배치 (gap/2 계산) */
      box-sizing: border-box;
      margin-bottom: 20px;         /* 아래 여유 */
      text-align: center;
      opacity: 1 !important;  
      transform: none !important;
    }
  
    .image-wrapper {
      width: 100%;
      padding-top: 100%;          /* 1:1 비율 유지 */
      position: relative;
      border-radius: 50%;
      overflow: hidden;
      margin: 0 auto 10px;
    }
    .image-wrapper img {
      position: absolute;
      top: 0; left: 0;
      width: 100%; height: 100%;
      object-fit: cover;
    }
  
    .en {
      font-size: 12px;
    }
    .ko {
      font-size: 16px;
    }
  }
  
  /* =========================
     BRAND KEYWORD 초소형(≤480px)
     ========================= */
  @media screen and (max-width: 480px) {
    .keyword-item {
    /* 1열로 변경 */
    }
  }

  