@charset "UTF-8";

/* 기본 설정들 */
html {
    overflow-x: hidden;
}

body {
    position: relative;
    overflow: hidden;
}

html * {
    word-break: keep-all;
}

html,
body {
    font-family: 'Pretendard', 'Noto Sans KR', sans-serif;
}

img,
p,
span,
h1,
h2,
h3,
h4,
h5,
h6 {
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -o-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
}

.p {
    display: block;
}

.t {
    display: none;
}

.m {
    display: none;
}

.fb {
    font-family: 'Pretendard', 'Noto Sans KR', sans-serif;
    font-weight: 600;
    font-style: bold;
}

::-webkit-scrollbar {
    width: 8px;
}

::-webkit-scrollbar-thumb {
    background-color: #2f3542;
    border-radius: 10px;
}

.con {
    max-width: 1320px;
    margin: 0 auto;
    width: 100%;
}

@media screen and (max-width: 1320px) {
    .p {
        display: none;
    }

    .t {
        display: block;
    }

    .con {
        width: 100%;
        margin: 0 auto;
        max-width: 767px;
    }

    .hover_img_2,
    .hover_img {
        top: 17% !important;
    }
}

@media screen and (max-width: 767px) {
    .m {
        display: block;
    }

    .pt {
        display: none;
    }

    .con {
        max-width: 767px;
        width: 90%;
    }
}

.re .blind {
    position: absolute;
    top: 0;
    left: 0;
    overflow: hidden;
    width: 1px;
    height: 1px;
    margin: -1px;
    clip: rect(0, 0, 0, 0);
}

.re .pc {
    display: block;
}

.re .mob {
    display: none;
}

.re .fw_600 {
    font-weight: 600;
}

.re .w_250 {
    max-width: 250px;
}

.re .w_370 {
    max-width: 370px;
}

.re .inner {
    width: 90%;
    max-width: 1644px;
    margin: 0 auto;
    padding: 0 22px;
    box-sizing: border-box;
}

.re .char {
    transform: translateY(100px);
    opacity: 0;
    filter: blur(10px);
}

.re .line {
    height: unset;
    margin: unset;
    background: none;
}

.re .sc_ttl {
    font-weight: 200;
    font-family: 'Noto Serif KR';
    font-size: 46px;
    line-height: 1.4;
    letter-spacing: -2.76px;
}

.re .sub_ttl {
    font-family: 'Noto Serif KR';
    font-size: 20px;
    line-height: 1.5;
    letter-spacing: 0.4px;
}

.re .desc {
    font-size: 18px;
    line-height: 1.6;
    letter-spacing: -0.36px;
}

.re .sc_ttl.eng_ttl {
    font-weight: 500;
    font-family: 'Cormorant Garamond';
    font-size: 80px;
    letter-spacing: -1.6px;
}

.re .swiper-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
}

.re .swiper-pagination .swiper-pagination-bullet {
    display: flex;
    align-items: center;
    margin: 0 20px;
    background-color: #fff;
}

.re .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
    width: fit-content;
    height: 34px;
    padding: 7px 32px;
    border: 1px solid #fff;
    background-color: transparent;
    border-radius: 999px;
}

.re .swiper-pagination .pagination-text {
    display: none;
    white-space: nowrap;
}

.re .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active .pagination-text {
    display: block;
}

.re .sticky {
    position: sticky;
    top: 0;
    left: 0;
    overflow: hidden;
    width: 100%;
    height: 100vh;
}

/* .re [data-ani="title"] .sub_title,
  .re [data-ani="title"] .desc { display: block; opacity: 0; transform: translate(10%);} */

@media screen and (max-width: 768px) {
    .re .inner {
        width: 100%;
    }

    .re .pc {
        display: none;
    }

    .re .mob {
        display: block;
    }

    .re .sc_ttl {
        font-size: 22px;
        letter-spacing: -1.32px;
    }

    .re .sub_ttl {
        font-size: 14px;
        letter-spacing: 0.28px;
    }

    .re .desc {
        font-size: 15px;
        letter-spacing: -0.3px;
    }

    .re .sc_ttl.eng_ttl {
        font-size: 34px;
    }

    .re .swiper-pagination {
        justify-content: flex-start;
    }

    .re .swiper-pagination .swiper-pagination-bullet {
        width: 5px;
        height: 5px;
        margin: 0 7px;
    }

    .re .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active {
        height: 24px;
        padding: 5px 24px;
    }

    .re .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active .pagination-text {
        font-size: 10px;
    }

    .re .sticky {
        height: calc(var(--vh) * 100);
    }
}

/* 기본 설정들 */
.body {
    background-color: #000;
    height: 200vh;
}

/* 헤더 시작 */
.header {
    z-index: 99999999;
    height: 100px;
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    background-color: #fff;
    box-shadow: 0 10px 20px #00000031;
}

.logo {
    transition: 0.6s;
    z-index: 1001;
    cursor: pointer;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.header_right_group {
    transition: 0.6s;
    position: relative;
    z-index: 1000;
    gap: 23px;
    color: #172e59;
    display: flex;
    width: 90%;
    margin: 0 auto;
    justify-content: flex-end;
    height: 100px;
    align-items: center;
}

.logreg_group {
    display: flex;
    gap: 5px;
    font-size: 20px;
    transition: 0.4s;
}

.logreg_list.hover {
    cursor: pointer;
    color: #1d5e58;
}

.ham_btn_group {
    cursor: pointer;
    width: 32px;
    height: 20px;
    position: relative;
}

.ham_bar {
    transition: 0.4s;
    position: absolute;
    left: 0;
    width: 32px;
    height: 3px;
    border-radius: 50px;
    position: absolute;
    background-color: #1c274c;
}

.ham_bar1 {
    top: 0;
}

.ham_bar2 {
    top: calc(50% - 1.5px);
    transform-origin: left;
}

.ham_bar3 {
    top: calc(100% - 3px);
}

.ham_btn_group:hover {}

.ham_btn_group:hover .ham_bar1 {
    transform: rotate(10deg);
    top: 2px;
}

.ham_btn_group:hover .ham_bar2 {
    transform: scaleX(0.8);
}

.ham_btn_group:hover .ham_bar3 {
    transform: rotate(-10deg);
    top: calc(100% - 5px);
}

.ham_btn_group:hover {}

.ham {
    overflow: hidden;
    transition: 0.6s;
    z-index: 999;
    width: 100%;
    position: fixed;
    top: -100%;
    left: 0%;
    height: 100%;
    background-color: #1a1a1ae1;
    backdrop-filter: blur(15px);
}

.ham_bg {
    position: absolute;
    top: 0;
    left: 0;
}

.ham_sub_df {
    gap: 75px;
    position: relative;
    z-index: 2;
    padding-top: 190px;
    margin: 0 auto;
    width: max-content;
    flex-direction: column;
    display: flex;
}

.ham_sub_group {
    display: flex;
    gap: 80px;
    gap: 80px;
}

.ham_sub_list_group {
    font-size: 20px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    color: #6d707d;
    font-size: 24px;
    font-weight: 500;
    width: 20%;
}

.ham_sub_list_tit {
    padding-bottom: 10px;
    color: #d3a142;
}

.ham_sub_list {
    font-size: 20px;
    line-height: 34px;
    cursor: pointer;
    transition: 0.4s;
    position: relative;
    width: max-content;
    padding-bottom: 3px;
}

.ham_sub_list::after {
    bottom: 0;
    left: 0;
    position: absolute;
    transition: 0.4s;
    content: '';
    width: 0%;
    height: 1px;
    background-color: #fff;
}

.ham_sub_list::before {
    opacity: 0;
    transition: 0.4s;
    content: '';
    position: absolute;
    width: 28px;
    height: 28px;
    right: calc(100% + 11px);
    top: 50%;
    transform: translateY(-50%) scale(0);
    background: url(/img/header/dia.png) no-repeat center / contain;
}

.ham_sub_list:hover {
    color: #fff;
}

.ham_sub_list:hover::after {
    width: 100%;
}

.ham_sub_list:hover:before {
    opacity: 1;
    transform: translateY(-50%) scale(1);
}

html.header_on {}

html.header_on .ham_bar1 {
    transform: rotate(45deg);
    top: 6px;
}

html.header_on .ham_bar2 {
    transform: scaleX(0);
}

html.header_on .ham_bar3 {
    transform: rotate(-45deg);
    top: calc(100% - 14px);
}

html.header_on .ham_btn_group:hover .ham_bar1 {
    transform: rotate(45deg);
    top: 6px;
}

html.header_on .ham_btn_group:hover .ham_bar2 {
    transform: scaleX(0);
}

html.header_on .ham_btn_group:hover .ham_bar3 {
    transform: rotate(-45deg);
    top: calc(100% - 14px);
}

html.header_on .logo {
    filter: brightness(100);
}

html.header_on .header_right_group {
    filter: brightness(100);
}

html.header_on .ham {
    top: 0;
}

html.header_on {}

.bold {
    font-weight: 700;
}

.h100bx {
    width: 100%;
    height: 100px;
}

.ham_logo {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;
}

@media screen and (max-width: 1350px) {
    .ham_sub_list_group {
        font-size: 18px;
        gap: 8px;
    }

    .ham_sub_group {
        gap: 40px;
    }

    .ham_sub_df {
        gap: 40px;
    }
}

@media screen and (max-width: 1024px) {
    .ham_btn_group:hover .ham_bar1 {
        top: 0;
        transform: none;
    }

    .ham_btn_group:hover .ham_bar2 {
        transform: none;
    }

    .ham_btn_group:hover .ham_bar3 {
        top: calc(100% - 3px);
        transform: none;
    }

    .ham_sub_list_group {
        font-size: 16px;
        gap: 5px;
    }

    .ham_sub_group {
        gap: 20px;
    }

    html.header_on {
        overflow: hidden;
    }

    html.header_on .ham {
        left: 0;
    }

    /* .ham_sub_df { width: 90%; margin: 0 auto; } .ham_sub_group { flex-wrap: wrap; } */
}

@media screen and (max-height: 900px) {
    .ham_btn_group:hover .ham_bar1 {
        top: 0;
        transform: none;
    }

    .ham_btn_group:hover .ham_bar2 {
        transform: none;
    }

    .ham_btn_group:hover .ham_bar3 {
        top: calc(100% - 3px);
        transform: none;
    }

    .ham_sub_list_group {
        font-size: 16px;
        gap: 5px;
    }

    .ham_sub_group {
        gap: 20px;
    }

    .ham_sub_list {
        font-size: 16px;
    }

    .ham_sub_list::before {
        width: 14px;
        height: 14px;
    }

    /* .ham_sub_df { width: 90%; margin: 0 auto; } .ham_sub_group { flex-wrap: wrap; } */
}

@media screen and (max-width: 767px) {
    .ham_sub_df.pt {
        display: none;
    }

    .header {
        height: 57px;
    }

    .h100bx {
        height: 57px;
    }

    .logo {
        width: 83px;
        left: 5%;
        transform: translateY(-50%);
    }

    .logreg_group {
        font-size: 12px;
    }

    .header_right_group {
        gap: 17px;
    }

    .ham_btn_group {
        width: 21px;
    }

    .ham_bar {
        width: 100%;
    }

    .ham_logo {
        display: none;
    }

    .ham_bar1 {
        top: 1px;
    }

    .ham_bar2 {}

    .ham_bar3 {
        top: calc(100% - 5px);
    }

    .ham_btn_group:hover .ham_bar1 {
        top: 1px;
    }

    .ham_btn_group:hover .ham_bar3 {
        top: calc(100% - 5px);
    }

    .ham {
        top: 0;
        left: -100%;
    }

    .logo {
        transition: 0.4s 0.1s;
    }

    .header_right_group {
        transition: 0.1s;
    }

    html.header_on .logo {
        transition: 0.4s;
    }

    html.header_on .header_right_group {
        transition: 0.4s 0.3s;
    }

    .ham_m_bg {
        border-bottom: 1px solid #cac7c1;
        position: relative;
        z-index: 1;
        background-color: #1a5198;
        height: 57px;
        width: 100%;
    }

    .ham_sub_m_df {
        height: calc(100% - 57px);
        overflow-y: auto;
        color: #fff;
        display: flex;
        flex-direction: column;
    }

    .ham_sub_m_group {
        display: flex;
        flex-direction: column;
    }

    .ham_sub_m_tit {
        align-items: center;
        border-bottom: 1px solid #766b5a;
        font-size: 20px;
        padding: 21px 5%;
        display: flex;
        justify-content: space-between;
    }

    .ham_sub_m_cont {
        transition: 0.4s;
        background-color: #ffffff49;
        font-size: 18px;
        height: 0;
        overflow: hidden;
    }

    .m_header_wrap {
        padding: 21px 5%;
        display: flex;
        flex-direction: column;
        gap: 20px;
    }

    .ham_sub_m_group.on .ham_sub_m_cont {
        height: max-content;
    }

    .tit_arr {
        transition: 0.4s;
    }

    .ham_sub_m_group.on .tit_arr {
        transform: rotate(-180deg);
    }
}

/* side_gnb 시작 */
.side_gnb_group {
    transition: 0.4s;
    position: fixed;
    bottom: 75px;
    right: 50px;
    z-index: 999999;
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.side_gnb_top_btn {
    transition: 0.6s;
    opacity: 0;
    transform: translateX(50px);
    cursor: pointer;
    color: #fff;
    display: flex;
    flex-direction: column;
    gap: 5px;
    align-items: center;
    justify-content: center;
    width: 80px;
    height: 80px;
    font-size: 20px;
    border-radius: 50%;
    background-color: #1a5198;
    box-shadow: 0 0 20px #0000006e;
}

.side_gnb_bottom_btn {
    position: relative;
    width: 80px;
    height: 80px;
    display: flex;
    cursor: pointer;
    align-items: center;
    justify-content: center;
    /* border-radius: 50%; background-color: #1A5198; box-shadow: 0 0 20px #0000006e;  */
}

.side_gnb_group.nontop .side_gnb_top_btn {
    transform: translateX(0px);
    opacity: 1;
}

.bottom_btn_abbx {
    box-shadow: 0 0 20px #0000006e;
    opacity: 0;
    overflow: hidden;
    padding: 0;
    border-radius: 50px;
    transition: 0.8s;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    background-color: #1a5198;
}

.abbx_list {
    border-bottom: 1px solid #fff;
    padding: 16px 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    color: #fff;
    align-items: center;
    justify-content: center;
}

.abbx_list.last {
    border-bottom: none;
}

.bottom_btn_img {
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.bottom_btn_img img {
    width: 38px;
}

.bottom_btn_abbx.on {
    padding: 30px 0 15px;
    opacity: 1;
}

.abbx_list.list_hov>.abbx_list_img {
    transform: scale(1);
    transition: 0.4s;
}

.abbx_list.list_hov>.abbx_list_img img {
    max-width: 34px;
}

.abbx_list.list_hov:hover>.abbx_list_img {
    transform: scale(1.1);
}

.abbx_list.list_hov.first {
    padding-top: 0;
}

.open_quick_btn {
    position: absolute;
    bottom: -75px;
}

.abbx_list.last.list_hov>.abbx_list_img img {
    max-width: 32px;
}

/* side_gnb 끝 */

@media screen and (max-width: 767px) {
    .side_gnb_top_btn {
        display: none;
    }

    .side_gnb_group {
        right: 20px;
        bottom: 50px;
    }

    .side_gnb_bottom_btn {
        width: 60px;
        height: 60px;
    }

    .bottom_btn_img {
        width: 60px;
        height: 60px;
    }

    .bottom_btn_img img {
        width: 26px;
    }

    .abbx_list_txt {
        font-size: 11px;
    }

    .bottom_btn_abbx.on {
        padding: 20px 0 10px;
    }

    .abbx_list.list_hov>.abbx_list_img img {
        max-width: 32px;
    }

    .abbx_list.last.xbtn {
        padding-top: 0;
    }

    .abbx_list.last.xbtn img {
        width: 18px;
    }

    .abbx_list {
        padding: 10px 0;
    }

    .footer2_right {
        max-width: none;
    }

    .bottom_btn_abbx {
        bottom: 20px;
    }

    .open_quick_btn {
        bottom: -45px;
    }
}

/* 빠른예약 시작 */
.bottom_reserve_group {
    position: fixed;
    bottom: -100px;
    left: 0;
    z-index: 9999999;
    width: 100%;
    transition: 0.4s;
}

.bottom_reserve_top {
    position: absolute;
    transition: 0.4s;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%);
    cursor: pointer;
    background-color: #1a5198;
    color: #fff;
    font-size: 25px;
    display: flex;
    margin: 0 auto;
    gap: 15px;
    width: 200px;
    align-items: center;
    justify-content: center;
    height: 60px;
    border-radius: 20px 20px 0 0;
    box-shadow: 0 0 15px #00000031;
}

.bottom_reserve_top:hover {
    filter: brightness(0.8);
}

.bottom_reserve_top2 {
    display: flex;
    align-items: center;
    justify-content: center;
}

.bottom_reserve_bottom {
    height: 100px;
    background-color: #1a5198;
    position: relative;
    z-index: 3;
    display: none;
}

html.rev_on .bottom_reserve_group {
    bottom: 0;
}

html.rev_on .side_gnb_group {
    bottom: 130px;
}

html.rev_on .bottom_reserve_top2 img {
    transform: rotate(180deg);
}

.bottom_reserve_top2 img {
    transition: 0.4s;
}

.bottom_reserve_bottom .con {
    max-width: max-content;
    display: flex;
    gap: 37px;
    height: 100px;
    align-items: center;
}

.input_small_group {
    gap: 20px;
    display: flex;
}

.reserve_input.name {
    width: 200px;
}

.reserve_input.phone {
    width: 250px;
}

.bottom_reserve_bottom input[type='text'],
.bottom_reserve_bottom select {
    width: 100%;
    height: 50px;
    border-radius: 8px;
    box-sizing: border-box;
    padding-left: 20px;
    font-size: 20px;
    color: #fff;
    font-family: 'Pretendard';
    border: none;
    background-color: #ffffff1f;
    color: #fff;
}

.bottom_reserve_bottom input[type='text']::placeholder {
    color: #fff;
}

.bottom_reserve_bottom select {
    width: 250px;
    background: #ffffff1f url(/img/header/sel_arr.png) no-repeat 90% 50% / 8%;
}

.bottom_reserve_bottom select option {
    color: #1a1a1a;
}

.reserve_input_group {
    display: flex;
    gap: 37px;
}

.reserve_input.agree {
    display: flex;
    gap: 10px;
    height: 50px;
    align-items: center;
}

.reserve_input.agree .agree_check {
    padding-left: 30px;
    position: relative;
}

.reserve_input.agree .agree_check input {
    display: none;
}

.reserve_input.agree .agree_check label {
    font-size: 16px;
    color: #fff;
    cursor: pointer;
}

.reserve_input.agree .agree_check label::after {
    transition: 0.4s;
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    border-radius: 5px;
    border: 1px solid #fff;
    background-color: #05071442;
    box-sizing: border-box;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
}

.reserve_input.agree .agree_check label::before {
    z-index: 2;
    transition: 0.4s;
    opacity: 0;
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-70%) rotate(315deg);
    left: 3px;
    width: 15px;
    height: 8px;
    box-sizing: border-box;
    border-bottom: 3px solid #1a5198;
    border-left: 3px solid #1a5198;
}

.reserve_input.agree .agree_check label:hover::before {
    opacity: 0.5;
    border-color: #fff;
}

.reserve_input.agree .agree_check input:checked~label::before {
    opacity: 1;
}

.reserve_input.agree .agree_check input:checked~label::after {
    background-color: #fff;
}

.reserve_input.agree .agree_check label:hover::after {
    background-color: #05071442;
}

.reserve_input.agree .agree_check input:checked~label:hover::after {
    background-color: #05071442;
}

.reserve_input.agree .agree_link {
    cursor: pointer;
    font-size: 14px;
    width: 69px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    border-radius: 5px;
    background-color: #bbbcba44;
}

.reserve_input.agree {}

.reserve_input input[type='button'] {
    transition: 0.4s;
    cursor: pointer;
    font-family: 'Pretendard';
    width: 250px;
    height: 50px;
    border-radius: 8px;
    background-color: #d3a142;
    color: #fff;
    font-size: 20px;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
}

.reserve_input input[type='button']:hover {
    filter: brightness(0.8);
}

/* 빠른예약 끝 */

@media screen and (max-width: 1320px) {
    .bottom_reserve_top {
        gap: 10px;
        width: 150px;
        height: 50px;
        border-radius: 20px 20px 0 0;
        font-size: 18px;
    }

    .bottom_reserve_top2 img {
        width: 12px;
    }

    .bottom_reserve_bottom {
        padding: 20px 0 25px;
        border-radius: 20px 20px 0 0;
        height: auto;
    }

    .reserve_input_group {
        flex-direction: column;
        width: 100%;
        gap: 20px;
        max-width: 400px;
        margin: 0 auto;
    }

    .input_small_group {
        flex-direction: column;
        width: 100%;
    }

    .reserve_input.name {
        width: 100%;
    }

    .bottom_reserve_bottom .con {
        max-width: none;
        width: 90%;
        height: auto;
    }

    .reserve_input.phone {
        width: 100%;
    }

    html.rev_on .bottom_reserve_group {
        bottom: 0;
    }

    .bottom_reserve_group {
        bottom: -375px;
    }

    .bottom_reserve_bottom select {
        width: 100%;
        background-size: 5%;
        background-position: 95% 50%;
    }

    .reserve_input input[type='button'] {
        width: 100%;
    }

    .bottom_reserve_bottom input[type='text'],
    .bottom_reserve_bottom select {
        font-size: 18px;
    }

    html.rev_on .side_gnb_group {
        bottom: 400px;
    }

    .reserve_input.agree .agree_check input~label:hover::before {
        opacity: 0;
        border-color: #1a5198;
    }

    .reserve_input.agree .agree_check input:checked~label:hover::before {
        opacity: 1;
    }

    .reserve_input.agree .agree_check label:hover::after {
        background-color: #05071442;
    }

    .reserve_input.agree .agree_check input:checked~label:hover::after {
        background-color: #fff;
    }
}

/* 로그인 팝업 */

html.login_on {
    overflow: hidden;
}

.login_filter {
    display: none;
    position: fixed;
    z-index: 9999999999999;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #000000ad;
    backdrop-filter: blur(20px);
}

.popup_set {
    display: none;
}

html.login_on .login_filter {
    display: block;
}

.login_popup {
    display: none;
    padding-top: 30px;
    box-sizing: border-box;
    position: fixed;
    z-index: 99999999999999;
    width: 600px;
    min-height: 400px;
    max-height: 80vh;
    overflow-y: auto;
    background-color: #fff;
    border-radius: 20px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

html.login_on .login_popup {
    display: block;
}

.login_cont {
    display: flex;
    flex-direction: column;
    width: calc(100% - 100px);
    margin: 0 auto;
}

.login_logo {
    margin-bottom: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.login_cont input {
    font-size: 20px;
    width: 100%;
    font-family: 'Pretendard';
    border-radius: 8px;
    height: 60px;
    box-sizing: border-box;
    border: none;
}

.login_input_group input {
    background-color: #172e5923;
    color: #1a1a1a;
    padding-left: 5%;
}

.login_input_group input::placeholder {
    color: #1a1a1a46;
}

.login_input_group {
    display: flex;
    flex-direction: column;
    gap: 5px;
}

.login_submit_btn {
    padding: 20px 0;
}

.login_submit_btn input {
    background-color: #2473c7;
    color: #fff;
    cursor: pointer;
    transition: 0.4s;
}

.login_submit_btn input:hover {
    filter: brightness(0.8);
}

.login_bottom_group {
    display: flex;
    justify-content: center;
    gap: 20px;
    color: #aaadaf;
}

.login_bottom_line {
    width: 1px;
    height: 15px;
    background-color: #aaadaf;
}

.register_btn,
.find_btn {
    cursor: pointer;
}

.login_xbtn {
    position: absolute;
    top: 30px;
    right: 30px;
    cursor: pointer;
    transition: 0.4s;
}

.login_xbtn:hover {
    transform: rotate(90deg);
}

.easy_login {
    display: flex;
    flex-direction: column;
    gap: 23px;
    margin-top: 20px;
}

.easy_login .easy_login_tit {
    font-size: 16px;
    color: #bbbcba;
    align-items: center;
    display: flex;
    justify-content: center;
    align-items: center;
}

.easy_login .easy_login_tit .easy_tit_line {
    width: 100%;
    height: 1px;
    background-color: #bbbcba;
}

.easy_login .easy_login_tit .easy_tit {
    padding: 0 30px;
    white-space: nowrap;
}

.easy_login {}

.easy_login_btn_group {
    display: flex;
    justify-content: center;
    gap: 20px;
    padding-bottom: 45px;
}

.easy_login_btn {
    cursor: pointer;
    transition: 0.4s;
    max-width: 140px;
}

.easy_login_btn:hover {
    filter: brightness(0.8);
}

@media screen and (max-width: 767px) {
    .login_popup {
        width: 90%;
    }

    .login_cont {
        width: calc(100% - 30px);
    }
}

/* 회원가입 팝업 */
.join_popup {
    padding-top: 30px;
    box-sizing: border-box;
    position: fixed;
    z-index: 99999999999999;
    width: 600px;
    height: auto;
    background-color: #fff;
    border-radius: 20px;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    padding-bottom: 65px;
}

.join_cont {
    display: flex;
    flex-direction: column;
    width: calc(100% - 100px);
    margin: 0 auto;
    padding-bottom: 50px;
}

.join_id {
    position: relative;
}

.join_id .join_box {
    padding-bottom: 40px;
}

.join_id p {
    position: absolute;
    right: 0;
    bottom: 10px;
    color: #bbbcba;
    font-size: 16px;
}

/* .join_cont input { font-size: 20px; width: 100%; font-family: 'Pretendard'; border-radius: 8px; height: 60px; box-sizing: border-box; border: none; } */
.join_cont input[type='checkbox'] {
    border: solid 2px #bbbcba;
    width: 20px;
    height: 20px;
    border-radius: 5px;
    vertical-align: text-bottom;
}

.join_area {
    height: 150px;
    width: 100%;
    border-radius: 10px;
    border: 1px solid #bbbcba;
    background: #fff;
    resize: none;
    padding: 20px;
    line-height: 1.5;
    font-family: 'Pretendard';
    box-sizing: border-box;
}

.join_info_title {
    color: #000;
    font-family: Pretendard;
    font-size: 22px;
    font-style: normal;
    font-weight: 400;
    margin-bottom: 20px;
}

.join_info_title span {
    color: #a48362;
}

.checkbox_layout {
    display: flex;
}

.join_cont .check_layout input[type='checkbox'] {
    appearance: initial;
}

.join_cont .required_title {
    margin-top: 25px;
    font-family: Pretendard;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 25px;
    color: #a48362;
    border-bottom: solid 1px #bbbcba;
    text-align: right;
}

.join_dot {
    width: 5px;
    height: 5px;
    background-color: #a48362;
    display: inline-block;
    border-radius: 50%;
    vertical-align: top;
}

.join_box {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 0;
    border-bottom: solid 1px #bbbcba;
}

.join_box2 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 0;
    border-bottom: solid 1px #bbbcba;
}

.join_box2 .dep_2 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 70%;
}

.join_box2 .dep_2 input[type='text'] {
    width: 45%;
}

.join_box2 .dep_3 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 70%;
    gap: 10px;
}

.join_box2 select {
    height: 50px;
    box-sizing: border-box;
    border-radius: 10px;
    border: 1px solid #bbbcba;
    background: #fff;
    font-family: Pretendard;
    font-size: 22px;
    font-style: normal;
    font-weight: 400;
    line-height: 22px;
    color: #000;
    display: flex;
    align-items: center;
    padding-left: 20px;
    justify-content: center;
    width: 33%;
}

.join_box2 .dep_3 input[type='text'] {
    width: 33%;
}

.join_box3 {
    display: flex;
    gap: 30px;
    align-items: center;
    padding: 20px 0;
}

.join_cont label {
    color: #000;
    font-family: Pretendard;
    font-size: 22px;
    font-style: normal;
    font-weight: 400;
    line-height: 22px;
}

.join_cont input[type='text'],
.join_cont input[type='password'] {
    border-radius: 10px;
    border: 1px solid #bbbcba;
    background: #fff;
    font-family: Pretendard;
    font-size: 22px;
    font-style: normal;
    height: 50px;
    box-sizing: border-box;
    font-weight: 400;
    line-height: 22px;
    color: #000;
    padding: 14px 20px;
}

.join_box input[type='text'],
.join_box input[type='password'] {
    width: 62%;
}

.join_btn {
    margin-top: 42px;
    width: 100%;
    border-radius: 8px;
    background: #2473c7;
    color: #fff;
    text-align: center;
    font-family: Pretendard;
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    border: none;
    padding: 20px 0;
}

/* 서브페이지 subheader */
.sub_header {
    overflow: hidden;
    position: relative;
    width: 100%;
}

.sub_header_bg {
    width: 100%;
    height: calc(100vh - 100px);
    position: relative;
}

.sub_header_remote {
    position: absolute;
    bottom: -1px;
    left: 0;
    z-index: 2;
    display: flex;
    width: 100%;
}

.sub_menu_list:nth-child(2) {
    z-index: 3;
}

.sub_menu_list:nth-child(3) {
    z-index: 2;
}

.sub_menu_list:nth-child(4) {
    z-index: 1;
}

.sub_menu_list:nth-child(5) {
    z-index: 0;
}

.sub_menu_list {
    transition: 0.4s;
    cursor: pointer;
    width: 100%;
    font-weight: 700;
    font-size: 26px;
    position: relative;
    border-radius: 50px 50px 0 0;
    height: 90px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}

.sub_menu_list .sub_list_txt {
    transition: 0.4s;
    opacity: 0.8;
    position: relative;
}

.sub_menu_list .sub_list_txt::after {
    width: 28px;
    height: 28px;
    transition: 0.4s;
    content: '';
    position: absolute;
    right: calc(100% + 5px);
    top: 50%;
    transform: translateY(-50%) scale(0);
    background: url(/img/header/dia.png) no-repeat center/contain;
}

.sub_menu_list.on .sub_list_txt,
.sub_menu_list:hover .sub_list_txt {
    opacity: 1;
}

.sub_menu_list.on .sub_list_txt::after,
.sub_menu_list:hover .sub_list_txt::after {
    transform: translateY(-50%) scale(1);
}

.sub_menu_list.on {
    z-index: 3;
    box-shadow: 0 4px 6px #225d9c42;
}

.sub_menu_list:hover {}

.sub_header_tit {
    position: absolute;
    display: flex;
    flex-direction: column;
    gap: 5px;
    align-items: center;
    top: 110px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
}

.sub_header_tit1 {
    font-size: 56px;
    font-weight: 700;
}

.sub_header_tit2 {
    font-size: 28px;
    font-weight: 500;
    color: #838383;
    text-transform: capitalize;
}

.sub {
    position: relative;
    z-index: 5;
    top: -1px;
    overflow: hidden;
}

@media screen and (max-width: 1320px) {
    .sub_menu_list {
        display: flex;
        align-items: center;
        justify-content: center;
        line-height: 1.3;
        text-align: center;
        height: 45px;
        border-radius: 0;
        font-size: 12px;
        box-shadow: none;
        border-right: 1px solid #fff;
    }

    .sub_menu_list:last-child {
        border-right: none;
    }

    .sub_menu_list .sub_list_txt::after {
        width: 15px;
        height: 15px;
    }

    .sub_menu_list .sub_list_txt {
        width: max-content;
    }
}

@media screen and (max-width: 767px) {
    .sub_header_tit {
        top: 40px;
        width: max-content;
    }

    .sub_header_tit1 {
        font-size: 30px;
    }

    .sub_header_tit2 {
        font-size: 24px;
    }

    .sub_header_bg {
        aspect-ratio: 75/152;
        height: auto;
    }
}

/* 아이디 비번 찾기 */
.set3_con {
    width: calc(100% - 100px);
    margin: 0 auto;
}

.set3_tit {
    margin-top: 56px;
    display: flex;
}

.set3_tit>div {
    width: 50%;
    transition: 0.4s;
    cursor: pointer;
    font-weight: 700;
    padding-bottom: 21px;
    border-bottom: 2px solid #bbbcba;
    text-align: center;
    font-size: 22px;
    opacity: 0.6;
}

.set3_tit>div:hover,
.set3_tit>div.on {
    opacity: 1;
    border-bottom: 2px solid #042b48;
}

.set3_con_group input[type='text'],
.set3_con_group input[type='password'] {
    height: 50px;
    width: 70%;
    font-size: 22px;
    padding: 14px 20px;
    box-sizing: border-box;
    border-radius: 10px;
    border: 1px #bbbcba solid;
}

.set3_con_group input[type='text']::placeholder,
.set3_con_group input[type='password']::placeholder {
    color: #bbbcba;
    font-size: 16px;
}

.set3_con_group {
    padding-bottom: 50px;
}

.set3_con_group>form.set3_con2 {
    display: none;
}

.find_bx {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 20px 0;
}

.bbbx {
    border-bottom: 1px solid #bbbcba;
}

.find_bx label {
    font-size: 22px;
}

.find_id_btn {
    cursor: pointer;
    transition: 0.4s;
    margin-top: 20px;
    width: 100%;
    border-radius: 8px;
    background: #2473c7;
    color: #fff;
    text-align: center;
    font-family: Pretendard;
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    border: none;
    padding: 20px 0;
}

.find_id_btn:hover {
    filter: brightness(0.8);
}

.find_pw_btn {
    cursor: pointer;
    transition: 0.4s;
    margin-top: 20px;
    width: 100%;
    border-radius: 8px;
    background: #2473c7;
    color: #fff;
    text-align: center;
    font-family: Pretendard;
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    border: none;
    padding: 20px 0;
}

.find_pw_btn:hover {
    filter: brightness(0.8);
}

.find_last_btn {
    margin-bottom: 50px;
    cursor: pointer;
    transition: 0.4s;
    margin-top: 20px;
    width: 100%;
    border-radius: 8px;
    background: #2473c7;
    color: #fff;
    text-align: center;
    font-family: Pretendard;
    font-size: 20px;
    font-style: normal;
    font-weight: 400;
    border: none;
    padding: 20px 0;
}

.find_last_btn:hover {
    filter: brightness(0.8);
}

.find_last_con_group {
    padding-bottom: 90px;
    display: flex;
    flex-direction: column;
    gap: 50px;
    align-items: center;
}

.find_img {
    width: 73px;
}

.find_txt_group {
    text-align: center;
}

.find_txt_group>div {
    display: none;
}

.find_id_data {
    color: #2473c7;
}

.find_txt1 {
    font-size: 20px;
    font-weight: 700;
}

.find_txt2 {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.find_txt2_1 {
    font-size: 20px;
    font-weight: 700;
}

.find_txt2_2 {
    font-size: 16px;
    line-height: 1.5;
}

.pw_cont1 {
    margin-top: 50px;
    padding-bottom: 50px;
    border-bottom: 1px solid #bbbcba;
}

.pw_cont2 {
    margin-top: 50px;
}

.pw_cont2_tit {
    text-align: center;
    font-size: 22px;
}

.pw_email_label {
    font-size: 22px;
    width: max-content;
    padding-top: 14px;
}

.pw_email {
    display: flex;
    gap: 16px;
}

.pw_email input[type='text'] {
    width: calc(100% - 12px - 79px);
    font-size: 16px;
}

.pw_email_input_group {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: calc(100% - 118px);
}

.pw_email_input_group>div {
    display: flex;
    gap: 12px;
    width: 100%;
}

.pw_btn_class {
    height: 50px;
    transition: 0.4s;
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
    background-color: #838383;
    border-radius: 10px;
    color: #fff;
    border: none;
    width: 79px;
    cursor: pointer;
}

.pw_btn_class:hover {
    filter: brightness(0.8);
}

.time_abbx {
    width: calc(100% - 12px - 79px);
    position: relative;
}

.time_abbx input[type='text'] {
    width: 100%;
}

.time_txt {
    top: 15px;
    opacity: 0.4;
    font-size: 20px;
    right: 13px;
    position: absolute;
}

.check_txt {
    position: absolute;
    top: calc(100% + 13px);
    right: 10px;
    font-size: 20px;
    font-weight: 500;
    text-align: right;
}

.pass {
    color: #2473c7;
}

.non_pass {
    color: #c02727;
}

.check_layout {
    padding-left: 30px;
    position: relative;
    margin-top: 15px;
}

.check_layout input {
    display: none;
}

.check_layout label {
    font-size: 16px;
    color: #000;
    cursor: pointer;
}

.check_layout label::after {
    transition: 0.4s;
    content: '';
    position: absolute;
    width: 20px;
    height: 20px;
    border-radius: 5px;
    border: 1px solid #bbbcba;
    background-color: #fff;
    box-sizing: border-box;
    top: 50%;
    transform: translateY(-50%);
    left: 0;
}

.check_layout label::before {
    z-index: 2;
    transition: 0.4s;
    opacity: 0;
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-70%) rotate(315deg);
    left: 3px;
    width: 15px;
    height: 8px;
    box-sizing: border-box;
    border-bottom: 3px solid #1a5198;
    border-left: 3px solid #1a5198;
}

.check_layout label:hover::before {
    opacity: 0.5;
}

.check_layout input:checked~label::before {
    opacity: 1;
}

.check_layout input:checked~label::after {}

.check_layout label:hover::after {}

.check_layout input:checked~label:hover::after {}

@media screen and (max-width: 767px) {
    .find_bx label {
        font-size: 16px;
    }

    .find_bx {
        flex-direction: column;
        align-items: flex-start;
        gap: 15px;
        padding: 10px 0;
    }

    .set3_con_group input[type='text'],
    .set3_con_group input[type='password'] {
        height: 50px;
        font-size: 16px;
        width: 100%;
    }

    .bbbx {
        border-bottom: none;
    }

    .set3_tit>div {
        font-size: 16px;
        padding-bottom: 20px;
    }

    .set3_con {
        width: 90%;
    }

    .set3_con_group {
        padding-top: 30px;
        padding-bottom: 30px;
    }

    .find_id_btn {
        height: 50px;
        box-sizing: border-box;
        padding: 0;
    }

    .join_info_title {
        font-size: 16px;
    }

    .join_cont {
        width: 90%;
    }

    .pw_email {
        flex-direction: column;
    }

    .pw_email {}

    .pw_email {}

    .pw_email_label {
        font-size: 16px;
    }

    .pw_cont1 {
        margin-top: 0;
        margin-bottom: 30px;
        padding-bottom: 30px;
    }

    .pw_email_input_group {
        width: 100%;
    }

    .pw_btn_class {
        font-size: 16px;
        width: 100%;
    }

    .pw_email_input_group>div {
        flex-direction: column;
    }

    .time_abbx {
        width: 100%;
    }

    .time_abbx {
        margin-bottom: 0px;
    }

    .check_txt {
        font-size: 16px;
        position: relative;
        margin-top: 10px;
    }

    .pw_cont2 {
        margin-top: 30px;
    }

    .pw_cont2_tit {
        margin-bottom: 30px;
    }

    .check_layout label {
        font-size: 12px !important;
    }

    .join_box {
        padding: 10px 0;
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
        border-bottom: none;
    }

    .join_cont label {
        font-size: 16px;
    }

    .check_layout input~label:hover::before {
        opacity: 0;
    }

    .check_layout input:checked~label:hover::before {
        opacity: 1;
    }

    .check_layout label:hover::after {}

    .check_layout input:checked~label:hover::after {}

    .join_cont input[type='text'],
    .join_cont input[type='password'] {
        width: 100%;
        font-size: 16px;
    }

    .join_box2 select {
        font-size: 16px;
    }

    .join_box2 .dep_2 {}

    .join_cont input[type='text'],
    .join_cont input[type='password'] {
        padding: 0;
        padding-left: 5px;
    }

    .join_box2 .dep_2 input[type='text'] {
        width: 45%;
    }

    .join_box2 {
        border-bottom: none;
        padding: 10px 0;
        flex-direction: column;
        align-items: flex-start;
        gap: 10px;
    }

    .join_box3 {
        border-top: 1px solid #bbbcba;
    }

    .join_box2 .dep_3 {
        width: 100%;
    }
}

.header_box {
    display: flex;
    flex-direction: column;
    background-color: #fff;
}

@media screen and (max-width: 767px) {
    .header_right_group {
        height: 57px;
    }
}

/* datepicker start */
.ui-widget-header {
    border: 0px solid #dddddd;
    background: #fff;
}

.ui-datepicker-calendar>thead>tr>th {
    font-size: 14px !important;
}

.ui-datepicker .ui-datepicker-header {
    position: relative;
    padding: 10px 0;
}

.ui-state-default,
.ui-widget-content .ui-state-default,
.ui-widget-header .ui-state-default,
.ui-button,
html .ui-button.ui-state-disabled:hover,
html .ui-button.ui-state-disabled:active {
    border: 0px solid #c5c5c5;
    background-color: transparent;
    font-weight: normal;
    color: #454545;
    text-align: center;
}

.ui-datepicker .ui-datepicker-title {
    margin: 0 0em;
    line-height: 16px;
    text-align: center;
    font-size: 14px;
    padding: 0px;
    font-weight: bold;
}

.ui-datepicker {
    display: none;
    background-color: #fff;
    border-radius: 4px;
    margin-top: 10px;
    margin-left: 0px;
    margin-right: 0px;
    padding: 20px;
    padding-bottom: 10px;
    width: 300px;
    box-shadow: 10px 10px 40px rgba(0, 0, 0, 0.1);
}

.ui-widget.ui-widget-content {
    border: 1px solid #eee;
}

#datepicker:focus>.ui-datepicker {
    display: block;
}

.ui-datepicker-prev,
.ui-datepicker-next {
    cursor: pointer;
}

.ui-datepicker-next {
    float: right;
}

.ui-state-disabled {
    cursor: auto;
    color: hsla(0, 0%, 80%, 1);
}

.ui-datepicker-title {
    text-align: center;
    padding: 10px;
    font-weight: 100;
    font-size: 20px;
}

.ui-datepicker-calendar {
    width: 100%;
}

.ui-datepicker-calendar>thead>tr>th {
    padding: 5px;
    font-size: 20px;
    font-weight: 400;
}

.ui-datepicker-calendar>tbody>tr>td>a {
    color: #000;
    font-size: 12px !important;
    font-weight: bold !important;
    text-decoration: none;
}

.ui-datepicker-calendar>tbody>tr>.ui-state-disabled:hover {
    cursor: auto;
    background-color: #fff;
}

.ui-datepicker-calendar>tbody>tr>td {
    border-radius: 100%;
    width: 44px;
    height: 30px;
    cursor: pointer;
    padding: 5px;
    font-weight: 100;
    text-align: center;
    font-size: 12px;
}

.ui-datepicker-calendar>tbody>tr>td:hover {
    background-color: transparent;
    opacity: 0.6;
}

.ui-state-hover,
.ui-widget-content .ui-state-hover,
.ui-widget-header .ui-state-hover,
.ui-state-focus,
.ui-widget-content .ui-state-focus,
.ui-widget-header .ui-state-focus,
.ui-button:hover,
.ui-button:focus {
    border: 0px solid #cccccc;
    background-color: transparent;
    font-weight: normal;
    color: #2b2b2b;
}

.ui-icon-circle-triangle-e {
    background-position: -20px 0px;
    background-size: 36px;
}

.ui-icon-circle-triangle-w {
    background-position: -0px -0px;
    background-size: 36px;
}

.ui-datepicker-calendar>tbody>tr>td:first-child a {
    color: red !important;
}

.ui-datepicker-calendar>tbody>tr>td:last-child a {
    color: #0099ff !important;
}

.ui-datepicker-calendar>thead>tr>th:first-child {
    color: red !important;
}

.ui-datepicker-calendar>thead>tr>th:last-child {
    color: #0099ff !important;
}

.ui-state-highlight,
.ui-widget-content .ui-state-highlight,
.ui-widget-header .ui-state-highlight {
    width: 100%;
    align-items: center;
    justify-content: center;
    display: flex;
    border: 0px;
    background: #f1f1f1;
    border-radius: 50%;
    padding: 5px;
    padding-top: 3px;
}

.inp {
    padding: 10px 10px;
    background-color: #f1f1f1;
    border-radius: 4px;
    border: 0px;
}

.inp:focus {
    outline: none;
    background-color: #eee;
}

.datepicker {
    padding: 5px;
    font-size: 18px;
    font-family: 'Noto Sans', sans-serif;
    border: 1px solid #000;
    border-radius: 3px;
}

.ui-datepicker .ui-datepicker-title {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

@media screen and (max-width: 767px) {
    .abbx_list {
        gap: 6px;
        padding: 8px 0;
    }

    .bottom_btn_abbx.on {
        padding: 14px 0 6px;
    }

    .abbx_list:not(.list_hov).last {
        padding: 0 0 8px;
        gap: 4px;
    }

    .abbx_list.last .top_btn2 {
        font-size: 11px;
    }

    .abbx_list.last .top_btn1 {
        max-width: 24px;
    }

    .abbx_list.list_hov>.abbx_list_img img {
        max-width: 28px;
    }
}

.w1440 {
    width: 90%;
    max-width: 1440px;
    margin: 0 auto;
}

.w1280 {
    width: 90%;
    max-width: 1280px;
    margin: 0 auto;
}

.sub_big_tit {
    color: var(--grayscale-900, #171717);
    font-family: 'Noto Serif KR';
    font-size: 34px;
    font-style: normal;
    font-weight: 300;
    line-height: 140%;
    /* 47.6px */
    letter-spacing: -2.04px;
    display: block;
}

.sub_big_tit b {
    color: #1c5c6b;
    font-weight: 500;
}

.sub_tit_txt {
    color: var(--grayscale-700, #404040);
    font-family: Pretendard;
    font-size: 18px;
    font-style: normal;
    font-weight: 300;
    line-height: 160%;
    /* 28.8px */
    letter-spacing: -0.36px;
    display: block;
}

._cover img,
._cover video,
._cover iframe {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mobile_block {
    display: none;
}

.ovh {
    overflow: hidden;
}

/* 커스텀 셀렉트 박스 */
.selectBox {
    position: relative;
}

.selectBox .label {
    box-shadow: 0px 3px 4px 0px rgba(0, 0, 0, 0.25);
    background: #fff;
    border-radius: 6px;
    border: 0;
    color: #333;
    font-size: 14px;
    font-weight: 400;
    line-height: 120%;
    letter-spacing: -0.56px;
    padding: 8px 10px;
}

.selectBox .optionList {
    position: absolute;
    height: 0;
    overflow: hidden;
    transition: 0.3s ease-in;
    top: calc(100% + 10px);
    left: 0;
    z-index: 10;
    background: #fff;
    border-radius: 10px;
    box-shadow: 5px 9px 10px rgba(0, 0, 0, 0.1);
}

.selectBox .optionList>div {
    display: flex;
    flex-direction: column;
}

.selectBox .optionList.active {
    height: fit-content;
}

@media screen and (max-width: 768px) {
    .mobile_block {
        display: block;
    }

    .pc_block {
        display: none;
    }

    .sub_tit_txt {
        font-size: 15px;
        letter-spacing: -0.3px;
    }
}

/* 과천 - 이미지 슬라이더 */
.img_slider_box {
    overflow: hidden;
    position: relative;
    flex-direction: column;
    user-select: none;
    touch-action: pan-x;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 20px;
    overflow: hidden;
}

.img_slider_box .slider_img_box {
    max-height: 396px;
    /* aspect-ratio: 759 / 396; */
    width: 100%;
    height: 100%;
    object-fit: cover;
    /* overflow: hidden; */
}

.img_slider_box .slider_img_box:nth-child(2) {
    position: absolute;
    top: 0;
    left: 0;
    clip-path: polygon(50% 0, 100% 0, 100% 100%, 50% 100%);
}

.img_slider_box .slider_img_box img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: contain;
}

.img_slider_box .slider_btn {
    position: absolute;
    left: 50%;
    background: #fff;
    width: 2px;
    top: 0;
    height: 100%;
}

.img_slider_box .slider_btn .slider_shape {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 64px;
    height: 64px;
    display: block;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: grab;
    user-select: none;
}

.img_slider_box .slider_btn>img {
    display: block;
    pointer-events: none;
}

.img_slider_box .slider_btn .tag {
    display: flex;
    align-items: center;
    gap: 6px;
    position: absolute;
    left: calc(100% + 32px);
    top: 50%;
    transform: translateY(-50%);
    border-radius: 6px;
    background: rgba(0, 0, 0, 0.4);
    padding: 0 6px;
    width: max-content;
    color: #fff;
    text-align: center;
    font-family: Pretendard;
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: 160%;
    /* 25.6px */
    letter-spacing: -0.32px;
    transition: 0.3s;
}

.img_slider_box .slider_btn:hover .tag {
    opacity: 0;
}

.img_slider_box .slider_btn .tag img {
    width: 20px;
    height: 20px;
}

.slider_wrap .info_group {
    display: flex;
    padding-top: 10px;
    justify-content: space-between;
    width: 100%;
    font-family: Pretendard;
    box-sizing: border-box;
}

.slider_wrap .info_group p {
    text-align: center;
    color: #737373;
    font-family: Pretendard;
    font-size: 16px;
    font-style: normal;
    font-weight: 500;
    line-height: 160%;
    /* 25.6px */
    letter-spacing: -0.32px;
    flex: 1;
    opacity: 1;
    transition: 0.4s;
}

.slider_wrap .info_group p:first-child {
    color: var(--grayscale-800, #262626);
}

.slider_wrap.left .info_group p {
    opacity: 0;
}

.slider_wrap.left .info_group p:first-child {
    opacity: 1;
}

.slider_wrap.right .info_group p {
    opacity: 0;
}

.slider_wrap.right .info_group p:last-child {
    opacity: 1;
}

.slider_wrap .info_group span {
    display: block;
}

@media screen and (max-width: 980px) {
    .img_slider_box .slider_btn {
        position: absolute;
        left: 50%;
        background: #fff;
        height: fit-content;
        width: 1px;
        top: 0;
        height: 100%;
        height: 100%;
        z-index: 1;
    }

    .img_slider_box .slider_btn .slider_shape {
        width: 30px;
        height: 30px;
    }

    .slider_wrap .info_group {
        padding: 10px 20px 0;
    }

    .slider_wrap .info_group p {
        font-weight: 600;
    }
}

@media screen and (max-width: 768px) {
    .img_slider_box .slider_btn .tag img {
        width: 12px;
        height: 12px;
    }

    .img_slider_box .slider_btn .tag {
        font-size: 10px;
        gap: 3px;
    }
}

@media screen and (max-width: 480px) {
    .slider_wrap .info_group span {
        display: none;
    }
}

/* 텍스트 롤링 */
.rolling_wrap {
    display: flex;
    padding: 50px 0;
}

.rolling_wrap img {
    max-width: unset;
}

.rolling_wrap img:first-child {
    animation: rolltxt1 35s linear infinite;
    padding-right: 70px;
}

.rolling_wrap img:last-child {
    animation: rolltxt2 35s linear infinite;
    padding-right: 70px;
}

@keyframes rolltxt1 {
    0% {
        transform: translateX(0);
    }

    50% {
        transform: translateX(-100%);
    }

    50.1% {
        transform: translateX(100%);
    }

    100% {
        transform: translateX(0);
    }
}

@keyframes rolltxt2 {
    0% {
        transform: translateX(0);
    }

    100% {
        transform: translateX(-200%);
    }
}

@media screen and (max-width: 768px) {
    .rolling_wrap {
        padding: 19px 0;
    }

    .rolling_wrap img {
        height: 30px;
    }

    .rolling_wrap img:first-child {
        padding-right: 30px;
    }

    .rolling_wrap img:last-child {
        padding-right: 30px;
    }
}

[data-aos='fade-right'] {
    transform: translate3d(-30px, 0, 0);
}

[data-aos='fade-left'] {
    transform: translate3d(30px, 0, 0);
}

[data-aos='fade-down'] {
    transform: translate3d(0, -30px, 0);
}

[data-aos='fade-up'] {
    transform: translate3d(0, 30px, 0);
}