@charset "utf-8";
/* 아이랩스 전현진 팀장 */

#wrapper {
    position: relative;
    padding-top: 60px;
}

@media screen and (min-width: 979px) {
    #wrapper {
        padding-top: 80px;
    }
}


/* 상단 헤더 */
#header {
    position: fixed;
    top: 0;
    left: 0;
    overflow: hidden;
    width: 100%;
    height: 60px;
    background-color: #fff;
    box-shadow: 0 2px 3px rgba(0,0,0,0);
    transition: .3s;
    z-index: 5000;
}

#header h1 {
    font-size: 0;
}

#header h1 a {
    display: inline-block;
    padding: 15px;
}

#header h1 a img {
    height: 30px;
}

#header .mnubtn {
    position: absolute;
    top: 5px;
    right: 5px;
}

#header.open {
    overflow-y: auto;
    height: 100vh;
}

#header .start-counsel {
    position: relative;
    overflow: hidden;
    width: calc(100% - 40px);
    max-width: 400px;
    margin: 10px auto 0;
    border-radius: 25px;
}

#header .start-counsel a {
    flex-grow: 1;
    position: relative;
    display: block;
    height: 50px;
    line-height: 50px;
    padding: 0 15px;
    background-color: var(--color-blue);
    text-align: center;
    color: #fff;
}

#header .start-counsel a:not(:first-child):after {
    position: absolute;
    top: 10px;
    left: 0;
    bottom: 10px;
    width: 1px;
    background-color: rgba(0,0,0,0.2);
    content: '';
}

#header .gnb {
    margin-top: 20px;
}

#header .gnb ul.gnb-1ul li.gnb-1li {
    position: relative;
    width: 100%;
}

#header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 70px;
    padding: 0 20px;
    font-size: 18px;
    font-weight: 500;
}

#header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a:after {
    position: absolute;
    bottom: 0;
    left: 20px;
    right: 20px;
    height: 1px;
    background-color: #f2f2f2;
    transition: 0.3s;
    content: '';
}

#header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a .ico {
    color: #c9c9c9;
    transition: .3s;
}

#header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a.on:after {
    left: 0;
    right: 0;
}

#header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a.on .ico {
    transform: rotate(180deg);
}

#header .gnb .gnb-2ul {
    display: none;
    padding: 10px 20px;
    background-color: var(--bg-gray);
}

#header .gnb ul.gnb-2ul li.gnb-2li a.gnb-2a,
#header .gnb ul.gnb-3ul li.gnb-3li a.gnb-3a {
    display: block;
    height: 40px;
    line-height: 40px;
    color: #060b11;
}

#header .gnb ul.gnb-2ul li.gnb-2li a.gnb-2a.active,
#header .gnb ul.gnb-3ul li.gnb-3li a.gnb-3a.active {
    color: var(--color-blue);
    font-weight: 500;
}

#header .gnb div.gnb-2ul .inner {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

#header .gnb div.gnb-2ul .in-sec h4 {
    margin-bottom: 10px;
    font-weight: 500;
    font-size: 18px;
}

@media screen and (min-width: 639px) {
}

@media screen and (min-width: 767px) {
}

@media screen and (min-width: 1239px) {
    #header {
        display: flex;
        justify-content: flex-start;
        align-items: center;
        overflow: visible;
        height: 80px !important;
        padding: 0 20px;
        box-shadow: 0 6px 15px rgba(0,0,0,0.08);
    }

    #header.mnuopen {
        background-color: var(--bg-gray);
    }

    #header h1 a {
        padding: 23px 20px;
    }

    #header h1 a img {
        height: 34px;
    }

    #header .mnubtn {
        display: none;
    }

    #header .start-counsel {
        position: absolute;
        top: 15px;
        right: 40px;
        justify-content: flex-end;
        gap: 10px;
        max-width: 500px;
        margin: 0;
        border-radius: 0px;
    }

    #header .start-counsel a:not(:first-child):after {
        display: none;
    }
    
    #header .start-counsel a.start-btn {
        flex-shrink: 0;
        padding: 0;
        background-color: transparent;
        color: #000;
    }
    
    #header .start-counsel a.counsel-btn,
    #header .start-counsel a.reserve-btn {
        flex-shrink: 0;
        padding: 0 20px;
        border-radius: 25px;
    }

    #header .start-counsel a.reserve-btn {
        background-color: #00bcdd;
    }

    #header .gnb {
        margin-top: 0px;
        margin-left: 30px;
    }
    
    #header .gnb ul.gnb-1ul li.gnb-1li {
        width: auto;
    }

    #header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a {
        justify-content: center;
        height: 80px;
        padding: 0 20px;
    }
    
    #header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a:after {
        bottom: 0;
        left: 50%;
        right: auto;
        width: 1px;
        height: 4px;
        background: #1d77fb; /* Old browsers */
        background: -moz-linear-gradient(-45deg,  #1d77fb 0%, #0098c6 100%); /* FF3.6-15 */
        background: -webkit-linear-gradient(-45deg,  #1d77fb 0%,#0098c6 100%); /* Chrome10-25,Safari5.1-6 */
        background: linear-gradient(135deg,  #1d77fb 0%,#0098c6 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
        filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#1d77fb', endColorstr='#0098c6',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
        opacity: 0;
    }

    #header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a em {
        flex-grow: 1;
    }

    #header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a .ico {
        flex-shrink: 0;
        margin-left: 10px;
        color: #000;
    }

    #header .gnb ul.gnb-1ul li.gnb-1li.active a.gnb-1a:after,
    #header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a.on:after {
        left: 0;
        width: 100%;
        opacity: 1;
    }
    
    #header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a.on .ico {
        transform: rotate(0deg);
    }
    
    #header .gnb .gnb-2ul {
        position: absolute;
        top: 80px;
        left: 0;
        right: 0;
        padding: 20px 0;
        background-color: #fff;
        box-shadow: 0px 15px 8px rgba(0,0,0,0.06);
        border-radius: 0 0 8px 8px;
    }
    
    #header .gnb ul.gnb-2ul li.gnb-2li a.gnb-2a,
    #header .gnb ul.gnb-3ul li.gnb-3li a.gnb-3a {
        font-size: 16px;
        letter-spacing: -.25pt;
    }

    #header .gnb ul.gnb-2ul li.gnb-2li a.gnb-2a {
        padding-left: 20px;
    }
    
    #header .gnb div.gnb-2ul {
        min-width: var(--gnb-2ul-width);
    }
    
    #header .gnb div.gnb-2ul .inner {
        flex-direction: row;
        align-items: stretch;
        gap: 0;
    }
    
    #header .gnb div.gnb-2ul .in-sec {
        flex-shrink: 0;
        padding: 0 30px;
    }

    #header .gnb div.gnb-2ul .in-sec h4 {
        font-weight: 700;
    }
    
    #header .gnb div.gnb-2ul .inner .in-sec:not(:first-child) {
        border-left: 1px solid #DDD; 
    }
}

@media screen and (min-width: 1439px) {
    #header {
        padding: 0 80px;
    }

    #header .start-counsel {
        right: 80px;
    }
    
    #header .start-counsel a.start-btn {
        padding: 0 20px;
    }

    #header .gnb {
        margin-left: 50px;
    }
}

@media screen and (min-width: 1639px) {
    #header .gnb {
        margin-left: 100px;
    }

    #header .gnb ul.gnb-1ul li.gnb-1li a.gnb-1a {
        padding: 0 30px;
    }

    #header .start-counsel {
        gap: 20px;
    }

    #header .start-counsel a.counsel-btn,
    #header .start-counsel a.reserve-btn {
        width: 170px;
    }
}


/* 하단 푸터 */
#footer {
    position: relative;
    background-color: #2b2f3c;
    color: #fff;
}

#footer .foot-gnb ul.gnb-1ul li.gnb-1li {
    width: 100%;
}

#footer .foot-gnb ul.gnb-1ul li.gnb-1li a.gnb-1a {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 60px;
    padding: 0 20px;
    color: #fff;
    font-weight: 500;
}

#footer .foot-gnb ul.gnb-1ul li.gnb-1li a.gnb-1a:after {
    position: absolute;
    bottom: 0;
    left: 20px;
    right: 20px;
    height: 1px;
    background-color: #484e62;
    transition: 0.3s;
    content: '';
}

#footer .foot-gnb ul.gnb-1ul li.gnb-1li a.gnb-1a .ico {
    color: #c9c9c9;
}

#footer .foot-gnb ul.gnb-1ul li.gnb-1li a.gnb-1a.on:after {
    left: 0;
    right: 0;
}

#footer .foot-gnb ul.gnb-1ul li.gnb-1li a.gnb-1a.on .ico {
    transform: rotate(180deg);
}

#footer .foot-gnb .gnb-2ul {
    display: none;
    padding: 10px 20px;
    background-color: #232631;
}

#footer .foot-gnb ul.gnb-2ul li.gnb-2li a.gnb-2a,
#footer .foot-gnb ul.gnb-3ul li.gnb-3li a.gnb-3a {
    display: block;
    height: 34px;
    line-height: 34px;
    color: #c9c9c9;
    font-size: 14px;
}

#footer .foot-gnb ul.gnb-2ul li.gnb-2li a.gnb-2a.active,
#footer .foot-gnb ul.gnb-3ul li.gnb-3li a.gnb-3a.active {
    color: var(--color-blue);
    font-weight: 500;
}

#footer .foot-gnb div.gnb-2ul .inner {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

#footer .foot-gnb div.gnb-2ul .in-sec h4 {
    margin-bottom: 10px;
    font-weight: 500;
    font-size: 18px;
}

#footer .foot-info {
    padding: 0 20px;
    margin-top: 30px;
}

#footer .foot-info h1 {
    font-size: 15px;
    font-weight: 500;
}

#footer .foot-info ul {
    margin-top: 18px;
}

#footer .foot-info ul li:not(:first-child) {
    margin-top: 5px;
}

#footer .foot-info ul:first-of-type {
    margin-top: 12px;
}

#footer .foot-info ul li span {
    color: #c9c9c9;
}

#footer .foot-downbox {
    padding: 30px 20px;
}

#footer .foot-downbox .app-down {
    max-width: 320px;
}

#footer .foot-downbox .app-down a {
    display: block;
    overflow: hidden;
    width: 47%;
    border-radius: 5px;
    font-size: 0;
}

#footer .foot-downbox .service-guide-down {
    display: block;
    height: 50px;
    line-height: 50px;
    margin-top: 20px;
    background-color: #fff;
    border-radius: 25px;
    font-weight: 500;
    text-align: center;
}

#footer .foot-link-copyright {
    padding: 20px;
    background-color: #5f6371;
    color: #c9c9c9;
}

#footer .foot-link-copyright ul li:not(:first-child) {
    margin-left: 20px;
}

#footer .foot-link-copyright ul li a {
    color: #c9c9c9;
}

#footer .foot-link-copyright ul li:first-child a {
    font-weight: 500;
    color: #fff;
}

#footer .foot-link-copyright p.coptright {
    margin-top: 6px;
    font-size: 13px;
}

@media screen and (min-width: 639px) {
    #footer .foot-downbox {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    #footer .foot-downbox .service-guide-down {
        flex-shrink: 0;
        width: 250px;
        margin-top: 0;
    }
}

@media screen and (min-width: 767px) {
    #footer .foot-link-copyright {
        padding: 25px 20px;
    }

    #footer .foot-link-copyright .respon {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    #footer .foot-link-copyright p.coptright {
        margin-top: 0;
    }
}

@media screen and (min-width: 1239px) {
    #footer .foot-infobox {
        display: flex;
        flex-direction: row-reverse;
        justify-content: space-between;
        align-items: flex-start;
        padding-top: 60px;
    }

    #footer .foot-gnb {
        flex-grow: 1;
        max-width: 800px;
    }

    #footer .foot-gnb ul.gnb-1ul li.gnb-1li {
        width: auto;
    }

    #footer .foot-gnb ul.gnb-1ul li.gnb-1li:not(:first-child) {
        margin-left: 30px;
    }

    #footer .foot-gnb ul.gnb-1ul li.gnb-1li a.gnb-1a {
        height: auto;
        line-height: 1.2;
        font-size: 20px;
    }

    #footer .foot-gnb ul.gnb-1ul li.gnb-1li a.gnb-1a .ico {
        display: none;
    }

    #footer .foot-gnb ul.gnb-1ul li.gnb-1li a.gnb-1a:after {
        display: none;
    }

    #footer .foot-gnb .gnb-2ul {
        display: block !important;
        background-color: transparent;
        padding-top: 20px;
    }    

    #footer .foot-gnb ul.gnb-2ul li.gnb-2li a.gnb-2a,
    #footer .foot-gnb ul.gnb-3ul li.gnb-3li a.gnb-3a {
        font-size: 15px;
    }

    #footer .foot-gnb div.gnb-2ul .in-sec h4 {
        font-size: 14px;
        font-weight: 400;
    }

    #footer .foot-info {
        flex-shrink: 0;
        width: 320px;
        padding: 0;
        margin-top: 0;
        font-size: 16px;
    }

    #footer .foot-info h1 {
        font-size: 20px;
    }

    #footer .foot-downbox {
        padding: 30px 0px 60px;
    }

    #footer .foot-downbox .service-guide-down {
        height: 60px;
        line-height: 60px;
        border-radius: 30px;
        font-size: 20px;
    }
    #footer .foot-link-copyright {
        padding: 25px 0px;
    }

    #footer .foot-link-copyright p.coptright {
        font-size: 16px;
    }
}


/* 모바일 네비 */
.m-gnb {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 62px;
    background-color: #fff;
    box-shadow: 0 0 10px rgba(0,0,0,0.12);
    z-index: 3000;
}

.m-gnb a {
    display: block;
    width: 25%;
    height: 62px;
    padding: 8px 0;
    text-align: center;
    font-size: 12px;
    color: #1d1d1d;
}

.m-gnb a span.ico,
.m-gnb a em {
    display: block;
}

.m-gnb a span.ico {
    font-size: 20px;
}

.m-gnb a.active {
    color: var(--color-blue);
}

@media screen and (min-width: 767px) {
    .m-gnb {
        left: calc(50% - 384px);
        width: 768px;
    }
}


/* 알람 박스 */
.shadowbox {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0,0,0,0.43);
    z-index: 8000;
}

.shadowbox.open {
    display: block;
}

.alarm-box {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 40px 30px 30px;
    background-color: #fff;
    border-radius: 18px 18px 0 0;
    z-index: 9000;
}

.alarm-box.open {
    display: block;
}

.alarm-box:after {
    position: absolute;
    top: 12px;
    left: calc(50% - 15px);
    width: 30px;
    height: 4px;
    background-color: var(--color-line-gray);
    border-radius: 2px;
    content: '';
}

.alarm-box h1.alram-tit {
    line-height: 26px;
    font-size: 20px;
    font-weight: 400;
}

.alarm-box p.light-comment {
    color: var(--color-darkgray);
}

.alarm-box p.light-comment b {
    color: #000;
}

.alarm-box figure {
    font-size: 0;
}

.service-app dt {
    margin-bottom: 10px;
}

.service-app .service-app-list a {
    width: 105px;
    text-align: center;
}

.service-app .service-app-list a span.ico {
    display: block;
    width: 45px;
    margin: 0 auto;
    font-size: 0;
}

.service-app .service-app-list a em {
    display: block;
    margin-top: 5px;
    font-size: 12px;
}


/* 모달팝업 */
.modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 100%;
    overflow-y: auto;
    background-color: rgba(255,255,255,1);
    z-index: 9999;
    outline: 0;
}

.modal .modal-dialog {
    position: relative;
    width: auto;
    margin: 0;
    pointer-events: none;
}

.modal .modal-dialog .modal-content {
    position: relative;
    display: flex;
    flex-direction: column;
    pointer-events: auto;
    max-width: 600px;
    min-height: 100vh;
    margin: 0 auto;
    background-color: #fff;
    background-clip: padding-box;
    border-radius: 0;
    outline: 0;
}

.modal .modal-dialog .modal-content .modal-header {
    position: relative;
    height: 60px;
    border-bottom: 1px solid #ddd;
    border-top-left-radius: calc(.3rem - 1px);
    border-top-right-radius: calc(.3rem - 1px);
    text-align: center;
}

.modal .modal-dialog .modal-content .modal-header h1 {
    line-height: 60px;
    font-size: 15px;
    font-weight: 400;
}

.modal .modal-dialog .modal-content .modal-header .modal-close-btn {
    position: absolute;
    top: 15px;
    right: 10px;
    width: 30px;
    height: 30px;
    border: none;
    background-color: transparent;
    font-size: 0px;
    color: #696c6f;
}

.modal .modal-dialog .modal-content .modal-body {
    position: relative;
    flex: 1 1 auto;
    padding: 1rem;
}

.modal .modal-dialog .modal-content .modal-footer {
    display: flex;
    flex-wrap: wrap;
    flex-shrink: 0;
    align-items: center;
    justify-content: flex-end;
    overflow: hidden;
    padding: 0;
    border: none;
    border-bottom-left-radius: calc(.3rem - 1px);
    border-bottom-right-radius: calc(.3rem - 1px);
}

.modal .modal-dialog .modal-content .modal-footer a,
.modal .modal-dialog .modal-content .modal-footer button {
    margin: 0;
}

.modal .modal-dialog .modal-content .modal-footer.gray-blue-area {
    justify-content: space-between;
}

.modal .modal-dialog .modal-content .modal-footer.gray-blue-area .leftBtn {
    flex-shrink: 0;
    width: 30%;
    border-width: 1px 0 0 0;
}

.modal .modal-dialog .modal-content .modal-footer.gray-blue-area .rightBtn {
    flex-grow: 1;
}

@media screen and (min-width: 639px) {
    .modal {
        background-color: rgba(0,0,0,0.6);
    }

    .modal .modal-dialog {
        margin: 50px;
    }

    .modal .modal-dialog .modal-content {
        min-height: auto;
        border-radius: 0.3rem;
    }

    .modal .modal-dialog .modal-content .modal-body {
        padding: 40px;
    }
}


/* 모달팝업 // 개인정보 수집  및 이용 동의 */
.agree-modal .modal-body {
    padding: 40px !important;
}

.agree-modal .modal-body h1 {
    margin-bottom: 20px;
    font-size: 20px;
    font-weight: 500;
}

.agree-modal .modal-body p {
    line-height: 28px;
    font-size: 13px;
}

.agree-modal .modal-body .submit-btn {
    position: absolute;
    bottom: 0;
    left: 0;
}

.agree-modal .modal-body .close-btn {
    position: absolute;
    top: 20px;
    right: 20px;
    width: 30px;
    height: 30px;
    line-height: 30px;
    text-align: center;
    font-size: 20px;
    color: #666;
}

@media screen and (min-width: 639px) {
    .modal.agree-modal .modal-dialog {
        margin: 100px 50px;
    }

    .agree-modal .modal-body {
        padding: 40px 40px 100px!important;
    }

    .agree-modal .modal-body .close-btn {
        font-size: 26px;
    }
}


/* 개인정보처리방침, 애니싸인 이용 약관 */
.fixed-popup {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #fff;
    z-index: 8000;
}

.fixed-popup header h2 {
    height: 56px;
    line-height: 56px;
    padding: 0 20px;
    border-bottom: 1px solid var(--color-line-gray);
    font-size: 16px;
    font-weight: 500;
}

.fixed-popup .process {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
}

.fixed-popup .overflow {
    position: absolute;
    top: 56px;
    bottom: 56px;
    left: 0;
    width: 100%;
}

.fixed-popup .overflow iframe {
    width: 100%;
    height: 100%;
    border: none;
}

.fixed-popup .process .large {
    display: block;
    width: 100%;
    height: 56px;
    line-height: 56px;
    background-color: var(--color-blue);
    color: #fff;
    text-align: center;
    font-weight: 500;
}

@media screen and (min-width: 639px) {
    .fixed-popup {
        padding: 100px 40px;
        background-color: rgba(0,0,0,0.7);
    }

    .fixed-popup .wrap {
        position: relative;
        overflow: hidden;
        width: 100%;
        max-width: 630px;
        height: 500px;
        margin: 0 auto;
        background-color: #fff;
        border-radius: 20px;
    }
}



/* -------------------------------- */
@media screen and (min-width: 639px) {
}

@media screen and (min-width: 767px) {
}

@media screen and (min-width: 979px) {
}

@media screen and (min-width: 1239px) {
}

@media screen and (min-width: 1439px) {
}