/* Common */
.f_point {
    font-family: 'GmarketSans';
    /*font-family: 'jalnan';*/
}

.mt10 {
    margin-top: 10px;
}

.mt20 {
    margin-top: 20px;
}

.mt30 {
    margin-top: 30px;
}

.mt40 {
    margin-top: 40px;
}

.mt50 {
    margin-top: 50px;
}

.mt60 {
    margin-top: 60px;
}

.mt70 {
    margin-top: 70px;
}

.mt80 {
    margin-top: 80px;
}

.mt90 {
    margin-top: 90px;
}

.mt100 {
    padding-top: 100px;
}

.pt10 {
    padding-top: 10px;
}

.pt20 {
    padding-top: 20px;
}

.pt30 {
    padding-top: 30px;
}

.pt40 {
    padding-top: 40px;
}

.pt50 {
    padding-top: 50px;
}

.pt60 {
    padding-top: 60px;
}

.pt70 {
    padding-top: 70px;
}

.pt80 {
    padding-top: 80px;
}

.pt90 {
    padding-top: 90px;
}

.pt100 {
    padding-top: 100px;
}

.sub-left {
    float: left;
    width: 280px;
    overflow: hidden;
}

.sub-wrap.sub-wrap_full .sub-contents {
    width: calc(100% - 280px);
    padding-left: 50px;
}

.sub-left .login-area {
    background: #f9f9f9;
    border: 1px solid #cccccc;
    padding: 35px;
    border-radius: 15px;
    margin-bottom: 20px;
    overflow: hidden;
}

.sub-left b {
    display: block;
    margin-bottom: 15px;
    font-size: 20px;
    color: #333333;
    font-weight: 600;
}

.sub-left .login-box {
    margin-bottom: 10px;
}

.sub-left .login-box ul {}

.sub-left .login-box ul li {
    margin-bottom: 5px;
}

.sub-left .login-box ul li input {
    line-height: 45px;
    border: 1px solid #cccccc;
    padding: 0px 10px 0px 60px;
    width: 100%;
    display: block;
    border-radius: 5px;
    font-weight: 500;
}

.sub-left .login-box ul li input::placeholder {
    font-weight: 500;
}

.sub-left .login-box ul li .login-id {
    background: url(../img/login-id.png) no-repeat 20px center #fff;
}

.sub-left .login-box ul li .login-pw {
    background: url(../img/login-pw.png) no-repeat 20px center #fff;
}

.sub-left .btn-login {
    margin-top: 10px;
    background: #e4342b;
    display: block;
    line-height: 50px;
    border-radius: 5px;
    font-size: 18px;
    font-weight: bold;
    color: #fff;
    width: 100%;
    border: none;
}

.sub-left .login-links {
    display: block;
    overflow: hidden;
}

.sub-left .login-links .find ::after {
    content: '';
    display: block;
    clear: both;
}

.sub-left .login-links .find .find-left {
    float: left;
}

.sub-left .login-links .find .find-left::after {
    content: '';
    display: block;
    clear: both;
}

.sub-left .login-links .find .find-left a {
    font-size: 15px;
    font-weight: 400;
    float: left;
    color: #333333;
}

.sub-left .login-links .find .find-left a:hover {
    color: #e4342b;
}

.sub-left .login-links .find .find-left span {
    float: left;
    font-size: 15px;
    font-weight: 400;
    color: #333333;
}

.sub-left .login-links .find .find-right {
    float: right;
}

.sub-left .login-links .find .find-right a {
    font-size: 15px;
    font-weight: 400;
    color: #333333;
}

.sub-left .login-links .find .find-right a:hover {
    color: #e4342b;
}

.sub-left .qr-area {
    padding: 30px 20px 30px 100px;
    background: url(../img/qr-bg.png) no-repeat center center;
    border-radius: 15px;
    overflow: hidden;
    text-align: right;
    margin-bottom: 20px;
}

.sub-left .qr-area strong {
    font-size: 18px;
    font-weight: 800;
    letter-spacing: -0.03em;
    text-align: left;
    color: #161616;
    line-height: 1.2;
    display: block;
    margin-bottom: 0;
}

.sub-left .qr-area .btn-qr {
    display: none;
    background: #e01e1e;
    font-size: 17px;
    color: #fff;
    font-weight: bold;
    padding: 0px 25px;
    border-radius: 50px;
    border: none;
    line-height: 45px;
}

.sub-left .system-area {
    padding: 30px 20px 30px 23px;
    background: url(../img/system-bg.png) no-repeat center right/cover;
    border-radius: 15px;
    overflow: hidden;
    text-align: left;
    margin-bottom: 20px;
}

.sub-left .system-area strong {
    font-size: 20px;
    font-weight: 800;
    letter-spacing: -0.03em;
    text-align: left;
    padding-left: 0;
    color: #161616;
    line-height: 1.2;
    display: block;
    margin-bottom: 10px;
}

.sub-left .system-area .btn-qr {
    background: #e01e1e;
    font-size: 15px;
    color: #fff;
    font-weight: bold;
    padding: 0px 25px;
    border-radius: 50px;
    border: none;
    line-height: 40px;
}

.sub-left .links-area {}

.sub-left .links-area ul {
    border: 1px solid #cdcdcd;
    overflow: hidden;
    border-radius: 15px;
}

.sub-left .links-area li {
    border-bottom: 1px solid #cdcdcd;
}

.sub-left .links-area li:last-child {
    border-bottom: none;
}

.sub-left .links-area a {
    display: block;
    padding: 10px;
    text-align: center;
}

.sub-left .links-area a img {
    vertical-align: middle;
}

/* Main */

/* Sub */
.btn-gps img {
    vertical-align: middle;
    display: inline-block;
    margin-right: 5px;
}

.board-list.txt-type02 > table > thead > tr > th {
    text-align: center;
}

.board-list.txt-type02.td-left > table > tbody > tr > th {
    text-align: center;
}

.board-list.txt-type02.td-left > table > tbody > tr > td {
    text-align: left;
}

.line-box {
    display: inline-block;
    vertical-align: middle;
    font-weight: 600;
    font-size: 16px;
    padding: 0 32px;
    border-radius: 7px;
    background-color: #fff;
    color: #333;
    border: 1px solid #333;
    transition: .3s;
    height: 50px;
    line-height: 50px;
}
.apply-last-box {
    padding:50px 20px 30px;
}
.apply-table {
    border-right:1px solid #ddd;
    border-left:1px solid #ddd;
    min-width:767px;
}
.apply-table table tr th {
    font-weight:600 !important;
}
.apply-table table tr td {
    font-weight:500 !important;
}
.apply-table table tr td .dot-ul {
    padding:20px;
}
.apply-table table tr td .dot-ul + .symbol {
    padding-left:20px;
    padding-bottom:20px;
}

.apply-table table tr td .dot-ul li {
    padding-left:10px;
    position:relative;
}
.apply-table table tr td.pl20 {padding-left:20px;}

.apply-table table tr td .dot-ul li::before {
    content:'';
    display:block;
    width:3px;
    height:3px;
    position:absolute;
    background:#666666;
    border-radius:50%;
    left:0;
    top:9px;
}
.big-dot {
    font-size:20px;
    font-weight:bold;
    margin-left:15px;
    padding-left:10px;
    color:#333;
    position:relative;
}
.big-dot::before {
    content:'';
    display:block;
    width:4px;
    height:4px;
    background:#333;
    border-radius:10px;
    left:0;
    position:absolute;
    top:50%;
    transform:translateY(-50%);
}
.img {
    text-align: center;
}
.img img {
    max-width:100%;
}

.sign-in-type {
    border:1px solid #cccccc;
    padding:30px 50px;
    border-radius:15px;
    background:#f7f7f7;
}
.sign-in-type p {
    font-size:18px;
    color:#333333;
    line-height:1.4;
    font-weight:500;
    padding:20px 0px 20px 100px;
    background:url(../img/member/icon-info.png) no-repeat left center;
}
.type-select {
    margin-top:50px;
}
.type-select ul {
}
.type-select ul::after {
    content:'';
    display:block;
    clear:both;
}
.type-select ul li {
    float:left;
    width:42%;
    margin:0px 4%;
    border:1px solid #d5d5d5;
    text-align: center;
    border-radius:10px;
    padding:70px 0px;
}
.type-select ul li strong {
    display:block;
    font-size:24px;
    font-weight:bold;
    margin-bottom:40px;
}
.type-select ul li .img {
    margin-bottom:30px;
}
.scrollbar {
    border:solid 1px #cccccc;
    border-radius:10px;
    height:250px;
    overflow-y:auto;
    width:100%;
    padding:30px;
}
.agreement-check {
    margin-top:10px;
}

.sign-in-type2 {
    border:1px solid #cccccc;
    padding:30px 50px;
    border-radius:15px;
    background:#f7f7f7;
    margin-bottom:70px;
}
.sign-in-type2 p {
    font-size:18px;
    color:#333333;
    line-height:1.4;
    font-weight:500;
    padding-left:60px;
    background:url(../img/member/icon-info2.png) no-repeat left center;
}
.one-line .input-wrap {
    display:inline-block;
}
.one-line .sign-in-warning {
    display:inline-block;
}
.sign-in-warning {
    padding-left:23px;
    line-height:20px;
    font-weight:500;
    font-size:15px;
    color:#666;
    margin:2px 0px;
    position:relative;
}
.sign-in-warning::before {
    position:absolute;
    content:'';
    display:block;
    background:url(../img/member/warning.png) no-repeat center center;
    width:16px;
    height:16px;
    left:0;
    top:2px;
}

@media screen and (max-width:1600px) {}

@media screen and (max-width:1440px) {
    .sub-left {
        display: none !important;
    }

    .sub-wrap.sub-wrap_full .sub-contents {
        width: 100%;
        padding-left: 0;
        padding-top: 0;
    }

}


/* main index */
.main-visual {
    background: url(../img/main/main-visual.jpg) no-repeat center center;
    min-height: 620px;
    background-size: cover;
}
.main-visual .wrapper::after {
    content:'';
    display:block;
    clear:both;
}
.main-visual .wrapper .main-txt {
    padding-top:100px;
    float:left;
}
.main-visual .wrapper .main-txt strong {
    font-family: 'GmarketSans';
    color:#fff;
    font-size:42px;
}
.main-visual .wrapper .main-txt p {
    font-size:20px;
    color:#fff;
}
.main-visual .wrapper .main-login{
    float:right;
    margin-top:70px;
    background:rgba(255,255,255,0.9);
    border-radius:11px;
    padding:30px 40px;
    border:1px solid #ccc;
}
.main-visual .wrapper .main-login span {
    font-size:20px;
    font-weight:700;
    display:block;
    margin-bottom:10px;
}
.main-visual .wrapper .main-login ul::after {
}
.main-visual .wrapper .main-login ul li {
}
.main-visual .wrapper .main-login ul li input {
    width:210px;
    border:1px solid #ccc;
    height:50px;
    line-height:48px;
    padding:0px 10px 0px 50px;
}
.main-visual .wrapper .main-login ul li input.lg-id {
    border-radius:6px 6px 0px 0px;
    background:url(../img/main/icon-id.png) no-repeat 15px center #fff;
}
.main-visual .wrapper .main-login ul li input.lg-pw {
    border-top:none;
    border-radius:0px 0px 6px 6px;
    background:url(../img/main/icon-pw.png) no-repeat 15px center #fff;
}
.main-visual .wrapper .main-login .btn-lg {
    font-size:18px;
    color:#fff;
    background:#e4342b;
    border-radius:6px;
    display:block;
    width:100%;
    border:none;
    line-height:50px;
    margin:10px 0px 15px;
}
.main-visual .wrapper .main-login .main-lg-opt::after {
    content:'';
    display:block;
    clear:both;
}
.main-visual .wrapper .main-login .main-lg-opt .left  {
    float:left;
    font-weight:500;
}
.main-visual .wrapper .main-login .main-lg-opt .left a {
    font-size:15px;
    font-weight:500;
}
.main-visual .wrapper .main-login .main-lg-opt .right {
    float:right;
    font-weight:600;
}
.main-visual .wrapper .main-login .main-lg-opt .right a {
    font-size:15px;
    font-weight:500;
}

.board {
    margin-top:-240px;
    position:relative;
    z-index: 1;
}
.board .board-tab {
    margin-bottom:20px;
}
.board .board-tab:after {content: ""; display: table; clear: both;}
.board .board-tab ul {float: left;}
.board .board-tab ul li {
    display:inline-block;
    margin-right:10px;
    vertical-align: middle;
}
.board .board-tab ul li .a-tab {
    background:rgba(50,50,50,0.8);
    border-radius:50px;
    font-size:18px;
    color:#fff;
    font-weight:500;
    padding:0 20px;
    cursor: pointer;
    height: 50px;
    line-height: 50px;
}
.board .board-tab ul li .a-tab > * {
    display: inline-block;
    vertical-align: middle;
}
.board .board-tab ul li .a-tab > a { 
    display: none; 
}
.board .board-tab ul li .a-tab.active{
    font-size:22px;
    font-weight:600;
    border-radius:50px 50px 0px 50px;
    background-color: #e2190f;
}
.board .board-tab ul li .a-tab.active > a { 
    display: inline-block; 
}
.board .board-tab ul li .a-tab.active > p { 
    margin-right: 15px;
}

.main_more_wr {float: right;}
.main_more_btn {display: block; margin-top: 25px; font-size: 20px; font-weight: 700; color: #fff; line-height: 1; transition: 0.3s;}
.main_more_btn i {display: inline-block; position: relative; z-index: 1; width: 22px; height: 22px; margin: -2px 0 0 10px; border: 0; border-radius: 50%; background: #fff; vertical-align: middle; transition: 0.3s;}
.main_more_btn i::before {content: ""; display: block; position: absolute; top: 50%; left: 50%; z-index: 1; width: 10px; height: 2px; margin: -1px 0 0 -5px; background-color: #000;}
.main_more_btn i::after {content: ""; display: block; position: absolute; top: 50%; left: 50%; z-index: 1; width: 2px; height: 10px; margin: -5px 0 0 -1px; background-color: #000;}
.main_more_btn:hover {color: #e2190f; }
.main_more_btn:hover i {background: #e2190f;}
.main_more_btn:hover i::before {background-color: #fff;}
.main_more_btn:hover i::after {background-color: #fff;}


.board .board-tab-cont {
}
.board .board-tab-cont .b-tab {
    display:none;
}
.board .board-tab-cont .b-tab.active {
    display:block;
}
.board .board-tab-cont .b-tab ul {
    margin:0px -15px;
}
.board .board-tab-cont .b-tab ul::after {
    content:'';
    display:block;
    clear:both;
}
.board .board-tab-cont .b-tab ul li {
    float:left;
    width:calc(25% - 30px);
    margin:0px 15px;
}
.board .board-tab-cont .b-tab ul li a {
    display:block;
    background:#f7f7f7;
    border-radius:22px;
    position:relative;
    padding:30px;
    height:310px;
}
.board .board-tab-cont .b-tab ul li a span{
    font-size:16px;
    line-height:1;
    padding:9px 15px;
    background:#e2190f;
    color:#fff;
    font-weight:500;
    border-radius:50px;
}
.board .board-tab-cont .b-tab ul li a .date {
    display:block;
    margin-top:20px;
}
.board .board-tab-cont .b-tab ul li a .date b {
    font-size:30px;
    font-weight:bold;
    letter-spacing:-0.05em;
}
.board .board-tab-cont .b-tab ul li a .date em {
    font-size:14px;
    font-weight:bold;
    font-style:normal;
    display:inline-block;
    margin-left:7px;
}
.board .board-tab-cont .b-tab ul li a .b-tit {
    font-size:20px;
    font-weight:600;
    display: -webkit-box;
    max-width: 100%;
    line-height:1.35;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-bottom:5px;
}
.board .board-tab-cont .b-tab ul li a .b-con {
    display: -webkit-box;
    max-width: 100%;
    line-height:1.5;
    -webkit-line-clamp: 2;
    font-size:16px;
    font-weight:400;
    color:#777;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.board .board-tab-cont .b-tab ul li a .btn-more {
    line-height:1.2;
    font-size:14px;
    position:absolute;
    bottom:30px;
    left:30px;
    font-style:normal;
    color:#888;
    border-bottom:1px solid #666;
    font-weight:600;
}
.main-btm {
    padding: 60px 0px;
}
.main-btm .wrapper::after {
    content:'';
    display:block;
    clear:both;
}
.main-btm .wrapper .mb-left {
    float: left;
    width: calc(25% - 15px);
}
.main-btm .wrapper .mb-left .introduce {
    background:url(../img/main/main-img.png) no-repeat calc(50% + 20px) bottom#dceee7;
    border-radius:15px;
    height:380px;
    padding:40px 30px;
}
.main-btm .wrapper .mb-left .introduce .intro-title {
    font-size:24px;
    font-weight:800;
    line-height:1.2;
    letter-spacing:-0.04em;
    margin-bottom:15px;
    display:block;
}
.main-btm .wrapper .mb-left .introduce .btn-detail {
    line-height:40px;
    font-size:15px;
    font-weight:600;
    color:#fff;
    background:#e2190f;
    border-radius:50px;
    display:inline-block;
    padding:0px 20px;
}
.main-btm .wrapper .mb-left .qrcode {
    width:100%;
    background:#f2f2f2;
    border-radius:15px;
    margin-top:30px;
    height:105px;
    padding:25px;
}
.main-btm .wrapper .mb-left .qrcode .img {
    vertical-align:middle;
    display:inline-block;
}
.main-btm .wrapper .mb-left .qrcode .img img {
    display:inline-block;
}
.main-btm .wrapper .mb-left .qrcode p {
    vertical-align:middle;
    margin-top:-5px;
    display:inline-block;
    font-weight:800;
    padding-left:15px;
    font-size:18px;
    line-height:1.4;
}
.main-btm .wrapper .mb-right {float: right;width: calc(75% - 15px);position: relative;}
.main-btm .wrapper .mb-right .map {
    height: 520px;
    border: 1px solid #ccc;
    border-radius: 15px;
}
.main-btm .wrapper .mb-right .map-search {
    position: absolute;
    z-index: 1;
    background: rgba(226,25,15,0.88);
    border-radius: 15px;
    top: 25px;
    width:330px;
    right: 25px;
    padding: 35px 30px 40px;
}
.main-btm .wrapper .mb-right .map-search strong {
    display: inline-block;
    padding-right: 30px;
    background: url(../img/main/icon-sch.png) no-repeat right center;
    font-size: 26px;
    color: #fff;
    font-weight: 500;
}
.main-btm .wrapper .mb-right .map-search p {
    font-size: 16px;
    color: #fff;
}
.main-btm .wrapper .mb-right .map-search ul {
    margin:15px -5px 10px;
}
.main-btm .wrapper .mb-right .map-search ul::after {
    content:'';
    display:block;
    clear:both;
}
.main-btm .wrapper .mb-right .map-search ul li {
    float:left;
    width:calc(50% - 10px);
    margin:0px 5px;
}
.main-btm .wrapper .mb-right .map-search ul li select {
    border:none;
    width:100%;
    border-radius:5px;
    line-height:40px;
    height:40px;
}
.main-btm .wrapper .mb-right .map-search .sch-input::after {
    content:'';
    display:block;
    clear:both;
}
.main-btm .wrapper .mb-right .map-search .sch-input input{
    float:left;
    line-height:40px;
    border:none;
    border-radius:5px;
    padding:0px 10px;
    margin-right:5px;
    width:calc(100% - 95px);
}
.main-btm .wrapper .mb-right .map-search .sch-input .btn-sch-map {
    width:90px;
    display:inline-block;
    line-height:40px;
    border:none;
    color:#fff;
    background:#5c0000;
    font-weight:500;
    border-radius:5px;
}

.main-rel-site-section {padding: 30px 0; border-top: 1px solid #ccc;}
.rel-site-wr { font-size: 0; margin-right: -76px; }
.rel-site-wr > * { display: inline-block; vertical-align: middle; }
.rel-site-wr .swiper-wrapper {align-items: center;}
.rel-site-title {font-weight: 700; font-size: 20px; width: 170px;}
.rel-site-sl-wr {width: calc(100% - 170px); padding: 0 76px; text-align: right; position: relative;}
.rel-site-sl {overflow: hidden;}
.rel-site-item {display: inline-block; text-align: center; font-size: 0;}
.rel-site-item img { width: 177px; }
.rel-site-sl-wr .rel-btn {border-radius: 50%; border: 1px solid #aaacb5; width: 47px; height: 47px; text-align: center; background-color: #fff; position: absolute; top: 50%; transform: translateY(-50%);}
.rel-site-sl-prev {left: 0;}
.rel-site-sl-next {right: 0;}

.hd .logo {
    width:362px;
}
.gnb {
    width:calc(100% - 370px);
}
/* 로그인 후 박스 추가 */
.login-cpom-box {font-weight: 400; font-size: 22px; color: #333; margin-bottom: 15px;}
.login-cpom-box .bold {font-weight: 600; display: inline-block;}

.main-login .login-cpom-box {color: #333; font-size: 20px;}
.main-login .login-cpom-box span {display: inline-block!important; margin-bottom: 0!important;}

/* 로그인 페이지 */
.login-wrap {}
.login-head {margin-bottom: 90px; font-size: 0;}
.login-head-icon {display: inline-block; vertical-align: middle; width: 109px;}
.login-head-content {display: inline-block; vertical-align: middle; width: calc(100% - 109px); padding-left: 20px;}
.login-head-text1 {margin-bottom: 5px; font-size: 28px; font-weight: 600; color: #303030;}
.login-head-text2 {font-size: 17px; font-weight: 500; color: #666666; line-height: 1.4;}
.login-body {width: 530px; max-width: 100%; margin: 0 auto; text-align: center;}
.login-title {margin-bottom: 45px; font-size: 32px; font-weight: 600; color: #0f0f0f;}
.login-notice {display: block; margin-bottom: 20px; font-size: 0; text-align: left;}
.login-notice i {display: inline-block; vertical-align: top; width: 26px; height: 26px; background: url('../img/login-notice.png') no-repeat center center / contain;}
.login-notice p {display: inline-block; vertical-align: top; width: calc(100% - 26px); padding-left: 8px; font-size: 18px; font-weight: 300; color: #444444;}
.login-input {}
.login-input-text {width: 100%; height: 50px; padding: 0 30px; border: 1px solid #cccccc; border-radius: 5px;}
.login-input-text ~ .login-input-text {margin-top: 8px;}
.login-bottom {margin-top: 10px; text-align: right;}
.login-find {position: relative; font-size: 16px; font-weight: 300; color: #3a3a3a; border: none; background: #ffffff;}
.login-find b {font-weight: 600;}
.login-find:not(:first-child) {margin-left: 20px;}
.login-find:not(:first-child)::before {position: absolute; left: -12px; top: 2px; width: 2px; height: 15px; background: #cccccc; content:"";}
.login-btn {margin-top: 70px;}
.login-btn-submit {width: 100%; height: 65px; border-radius: 5px; border: none; background: #e4342b; font-size: 18px; font-weight: 400; color: #ffffff;}
.login-btn-join {display: block; width: 100%; height: 65px; line-height: 65px; margin-top: 10px; border-radius: 5px; background: #111111; font-size: 18px; font-weight: 400; color: #ffffff;}

.sub-visual {
    background:url(../img/sub-visual.jpg) no-repeat center center / cover;
}

/* 20240806 요청사항 반영 */
.manage-btn a {
    display: block;
    width: 100%;
    margin-top: 8px;
    line-height: 50px;
    background: #333333;
    font-size: 16px;
    font-weight: 400;
    color: #ffffff;
    border-radius: 6px;
    text-align: center;
}