@charset "utf-8";

/* Zig Alert */
#zig-alert-wrap {
    background: rgba(0, 0, 0, 0.15);
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 900;
}

#zig-alert {
    background: #fff;
    border-radius: 8px;
    box-shadow: 3px 3px 50px rgba(0, 0, 0, 0.1);
    box-sizing: border-box;
    left: 50%;
    opacity: 0;
    position: fixed;
    top: calc(50% - 5px);
    transform: translate(-50%, -50%);
    transition: all 0.3s;
    width: 450px;
    z-index: 901;
}

#zig-alert.show {
    opacity: 1;
    top: 50%;
}

#zig-alert .content {
    border-bottom: 1px solid #eee;
    max-height: calc(100vh - 160px);
    overflow-y: auto;
    padding: 35px;
}

#zig-alert .content p {
    color: #000;
    font-size: 15px;
    line-height: 24px;
    letter-spacing: -1px;
    text-align: center;
    word-break: break-all;
}

#zig-alert .button {
    padding: 15px;
    text-align: center;
}

#zig-alert .button button {
    background: none;
    border: none;
    border-radius: 4px;
    color: var(--primary);
    font-size: 16px;
    font-weight: bold;
    letter-spacing: -1px;
    line-height: 40px;
    padding: 0 20px;
}

#zig-alert .button button:hover {
    background: #f7f7f7;
}

/* Zig Confirm */
#zig-confirm-wrap {
    background: rgba(0, 0, 0, 0.15);
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 900;
}

#zig-confirm {
    background: #fff;
    border-radius: 8px;
    box-shadow: 3px 3px 50px rgba(0, 0, 0, 0.1);
    box-sizing: border-box;
    left: 50%;
    opacity: 0;
    position: fixed;
    top: calc(50% - 5px);
    transform: translate(-50%, -50%);
    transition: all 0.3s;
    width: 450px;
    z-index: 901;
}

#zig-confirm.show {
    opacity: 1;
    top: 50%;
}

#zig-confirm .content {
    border-bottom: 1px solid #eee;
    max-height: calc(100vh - 160px);
    overflow-y: auto;
    padding: 35px;
}

#zig-confirm .content p {
    color: #000;
    font-size: 15px;
    line-height: 24px;
    letter-spacing: -1px;
    text-align: center;
    word-break: break-all;
}

#zig-confirm .button {
    padding: 15px;
    text-align: center;
}

#zig-confirm .button button {
    background: none;
    border: none;
    border-radius: 4px;
    font-size: 16px;
    letter-spacing: -1px;
    line-height: 40px;
    padding: 0 20px;
}

#zig-confirm .button button:hover {
    background: #f7f7f7;
}

#zig-confirm .button button.no {
    color: #999999;
}

#zig-confirm .button button.yes {
    color: #6b52e9;
    font-weight: bold;
}

.padding-top-2 {
    padding-top: 2rem;
}

.padding-top-4 {
    padding-top: 4rem;
}

.padding-top-6 {
    padding-top: 6rem;
}

.padding-top-8 {
    padding-top: 8rem;
}

/* Popup */
.ph-pop {
    background: #ffffff;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 3px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.05);
    overflow: hidden;
    position: absolute;
    z-index: 50;
}

.ph-pop .link {
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2;
}

.ph-pop .pop-cont {
    overflow: hidden;
    position: relative;
}

.ph-pop .pop-btn {
    border-top: 1px solid rgba(0, 0, 0, 0.1);
    position: relative;
    z-index: 3;
    zoom: 1;
}


.ph-pop .pop-btn:after {
    clear: both;
    content: '';
    display: block;
}

.ph-pop .pop-btn a {
    background: #f7f7f7;
    border-left: 1px solid rgba(0, 0, 0, 0.1);
    box-sizing: border-box;
    color: #333333;
    display: block;
    float: left;
    font-size: 12px;
    letter-spacing: -1px;
    line-height: 35px;
    text-align: center;
    text-decoration: none;
    width: 50%;
}

.ph-pop .pop-btn a:first-child {
    border-left: none;
}

.ph-pop .pop-btn .close {
    left: 0;
    top: 0;
}

.ph-pop .pop-btn .close-today {
    right: 0;
    top: 0;
}


@media (max-width: 992px) {
    .ph-pop {
        display: none;
    }
}


/* ==========================================
   HEADER - basic-N56 (PC + 모바일)
   ========================================== */

/* PC 헤더 기본 스타일 */
.basic-N56 {
    width: 100%;
    min-height: 6rem;
    background: #0B0C0CFF;
    will-change: background, height;
    transition: background 0.3s, min-height 0.3s;
    top: 0;
    left: 0;
    z-index: 999;
    position: fixed;
    padding-top: 0rem;
}

.basic-N56.top-menu-active .header-container {
    padding-top: 6.7rem;
}

.basic-N56.gnb-active {
    min-height: 28rem;
}

.basic-N56.top-menu-active.gnb-active {
    min-height: calc(28rem + 6.6rem);
}

.basic-N56.block-active {
    background: var(--black);
}

.basic-N56 .header-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 8rem;
    box-sizing: border-box;
}

.basic-N56 .header-top {
    width: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: #111;
}

.basic-N56 .user-menu {
    width: 100%;
    max-width: 1440px;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 0 8rem;
    margin: 0 auto;
}

.basic-N56 .user-menu li {
    position: relative;
}

.basic-N56 .user-menu li:not(:first-child)::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 1px;
    height: 1.2rem;
    background: #767676;
}

.basic-N56 .user-menu li a {
    padding: 2rem 1.2rem;
    color: #e5e5e5;
    text-align: center;
    white-space: nowrap;
}

.basic-N56 .user-menu li:last-child a {
    padding: 2rem 0 2rem 1.2rem;
}

.basic-N56 .header-left {
    display: flex;
    align-items: center;
    gap: 3rem;
}

.basic-N56 .header-title {
    margin-bottom: 0;
}

.basic-N56 .header-title a {
    height: 3.3rem;
}

.basic-N56 .header-title img {
    height: 100%;
    object-fit: contain;
    vertical-align: top;
}

.basic-N56 .header-member {
    display: none;
}

/* PC 메뉴 스타일 */
.basic-N56 .header-gnblist {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    margin: 0;
    padding: 0;
}

.basic-N56 .header-gnbitem {
    width: 180px;
    text-align: center;
}

.basic-N56 .header-gnblink {
    color: white;
    text-decoration: none;
    font-size: 16px;
    font-weight: 500;
    padding: 25px 0;
    display: block;
    transition: all 0.3s ease;
    white-space: nowrap;
    border-right: 1px solid #333;
    position: relative;
    width: 100%;
}

.basic-N56 .header-gnbitem:last-child .header-gnblink {
    border-right: none;
}

.basic-N56 .header-gnblink:hover {
    color: #005C9C;
}

.basic-N56 .header-gnblink span {
    position: relative;
}

.basic-N56 .header-gnblink span::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 3px;
    background: #005C9C;
    transform: scaleX(0);
    transition: transform 0.3s ease;
}

.basic-N56 .header-gnbitem:hover .header-gnblink span::after {
    transform: scaleX(1);
}

/* PC 호버 메뉴 */
.basic-N56 .header-hover-menu {
    position: fixed;
    top: 80px;
    left: 0;
    right: 0;
    width: 100vw;
    background: #000;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-20px);
    transition: all 0.4s ease;
    z-index: 999;
    border-top: 1px solid #333;
}

.basic-N56 .header-center:hover .header-hover-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.basic-N56 .hover-menu-wrapper {
    max-width: 1400px;
    margin: 0 auto;
    padding: 2px 20px;
    position: relative;
    /* 기존 display: flex; justify-content: space-between; 제거 */
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}

/* JavaScript로 정렬할 때 사용할 클래스 */
.basic-N56 .hover-menu-wrapper.js-aligned {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
}


basic-N56 .hover-menu-wrapper.js-aligned .hover-menu-spacer,
.basic-N56 .hover-menu-wrapper.js-aligned .hover-menu-spacer-right {
    /* 기존 고정 width 값들 제거하고 동적으로 설정 */
    width: auto;
    flex-shrink: 0;
    min-height: 1px;
    display: flex;
    align-items: center;
}

.basic-N56 .hover-menu-wrapper.js-aligned .hover-menu-content {
    flex: 0 0 auto;
    display: flex;
    justify-content: center;
}

/* JavaScript 로드 후 .js-aligned 클래스가 추가되면 동적 계산값 사용 */
.basic-N56 .hover-menu-wrapper.js-aligned .hover-menu-spacer {
    width: auto !important;
    /* JavaScript에서 설정한 값 사용 */
}

.basic-N56 .hover-menu-wrapper.js-aligned .hover-menu-spacer-right {
    width: auto !important;
    /* JavaScript에서 설정한 값 사용 */
}


.basic-N56 .hover-menu-spacer {
    width: 200px;
}

.basic-N56 .hover-menu-column {
    width: 180px;
    padding: 0 0;
    border-right: 1px solid #333;
    text-align: center;
    box-sizing: border-box;
}

.basic-N56 .hover-menu-column:last-child {
    border-right: none;
}

.basic-N56 .hover-menu-sublist {
    list-style: none;
    padding: 0;
    margin: 0;
}

.basic-N56 .hover-menu-subitem {
    margin-bottom: 0;
}

.basic-N56 .hover-menu-sublink {
    color: #ccc;
    text-decoration: none;
    font-size: 14px;
    font-weight: 400;
    transition: all 0.3s ease;
    display: block;
    padding: 12px 10px;
    position: relative;
    text-align: center;
}

.basic-N56 .hover-menu-sublink:hover {
    color: #005C9C;
}

.basic-N56 .hover-menu-content {
    display: flex;
    justify-content: center;
    flex: 1;
}

.basic-N56 .hover-menu-spacer-right {
    width: 191px;
}

/* 헤더 오른쪽 영역 */
.basic-N56 .header-right {
    display: flex;
    align-items: center;
}

.basic-N56 .header-right .header-gnb {
    margin-right: 1.8rem;
}

.basic-N56 .header-utils>ul {
    display: flex;
    align-items: center;
}

.basic-N56 .header-utils>ul>li {
    margin-left: 1.2rem;
}

.basic-N56 .header-utils>ul>li>img {
    width: auto;
    height: 100%;
    object-fit: cover;
    vertical-align: top;
}

.basic-N56 .header-right button {
    max-width: 3.2rem;
    background: none;
    border: none;
}

.basic-N56 .header-right button img {
    width: auto;
    max-height: 100%;
    object-fit: cover;
    vertical-align: top;
}

.basic-N56 .header-utils .member a {
    width: 3.2rem;
    height: 3.2rem;
    font-size: 0;
    display: block;
}

.basic-N56 .header-utils .member img {
    max-width: 100%;
    max-height: 100%;
    object-fit: cover;
    vertical-align: top;
}

.basic-N56 .header-utils .btn-allmenu {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.basic-N56 .header-utils .btn-allmenu:hover .ico-hamburger:nth-child(2) {
    width: 2.4rem;
}

.basic-N56 .header-utils .btn-allmenu .ico-hamburger,
.basic-N56 .btn-momenu .ico-hamburger {
    width: 2.4rem;
    height: 0.3rem;
    background: white;
    border-radius: 0.15rem;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.basic-N56 .header-utils .btn-allmenu .ico-hamburger:nth-child(even),
.basic-N56 .btn-momenu .ico-hamburger:nth-child(2) {
    width: 1.8rem;
}

.basic-N56 .btn-momenu {
    display: none;
}

.basic-N56 .btn-moclose {
    display: none;
}

/* 풀스크린 메뉴 */
.basic-N56 .header-fullmenu {
    position: fixed;
    z-index: 99999;
    padding: 0 2.4rem;
    background: var(--black);
    transition: 0.3s;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
}

.basic-N56 .header-fullmenu.fullmenu-right {
    width: 0;
    height: 100%;
    top: 0;
    right: 0;
}

.basic-N56 .header-fullmenu.fullmenu-left {
    width: 0;
    height: 100%;
    top: 0;
    left: 0;
}

.basic-N56 .header-fullmenu.fullmenu-top {
    top: 0;
    left: 0;
    width: 100%;
    height: 0;
}

.basic-N56 .header-fullmenu.fullmenu-bottom {
    bottom: 0;
    left: 0;
    width: 100%;
    height: 0;
}

.basic-N56 .header-fullmenu.fullmenu-active {
    width: 100%;
    height: 100vh;
    opacity: 1;
    visibility: visible;
}

.basic-N56 .fullmenu-wrapper {
    position: relative;
    top: 50%;
    transform: translateY(-50%);
    width: 100%;
    max-width: 128rem;
    margin: 0 auto;
}

.basic-N56 .fullmenu-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10rem;
}

.basic-N56 .fullmenu-title {
    margin-bottom: 0;
}

.basic-N56 .fullmenu-title a {
    width: 13.6rem;
    height: 4.3rem;
}

.basic-N56 .fullmenu-title img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.basic-N56 .fullmenu-gnblist {
    display: flex;
    justify-content: center;
}

.basic-N56 .fullmenu-gnbitem {
    width: 20%;
}

.basic-N56 .fullmenu-gnbitem+.fullmenu-gnbitem {
    margin-left: 4rem;
}

.basic-N56 .fullmenu-gnblink {
    position: relative;
    width: 100%;
    padding-bottom: 4rem;
    color: var(--white);
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

.basic-N56 .fullmenu-gnblink::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    display: block;
    width: 0;
    height: 0.1rem;
    background: var(--white) fff;
    transition: 0.2s;
}

.basic-N56 .fullmenu-gnblink.on::after {
    width: 18rem;
}

.basic-N56 .fullmenu-sublist {
    padding-top: 4rem;
}

.basic-N56 .fullmenu-subitem+.fullmenu-subitem {
    padding-top: 0.8rem;
}

.basic-N56 .fullmenu-sublink {
    position: relative;
    padding-bottom: 5px;
    transition: 0.3s;
    color: #a2a2a2;
}

.basic-N56 .fullmenu-sublink::before {
    content: "";
    width: 0;
    height: 1px;
    background-color: var(--white);
    position: absolute;
    top: 100%;
    right: 0;
    transition: width 0.7s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.basic-N56 .fullmenu-sublink:hover {
    color: var(--white);
}

.basic-N56 .fullmenu-sublink:hover::before {
    width: 100%;
    right: auto;
    left: 0;
}

.basic-N56 .fullmenu-close {
    position: fixed;
    right: 8rem;
    top: 2.4rem;
    width: 3.2rem;
    height: 3.2rem;
    padding: 0.5rem;
    background: transparent;
    border: none;
}

.basic-N56 .fullmenu-close img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ==========================================
   MOBILE 반응형 (992px 이하)
   ========================================== */

@media (max-width: 992px) {

    /* 모바일 헤더 기본 설정 */
    .basic-N56 {
        padding-top: 0;
        padding-bottom: 0;
    }

    .basic-N56.top-menu-active .header-container {
        padding-top: 0;
    }

    .basic-N56.gnb-active,
    .basic-N56.top-menu-active.gnb-active {
        min-height: auto;
    }

    .basic-N56 .header-container {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        min-height: 7rem;
        padding: 1rem 2rem;
        box-sizing: border-box;
    }

    .basic-N56 .header-title a {
        width: auto;
        height: 3rem;
    }

    /* 헤더 유틸 정렬 */
    .basic-N56 .header-utils {
        display: flex !important;
        align-items: center !important;
        gap: 1rem;
    }

    .basic-N56 .header-utils>ul {
        display: inline-flex !important;
        align-items: center !important;
        margin: 0 !important;
        padding: 0 !important;
        list-style: none !important;
        gap: 1rem;
    }

    .basic-N56 .header-utils>ul>li {
        display: flex !important;
        align-items: center !important;
        margin: 0 !important;
    }

    .basic-N56 .header-utils .allmenu {
        display: none !important;
    }

    /* 햄버거 버튼 */
    .basic-N56 .btn-momenu {
        display: flex !important;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        flex-shrink: 0;
        width: 4rem;
        height: 4rem;
        padding: 0.8rem;
        background: transparent;
        border: none;
        cursor: pointer;
        gap: 0.4rem;
        border-radius: 0.5rem;
        transition: all 0.3s ease;
    }

    .basic-N56 .btn-momenu:hover {
        background: rgba(255, 255, 255, 0.1);
    }

    .basic-N56 .btn-momenu .ico-hamburger {
        width: 2.4rem;
        height: 0.3rem;
        background: white;
        border-radius: 0.15rem;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    }

    .basic-N56 .btn-momenu .ico-hamburger:nth-child(2) {
        width: 1.8rem;
    }

    /* 햄버거 애니메이션 */
    .basic-N56.block-active .btn-momenu .ico-hamburger:nth-child(1) {
        transform: translateY(0.7rem) rotate(45deg);
    }

    .basic-N56.block-active .btn-momenu .ico-hamburger:nth-child(3) {
        transform: translateY(-0.7rem) rotate(-45deg);
    }

    .basic-N56.block-active .btn-momenu .ico-hamburger:nth-child(2) {
        opacity: 0;
        transform: scale(0);
        visibility: hidden;
    }

    /* 2컬럼 모바일 메뉴 */
    .basic-N56 .header-gnb {
        width: 100%;
        height: calc(100vh - 7rem);
        position: absolute;
        top: 100%;
        left: 0;
        background: rgba(0, 0, 0, 0.95);
        backdrop-filter: blur(10px);
        overflow: hidden;
        padding: 0;
        z-index: 999;
        display: flex;

        /* 오른쪽에 숨김 - 투명도 제거 */
        transform: translateX(100%);

        /* 슬라이드만 애니메이션 */
        transition: transform 0.4s ease-in-out;
    }

    .basic-N56.block-active .header-gnb {
        transform: translateX(0);
        overflow: visible;
    }

    /* 왼쪽 컬럼: 주메뉴 */
    .basic-N56 .header-gnblist {
        width: 40%;
        background: rgba(0, 0, 0, 0.98);
        border-right: 1px solid rgba(255, 255, 255, 0.1);
        padding: 1rem 0;
        margin: 0;
        list-style: none;
        overflow-y: auto;
        display: block;
        opacity: 1;
        visibility: visible;
    }

    .basic-N56 .header-gnbitem {
        margin: 0;
        text-align: left;
    }

    .basic-N56 .header-gnblink {
        display: block;
        width: 100%;
        padding: 1.2rem 1.5rem;
        color: white;
        text-decoration: none;
        font-size: 1.5rem;
        font-weight: 500;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
        transition: all 0.3s ease;
        cursor: pointer;
        position: relative;
    }

    .basic-N56 .header-gnblink:hover,
    .basic-N56 .header-gnblink.active {
        background: rgba(0, 92, 156, 0.2);
        color: #005C9C;
    }

    .basic-N56 .header-gnblink.active::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        bottom: 0;
        width: 4px;
        background: #005C9C;
    }

    /* 오른쪽 컬럼: 서브메뉴 */
    .basic-N56 .mobile-submenu-container {
        width: 60%;
        background: rgba(0, 0, 0, 0.9);
        overflow-y: auto;
        position: relative;
        padding-bottom: 60vh;
        /* 하단에 50% 높이만큼 여유 공간 추가 */
    }

    .basic-N56 .mobile-submenu-section {
        padding: 0.8rem;
        /* 기존보다 축소 */
        margin-bottom: 0;
        /* 섹션 간 간격 제거 */
    }

    .basic-N56 .mobile-submenu-title {
        color: #005C9C;
        font-size: 1.4rem;
        /* 1.6rem → 1.4rem */
        font-weight: 600;
        margin-bottom: 0.5rem;
        /* 1rem → 0.5rem */
        padding-bottom: 0.5rem;
        /* 0.8rem → 0.5rem */
        border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    }

    /* 서브메뉴 리스트 간격 축소 */
    .basic-N56 .mobile-submenu-list {
        list-style: none;
        margin: 0;
        padding: 0;
    }

    /* 서브메뉴 아이템 간격 축소 */
    .basic-N56 .mobile-submenu-item {
        margin-bottom: 0.2rem;
        /* 0.3rem → 0.2rem */
    }

    /* 서브메뉴 링크 패딩 축소 */
    .basic-N56 .mobile-submenu-link {
        display: block;
        padding: 0.6rem 0.8rem;
        /* 0.8rem 1rem → 0.6rem 0.8rem */
        color: #ccc;
        text-decoration: none;
        font-size: 1.3rem;
        /* 1.3rem → 1.2rem */
        font-weight: 500;
        border-radius: 0.4rem;
        transition: all 0.3s ease;
        background: rgba(255, 255, 255, 0.03);
    }

    .basic-N56 .mobile-submenu-link:hover {
        background: rgba(76, 175, 80, 0.1);
        color: #005C9C;
        transform: translateX(0.3rem);
        /* 0.5rem → 0.3rem */
    }

    /* 서브메뉴가 없는 경우 패딩 축소 */
    .basic-N56 .mobile-no-submenu {
        padding: 1rem 0.8rem;
        /* 2rem 1rem → 1rem 0.8rem */
        text-align: center;
        color: #666;
        font-size: 1.2rem;
    }

    /* 호버 메뉴 숨김 */
    .basic-N56 .header-hover-menu {
        display: none !important;
    }

    /* 첫 번째 서브메뉴 섹션 상단 여백 제거 */
    .basic-N56 .mobile-submenu-section:first-child {
        padding-top: 0.5rem;
    }

    /* 마지막 서브메뉴 섹션 하단 여백 제거 */
    .basic-N56 .mobile-submenu-section:last-child {
        padding-bottom: 0.5rem;
    }

    /* 스크롤바 스타일 */
    .basic-N56 .header-gnblist::-webkit-scrollbar,
    .basic-N56 .mobile-submenu-container::-webkit-scrollbar {
        width: 4px;
    }

    .basic-N56 .header-gnblist::-webkit-scrollbar-track,
    .basic-N56 .mobile-submenu-container::-webkit-scrollbar-track {
        background: transparent;
    }

    .basic-N56 .header-gnblist::-webkit-scrollbar-thumb,
    .basic-N56 .mobile-submenu-container::-webkit-scrollbar-thumb {
        background: rgba(0, 92, 156, 0.5);
    }

    /* 기존 서브메뉴 숨김 */
    .basic-N56 .header-sublist {
        display: none !important;
    }

    /* 풀메뉴 숨김 */
    .basic-N56 .header-fullmenu {
        display: none;
    }
}

/* 작은 모바일 최적화 */
@media (max-width: 480px) {
    .basic-N56 .header-container {
        padding: 1rem 1.5rem;
    }

    .basic-N56 .header-utils {
        gap: 0.5rem;
    }

    .basic-N56 .header-utils>ul {
        gap: 0.5rem;
    }

    .basic-N56 .header-utils .member a {
        font-size: 0;
    }

    .basic-N56 .header-utils .member img {
        margin-right: 0;
    }
}

/* ==========================================
   기타 컴포넌트들 (basic-N5, N6, N7...)
   ========================================== */

/* basic-N5 */
.basic-N5 {
    position: relative;
    overflow: hidden;
    padding-top: 8rem;
}

.basic-N5 .contents-container {
    display: block;
    height: 80rem;
}

.basic-N5 .fullscreen {
    height: calc(100vh - 8rem);
    min-height: calc(100vh - 8rem);
}

.basic-N5 .contents-swiper {
    position: relative;
    width: 100vw;
    height: 100%;
    left: 50%;
    transform: translateX(-50%);
}

.basic-N5 .swiper-wrapper {
    width: 100%;
}

.basic-N5 .swiper-slide {
    position: relative;
}

.basic-N5 .contents-backimg,
.basic-N5 .contents-backimg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: brightness(0.8);
}

.basic-N5 .contents-backimg {
    position: relative;
}

.basic-N5 .contents-backimg::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.1) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.1) 1px, transparent 1px);
    background-size: 3px 3px;
    z-index: 1;
}

.basic-N5 .contents-slide-group {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    padding: 0 8rem;
    z-index: 1;
    width: 100%;
    text-align: center;
}

.basic-N5 .textset {
    padding: 0;
}

.basic-N5 .textset-tit {
    color: var(--white);
    text-align: center;
    word-break: keep-all;
}

.basic-N5 .textset-desc {
    color: var(--text-color4);
    word-break: keep-all;
}

.basic-N5 .btnset {
    min-width: 18rem;
    margin-top: 10rem;
}

.basic-N5 .contents-control {
    display: flex;
    align-items: center;
    gap: 0.8rem;
    position: absolute;
    left: 50%;
    bottom: 8rem;
    transform: translateX(-50%);
    z-index: 10;
}

.basic-N5 .contents-deco {
    display: inline-block;
    width: 1.2rem;
    height: 0.2rem;
    background: var(--white);
    opacity: 0.5;
    border-radius: 1rem;
}

.basic-N5 .swiper-button-prev,
.basic-N5 .swiper-button-next {
    position: static;
    flex-shrink: 0;
    display: inline-block;
    width: 2rem;
    height: 2rem;
    margin-top: 0;
    background-image: url(/theme/zigger-hyangnam/layout/resources/icons/ico_arrow_withe.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    opacity: 0.5;
    transition: 0.3s;
}

.basic-N5 .swiper-button-prev {
    transform: rotate(180deg);
}

.basic-N5 .swiper-button-prev:after,
.basic-N5 .swiper-button-next:after {
    content: none;
}

.basic-N5 .swiper-button-prev:hover,
.basic-N5 .swiper-button-next:hover {
    opacity: 1;
}

.basic-N5 .swiper-pagination {
    display: flex;
    align-items: center;
    position: static;
    gap: 0.8rem;
}

.basic-N5 .swiper-pagination-current {
    font-weight: 500;
    color: var(--white);
}

.basic-N5 .swiper-pagination-total {
    font-weight: 500;
    color: var(--text-color4);
}

.basic-N5 .swiper-button-play,
.basic-N5 .swiper-button-pause {
    flex-shrink: 0;
    width: 2rem;
    height: 2rem;
    opacity: 0.5;
    transition: 0.3s;
    cursor: pointer;
}

.basic-N5 .swiper-button-play img,
.basic-N5 .swiper-button-pause img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    vertical-align: top;
}

.basic-N5 .swiper-button-play:hover,
.basic-N5 .swiper-button-pause:hover {
    opacity: 1;
}

.basic-N5 .swiper-button-play {
    display: none;
}

@media (max-width: 1200px) {
    .basic-N5 .contents-slide-group {
        padding: 0 4rem;
    }
}

@media (max-width: 992px) {
    .basic-N5 .fullscreen {
        height: calc(100vh - 7rem);
        min-height: calc(100vh - 7rem);
    }

    .basic-N5 .contents-slide-group {
        width: 100%;
        padding: 0 1.6rem;
    }

    .basic-N5 .textset .textset-tit+.textset-desc {
        margin-top: 2rem;
    }

    .basic-N5 .btnset {
        min-width: 16rem;
        margin-top: 8rem;
    }

    .basic-N5 .contents-control {
        bottom: 6rem;
    }

    .basic-N5 {
        padding-top: 0rem;
    }
}

@media (max-width: 576px) {
    .basic-N5 .textset-desc br {
        display: none;
    }
}

/* ==========================================
   기타 컴포넌트들 (basic-N6~N36)
   ========================================== */

/* basic-N6 */
.basic-N6 {
    position: relative;
    padding-top: 8rem;
    padding-bottom: 8rem;
    overflow: hidden;
}

.basic-N6 .textset {
    text-align: center;
    margin-bottom: 0;
}

.basic-N6 .textset-desc {
    color: var(--text-color3);
}

@media (max-width: 992px) {
    .basic-N6 {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .basic-N6 .textset .textset-tit+.textset-desc {
        margin-top: 2rem;
    }

    .basic-N6 .textset-desc {
        word-break: keep-all;
    }

    .basic-N6 .textset-desc br {
        display: none;
    }
}

/* basic-N7 */
.basic-N7 {
    position: relative;
    padding-top: 8rem;
    padding-bottom: 8rem;
    overflow: hidden;
}

.basic-N7 .videoset {
    height: auto;
}

.basic-N7 .videoset-button {
    height: 42rem;
    z-index: 1;
    border-radius: 2rem;
    overflow: hidden;
}

.basic-N7 .contents-bottom {
    position: relative;
    width: calc(100% + 3.2rem);
    margin: -21rem -1.6rem 0 -1.6rem;
    padding: 21rem 1.6rem 5rem 1.6rem;
}

.basic-N7 .contents-bottom::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100vw;
    height: 100%;
    background: #f7f7fb;
}

.basic-N7 .textset {
    margin-top: 6rem;
}

.basic-N7 .textset .textset-desc {
    color: var(--text-color3);
}

@media (max-width: 992px) {
    .basic-N7 {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .basic-N7 .contents-bottom {
        padding-bottom: 4rem;
    }

    .basic-N7 .textset {
        margin-top: 4rem;
    }

    .basic-N7 .textset .textset-tit+.textset-desc {
        margin-top: 2rem;
    }

    .basic-N7 .textset .textset-desc {
        word-break: keep-all;
    }

    .basic-N7 .textset .textset-desc br {
        display: none;
    }
}

/* basic-N8 */
.basic-N8 {
    position: relative;
    padding-top: 8rem;
    padding-bottom: 8rem;
    overflow: hidden;
}

.basic-N8 .cardset {
    width: calc(50% + 4rem);
    padding-bottom: 10rem;
}

.basic-N8 .cardset+.cardset {
    margin-top: 10rem;
    margin-left: -8rem;
    padding-bottom: 0;
}

.basic-N8 .cardset .cardset-body {
    width: calc(100% - 10rem);
    padding: 0;
}

.basic-N8 .cardset .cardset-figure {
    width: 100%;
    height: 44rem;
    border-radius: 2rem;
    overflow: hidden;
}

.basic-N8 .cardset .cardset-figure+.cardset-body {
    margin-top: 4rem;
}

.basic-N8 .cardset .cardset-tit+.cardset-desc {
    margin-top: 2rem;
}

.basic-N8 .cardset .cardset-desc {
    display: block;
    color: var(--text-color3);
}

.basic-N8 .textset {
    margin-bottom: 4rem;
}

@media (max-width: 992px) {
    .basic-N8 {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .basic-N8 .cardset {
        width: 100%;
        padding-bottom: 0;
    }

    .basic-N8 .cardset+.cardset {
        margin-left: 0;
        margin-top: 4rem;
    }

    .basic-N8 .cardset .cardset-figure+.cardset-body {
        margin-top: 3rem;
    }

    .basic-N8 .cardset .cardset-body {
        width: 100%;
    }
}

/* basic-N9 */
.basic-N9 {
    position: relative;
    padding-top: 8rem;
    padding-bottom: 8rem;
    overflow: hidden;
}

.basic-N9 .contents-inner {
    position: relative;
}

.basic-N9 .textset {
    margin-bottom: 6rem;
}

.basic-N9 .textset .textset-desc {
    margin-top: 1.9rem;
    padding-right: 14.4rem;
    color: var(--text-color3);
}

.basic-N9 .contents-swiper {
    width: calc(100% + 32rem);
}

.basic-N9 .swiper-slide {
    width: calc(100% / 3);
    margin-right: 4rem;
}

.basic-N9 .swiper-slide .cardset .cardset-tit {
    color: var(--white);
}

.basic-N9 .swiper-slide .cardset .cardset-tit+.cardset-desc {
    margin: 1.6rem 0 0 0;
}

.basic-N9 .contents-control {
    position: absolute;
    right: 0;
    bottom: 44rem;
    display: flex;
    align-items: center;
    gap: 2.4rem;
}

.basic-N9 .swiper-button-prev,
.basic-N9 .swiper-button-next {
    display: inline-block;
    flex-shrink: 0;
    position: static;
    margin-top: 0;
    width: 6rem;
    height: 6rem;
    background-image: url(/theme/zigger-hyangnam/layout/resources/icons/ico_arrow_black.svg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 2.4rem;
    border-radius: 50%;
    background-color: #f7f7fb;
    opacity: 0.7;
    transition: 0.3s;
}

.basic-N9 .swiper-button-prev {
    transform: rotate(180deg);
}

.basic-N9 .swiper-button-prev::after,
.basic-N9 .swiper-button-next::after {
    content: none;
}

.basic-N9 .contents-bottom .textset-desc {
    padding-right: 0;
}

.basic-N9 .cardset {
    overflow: hidden;
}

.basic-N9 .cardset .cardset-figure {
    height: 38rem;
    border-radius: 2rem;
    overflow: hidden;
}

.basic-N9 .cardset .cardset-figure+.cardset-body {
    position: absolute;
    z-index: 10;
    bottom: 0;
    width: 100%;
    padding: 3.2rem;
    margin-top: 0;
    background: transparent;
}

.basic-N9 .cardset .cardset-tit {
    color: var(--text-color1);
}

.basic-N9 .cardset .cardset-tit+.cardset-desc {
    margin-top: 1.6rem;
    letter-spacing: -0.1rem;
    margin: 4rem 0;
}

.basic-N9 .cardset .cardset-desc {
    color: var(--text-color3);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    padding-top: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    border-top: 0;
}

.basic-N9 .cardset-cont {
    padding: 6rem 4rem;
}

@media (max-width: 992px) {
    .basic-N9 {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .basic-N9 .textset {
        margin-bottom: 4rem;
    }

    .basic-N9 .textset .textset-desc {
        padding-right: 0;
        word-break: keep-all;
    }

    .basic-N9 .textset .textset-desc br {
        display: none;
    }

    .basic-N9 .contents-control {
        position: relative;
        bottom: 0;
        justify-content: flex-end;
        margin-bottom: 4rem;
    }

    .basic-N9 .contents-swiper {
        width: 100%;
    }

    .basic-N9 .swiper-slide {
        width: 100%;
        margin-right: 2rem;
    }

    .basic-N9 .row {
        --th-gutter: 0.2rem;
    }

    .basic-N9 .cardset .cardset-figure+.cardset-body {
        padding: 2rem;
    }

    .basic-N9 .cardset {
        width: 100%;
    }

    .basic-N9 .cardset+.cardset {
        margin-top: 2rem;
    }

    .basic-N9 .cardset .cardset-cont {
        padding: 4rem 2.4rem;
    }

    .basic-N9 .cardset-body {
        width: 100%;
    }
}

@media (max-width: 576px) {
    .basic-N9 .cardset-tit+.cardset-desc br {
        display: none;
    }
}

/* basic-N57 */
.basic-N57 {
    position: relative;
    padding-top: 8rem;
    padding-bottom: 8rem;
    overflow: hidden;
    background: #f7f7fb;
}

.basic-N57 .textset {
    margin-bottom: 8rem;
}

.basic-N57 .cardset {
    overflow: hidden;
}

.basic-N57 .cardset .cardset-figure {
    height: 38rem;
    border-radius: 2rem;
    overflow: hidden;
}

.basic-N57 .cardset .cardset-figure+.cardset-body {
    position: absolute;
    z-index: 10;
    bottom: 0;
    width: 100%;
    padding: 3.2rem;
    margin-top: 0;
    background: transparent;
}

.basic-N57 .cardset .cardset-tit {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--text-color1);
}

.basic-N57 .cardset .cardset-tit+.cardset-desc {
    margin-top: 1.6rem;
    letter-spacing: -0.1rem;
    margin: 4rem 0;
}

.basic-N57 .cardset .cardset-desc {
    color: var(--text-color3);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    padding-top: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    border-top: 0;
}

.basic-N57 .cardset-cont {
    padding: 6rem 4rem;
}

.basic-N57 .contents-btn {
    margin-top: 4rem;
    text-align: center;
}

.basic-N57 .contents-btn .btnset {
    min-width: 18rem;
    padding: 0 2rem;
}

.basic-N57 .contents-btn .btnset::before {
    content: "";
    display: inline-block;
    width: 2.4rem;
    height: 2.4rem;
    margin-right: 0.4rem;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    color: var(--white);
    background-image: url(/theme/zigger-hyangnam/layout/resources/icons/ico_plus_white.svg);
}

@media (max-width: 992px) {
    .basic-N57 {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .basic-N57 .textset {
        margin-bottom: 4rem;
    }

    .basic-N57 .textset .textset-desc {
        padding-right: 0;
        word-break: keep-all;
    }

    .basic-N57 .textset .textset-desc br {
        display: none;
    }

    .basic-N57 .row {
        --th-gutter: 0.2rem;
    }

    .basic-N57 .cardset .cardset-figure+.cardset-body {
        padding: 2rem;
    }

    .basic-N57 .cardset {
        width: 100%;
    }

    .basic-N57 .cardset+.cardset {
        margin-top: 2rem;
    }

    .basic-N57 .cardset .cardset-cont {
        padding: 4rem 2.4rem;
    }

    .basic-N57 .cardset-body {
        width: 100%;
    }

    .basic-N57 .contents-btn .btnset {
        min-width: 16rem;
        padding: 0 1.6rem;
    }
}

@media (max-width: 576px) {
    .basic-N57 .cardset-tit+.cardset-desc br {
        display: none;
    }
}

/* basic-N4 (Footer) */
.basic-N4 {
    position: relative;
    background: #111;
    padding-top: 2.4rem;
    padding-bottom: 2.4rem;
    overflow: hidden;
}

.basic-N4 .footer-top {
    display: flex;
    justify-content: space-between;
    position: relative;
    margin-bottom: 1.6rem;
}

.basic-N4 .footer-logo {
    text-align: center;
    margin-bottom: 0;
}

.basic-N4 .footer-logo img {
    height: 3.3rem;
    object-fit: contain;
}

.basic-N4 .footer-menulist {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: var(--fs-p2);
}

.basic-N4 .footer-menulink a {
    padding-right: 1.2rem;
    color: var(--white);
}

.basic-N4 .footer-menulink+.footer-menulink a {
    padding-left: 1.2rem;
}

.basic-N4 .footer-menulink {
    position: relative;
}

.basic-N4 .footer-menulink+.footer-menulink::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 1px;
    height: 1.4rem;
    background: rgba(var(--white-rgb), 0.1);
}

.basic-N4 .footer-snslist {
    display: flex;
    align-items: center;
}

.basic-N4 .footer-snsitem+.footer-snsitem {
    margin-left: 0.8rem;
}

.basic-N4 .footer-snslink {
    width: 3.6rem;
    height: 3.6rem;
    padding: 0.6rem;
}

.basic-N4 .footer-snslink img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    vertical-align: top;
}

.basic-N4 .footer-bottom {
    padding-top: 2.4rem;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.basic-N4 .footer-txt {
    display: flex;
    justify-content: center;
}

.basic-N4 .footer-txt+.footer-txt {
    margin-top: 0.3rem;
}

.basic-N4 .footer-txt p,
.basic-N4 .footer-txt span {
    margin-bottom: 0;
    color: var(--text-color3);
}

.basic-N4 .footer-txt p+p {
    margin-left: 0.8rem;
}

.basic-N4 .footer-txt p span+span {
    margin-left: 0.8rem;
}

.basic-N4 .info-area {
    overflow-y: auto;
}

.basic-N4 .info-group+.info-group {
    margin-top: 2.4rem;
}

.basic-N4 .info-group strong {
    padding-bottom: 1.2rem;
    display: block;
}

.basic-N4 .info-desc {
    max-height: 20.7rem;
    padding: 1.6rem;
    background: #f8f8fa;
    border-radius: 1.6rem;
    overflow-y: auto;
    scrollbar-width: none;
}

.basic-N4 .info-desc p.fw-medium {
    font-weight: var(--fw-medium);
}

.basic-N4 .info-desc .mtb {
    margin: 2.4rem 0;
}

.basic-N4 .info-desc em {
    font-style: normal;
    font-weight: 600;
    margin: 2.4rem 0 1rem;
    position: relative;
    display: flex;
    align-items: center;
}

.basic-N4 .info-list em::before {
    content: "";
    width: 0.4rem;
    height: 0.4rem;
    background: var(--black);
    border-radius: 50%;
    margin-right: 0.8rem;
}

.basic-N4 .info-list p {
    padding-left: 1.2rem;
}

@media (max-width: 992px) {
    .basic-N4 {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }

    .basic-N4 .footer-top {
        margin-bottom: 0;
        flex-direction: column;
        align-items: flex-start;
    }

    .basic-N4 .footer-logo a {
        height: 2.6rem;
    }

    .basic-N4 .footer-menulist {
        justify-content: flex-start;
        position: relative;
        left: 0;
        transform: translate(0);
        margin-top: 1.3rem;
    }

    .basic-N4 .footer-menulink a {
        padding-right: 0.8rem;
    }

    .basic-N4 .footer-menulink+.footer-menulink a {
        padding-left: 0.8rem;
    }

    .basic-N4 .footer-snslist {
        margin: 2.4rem 0 1.6rem 0;
        justify-content: center;
    }

    .basic-N4 .footer-bottom {
        text-align: left;
    }

    .basic-N4 .footer-txt {
        flex-direction: column;
    }

    .basic-N4 .footer-txt p+p {
        margin-left: 0;
    }

    .basic-N4 .footer-txt+.footer-txt {
        margin-top: 0.6rem;
    }

    .basic-N4 .email {
        display: none;
    }
}

@media (max-width: 375px) {
    .basic-N4 .footer-menulist {
        justify-content: flex-start;
        overflow-x: auto;
    }

    .basic-N4 .footer-menulink {
        flex-shrink: 0;
    }
}

/* mediastock-N7 */
.mediastock-N7 {
    overflow: hidden;
    position: relative;
    padding-top: 13.4rem;
    padding-bottom: 13.4rem;
    background: url(/theme/zigger-hyangnam/layout/resources/images/center_10.png) no-repeat center/cover;
}

.mediastock-N7.facility {
    background: url(/theme/zigger-hyangnam/layout/resources/images/center_02.png) no-repeat center/cover;
}

.mediastock-N7.greeting {
    background: url(/theme/zigger-hyangnam/layout/resources/images/center_05.png) no-repeat center/cover;
}


.mediastock-N7.membership {
    background: url(https://images.unsplash.com/photo-1629339837617-7069ce9e7f6b?ixid=M3w0OTE2MDd8MHwxfHNlYXJjaHw0ODB8fGd5bXxrb3wwfHx8fDE3NTc0ODg5NTl8MA&ixlib=rb-4.1.0) no-repeat center/cover;
}

.mediastock-N7.courses {
    background: url(https://images.unsplash.com/photo-1659303388062-d61383748059?ixid=M3w0OTE2MDd8MHwxfHNlYXJjaHw0OTl8fHN3aW1taW5nJTIwbGVzc29uc3xrb3wwfHx8fDE3NTc0ODk4MzN8MA&ixlib=rb-4.1.0) no-repeat center/cover;
}


.mediastock-N7.instructors {
    background: url(https://images.unsplash.com/photo-1573858129683-59f4d9c445d9?ixid=M3w0OTE2MDd8MHwxfHNlYXJjaHwzNjB8fGd5bXxrb3wwfHx8fDE3NTc0ODg4ODN8MA&ixlib=rb-4.1.0) no-repeat center/cover;
}

.mediastock-N7.registration {
    background: url(https://images.unsplash.com/photo-1623720723560-d85879d0db79?ixid=M3w0OTE2MDd8MHwxfHNlYXJjaHw0M3x8c3dpbW1pbmd8a298MHx8fHwxNzU3NDg4MzMxfDA&ixlib=rb-4.1.0) no-repeat center/cover;
}

.mediastock-N7.pricing {
    background: url(https://images.pexels.com/photos/2062702/pexels-photo-2062702.jpeg) no-repeat center/cover;
}

.mediastock-N7.safety {
    background: url(https://images.pexels.com/photos/4852724/pexels-photo-4852724.jpeg) no-repeat center/cover;
}

.mediastock-N7.history {
    background: url(https://images.pexels.com/photos/11412596/pexels-photo-11412596.jpeg) no-repeat center/cover;
}

.mediastock-N7.refund {
    background: url(https://images.unsplash.com/photo-1667053312046-e186fdca8bc2?ixid=M3w0OTE2MDd8MHwxfHNlYXJjaHwyODN8fCUyMGV4ZXJjaXNlJTIwc2FmZXR5fGtvfDB8fHx8MTc1NzUwMTU3Mnww&ixlib=rb-4.1.0) no-repeat center/cover;
}


.mediastock-N7.news {
    background: url(https://images.pexels.com/photos/9169914/pexels-photo-9169914.jpeg) no-repeat center/cover;
}

.mediastock-N7.free {
    background: url(https://images.unsplash.com/photo-1611077544637-f826625c2776?ixid=M3w0OTE2MDd8MHwxfHNlYXJjaHwxN3x8dGFwZSUyMG1lYXN1cmV8a298MHx8fHwxNzU3NDkwNTI4fDA&ixlib=rb-4.1.0) no-repeat center/cover;
}


.mediastock-N7.contactus {
    background: url(https://images.pexels.com/photos/7947841/pexels-photo-7947841.jpeg) no-repeat center/cover;
}

.mediastock-N7::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.1) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.1) 1px, transparent 1px);
    background-size: 3px 3px;
    z-index: 1;
}

/* 모바일용 이미지 */
@media (max-width: 992px) {

    .mediastock-N7.facility {
        background: url(/theme/zigger-hyangnam/layout/resources/images/center_02.png) no-repeat center/cover;
    }

    .mediastock-N7.greeting {
        background: url(/theme/zigger-hyangnam/layout/resources/images/center_05.png) no-repeat center/cover;
    }


    .mediastock-N7.membership {
        background: url(https://images.unsplash.com/photo-1629339837617-7069ce9e7f6b?ixid=M3w0OTE2MDd8MHwxfHNlYXJjaHw0ODB8fGd5bXxrb3wwfHx8fDE3NTc0ODg5NTl8MA&ixlib=rb-4.1.0) no-repeat center/cover;
    }

    .mediastock-N7.courses {
        background: url(https://images.pexels.com/photos/711187/pexels-photo-711187.jpeg) no-repeat center/cover;
    }


    .mediastock-N7.instructors {
        background: url(https://images.unsplash.com/photo-1573858129683-59f4d9c445d9?ixid=M3w0OTE2MDd8MHwxfHNlYXJjaHwzNjB8fGd5bXxrb3wwfHx8fDE3NTc0ODg4ODN8MA&ixlib=rb-4.1.0) no-repeat center/cover;
    }

    .mediastock-N7.registration {
        background: url(https://images.unsplash.com/photo-1623720723560-d85879d0db79?ixid=M3w0OTE2MDd8MHwxfHNlYXJjaHw0M3x8c3dpbW1pbmd8a298MHx8fHwxNzU3NDg4MzMxfDA&ixlib=rb-4.1.0) no-repeat center/cover;
    }

    .mediastock-N7.pricing {
        background: url(https://images.pexels.com/photos/2062702/pexels-photo-2062702.jpeg) no-repeat center/cover;
    }

    .mediastock-N7.safety {
        background: url(https://images.pexels.com/photos/4852724/pexels-photo-4852724.jpeg) no-repeat center/cover;
    }

    .mediastock-N7.history {
        background: url(https://images.pexels.com/photos/11412596/pexels-photo-11412596.jpeg) no-repeat center/cover;
    }

    .mediastock-N7.refund {
        background: url(https://images.unsplash.com/photo-1667053312046-e186fdca8bc2?ixid=M3w0OTE2MDd8MHwxfHNlYXJjaHwyODN8fCUyMGV4ZXJjaXNlJTIwc2FmZXR5fGtvfDB8fHx8MTc1NzUwMTU3Mnww&ixlib=rb-4.1.0) no-repeat center/cover;
    }


    .mediastock-N7.news {
        background: url(https://images.pexels.com/photos/9169914/pexels-photo-9169914.jpeg) no-repeat center/cover;
    }

    .mediastock-N7.free {
        background: url(https://images.unsplash.com/photo-1611077544637-f826625c2776?ixid=M3w0OTE2MDd8MHwxfHNlYXJjaHwxN3x8dGFwZSUyMG1lYXN1cmV8a298MHx8fHwxNzU3NDkwNTI4fDA&ixlib=rb-4.1.0) no-repeat center/cover;
    }


    .mediastock-N7.contactus {
        background: url(https://images.pexels.com/photos/5428833/pexels-photo-5428833.jpeg) no-repeat center/cover;
    }

}


.mediastock-N7 .contents-container {
    display: flex;
    align-items: center;
}

.mediastock-N7 .contents-inner {
    width: 100%;
    text-align: center;
}

.mediastock-N7 .contents-inner h2 {
    color: var(--white);
}

.mediastock-N7 .contents-inner h4 {
    margin-top: 4rem;
    color: var(--white);
}

.mediastock-N7 .contents-inner .btnset {
    font-weight: var(--fw-medium);
}

@media (max-width: 992px) {
    .mediastock-N7 {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }

    .mediastock-N7 .contents-inner h2 {
        margin-bottom: 1.6rem;
    }
}

/* basic-N34, N35, N36 (간단한 컴포넌트들) */
.basic-N34 {
    position: relative;
    padding-top: 5rem;
    padding-bottom: 5rem;
    overflow: hidden;
}


.basic-N34 .textset {
    margin-bottom: 0;
}

.basic-N34 .textset .textset-tit+.textset-desc {
    margin-top: 0.8rem;
}

.basic-N34 .textset .textset-desc {
    color: var(--text-color3);
}

@media (max-width: 992px) {

    .basic-N34 {
        padding-top: 2rem;
        padding-bottom: 2rem;
    }
}

.basic-N35 {
    position: relative;
    padding-top: 0rem;
    padding-bottom: 8rem;
    overflow: hidden;
}

.basic-N35 .img {
    width: 100%;
}

.basic-N35 .img-mobile {
    display: none;
}

.basic-N35 .cardset+.cardset {
    margin-top: 10rem;
}

.basic-N35 .cardset .cardset-figure {
    height: 60rem;
    border-radius: 2rem;
    overflow: hidden;
}

.basic-N35 .cardset+.cardset .cardset-figure {
    height: 40rem;
}

.basic-N35 .cardset .cardset-body {
    padding: 0;
}

.basic-N35 .cardset .cardset-body+.cardset-figure {
    margin-top: 4rem;
}

.basic-N35 .cardset .cardset-tit+.cardset-desc {
    margin-top: 2rem;
}

.basic-N35 .cardset .cardset-desc {
    display: block;
    color: var(--text-color3);
}

@media (max-width: 992px) {
    .basic-N35 {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .basic-N35 .img-pc {
        display: none;
    }

    .basic-N35 .img-mobile {
        display: block;
    }

    .basic-N35 .cardset+.cardset {
        margin-top: 8rem;
    }

    .basic-N35 .cardset .cardset-figure {
        height: 48rem;
    }
}

@media (max-width: 576px) {
    .basic-N35 .cardset .cardset-desc br {
        display: none;
    }
}

.basic-N36 {
    position: relative;
    padding-top: 0rem;
    padding-bottom: 8rem;
    overflow: hidden;
}

.basic-N36 .mt-9 {
    margin-top: -80px;
}

.basic-N36 .cardset {
    border-radius: 2rem;
    overflow: hidden;
}

.basic-N36 .cardset .cardset-figure {
    height: 32rem;
}

.basic-N36 .cardset .cardset-cont .cardset-tit+.cardset-desc {
    margin-top: 2.4rem;
    margin-bottom: 0;
    padding-top: 0;
    border-top: 0;
}

.basic-N36 .cardset .cardset-cont .cardset-desc {
    display: block;
    color: var(--text-color3);
}

.basic-N36 .textset {
    margin-bottom: 4rem;
}

@media (max-width: 992px) {
    .basic-N36 {
        padding-top: 0rem;
        padding-bottom: 5rem;
    }

    .basic-N36 .mt-9 {
        margin-top: 0px;
    }
}


@media (max-width: 576px) {
    .basic-N36 .cardset-desc br {
        display: none;
    }
}

/* PC에서 숨김 */
@media (min-width: 993px) {
    .mobile-submenu-container {
        display: none !important;
    }
}

/* 모바일에서 표시 */
@media (max-width: 992px) {
    .mobile-submenu-container {
        display: block !important;
    }
}

/* ==========================================
   모바일 하단 고정 메뉴 (Bottom Navigation)
   ========================================== */

/* 모바일 하단 고정 메뉴 */
.mobile-bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    background: #0B0C0CFF;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
    z-index: 998;
    /* 헤더보다 낮게 설정 */
    backdrop-filter: blur(10px);
    display: none;
    /* 기본적으로 숨김 */
}

.bottom-nav-container {
    display: flex;
    justify-content: space-around;
    align-items: center;
    height: 7rem;
    max-width: 100%;
    margin: 0 auto;
    padding: 0.5rem 0;
}

.bottom-nav-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    color: #ccc;
    font-size: 1.2rem;
    font-weight: 500;
    transition: all 0.3s ease;
    flex: 1;
    padding: 0.5rem 0.25rem;
    border-radius: 0.5rem;
    position: relative;
    background: transparent;
    border: none;
    cursor: pointer;
    font-family: inherit;
}

.bottom-nav-item:hover,
.bottom-nav-item.active {
    color: #005C9C;
    background: rgba(0, 92, 156, 0.1);
}

.bottom-nav-item.active::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 2rem;
    height: 0.3rem;
    background: #005C9C;
    border-radius: 0.2rem;
}

.bottom-nav-icon {
    width: 2.4rem;
    height: 2.4rem;
    margin-bottom: 0.25rem;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* 아이콘 SVG 스타일 */
.bottom-nav-icon svg {
    width: 100%;
    height: 100%;
    fill: currentColor;
}

/* 햄버거 메뉴 아이콘 (기존 스타일과 통일) */
.bottom-nav-menu-icon {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
    align-items: center;
    justify-content: center;
}

.bottom-nav-menu-icon .ico-hamburger {
    width: 1.6rem;
    height: 0.2rem;
    background: currentColor;
    border-radius: 0.1rem;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.bottom-nav-menu-icon .ico-hamburger:nth-child(2) {
    width: 1.2rem;
}

/* 터치 피드백 */
.bottom-nav-item:active {
    transform: scale(0.95);
    background: rgba(0, 92, 156, 0.2);
}

/* 메뉴 활성화 시 햄버거 애니메이션 */
.basic-N56.block-active .bottom-nav-menu-icon .ico-hamburger:nth-child(1) {
    transform: translateY(0.5rem) rotate(45deg);
}

.basic-N56.block-active .bottom-nav-menu-icon .ico-hamburger:nth-child(3) {
    transform: translateY(-0.5rem) rotate(-45deg);
}

.basic-N56.block-active .bottom-nav-menu-icon .ico-hamburger:nth-child(2) {
    opacity: 0;
    transform: scale(0);
    visibility: hidden;
}

/* 모바일에서만 표시 */
@media (max-width: 992px) {
    .mobile-bottom-nav {
        display: block !important;
    }

    /* 하단 메뉴 공간 확보 */
    .th-layout-main {
        padding-bottom: 7rem;
    }
}

/* 작은 모바일 최적화 */
@media (max-width: 480px) {
    .bottom-nav-container {
        height: 6rem;
    }

    .bottom-nav-item {
        font-size: 1.1rem;
        padding: 0.4rem 0.2rem;
    }

    .bottom-nav-icon {
        width: 2rem;
        height: 2rem;
    }

    .bottom-nav-menu-icon .ico-hamburger {
        width: 1.4rem;
    }

    .bottom-nav-menu-icon .ico-hamburger:nth-child(2) {
        width: 1rem;
    }

    /* 하단 메뉴 공간 조정 */
    .th-layout-main {
        padding-bottom: 6rem;
    }
}

/* 안전 영역 대응 (iPhone X 이상) */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
    .mobile-bottom-nav {
        padding-bottom: env(safe-area-inset-bottom);
    }

    @media (max-width: 992px) {
        .th-layout-main {
            padding-bottom: calc(7rem + env(safe-area-inset-bottom));
        }
    }

    @media (max-width: 480px) {
        .th-layout-main {
            padding-bottom: calc(6rem + env(safe-area-inset-bottom));
        }
    }
}

@media (min-width: 1200px) and (max-width: 1439px) {
    .basic-N56 .hover-menu-wrapper {
        padding: 2px 30px;
    }
}

@media (min-width: 993px) and (max-width: 1199px) {
    .basic-N56 .hover-menu-wrapper {
        padding: 2px 20px;
    }

    .basic-N56 .hover-menu-column {
        width: 160px;
    }
}


/* ==========================================
   브레드크럼 네비게이션
   ========================================== */

.breadcrumb-navigation {
    width: 100%;
    background: #fff;
    border-bottom: 1px solid #f3f3f3;
    position: relative;
    z-index: 100;
}

.breadcrumb-wrapper {
    display: flex;
    align-items: center;
    height: 60px;
    gap: 1rem;
}

/* 홈 버튼 */
.breadcrumb-home {
    flex-shrink: 0;
}

.breadcrumb-home-btn {
    width: 60px;
    height: 60px;
    background: #000;
    border: none;
    border-left: 1px solid #f3f3f3;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.3s ease;
}

.breadcrumb-home-btn svg {
    width: 20px;
    height: 20px;
    fill: white;
}

.breadcrumb-home-btn:hover {
    background: #333;
}

/* 브레드크럼 메뉴들 */
.breadcrumb-menus {
    display: flex;
    align-items: center;
    flex: 1;
    gap: 0;
}

.breadcrumb-group {
    position: relative;
    display: flex;
    align-items: center;
}

.breadcrumb-menu {
    position: relative;
}

.breadcrumb-btn {
    display: flex;
    align-items: center;
    padding: 0 25px 0 25px;
    height: 60px;
    background: transparent;
    border: none;
    border-right: 1px solid #f3f3f3;
    font-size: 15px;
    font-weight: 500;
    color: #222;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
    min-width: 180px;
    justify-content: space-between;
}

.breadcrumb-btn:hover {
    color: #005C9C;
    background: rgba(0, 92, 156, 0.05);
}

.breadcrumb-group.current .breadcrumb-btn {
    color: #005C9C;
    font-weight: 600;
    background: rgba(0, 92, 156, 0.1);
}

.breadcrumb-text {
    flex: 1;
    text-align: left;
}

.breadcrumb-arrow {
    width: 16px;
    height: 16px;
    fill: currentColor;
    transition: transform 0.3s ease;
    margin-left: 8px;
}

.breadcrumb-group.hover .breadcrumb-arrow {
    transform: rotate(180deg);
}

/* 구분자 */
.breadcrumb-separator {
    color: #ccc;
    font-size: 14px;
    margin: 0 5px;
    user-select: none;
}

/* 드롭다운 메뉴 */
.breadcrumb-dropdown {
    position: absolute;
    top: 60px;
    left: -1px;
    width: 200px;
    background: #fff;
    border: 1px solid #eaeaea;
    border-top: 1px solid #eaeaea;
    box-shadow: 5px 5px 15px 0 rgba(0, 0, 0, 0.1);
    z-index: 200;
    display: none;
    overflow: hidden;
}

.breadcrumb-dropdown-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.breadcrumb-dropdown-item {
    border-bottom: 1px solid #eaeaea;
}

.breadcrumb-dropdown-item:last-child {
    border-bottom: 1px solid #d6d6d6;
}

.breadcrumb-dropdown-item a {
    display: block;
    padding: 12px 20px;
    color: #222;
    text-decoration: none;
    font-size: 14px;
    font-weight: 500;
    transition: all 0.3s ease;
    position: relative;
    background: url("../images/common/menu_icon02.png") no-repeat 90% 50%;
}

.breadcrumb-dropdown-item:hover a {
    background-color: #f8f8f8;
    color: #005C9C;
}

.breadcrumb-dropdown-item.active a {
    background-color: #005C9C;
    color: white;
    font-weight: 600;
}

/* 모바일 반응형 */
@media (max-width: 992px) {
    .breadcrumb-navigation {
        display: none;
        /* 모바일에서는 숨김 */
    }
}

@media (min-width: 993px) and (max-width: 1200px) {
    .breadcrumb-container {
        padding: 0 1.5rem;
    }

    .breadcrumb-btn {
        min-width: 160px;
        padding: 0 20px;
        font-size: 14px;
    }

    .breadcrumb-dropdown {
        width: 180px;
    }
}

@media (min-width: 1201px) {
    .breadcrumb-btn {
        min-width: 200px;
    }

    .breadcrumb-dropdown {
        width: 220px;
    }
}


/* temhafull2-N3 */
.temhafull2-N3 {
    position: relative;
    overflow: hidden;
}

.temhafull2-N3 .contents-container {
    display: flex;
    align-items: center;
    justify-content: center;
    position: static;
    height: 85rem;
}

.temhafull2-N3 .contents-inner {
    width: 100%;
}

.temhafull2-N3 .contents-left {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    width: 60%;
}

.temhafull2-N3 .contents-title {
    display: flex;
    align-items: center;
    gap: 2rem;
    margin-bottom: 4rem;
}

.temhafull2-N3 .contents-swiper {
    width: 100%;
    height: 100%;
    padding: 0 8rem 0 4rem;
}

.temhafull2-N3 .contents-swiper .swiper-wrapper {
    overflow: hidden;
}

.temhafull2-N3 .contents-swiper .swiper-slide {
    min-height: 56.6rem;
}

.temhafull2-N3 .textset .textset-tit {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.temhafull2-N3 .textset .textset-tit+.textset-desc {
    margin-top: 2.4rem;
}

.temhafull2-N3 .textset .textset-tit+.textset-subtit {
    margin-top: 3rem;
}

.temhafull2-N3 .textset .textset-subtit {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--primary);
}

.temhafull2-N3 .textset .textset-desc {
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #797981;
}

.temhafull2-N3 .textset .textset-desc+.textset-desc {
    margin-top: 2.4rem;
}

.temhafull2-N3 .imageset {
    width: 40rem;
    height: 10rem;
    margin-top: 6rem;
}

.temhafull2-N3 .imageset .imageset-img {
    object-fit: contain;
}

.temhafull2-N3 .swiper-controls {
    display: flex;
    position: absolute;
    top: 50%;
    right: 52.6rem;
    z-index: 20;
    background: #212126;
    border-radius: 0.8rem;
    overflow: hidden;
}

.temhafull2-N3 .swiper-button-prev,
.temhafull2-N3 .swiper-button-next {
    position: static;
    width: 9.2rem;
    height: 9.2rem;
    margin: 0;
    transition: background 0.3s;
}

.temhafull2-N3 .swiper-button-next {
    transform: rotate(180deg);
}

.temhafull2-N3 .swiper-button-prev:hover,
.temhafull2-N3 .swiper-button-next:hover {
    background: var(--primary);
}

.temhafull2-N3 .swiper-button-prev::after,
.temhafull2-N3 .swiper-button-next::after {
    content: "";
    width: 4.8rem;
    height: 4.8rem;
    background: url(/theme/zigger-hyangnam/layout/resources/icons/ico_arrow_lg_white.svg) no-repeat center/contain;
}

.temhafull2-N3 .swiper-pagination {
    position: static;
    width: auto;
    margin-top: 3.2rem;
    text-align: left;
}

.temhafull2-N3 .swiper-pagination-bullet {
    background: #d8d8d8;
    opacity: 1;
}

.temhafull2-N3 .swiper-pagination-bullet-active {
    background: var(--primary);
}

.temhafull2-N3 .cardset-warp {
    --th-gutter: 0.5rem;
    max-height: 40rem;
    margin-top: 3.5rem;
    overflow-y: auto;
}

.temhafull2-N3 .cardset .cardset-inner {
    width: 100%;
    height: 100%;
    padding: 3rem;
    border-radius: 0.8rem;
    background: #f6f8fc;
    overflow: hidden;
}

.temhafull2-N3 .cardset .cardset-top {
    display: flex;
    align-items: center;
    gap: 0.8rem;
}

.temhafull2-N3 .cardset .cardset-top strong {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.temhafull2-N3 .cardset .cardset-figure {
    flex-shrink: 0;
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    background: var(--primary);
}

.temhafull2-N3 .cardset .cardset-icon {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.temhafull2-N3 .cardset .cardset-body {
    padding-top: 1.2rem;
    padding-bottom: 0;
}

.temhafull2-N3 .cardset .cardset-tit {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.temhafull2-N3 .cardset .cardset-tit+.cardset-desc {
    margin-top: 0.4rem;
    margin-bottom: 0;
}

.temhafull2-N3 .cardset .cardset-desc {
    color: #797981;
}

.temhafull2-N3 .contents-visual {
    position: absolute;
    right: 0;
    top: 0;
    width: 61.8rem;
    height: 100%;
}

.temhafull2-N3 .contents-visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@media (max-width: 1400px) {
    .temhafull2-N3 .contents-visual {
        width: calc(50% - 18rem);
    }

    .temhafull2-N3 .swiper-controls {
        right: calc(50% - 18rem - 9.2rem);
    }

    .temhafull2-N3 .contents-swiper {
        padding-right: 4rem;
    }
}

@media (max-width: 992px) {
    .temhafull2-N3 {
        padding-top: 0rem;
        padding-bottom: 4rem;
    }

    .temhafull2-N3 .contents-container {
        align-items: flex-start;
        position: relative;
        height: auto;
    }

    .temhafull2-N3 .contents-inner {
        height: 100%;
    }

    .temhafull2-N3 .contents-title {
        margin-bottom: 2rem;
    }

    .temhafull2-N3 .contents-left {
        justify-content: flex-start;
        width: 100%;
        max-width: 100%;
        height: 100%;
    }

    .temhafull2-N3 .contents-swiper {
        height: auto;
        padding: 0 0 4rem 0;
    }

    .temhafull2-N3 .contents-swiper .swiper-slide {
        min-height: auto;
    }

    .temhafull2-N3 .textset .textset-tit+.textset-desc {
        margin-top: 2rem;
    }

    .temhafull2-N3 .textset .textset-tit+.textset-subtit {
        margin-top: 2rem;
    }

    .temhafull2-N3 .textset .textset-desc+.textset-desc {
        margin-top: 2rem;
    }

    .temhafull2-N3 .imageset {
        width: 100%;
        margin-top: 5rem;
    }

    .temhafull2-N3 .cardset-warp {
        --th-gutter: 0.4rem;
        max-height: 56rem;
        margin-top: 2rem;
    }

    .temhafull2-N3 .cardset .cardset-inner {
        padding: 2rem 1.6rem;
    }

    .temhafull2-N3 .cardset .cardset-body {
        padding-top: 0.8rem;
    }

    .temhafull2-N3 .cardset .cardset-figure {
        width: 3.2rem;
        height: 3.2rem;
    }

    .temhafull2-N3 .cardset .cardset-tit+.cardset-desc {
        margin-top: 0.2rem;
    }

    .temhafull2-N3 .cardset .cardset-desc {
        display: block;
    }

    .temhafull2-N3 .swiper-pagination {
        position: absolute;
        top: auto;
        bottom: 0;
        left: 1.6rem;
        margin-top: 0;
    }

    .temhafull2-N3 .swiper-controls {
        display: none;
    }

    .temhafull2-N3 .contents-visual {
        display: none;
    }
}

/* glamping-N25 CSS */
.glamping-N25 {
    overflow: hidden;
    position: relative;
    padding-top: 0rem;
    padding-bottom: 8rem;
}

.glamping-N25 .contents-container {
    display: flex;
    justify-content: space-between;
    gap: 19rem;
    /** max-width: 1200px; **/
    margin: 0 auto;
    /** padding: 0 2rem; **/
}

.glamping-N25 .contents-group {
    flex: 1;
}

.glamping-N25 .tableset-tit {
    display: block;
    margin-bottom: 2rem;
}

.glamping-N25 .tableset-table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1rem;
}

.glamping-N25 .tableset-table th,
.glamping-N25 .tableset-table td {
    text-align: center;
    padding: 1rem 0.5rem;
    border: 1px solid #dee2e6;
    vertical-align: middle;
}

.glamping-N25 .tableset-table tr th {
    background: #F7F7FB;
    font-weight: 600;
}

.glamping-N25 .tableset-desc {
    display: block;
    margin-top: 0.8rem;
    color: #242424;
}

/* 색상 구분 */
.adult-morning {
    background-color: #fff !important;
    /* 연한 주황 */
}

.aqua-therapy {
    background-color: #cfe2f3 !important;
    /* 연한 파랑 */
}

.children {
    background-color: #ead1dc !important;
    /* 연한 분홍 */
}

.adult-evening {
    background-color: #fce5cd !important;
    /* 연한 주황 */
}

@media (max-width: 992px) {
    .padding-top-4 {
        padding-top: 0rem;
    }
}

@media (max-width: 992px) {

    .glamping-N25 {
        padding-top: 0rem;
        padding-bottom: 5rem;
    }

    .glamping-N25 .contents-container {
        flex-direction: column;
        gap: 0rem;
        padding: 0 1rem;
    }

    .glamping-N25 .contents-group {
        width: 100%;
    }

    .glamping-N25 .tableset-tit {
        margin-bottom: 0.8rem;
    }

    .glamping-N25 .contents-group .tableset+.tableset {
        margin-top: 6rem;
    }

    .glamping-N25 .tableset .tableset-table> :not(caption):not(colgroup)>*>* {
        padding: 1rem 0.5rem;
        font-size: 1.3rem;
    }

    .glamping-N25 .tableset .tableset-table {
        min-width: 0;
    }

    .glamping-N25 .table-scroll-wrapper {
        position: relative;
        overflow-x: auto;
        border: 1px solid #dee2e6;
        border-radius: 0.375rem;
        background: white;
    }

    .glamping-N25 .table-scroll-wrapper::-webkit-scrollbar {
        height: 6px;
    }

    .glamping-N25 .table-scroll-wrapper::-webkit-scrollbar-track {
        background: #f1f1f1;
    }

    .glamping-N25 .table-scroll-wrapper::-webkit-scrollbar-thumb {
        background: #005C9C;
        border-radius: 3px;
    }

    .glamping-N25 .mobile-scroll-table {
        min-width: 700px;
        margin: 0;
    }

    /* 첫 번째 열(시간) 고정 */
    .glamping-N25 .mobile-scroll-table th:first-child,
    .glamping-N25 .mobile-scroll-table td:first-child {
        position: sticky;
        left: 0;
        background: white;
        z-index: 2;
        border-right: 2px solid #005C9C;
        box-shadow: 2px 0 4px rgba(0, 0, 0, 0.1);
        min-width: 100px;
        width: 100px;
    }

    /* 헤더 고정 */
    .glamping-N25 .mobile-scroll-table thead th {
        position: sticky;
        top: 0;
        z-index: 3;
        background: #F7F7FB;
    }

    /* 첫 번째 헤더 셀 (시간 + 고정) */
    .glamping-N25 .mobile-scroll-table thead th:first-child {
        z-index: 4;
    }

    .glamping-N25 .mobile-scroll-table th,
    .glamping-N25 .mobile-scroll-table td {
        padding: 0.8rem 0.5rem;
        text-align: center;
        vertical-align: middle;
        white-space: nowrap;
        min-width: 80px;
        font-size: 0.9rem;
    }

    .glamping-N25 .mobile-scroll-table td:nth-child(2) {
        min-width: 120px;
    }

    .glamping-N25 .mobile-scroll-table td:nth-child(3) {
        min-width: 140px;
    }

    .glamping-N25 .mobile-scroll-table td:nth-child(4) {
        min-width: 160px;
        white-space: normal;
        line-height: 1.2;
    }

    .glamping-N25 .mobile-scroll-table td:nth-child(5) {
        min-width: 80px;
    }

    .glamping-N25 .mobile-scroll-table td:nth-child(6) {
        min-width: 140px;
        white-space: normal;
        line-height: 1.2;
    }
}

/* PC에서는 모바일 테이블 숨김 */
@media (min-width: 993px) {
    .glamping-N25 .mobile-table-wrapper {
        display: none;
    }
}

/* 모바일에서 PC 테이블 숨김 */
@media (max-width: 992px) {
    .glamping-N25 .desktop-table {
        display: none;
    }
}


/* basic-N18 */
.basic-N18 {
    position: relative;
    padding-top: 0rem;
    padding-bottom: 4rem;
    overflow: hidden;
    background: #FFFFFFFF;
}

.basic-N18 .textset {
    margin-bottom: 4rem;
}

.basic-N18 .cardset .cardset-figure {
    height: 32rem;
    border-radius: 2rem;
    overflow: hidden;
}

.basic-N18 .cardset .cardset-figure+.cardset-body {
    margin-top: 4rem;
}

.basic-N18 .cardset .cardset-body {
    padding: 0;
    background: transparent;
}

.basic-N18 .cardset .cardset-tit+.cardset-desc {
    margin-top: 2rem;
}

.basic-N18 .cardset .cardset-desc {
    display: block;
    color: var(--text-color3);
}

@media (max-width: 992px) {
    .basic-N18 {
        padding-top: 0rem;
        padding-bottom: 5rem;
    }

    .basic-N18 .row {
        --th-gutter: 0.2rem;
    }

    .basic-N18 .cardset .cardset-figure {
        height: 30rem;
    }

    .basic-N18 .cardset .cardset-figure+.cardset-body {
        margin-top: 3rem;
    }
}

/* furniture-N19 */
.furniture-N19 {
    position: relative;
    padding-top: 4rem;
    padding-bottom: 4rem;
    overflow: hidden;
    background: #F7F7FBFF;
}

.furniture-N19 .contents-inner {
    width: 100%;
}

.furniture-N19 .title-area {
    margin-bottom: 6rem;
    text-align: center;
}

.furniture-N19 .title-area h2 {
    color: var(--text-color3);
    font-weight: var(--fw-medium);
}

.furniture-N19 .title-area p {
    margin-top: 1.2rem;
}

.furniture-N19 .process-area {
    display: flex;
    gap: 2.4rem;
}

.furniture-N19 .process-items {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4rem;
    background-color: #fff;
    padding: 4rem 2rem;
    border-radius: 0.8rem;
    position: relative;
}

.furniture-N19 .process-items:not(:first-child)::before {
    content: "";
    width: 4rem;
    height: 4rem;
    background: url(../icons/ico_arrow_black.svg) no-repeat center/cover;
    position: absolute;
    top: 50%;
    left: -3.2rem;
    transform: translateY(-50%);
}

.furniture-N19 .item-thumb,
.furniture-N19 .item-desc {
    text-align: center;
}

.furniture-N19 .item-thumb img {
    width: 100%;
    max-width: 8rem;
    height: 100%;
    max-height: 8rem;
}

.furniture-N19 .item-desc strong {
    font-weight: var(--fw-bold);
}

.furniture-N19 .item-desc p {
    margin-top: 1rem;
    color: var(--text-color3);
}

@media (max-width: 992px) {
    .furniture-N19 {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .furniture-N19 .title-area {
        margin-bottom: 3rem;
    }

    .furniture-N19 .title-area p {
        margin-top: 0;
    }

    .furniture-N19 .process-area {
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

    .furniture-N19 .process-items {
        gap: 1.8rem;
    }

    .furniture-N19 .process-items:nth-child(3)::before {
        content: none;
    }

    .furniture-N19 .item-desc p {
        margin-top: 0.8rem;
    }
}

@media (max-width: 576px) {
    .furniture-N19 .process-area {
        display: flex;
        flex-direction: column;
        gap: 1.4rem;
    }

    .furniture-N19 .process-items:not(:first-child)::before {
        top: -2.6rem;
        left: 50%;
        transform: translateX(-50%) rotate(90deg);
    }

    .furniture-N19 .process-items:nth-child(3)::before {
        content: "";
    }
}

/* rentalcar-N10 */
.rentalcar-N10 {
    overflow: hidden;
    position: relative;
    padding-top: 4rem;
    padding-bottom: 5rem;
    background: #FFFFFFFF;
}

.rentalcar-N10 .contents-inner {
    width: 100%;
}

.rentalcar-N10 .title-area .textset-desc {
    margin: 0.8rem 0 0;
    color: var(--text-color3);
}

.rentalcar-N10 .accordset {
    margin-top: 4rem;
}

.rentalcar-N10 .accordset.accordset-round {
    border-radius: 2rem;
}

.rentalcar-N10 .accordset.accent-header .accordset-item.active .accordset-button {
    background: #ecfbfb;
}

.rentalcar-N10 .accordset .accordset-q {
    color: var(--primary);
}

.rentalcar-N10 .accordset .accordset-q,
.rentalcar-N10 .accordset .accordset-a {
    align-self: flex-start;
}

.rentalcar-N10 .accordset .accordset-a {
    transform: translateY(0.4rem);
}

.rentalcar-N10 .accordset-header p {
    display: flex;
    align-items: center;
    align-self: stretch;
}

.rentalcar-N10 .accordset .accordset-body,
.rentalcar-N10 .accordset.accordset-plus .accordset-item.active .accordset-body {
    background: #f8f8fa;
}

.rentalcar-N10 .accordset .accordset-content {
    align-items: center;
    padding: 3rem 2.4rem;
    min-height: 9.4rem;
}

.rentalcar-N10 .accordset.accordset-plus .accordset-header::after {
    font-size: 2.4rem;
}

@media (max-width: 992px) {
    .rentalcar-N10 {
        padding-top: 4rem;
        padding-bottom: 4rem;
    }

    .rentalcar-N10 .accordset {
        margin-top: 4rem;
    }

    .rentalcar-N10 .accordset.accordset-round {
        border-radius: 1.6rem;
    }

    .rentalcar-N10 .accordset .accordset-content {
        padding: 1.6rem;
        min-height: 8rem;
    }

    .rentalcar-N10 .accordset.accordset-plus .accordset-header::after {
        width: 2.4rem;
        height: 2.4rem;
        font-size: 1.8rem;
    }

    .rentalcar-N10 .accordset .accordset-q {
        transform: translateY(0.2rem);
    }
}

/* sub_about-N15 */
.sub_about-N15 {
    overflow: hidden;
    position: relative;
    padding-top: 0rem;
    padding-bottom: 16rem;
}

.sub_about-N15 .title-area {
    text-align: center;
}

.sub_about-N15 .tabset {
    margin-bottom: 6rem;
}

.sub_about-N15 .tabset.tabset-text .tabset-link {
    color: var(--text-color3);
}

.sub_about-N15 .tabset.tabset-text .tabset-link.active,
.sub_about-N15 .tabset.tabset-text .tabset-link:hover {
    color: var(--secondary);
}

.sub_about-N15 .tabset.tabset-text .tabset-item+.tabset-item .tabset-link::before {
    content: none;
}

.sub_about-N15 .tab-cont {
    display: none;
}

.sub_about-N15 .tab-cont.active {
    display: block;
}

.sub_about-N15 .list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2.4rem;
}

.sub_about-N15 .item {
    overflow: hidden;
    position: relative;
    border-radius: 0.8rem;
    aspect-ratio: 342/420;
}

.sub_about-N15 .item a {
    display: block;
    width: 100%;
    height: 100%;
}

.sub_about-N15 .item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sub_about-N15 .desc {
    display: flex;
    align-items: center;
    gap: 1rem;
    position: absolute;
    bottom: 0;
    left: 0;
    padding: 1.2rem 1.6rem;
    width: 100%;
    background: var(--white-rgb), 0.16;
    backdrop-filter: blur(2rem);
}

.sub_about-N15 .desc strong {
    flex-shrink: 1;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 1;
    text-overflow: ellipsis;
    font-weight: var(--fw-bold);
}

.sub_about-N15 .desc p {
    font-weight: 600;
    font-size: 1.4rem;
    margin: 0 0 0.8rem 0;
    text-align: left;
}

.sub_about-N15 .pagiset {
    margin-top: 6rem;
}

.sub_about-N15 .pagiset .pagiset-link.active-line {
    color: var(--secondary);
    border-color: var(--secondary);
}

/* 자격증 정보 스타일 - 기존 CSS 활용 */
.sub_about-N15 .desc .certifications {
    font-size: 1rem;
    /* 이름보다 작은 폰트 사이즈 */
    font-weight: 400;
    color: #666;
    line-height: 1.3;
    margin: 0;
    text-align: left;
}

.sub_about-N15 .desc .certifications span {
    display: block;
    margin-bottom: 0.2rem;
}

.sub_about-N15 .desc .certifications span:last-child {
    margin-bottom: 0;
}

/* 반응형 스타일 */
@media (max-width: 992px) {
    .sub_about-N15 {
        padding-top: 0rem;
        padding-bottom: 12rem;
    }

    .sub_about-N15 .tabset {
        margin-bottom: 3rem;
    }

    .sub_about-N15 .tabset.tabset-text .tabset-list {
        justify-content: center;
        flex-wrap: nowrap;
        gap: 2.6rem;
    }

    .sub_about-N15 .list {
        grid-template-columns: repeat(3, 1fr);
    }

    .sub_about-N15 .desc {
        opacity: 1;
        visibility: visible;
    }
}

@media (max-width: 768px) {
    .sub_about-N15 .list {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.6rem;
    }
}

@media (max-width: 576px) {
    .sub_about-N15 .list {
        grid-template-columns: 1fr;
    }

    .sub_about-N15 .item {
        aspect-ratio: 328 / 400;
    }
}



.basic-N54 {
    position: relative;
    padding-top: 8rem;
    padding-bottom: 8rem;
    overflow: hidden;
}


.basic-N54 .container-md {
    position: relative;
    max-width: calc(1280px + 8rem);
    margin: 0 auto;
    padding: 0 0rem;
}


.basic-N54 .tabset {
    margin-bottom: 8rem;
}

.basic-N54 .tabset .tabset-list .tabset-item {
    flex-grow: 0;
    min-width: 16rem;
    overflow: hidden;
}

.basic-N54 .tabset .tabset-list .tabset-item:first-child {
    border-radius: 0.6rem 0 0 0.6rem;
}

.basic-N54 .tabset .tabset-list .tabset-item:last-child {
    border-radius: 0 0.6rem 0.6rem 0;
}

.basic-N54 .cardset .cardset-figure {
    height: 30rem;
    border-radius: 2rem;
    overflow: hidden;
}

.basic-N54 .cardset .cardset-figure+.cardset-body {
    margin-top: 2rem;
}

.basic-N54 .cardset .cardset-body {
    padding: 0;
}

.basic-N54 .cardset .cardset-desc {
    margin-top: 0.8rem;
}

.basic-N54 .cardset .cardset-desc+.cardset-txt {
    display: inline-block;
    margin-top: 2rem;
    color: var(--text-color4);
}

.basic-N54 .pagiset {
    margin-top: 4rem;
}

.basic-N54 .pagiset .pagiset-link {
    border-radius: 0.6rem;
}

@media (max-width: 992px) {
    .basic-N54 {
        padding-top: 0rem;
        padding-bottom: 5rem;
    }

    .basic-N54 .tabset {
        margin-bottom: 4rem;
    }

    .basic-N54 .tabset .tabset-list {
        flex-wrap: wrap;
        border-radius: 0.6rem;
        overflow: initial;
    }

    .basic-N54 .tabset .tabset-list .tabset-item {
        flex-grow: 1;
    }

    .basic-N54 .tabset .tabset-list .tabset-item+.tabset-item {
        border-left: 1px solid var(--border-color);
    }

    .basic-N54 .tabset .tabset-list .tabset-item:first-child {
        border-radius: 0.6rem 0.6rem 0 0;
    }

    .basic-N54 .tabset .tabset-list .tabset-item:last-child {
        border-radius: 0 0 0.6rem 0.6rem;
    }

    .basic-N54 .pagiset .pagiset-link {
        width: 3.2rem;
        height: 3.2rem;
    }
}


.opilsol-N24 {
    overflow: hidden;
    position: relative;
    padding-top: 0rem;
    padding-bottom: 4rem;
}

.opilsol-N24 .contents-inner {
    width: 100%;
}

.opilsol-N24 .tableset {
    text-align: center;
}

.opilsol-N24 .tableset .tableset-table>thead.thead-light>*>* {
    background: #fff;
}

.opilsol-N24 .tableset .tableset-table>thead.thead-border-top>*>* {
    border-top: 1px solid #111;
    border-bottom: 0;
}

.opilsol-N24 .tableset .tableset-table>tbody>*>td.text-left {
    text-align: left;
}

.opilsol-N24 .tableset tbody {
    border-top: 1px solid var(--border-color);
}

.opilsol-N24 .tableset tbody tr:hover {
    background-color: #fafafa;
}

.opilsol-N24 .tableset tbody td.date {
    color: #bbbbbb;
}

.opilsol-N24 .pagiset {
    margin-top: 8rem;
}

.opilsol-N24 .pagiset.pagiset-line .pagiset-ctrl .pagiset-link::after {
    font-size: 1.8rem;
}

@media (max-width: 992px) {
    .opilsol-N24 {
        padding-top: 0rem;
        padding-bottom: 0rem;
    }

    .opilsol-N24 .textset {
        margin-bottom: 2rem;
    }

    .opilsol-N24 .tableset-table {
        min-width: auto;
    }

    .opilsol-N24 .tableset-table .tableset-tit a {
        width: 100%;
        text-overflow: ellipsis;
        white-space: nowrap;
        overflow: hidden;
    }

    .opilsol-N24 .tableset.tableset-fract .tableset-table {
        display: block;
    }

    .opilsol-N24 .tableset.tableset-fract thead {
        display: none;
    }

    .opilsol-N24 .tableset.tableset-fract tbody {
        display: block;
        border-top: 1px solid #111;
    }

    .opilsol-N24 .tableset.tableset-fract tbody tr {
        display: flex;
        justify-content: flex-start;
        flex-wrap: wrap;
        padding: 1.6rem 0.8rem;
        gap: 0;
        border-bottom: 1px solid var(--border-color);
    }

    .opilsol-N24 .tableset.tableset-fract tbody tr td {
        padding: 0 !important;
        border: 0 !important;
    }

    .opilsol-N24 .tableset.tableset-fract .tableset-table td.tableset-mobile {
        display: none;
    }

    .opilsol-N24 .tableset.tableset-fract .tableset-table td.tableset-tit {
        width: 100%;
        max-width: 100%;
        max-height: 2.4rem;
    }

    .opilsol-N24 .tableset.tableset-fract .tableset-table td.tableset-order01 {
        order: 1;
    }

    .opilsol-N24 .tableset.tableset-fract .tableset-table td.tableset-order02 {
        order: 2;
    }

    .opilsol-N24 .tableset.tableset-fract .tableset-table td.tableset-order03 {
        order: 3;
    }

    .opilsol-N24 .tableset.tableset-fract .tableset-table td.tableset-order04 {
        order: 4;
    }

    .opilsol-N24 .tableset.tableset-fract .tableset-table td.tableset-order05 {
        order: 5;
    }

    .opilsol-N24 .tableset.tableset-fract .tableset-table td.tableset-order06 {
        order: 6;
    }

    .opilsol-N24 .pagiset {
        margin-top: 4rem;
    }

    .opilsol-N24 .pagiset.pagiset-line .pagiset-ctrl .pagiset-link::after {
        font-size: 1.2rem;
    }
}


.opilsol-N25 {
    overflow: hidden;
    position: relative;
    padding-top: 8rem;
    padding-bottom: 8rem;
}

.opilsol-N25 .contents-inner {
    width: 100%;
}

.opilsol-N25 .contant-header .textset-tit {
    font-weight: var(--fw-medium);
    text-align: center;
}

.opilsol-N25 .contant-header .textset-desc {
    margin-top: 2rem;
    padding-bottom: 2rem;
    color: #bbb;
    text-align: center;
}

.opilsol-N25 .contant-body {
    border-top: 1px solid #111;
    border-bottom: 1px solid #e5e5e5;
    padding: 4rem 0;
}

.opilsol-N25 .contant-bottom .contant-nav {
    display: flex;
    align-items: center;
    padding: 1.5rem 2.4rem;
    gap: 4rem;
    border-bottom: 1px solid #e5e5e5;
}

.opilsol-N25 .contant-bottom .contant-nav .nav-btn {
    display: flex;
    align-items: center;
    gap: .4rem;
}

.opilsol-N25 .contant-bottom .contant-nav .nav-btn i {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    height: 2rem;
}

.opilsol-N25 .contant-bottom .contant-nav .nav-btn i::before {
    font-size: 1.8rem;
    color: var(--black);
}

.opilsol-N25 .contant-bottom .contant-nav .nav-btn span {
    color: var(--text-color3);
}

.opilsol-N25 .contant-bottom .contant-nav p {
    gap: 0.4rem;
    color: var(--text-color3);
}

.opilsol-N25 .contant-bottom .contant-nav p img {
    transform: rotate(-90deg);
    width: 2.4rem;
    height: 2.4rem;
}

.opilsol-N25 .contant-bottom .con-link-btn {
    position: relative;
    padding: 0 2rem 0 3rem;
    color: var(--text-color3);
    text-align: center;
    border: 0 none;
    background-color: transparent;
}

.opilsol-N25 .contant-bottom .con-link-btn::before {
    content: "\e900";
    display: inline-block;
    position: absolute;
    left: -0.5rem;
    top: 50%;
    right: 2.4rem;
    transform: translateY(-50%);
    width: 2.8rem;
    height: 2.8rem;
    color: #111;
}

.opilsol-N25 .contant-bottom .con-link-btn.prve::before {
    transform: translateY(-50%) rotate(-180deg);
}

.opilsol-N25 .contant-bottom .con-link {
    overflow: hidden;
    flex: 1;
    white-space: nowrap;
    text-overflow: ellipsis;
    font-weight: var(--fw-medium);
    color: #111;
}

.opilsol-N25 .contant-bottom .con-link+span {
    color: #bbbbbb;
}

.opilsol-N25 .bottom-btn {
    margin-top: 6rem;
    text-align: center;
}

@media (max-width: 992px) {

    .opilsol-N25 {
        overflow: hidden;
        position: relative;
        padding-top: 0rem;
        padding-bottom: 0rem;
    }


    .opilsol-N25 .contant-header .textset-desc {
        margin-top: 0.8rem;
    }

    .opilsol-N25 .contant-body {
        padding: 2rem 0 4rem;
    }

    .opilsol-N25 .contant-bottom .contant-nav {
        padding: 1.4rem 0 1.4rem 1.6rem;
        gap: 0.8rem;
    }

    .opilsol-N25 .contant-bottom .contant-nav p img {
        width: 2rem;
        height: 2rem;
    }

    .opilsol-N25 .contant-bottom .con-link+span {
        padding-left: 2.2rem;
    }

    .opilsol-N25 .bottom-btn {
        margin-top: 4rem;
    }
}

/* glamping-N25_copy */
.glamping-N25_copy {
    overflow: hidden;
    position: relative;
    padding-top: 0rem;
    padding-bottom: 8rem;
}

.glamping-N25_copy .contents-container {
    display: flex;
    justify-content: space-between;
    gap: 19rem;
}

.glamping-N25_copy .contents-group {
    flex: 1;
}

.glamping-N25_copy .tableset-tit {
    display: block;
    margin-bottom: 2rem;
    font-weight: var(--fw-bold);
}

.glamping-N25_copy .tableset-table col {
    width: 24rem;
}

.glamping-N25_copy .contents-group .tableset+.tableset {
    margin-top: 10rem;
}

.glamping-N25_copy .tableset-table th,
.glamping-N25_copy .tableset-table td {
    text-align: center;
}

.glamping-N25_copy .tableset-table tr th {
    background: #fff;
}

.glamping-N25_copy .tableset-desc {
    display: block;
    margin-top: 0.8rem;
    color: #242424;
}

@media (max-width: 992px) {
    .glamping-N25_copy {
        padding-top: 0rem;
        padding-bottom: 5rem;
    }

    .glamping-N25_copy .contents-container {
        flex-direction: column;
        gap: 1rem;
    }

    .glamping-N25_copy .contents-tit {
        width: auto;
    }

    .glamping-N25_copy .contents-group {
        width: 100%;
    }

    .glamping-N25_copy .tableset-tit {
        margin-bottom: 0.8rem;
    }

    .glamping-N25_copy .contents-group .tableset+.tableset {
        margin-top: 6rem;
    }

    .glamping-N25_copy .tableset .tableset-table> :not(caption):not(colgroup)>*>* {
        padding: 1.4rem 0;
    }

    .glamping-N25_copy .tableset .tableset-table {
        min-width: 0;
    }
}

/* glamping-N33 */
.glamping-N33 {
    /*overflow: hidden;*/
    position: relative;
    padding-top: 0rem;
    padding-bottom: 4rem;
}

.glamping-N33 .contents-inner {
    width: 100%;
}

.glamping-N33 .title-area {
    display: flex;
    align-items: flex-end;
    gap: 0.4rem;
}

.glamping-N33 .title-area h2 {
    font-weight: var(--fw-bold);
}

.glamping-N33 .title-area span {
    color: #dc0000;
    font-weight: var(--fw-regular);
}

.glamping-N33 .desc-area {
    /*overflow-y: auto;*/
    display: flex;
    flex-direction: column;
    gap: 0.7rem;
    /*margin-top: 2.3rem;*/
    padding: 3.7rem 4rem;
    /*height: 25rem;*/
    background: #f6f8fa;
}

.glamping-N33 .desc strong {
    font-weight: var(--fw-medium);
}

.glamping-N33 .desc p {
    color: #666666;
    margin-top: 0.8rem;
}

.glamping-N33 .radioset-wrap {
    justify-content: flex-end;
    gap: 4rem;
    margin-top: 1.8rem;
}

.glamping-N33 .radioset {
    gap: 1.2rem;
}

.glamping-N33 .radioset .radioset-text {
    font-weight: var(--fw-regular);
    color: #242424;
}

.glamping-N33 .radioset .radioset-text,
.glamping-N33 .radioset-wrap .radioset+.radioset {
    margin: 0;
}

.glamping-N33 .radioset .radioset-input+.radioset-label {
    flex-shrink: 0;
}

@media (max-width: 992px) {
    .glamping-N33 {
        padding-top: 0rem;
        padding-bottom: 5rem;
    }

    .glamping-N33 .desc-area {
        gap: 2rem;
        margin-top: 0.8rem;
        padding: 1.6rem;
        height: auto;
        /* max-height: 28.8rem; */
    }

    .glamping-N33 .radioset-wrap {
        margin-top: 1.6rem;
        gap: 2rem;
    }

    .glamping-N33 .radioset {
        gap: 0.8rem;
    }
}

/* skin-N23 */
.skin-N23 {
    overflow: hidden;
    position: relative;
    padding-top: 0rem;
    padding-bottom: 0rem;
}

.skin-N23 .contents-inner {
    width: 100%;
}

.skin-N23 .title-area {
    margin-bottom: 4rem;
    text-align: center;
}

.skin-N23 .list-area {
    display: flex;
}

.skin-N23 .list-area li {
    display: flex;
    flex-direction: column;
    flex: 1;
    position: relative;
    padding: 4rem;
    text-align: center;
}

.skin-N23 .list-area li:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -6rem;
    transform: translateY(-50%);
    width: 12rem;
    height: 0.1rem;
    background: #e5e5e5;
}

.skin-N23 .list-area span {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.4rem 2.4rem;
    margin: 0 auto;
    width: 7.4rem;
    height: 3.7rem;
    color: #fff;
    font-weight: var(--fw-bold);
    background: var(--primary);
    border-radius: 1.9rem;
}

.skin-N23 .list-area .thumb {
    margin: 4.8rem 0 2.8rem;
}

.skin-N23 .list-area .thumb img {
    width: 6rem;
    height: 6rem;
    object-fit: cover;
}

.skin-N23 .list-area .desc strong {
    font-weight: var(--fw-bold);
    color: var(--primary);
}

.skin-N23 .list-area .desc p {
    margin-top: 1.6rem;
    color: #767676;
    word-break: keep-all;
    text-wrap: pretty;
}

@media (max-width: 992px) {
    .skin-N23 {
        padding-top: 0rem;
        padding-bottom: 0rem;
    }

    .skin-N23 .title-area {
        margin-bottom: 2.4rem;
    }

    .skin-N23 .list-area {
        flex-direction: column;
        gap: 8rem;
    }

    .skin-N23 .list-area li {
        align-items: center;
        padding: 2.4rem 0;
    }

    .skin-N23 .list-area li:not(:last-child)::after {
        top: auto;
        bottom: -8rem;
        right: auto;
        transform: none;
        width: 0.1rem;
        height: 8rem;
    }

    .skin-N23 .list-area span {
        padding: 0.2rem 1.8rem;
        width: 5.8rem;
        height: 2.8rem;
    }

    .skin-N23 .list-area .thumb {
        margin: 2.4em 0 1.8rem;
    }

    .skin-N23 .list-area .thumb img {
        width: 4.6rem;
        height: 4.6rem;
    }

    .skin-N23 .list-area .desc p {
        margin-top: 1.2rem;
    }
}

/* skin-N23_copy */
.skin-N23_copy {
    overflow: hidden;
    position: relative;
    padding-top: 6rem;
    padding-bottom: 6rem;
}

.skin-N23_copy .contents-inner {
    width: 100%;
}

.skin-N23_copy .title-area {
    margin-bottom: 4rem;
    text-align: center;
}

.skin-N23_copy .list-area {
    display: flex;
}

.skin-N23_copy .list-area li {
    display: flex;
    flex-direction: column;
    flex: 1;
    position: relative;
    padding: 4rem;
    text-align: center;
}

.skin-N23_copy .list-area li:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -6rem;
    transform: translateY(-50%);
    width: 12rem;
    height: 0.1rem;
    background: #e5e5e5;
}

.skin-N23_copy .list-area span {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.4rem 2.4rem;
    margin: 0 auto;
    width: 7.4rem;
    height: 3.7rem;
    color: #fff;
    font-weight: var(--fw-bold);
    background: var(--primary);
    border-radius: 1.9rem;
}

.skin-N23_copy .list-area .thumb {
    margin: 4.8rem 0 2.8rem;
}

.skin-N23_copy .list-area .thumb img {
    width: 6rem;
    height: 6rem;
    object-fit: cover;
}

.skin-N23_copy .list-area .desc strong {
    font-weight: var(--fw-bold);
    color: var(--primary);
}

.skin-N23_copy .list-area .desc p {
    margin-top: 1.6rem;
    color: #767676;
    word-break: keep-all;
    text-wrap: pretty;
}

@media (max-width: 992px) {
    .skin-N23_copy {
        padding-top: 8rem;
        padding-bottom: 8rem;
    }

    .skin-N23_copy .title-area {
        margin-bottom: 2.4rem;
    }

    .skin-N23_copy .list-area {
        flex-direction: column;
        gap: 8rem;
    }

    .skin-N23_copy .list-area li {
        align-items: center;
        padding: 2.4rem 0;
    }

    .skin-N23_copy .list-area li:not(:last-child)::after {
        top: auto;
        bottom: -8rem;
        right: auto;
        transform: none;
        width: 0.1rem;
        height: 8rem;
    }

    .skin-N23_copy .list-area span {
        padding: 0.2rem 1.8rem;
        width: 5.8rem;
        height: 2.8rem;
    }

    .skin-N23_copy .list-area .thumb {
        margin: 2.4em 0 1.8rem;
    }

    .skin-N23_copy .list-area .thumb img {
        width: 4.6rem;
        height: 4.6rem;
    }

    .skin-N23_copy .list-area .desc p {
        margin-top: 1.2rem;
    }
}


/* office-N3 */
.office-N3 {
    position: fixed;
    bottom: 5rem;
    right: 4.4rem;
    z-index: 50;
    pointer-events: none;
}

.office-N3 .quick-wrap {
    pointer-events: auto;
}

.office-N3 .quick {
    padding: 1rem 0;
    width: 4.4rem;
    background: rgba(var(--black-rgb), 0.6);
    border-radius: 9rem;
}

.office-N3 .quick li {
    width: 100%;
}

.office-N3 .quick li .btn {
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    width: 100%;
    height: 4rem;
    color: var(--white);
}

.office-N3 .quick li .ff-ico {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.6rem;
    height: 1.6rem;
    font-size: 1.6rem;
}

.office-N3 .quick span {
    color: var(--white);
    text-align: center;
}

@media (min-width: 993px) {
    .office-N3 .quick span {
        position: absolute;
        right: 100%;
        transform: translateX(-20%);
        opacity: 0;
        visibility: hidden;
        padding: 0.1rem 1.2rem;
        background: rgba(var(--black-rgb), 0.6);
        border-radius: 9rem;
        white-space: nowrap;
        transition: opacity 0.3s, visibility 0.3s, transform 0.3s;
    }

    .office-N3 .quick li .btn:hover span,
    .office-N3 .quick li .btn:focus-within span {
        opacity: 1;
        visibility: visible;
        transform: translateX(-0.4rem);
    }
}

@media (max-width: 992px) {

    .office-N3 {
        display: none;
    }

    /**
    .office-N3 {
        bottom: 1.6rem;
        right: 0;
        width: 100%;
    }**/

    .office-N3 .quick-wrap {
        padding: 0 1.6rem;
    }

    .office-N3 .quick {
        padding: 0;
        width: 100%;
        display: flex;
        border-radius: 27.5rem;
    }

    .office-N3 .quick li {
        flex: 1;
    }

    .office-N3 .quick li .btn {
        flex-direction: column;
        height: 5.4rem;
    }
}

/* loginpage-N9 */
.loginpage-N9 {
    overflow: hidden;
    position: relative;
}

.loginpage-N9 .contents-inner {
    display: flex;
    align-items: center;
    gap: 23rem;
    width: 100%;
    height: 100%;
}

.loginpage-N9 .login-area {
    flex: 1 1 49rem;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.loginpage-N9 .login-wrap {
    width: 100%;
    max-width: 48rem;
}

.loginpage-N9 .form-group {
    margin: 4rem 0;
}

.loginpage-N9 .form-box+.form-box,
.loginpage-N9 .form-box+.form-box-wrap {
    margin-top: 2rem;
}

.loginpage-N9 .form-box-wrap {
    display: flex;
    align-items: center;
    gap: 2rem;
}

.loginpage-N9 .form-box-wrap .form-box {
    margin-top: 0;
}

.loginpage-N9 .form-tit {
    font-weight: var(--fw-bold);
}

.loginpage-N9 .inputset .inputset-input {
    margin-top: 1.2rem;
}

.loginpage-N9 .form-btn {
    margin-top: 2rem;
}

.loginpage-N9 .login-more {
    margin-top: 2rem;
    text-align: center;
}

.loginpage-N9 .login-more a {
    color: var(--text-color3);
    text-decoration: underline;
}

.loginpage-N9 .sns-link {
    position: relative;
}

.loginpage-N9 .link-wrap {
    margin-top: 1.8rem;
}

.loginpage-N9 .link-wrap .btnset+.btnset {
    margin: 1.2rem 0 0;
}

.loginpage-N9 .ico-kakao::before {
    content: "";
    width: 2.6rem;
    height: 2.6rem;
    background: url(/theme/zigger-hyangnam/layout/resources/images/ico_kakao.png) no-repeat center/contain;
}

.loginpage-N9 .ico-naver::before {
    content: "";
    width: 2.6rem;
    height: 2.6rem;
    background: url(/theme/zigger-hyangnam/layout/resources/images/ico_naver.png) no-repeat center/contain;
}

.loginpage-N9 .thumb-area {
    flex: 1 1 74.3rem;
    position: relative;
    height: 80rem;
}

.loginpage-N9 .fullscreen .thumb-area {
    height: 100vh;
}

.loginpage-N9 .thumb-area img {
    width: calc(100% + 4rem);
    height: 100%;
    object-fit: cover;
}

.loginpage-N9 .thumb-area::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.1) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.1) 1px, transparent 1px);
    background-size: 3px 3px;
    z-index: 1;
}

.loginpage-N9 .contents-container:not(.container-full) .thumb-area img {
    position: absolute;
    left: 0;
    width: 50vw;
}

@media (max-width: 1200px) {
    .loginpage-N9 .contents-container:not(.container-full) .thumb-area img {
        position: static;
        width: calc(100% + 4rem);
    }
}

@media (max-width: 992px) {
    .loginpage-N9 {
        padding-bottom: 5rem;
    }

    .loginpage-N9 .contents-inner {
        flex-direction: column-reverse;
        justify-content: flex-end;
        gap: 4rem;
    }

    .loginpage-N9 .login-area {
        flex: none;
        width: 100%;
        padding: 0;
    }

    .loginpage-N9 .login-wrap {
        max-width: 100%;
    }

    .loginpage-N9 .form-box-wrap {
        gap: 1.2rem;
    }

    .loginpage-N9 .inputset .inputset-input {
        margin-top: 0.8rem;
    }

    .loginpage-N9 .ico-kakao::before,
    .loginpage-N9 .ico-naver::before {
        left: 3.2rem;
        width: 2.4rem;
        height: 2.4rem;
    }

    .loginpage-N9 .thumb-area,
    .loginpage-N9 .fullscreen .thumb-area {
        flex: none;
        width: 100%;
        height: 26rem;
    }

    .loginpage-N9 .contents-container:not(.container-full) .thumb-area img,
    .loginpage-N9 .thumb-area img {
        margin-left: -1.6rem;
        width: calc(100% + 3.2rem);
        object-position: top center;
    }
}


/* solution-N1 */
.solution-N1 {
    position: fixed;
    top: 0;
    z-index: 99;
    width: 100%;
    background: var(--white);
    transition: background .3s;
}

.solution-N1.top-menu-active {
    padding-top: 6.7rem;
}

.solution-N1.header-top-active {
    background: rgba(var(--white), 0);
}

.solution-N1 .header-container {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8rem;
    min-height: 8rem;
}

.solution-N1 .header-top {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    border-bottom: 1px solid #e5e5e5;
}

.solution-N1 .user-menu {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 0 8rem;
    margin: 0 auto;
    width: 100%;
}

.solution-N1 .user-menu li {
    position: relative;
}

.solution-N1 .user-menu li:not(:first-child)::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 0.1rem;
    height: 1.2rem;
    background: #e5e5e5;
}

.solution-N1 .user-menu li a {
    padding: 2rem 1.2rem;
    font-weight: 400;
    text-align: center;
    white-space: nowrap;
}

.solution-N1 .user-menu li:last-child a {
    padding: 2rem 0 2rem 1.2rem;
}

.solution-N1 .header-left {
    display: flex;
    align-items: center;
    gap: 3rem;
}

.solution-N1 .header-title {
    display: flex;
    margin-bottom: 0;
}

.solution-N1 .header-title a {
    height: 6rem;
}

.solution-N1 .header-title img {
    height: 100%;
    object-fit: contain;
    vertical-align: top;
    transition: filter 0.3s;
}

.solution-N1 .header-center {
    flex: 1;
}

.solution-N1 .header-gnblist {
    display: flex;
    align-items: center;
    height: 100%;
}

.solution-N1 .header-gnbitem {
    position: relative;
}

.solution-N1 .header-gnblink {
    padding: 2.8rem 3rem;
    height: 100%;
    font-weight: 500;
    text-align: center;
    white-space: nowrap;
}

.solution-N1 .header-gnblink span {
    position: relative;
    transition: color 0.3s;
}

.solution-N1 .header-gnblink span::after {
    content: "";
    transform: scaleX(0);
    width: 100%;
    height: 0.2rem;
    transition: 0.3s;
}

.solution-N1 .header-sublist {
    position: absolute;
    top: 100%;
    overflow: hidden;
    width: 100%;
    min-height: 0;
    opacity: 0;
    transition: opacity 0.3s;
    pointer-events: none;
}

.solution-N1 .header-gnbitem:hover .header-sublist {
    overflow: hidden;
    min-height: auto;
    opacity: 1;
    pointer-events: auto;
}

.solution-N1 .header-gnbitem:hover .header-gnblink span::after {
    content: "";
    display: inline-block;
    position: absolute;
    left: 0;
    top: 100%;
    transform: scaleX(1);
    background-color: var(--text-color1);
}

.solution-N1 .header-subitem {
    overflow: hidden;
    background: var(--white);
}

.solution-N1 .header-sublink {
    padding: 1rem;
    width: 100%;
    font-weight: 500;
    transition: color 0.2s, background 0.2s;
    will-change: color, background;
}

.solution-N1 .header-sublink:hover {
    background: var(--text-color1);
    color: var(--white);
}

.solution-N1 .header-right {
    display: flex;
    align-items: center;
}

.solution-N1 .header-right .header-gnb {
    margin-right: 1.8rem;
}

.solution-N1 .header-utils>ul {
    display: flex;
    align-items: center;
}

.solution-N1 .header-utils>ul>li {
    margin-left: 1.2rem;
}

.solution-N1 .header-utils>ul>li>img {
    width: auto;
    height: 100%;
    object-fit: cover;
    vertical-align: top;
    transition: filter 0.3s;
}

.solution-N1 .btnset.btnset-sm.btnset-icon::before {
    font-size: 2rem;
}

.solution-N1 .header-utils .ico-message::before {
    content: "";
    width: 2rem;
    height: 2rem;
    background: url(../icons/ico_message_w.svg) no-repeat center/contain;
}

.solution-N1 .header-right button {
    max-width: 3.2rem;
    background: none;
    border: none;
}

.solution-N1 .header-right button img {
    width: auto;
    max-height: 100%;
    object-fit: cover;
    vertical-align: top;
}

.solution-N1 .header-utils .member a {
    display: block;
    width: 3.2rem;
    height: 3.2rem;
    font-size: 0;
}

.solution-N1 .header-utils .member img {
    max-width: 100%;
    max-height: 100%;
    object-fit: cover;
    vertical-align: top;
}

.solution-N1 .header-utils .btn-allmenu {
    display: flex;
    flex-direction: column;
    gap: 0.6rem;
}

.solution-N1 .header-utils .btn-allmenu:hover .ico-hamburger:nth-child(2) {
    width: 2.4rem;
}

.solution-N1 .header-utils .btn-allmenu .ico-hamburger,
.solution-N1 .btn-momenu .ico-hamburger {
    width: 2.4rem;
    height: 0.2rem;
    background: var(--text-color1);
    border-radius: 1rem;
    transition: width 0.3s, transform 0.3s, opacity 0.3s;
    will-change: width, transform, opacity;
}

.solution-N1 .header-utils .btn-allmenu .ico-hamburger:nth-child(even),
.solution-N1 .btn-momenu .ico-hamburger:nth-child(2) {
    width: 1.4rem;
}

.solution-N1 .btn-momenu {
    display: none;
}

.solution-N1 .btn-moclose {
    display: none;
}

.solution-N1 .header-fullmenu {
    overflow: hidden;
    position: fixed;
    z-index: 99999;
    padding: 0 2.4rem;
    visibility: hidden;
    background: var(--black);
    transition: 0.3s;
    opacity: 0;
}

.solution-N1 .header-fullmenu.fullmenu-right {
    top: 0;
    right: 0;
    width: 0;
    height: 100%;
}

.solution-N1 .header-fullmenu.fullmenu-left {
    top: 0;
    left: 0;
    width: 0;
    height: 100%;
}

.solution-N1 .header-fullmenu.fullmenu-top {
    width: 100%;
    height: 0;
    top: 0;
    left: 0;
}

.solution-N1 .header-fullmenu.fullmenu-bottom {
    width: 100%;
    height: 0;
    bottom: 0;
    left: 0;
}

.solution-N1 .header-fullmenu.fullmenu-active {
    visibility: visible;
    width: 100%;
    height: 100vh;
    opacity: 1;
}

.solution-N1 .fullmenu-wrapper {
    position: relative;
    top: 50%;
    margin: 0 auto;
    transform: translateY(-50%);
    width: 100%;
    max-width: 128rem;
}

.solution-N1 .fullmenu-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 10rem;
}

.solution-N1 .fullmenu-title {
    margin-bottom: 0;
}

.solution-N1 .fullmenu-title a {
    height: 4.3rem;
}

.solution-N1 .fullmenu-title img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.solution-N1 .fullmenu-member {
    display: flex;
    position: absolute;
    top: 0;
    right: 0;
}

.solution-N1 .fullmenu-member li {
    position: relative;
}

.solution-N1 .fullmenu-member li a {
    padding: 1.2rem;
    font-weight: 500;
    color: var(--white);
}

.solution-N1 .fullmenu-member li::marker {
    content: "";
}

.solution-N1 .fullmenu-member li+li::after {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 0.1rem;
    height: 1.4rem;
    background: rgba(255, 255, 255, 0.2);
}

.solution-N1 .fullmenu-gnblist {
    display: flex;
    justify-content: center;
}

.solution-N1 .fullmenu-gnbitem {
    width: 20%;
}

.solution-N1 .fullmenu-gnbitem+.fullmenu-gnbitem {
    margin-left: 4rem;
}

.solution-N1 .fullmenu-gnblink {
    position: relative;
    padding-bottom: 4rem;
    width: 100%;
    font-weight: 500;
    color: var(--white);
    border-bottom: 1px solid rgba(255, 255, 255, 0.2);
}

.solution-N1 .fullmenu-gnblink::after {
    content: "";
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0;
    height: 0.1rem;
    background: var(--white);
    transition: 0.2s;
}

.solution-N1 .fullmenu-gnblink.on::after {
    width: 18rem;
}

.solution-N1 .fullmenu-sublist {
    padding-top: 4rem;
}

.solution-N1 .fullmenu-subitem+.fullmenu-subitem {
    padding-top: 0.8rem;
}

.solution-N1 .fullmenu-sublink {
    position: relative;
    padding-bottom: 5px;
    font-weight: 400;
    color: #a2a2a2;
    transition: 0.3s;
}

.solution-N1 .fullmenu-sublink::before {
    content: "";
    position: absolute;
    top: 100%;
    right: 0;
    width: 0;
    height: 1px;
    background-color: var(--white);
    transition: width 0.7s cubic-bezier(0.22, 0.61, 0.36, 1);
}

.solution-N1 .fullmenu-sublink:hover {
    color: var(--white);
}

.solution-N1 .fullmenu-sublink:hover::before {
    right: auto;
    left: 0;
    width: 100%;
}

.solution-N1 .fullmenu-close {
    position: fixed;
    right: 8rem;
    top: 2.4rem;
    padding: 0.5rem;
    width: 4.2rem;
    height: 4.2rem;
    background: transparent;
    border: none;
}

.solution-N1 .fullmenu-close img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

@media (max-width: 1120px) {
    .solution-N1 .header-container {
        gap: 4rem;
    }

    .solution-N1 .header-gnblink {
        padding: 2.8rem 2.4rem;
    }
}

@media (max-width: 992px) {
    .solution-N1 {
        padding-top: 0;
        padding-bottom: 0;
    }

    .solution-N1.block-active {
        background: var(--white);
    }

    .solution-N1 .header-gnb {
        overflow: hidden;
        position: absolute;
        top: 100%;
        left: 0;
        z-index: 9;
        padding: 0 1.6rem;
        width: 100%;
        height: 0;
        background-color: var(--white);
        transition: height 0.3s;
    }

    .solution-N1 .header-gnb::after {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        opacity: 0;
        visibility: hidden;
        width: 100%;
        height: 100%;
        background: linear-gradient(180deg, rgba(0, 0, 0, 0.5) 0%, rgba(0, 0, 0, 0.12) 60%, rgba(0, 0, 0, 0) 100%);
        transition: opacity 0.3s, visibility 0.3s;
    }

    .solution-N1.block-active .header-gnb {
        overflow-y: auto;
        height: calc(100vh - 6rem);
        padding-bottom: 19rem;
    }

    .solution-N1 .header-container {
        min-height: 6rem;
    }

    .solution-N1 .header-top {
        z-index: 10;
        visibility: hidden;
        border: none;
        opacity: 0;
        transition: opacity 0.3s 0.1s, visibilty 0.3s 0.1s;
        will-change: opacity, visibility;
    }

    .solution-N1.block-active .header-top {
        top: 100%;
        opacity: 1;
        visibility: visible;
    }

    .solution-N1 .user-menu {
        justify-content: flex-start;
        padding: 0 2.2rem;
    }

    .solution-N1 .user-menu li a,
    .solution-N1 .user-menu li:last-child a {
        padding: 2.4rem 1.2rem;
    }

    .solution-N1 .user-menu li:first-child a {
        padding-left: 0;
    }

    .solution-N1 .header-title a {
        width: 7rem;
        height: 3rem;
    }

    .solution-N1 .header-center {
        position: absolute;
        top: 100%;
        left: 0;
        transform: none;
        width: 100%;
        height: 0;
    }

    .solution-N1 .header-gnblist {
        display: block;
        visibility: hidden;
        transition: opacity 0.3s 0.1s;
        opacity: 0;
    }

    .solution-N1 .header-gnblink {
        display: flex;
        align-items: flex-end;
        padding: 1.8rem 0;
        width: 100%;
        text-align: left;
        transition: border 0.3s;
        will-change: border;
        border-bottom: 1px solid #e5e5e5;
    }

    .solution-N1.top-menu-active .header-gnbitem:first-child .header-gnblink {
        padding-top: 6.8rem;
    }

    .solution-N1 .header-gnbitem:hover .header-gnblink span {
        border: none;
    }

    .solution-N1 .header-gnbitem:hover .header-gnblink span::after {
        content: none;
    }

    .solution-N1 .header-sublist {
        display: none;
        position: relative;
        padding: 1.8rem 0 2rem 0;
        opacity: 1;
    }

    .solution-N1 .header-gnbitem.item-active .header-gnblink {
        border-bottom: 1px solid var(--text-color1);
    }

    .solution-N1 .header-subitem {
        width: 100%;
    }

    .solution-N1 .header-subitem+.header-subitem {
        padding-top: 0.8rem;
    }

    .solution-N1 .header-sublink {
        padding: 0;
        color: var(--text-color2);
    }

    .solution-N1 .header-sublink:active {
        color: var(--text-color1);
    }

    .solution-N1 .header-sublink:hover {
        background: var(--white);
        color: var(--text-color1);
    }

    .solution-N1 .header-right button,
    .solution-N1 .header-utils .member a {
        width: 2.8rem;
        height: 2.8rem;
    }

    .solution-N1 .header-utils>ul>li {
        margin-left: 0.6rem;
    }

    .solution-N1 .header-utils .allmenu {
        display: none;
    }

    .solution-N1 .header-utils .btnset-round {
        padding: 0 1.6rem;
    }

    .solution-N1 .header-utils .ico-message::before {
        width: 1.6rem;
        height: 1.6rem;
    }

    .solution-N1 .btn-momenu {
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 0.6rem;
        margin-left: 0.6rem;
    }

    .solution-N1 .btn-momenu .ico-hamburger {
        width: 2rem;
    }

    .solution-N1 .btn-momenu .ico-hamburger:nth-child(2) {
        width: 1.2rem;
    }

    .solution-N1.block-active .header-center {
        pointer-events: auto;
    }

    .solution-N1.block-active .header-title {
        display: flex;
        align-items: center;
        height: 6rem;
    }

    .solution-N1.block-active .header-gnblist {
        visibility: visible;
        opacity: 1;
    }

    .solution-N1 .header-gnbitem:has(.header-sublist) .header-gnblink::after {
        content: "";
        display: flex;
        width: 1.6rem;
        height: 1.6rem;
        background-image: url(../icons/ico_downarrow_black.svg);
        background-repeat: no-repeat;
        background-position: center right;
        background-size: cover;
        transition: transform 0.3s;
        will-change: transform;
    }

    .solution-N1.block-active .header-gnblink {
        align-items: center;
        justify-content: space-between;
    }

    .solution-N1.block-active .header-gnbitem.item-active .header-gnblink::after {
        content: "";
        transform: rotate(180deg);
    }

    .solution-N1.block-active .header-member {
        display: flex;
    }

    .solution-N1.block-active .btn-momenu .ico-hamburger:nth-child(1) {
        transform: translateY(0.8rem) rotate(45deg);
    }

    .solution-N1.block-active .btn-momenu .ico-hamburger:nth-child(3) {
        transform: translateY(-0.8rem) rotate(-45deg);
    }

    .solution-N1.block-active .btn-momenu .ico-hamburger:nth-child(2) {
        visibility: hidden;
        opacity: 0;
    }

    .solution-N1 .header-fullmenu {
        display: none;
    }
}

/* properties-N9 */
.properties-N9 {
    overflow: hidden;
    position: relative;
    padding-top: 14rem;
    padding-bottom: 14rem;
}

.properties-N9 .contents-inner {
    width: 100%;
}

.properties-N9 .title-area {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.2rem;
    margin-bottom: 6rem;
    text-align: center;
}

.properties-N9 .ico-dot {
    width: 1.6rem;
    height: 1.6rem;
    background: url(../icons/ico_diamond.svg) no-repeat center/contain;
}

.properties-N9 .form-group {
    width: 100%;
}

.properties-N9 .form-group .form-tit {
    margin-bottom: 0.8rem;
    font-weight: var(--fw-medium);
}

.properties-N9 .form-group .form-tit+.checkset-wrap,
.properties-N9 .form-group .form-tit+.radioset-wrap {
    gap: 1.2rem 4rem;
    margin-top: 1.6rem;
    flex-wrap: wrap;
}

.properties-N9 .form-group .form-tit span {
    color: #c90000;
}

.properties-N9 .form-box+.form-box {
    margin-top: 1.6rem;
}

.properties-N9 .inputset+.inputset {
    margin-top: 4rem;
}

.properties-N9 .inputset .inputset-tit {
    margin-bottom: 0.8rem;
}

.properties-N9 .inputset .inputset-label {
    width: 100%;
}

.properties-N9 .inputset .inputset-textarea {
    height: 14rem;
    resize: none;
}

.properties-N9 .form-wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-top: 2.4rem;
}

.properties-N9 .contents-agree {
    display: flex;
    align-items: center;
    gap: 0.8rem;
}

.properties-N9 .info-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 2.4rem;
    border-bottom: 1px solid #e5e5e5;
}

.properties-N9 .info-title h3 {
    font-size: var(--fs-h4);
}

.properties-N9 .modal-close {
    cursor: pointer;
}

.properties-N9 .info-area {
    overflow-y: auto;
}

.properties-N9 .info-group+.info-group {
    margin-top: 2.4rem;
}

.properties-N9 .info-group strong {
    display: block;
    padding-bottom: 1.2rem;
    font-size: var(--fs-h5);
}

.properties-N9 .info-desc {
    overflow-y: auto;
    padding: 1.6rem;
    max-height: 20.7rem;
    background: #f8f8fa;
    border-radius: 1.6rem;
}

.properties-N9 .info-desc::-webkit-scrollbar {
    width: 6px;
}

.properties-N9 .info-desc::-webkit-scrollbar-track {
    background-color: #ddd;
}

.properties-N9 .info-desc::-webkit-scrollbar-thumb {
    background-color: #888;
    border-radius: 3px;
}

.properties-N9 .info-desc p {
    font-size: var(--fs-p1);
}

.properties-N9 .info-desc p.fw-medium {
    font-weight: var(--fw-medium);
}

.properties-N9 .info-desc .mtb {
    margin: 2.4rem 0;
}

.properties-N9 .info-desc em {
    display: flex;
    align-items: center;
    position: relative;
    margin: 2.4rem 0 1rem;
    font-style: normal;
    font-weight: 600;
}

.properties-N9 .info-list em::before {
    content: "";
    margin-right: 0.8rem;
    width: 0.4rem;
    height: 0.4rem;
    background: var(--black);
    border-radius: 50%;
}

.properties-N9 .info-list p {
    padding-left: 1.2rem;
}

.properties-N9 .modal-confirm .modal-area {
    position: relative;
    padding: 3.2rem;
    max-width: 36rem;
    background: var(--text-color1);
    border-radius: 0.8rem;
}

.properties-N9 .modal-confirm .modal-icon {
    position: absolute;
    top: 1.4rem;
    right: 1.6rem;
    width: 2.8rem;
    height: 2.8rem;
    border: 0;
    background: transparent;
}

.properties-N9 .modal-confirm .modal-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.properties-N9 .modal-confirm .modal-figure {
    margin: 0 auto;
    width: 5.6rem;
    height: 5.6rem;
}

.properties-N9 .modal-confirm .modal-figure img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.properties-N9 .modal-confirm .modal-body {
    font-size: var(--fs-p1);
    text-align: center;
    color: var(--white);
}

.properties-N9 .modal-confirm .modal-textarea {
    margin: 1.6rem 0;
}

.properties-N9 .modal-confirm .modal-footer {
    text-align: center;
}

.properties-N9 .modal-confirm .modal-footer .btnset {
    min-width: 9.4rem;
    height: 4rem;
    border-radius: 0.4rem;
}

.properties-N9 .modal-confirm .modal-footer .btnset.btnset-line-light {
    border-color: var(--white);
    color: var(--white);
}

.properties-N9 .modalset .modalset-close::before {
    color: var(--text-color1);
}

@media (max-width: 992px) {
    .properties-N9 {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .properties-N9 .title-area {
        flex-direction: column;
        gap: 0.6rem;
        margin-bottom: 3rem;
    }

    .properties-N9 .ico-dot {
        width: 1.2rem;
        height: 1.2rem;
    }

    .properties-N9 .form-box+.form-box {
        margin-top: 1.4rem;
    }

    .properties-N9 .form-group .form-tit+.checkset-wrap,
    .properties-N9 .form-group .form-tit+.radioset-wrap {
        gap: 0.8rem 2.4rem;
    }

    .properties-N9 .form-wrap {
        display: block;
    }

    .properties-N9 .form-btn {
        margin-top: 1.4rem;
        max-width: 100%;
    }

    .properties-N9 .modal-confirm .modal-figure {
        width: 4.8rem;
        height: 4.8rem;
    }

    .properties-N9 .modal-confirm .modal-textarea {
        margin: 0.8rem 0;
    }
}

/* online-N10 CSS */
.online-N10 {
    overflow: hidden;
    position: relative;
    padding-top: 0rem;
    padding-bottom: 4rem;
}

.online-N10 .contents-inner {
    width: 100%;
}

/* 타이틀 영역 */
.online-N10 .title-area {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.2rem;
    margin-bottom: 6rem;
    text-align: center;
}

.online-N10 .ico-dot {
    width: 1.6rem;
    height: 1.6rem;
    background: url(../icons/ico_diamond.svg) no-repeat center/contain;
}

/* 공지사항 */
.online-N10 .notice-box {
    background-color: #e7f3ff;
    border-left: 0.4rem solid var(--primary);
    padding: 2.4rem;
    margin-bottom: 4rem;
    border-radius: 0.8rem;
}

.online-N10 .notice-header h4 {
    font-weight: 500;
    color: var(--primary);
    margin-bottom: 1.2rem;
}

.online-N10 .notice-content ul {
    margin: 0;
    padding-left: 2rem;
}

.online-N10 .notice-content li {
    margin-bottom: 0.8rem;
    color: var(--text-color1);
    font-size: var(--fs-p1);
}

.online-N10 .highlight {
    color: var(--primary);
    font-weight: 500;
}

/* 섹션 타이틀 */
.online-N10 .section-title {
    font-weight: 600;
    color: var(--text-color1);
    margin-bottom: 2rem;
    padding-bottom: 1rem;
    border-bottom: 0.2rem solid var(--primary);
    display: inline-block;
}

/* 검색 섹션 */
.online-N10 .search-section {
    background-color: #F7F7FB;
    border-radius: 0.6rem;
    padding: 3.2rem;
    margin-bottom: 4rem;
    box-shadow: 0 0.2rem 0.2rem rgba(0, 0, 0, 0.1);
}

.online-N10 .form-group {
    width: 100%;
}


/* HR 스타일링 */
.online-N10 hr {
    border: none;
    height: 0.1rem;
    background: linear-gradient(to right, transparent, var(--primary), transparent);
    margin: 3rem 0;
}

.online-N10 hr.thick {
    height: 0.3rem;
    background: var(--primary);
}

.online-N10 hr.dotted {
    height: 0.2rem;
    background-image: repeating-linear-gradient(to right,
            var(--primary),
            var(--primary) 0.5rem,
            transparent 0.5rem,
            transparent 1rem);
}

.online-N10 hr.double {
    height: 0.3rem;
    background: linear-gradient(to bottom, var(--primary) 0, var(--primary) 0.1rem, transparent 0.1rem, transparent 0.2rem, var(--primary) 0.2rem, var(--primary) 0.3rem);
}

.online-N10 hr.gradient {
    height: 0.2rem;
    background: linear-gradient(to right, #007bff, #28a745, #ffc107, #dc3545);
}

.online-N10 hr.section-divider {
    margin: 4rem 0;
    height: 0.2rem;
    background: var(--primary);
    position: relative;
}

.online-N10 hr.section-divider::before {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 2rem;
    height: 2rem;
    background: var(--primary);
    border-radius: 50%;
}


.online-N10 .filter-row {
    display: flex;
    gap: 2rem;
    margin-bottom: 2rem;
    flex-wrap: wrap;
}

.online-N10 .form-box {
    flex: 1;
    min-width: 20rem;
}

.online-N10 .form-box.full-width {
    flex-basis: 100%;
}

.online-N10 .form-box+.form-box {
    margin-top: 0;
}

.online-N10 .inputset {
    position: relative;
}

.online-N10 .form-tit {
    display: block;
    margin-bottom: 0.8rem;
    font-weight: 600;
    color: var(--text-color1);
}

.online-N10 .inputset-input {
    width: 100%;
    /* padding: 1.2rem 1.6rem; */
    border: 0.1rem solid #ddd;
    border-radius: 0.8rem;
    font-size: var(--fs-p1);
    transition: border-color 0.3s ease;
}

.online-N10 .inputset-input:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

/* Select 드롭다운 화살표 */
.online-N10 select.inputset-input {
    background-image: url("data:image/svg+xml;charset=UTF-8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6,9 12,15 18,9'></polyline></svg>");
    background-repeat: no-repeat;
    background-position: right 1.2rem center;
    background-size: 1.6rem;
    padding-right: 4rem;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
}

.online-N10 select.inputset-input:focus {
    background-image: url("data:image/svg+xml;charset=UTF-8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23007bff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6,9 12,15 18,9'></polyline></svg>");
}


/* 체크박스 그룹 */
.online-N10 .checkset-wrap {
    display: flex;
    gap: 1.2rem 4rem;
    margin-top: 1.6rem;
    flex-wrap: wrap;
}

.online-N10 .checkset {
    display: flex;
    align-items: center;
    gap: 0.6rem;
}

.online-N10 .checkset-input {
    width: 1.8rem;
    height: 1.8rem;
    border: 0.1rem solid #ddd;
    border-radius: 0.3rem;
    appearance: none;
    cursor: pointer;
    position: relative;
}

.online-N10 .checkset-input:checked {
    background-color: var(--primary);
    border-color: var(--primary);
}

.online-N10 .checkset-input:checked::after {
    content: '';
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 0.6rem;
    height: 1rem;
    border: solid white;
    border-width: 0 0.2rem 0.2rem 0;
    transform: translate(-50%, -60%) rotate(45deg);
}

.online-N10 .checkset-label {
    font-size: var(--fs-p1);
    color: var(--text-color1);
    cursor: pointer;
}

/* 버튼 */
.online-N10 .form-btn {
    display: flex;
    justify-content: center;
    gap: 1.6rem;
    margin-top: 3.2rem;
}

.online-N10 .btnset {
    padding: 1.2rem 2.4rem;
    border-radius: 0.4rem;
    font-size: var(--fs-p1);
    font-weight: var(--fw-medium);
    text-decoration: none;
    display: inline-block;
    text-align: center;
    cursor: pointer;
    border: none;
    transition: all 0.3s ease;
    min-width: 10rem;
}

.online-N10 .btnset-primary {
    background-color: var(--primary);
    color: white;
    font-size: var(--fs-p1);
    font-weight: var(--fw-medium);
    padding-top: 0.9rem;
}

.online-N10 .btnset-primary:hover {
    background-color: var(--primary-dark, #0056b3);
}

.online-N10 .btnset-line-light {
    background-color: #FF404B;
    color: var(--white);
    border: 0.1rem solid var(--text-color2);
    font-size: var(--fs-p1);
    font-weight: var(--fw-medium);
    padding-top: 0.8rem;
}

.online-N10 .btnset-line-light:hover {
    background-color: var(--danger);
    color: white;
}

.online-N10 .btnset-sm {
    padding: 0.8rem 1.6rem;
    font-size: var(--fs-p2);
    min-width: 8rem;
}

.online-N10 .btnset-xs {
    padding: 0.6rem 1.2rem;
    font-size: var(--fs-p2);
    min-width: 6rem;
}

.online-N10 .btnset-success {
    background-color: #0056b3;
    color: white;
}

.online-N10 .btnset-success:hover {
    background-color: #0056b3;
}

.online-N10 .btnset-warning {
    background-color: #FF404B;
    color: white;
}

.online-N10 .btnset-warning:hover {
    background-color: #FF404B;
}

.online-N10 .btnset-secondary {
    background-color: #6c757d;
    color: white;
}

.online-N10 .btnset-secondary:hover {
    background-color: #545b62;
}

/* 프로그램 섹션 */
.online-N10 .program-section {
    margin-bottom: 4rem;
}

/* 테이블 스타일 */
.online-N10 .tableset {
    margin-bottom: 2rem;
}

.online-N10 .tableset-table>thead.thead-border-top>*>* {
    border-top: 1px solid var(--line-color3);
}

.online-N10 .table-wrapper {
    overflow-x: auto;
    /*border-radius: 0.6rem;*/
    box-shadow: 0 0.2rem 0.2rem rgba(0, 0, 0, 0.1);
}

.online-N10 .tableset-table {
    width: 100%;
    border-collapse: collapse;
    background: white;
}

.online-N10 .tableset-table th,
.online-N10 .tableset-table td {
    padding: 1.6rem 1.2rem;
    text-align: center;
    border-bottom: 0.1rem solid #e5e5e5;
    vertical-align: middle;
}

.online-N10 .tableset-table th {
    background-color: #F7F7FB;
    font-weight: 600;
    color: var(--text-color1);
    font-size: var(--fs-p1);
}

.online-N10 .tableset-table tbody tr:hover {
    background-color: #F7F7FB;
}

.online-N10 .program-name {
    text-align: left;
    font-weight: var(--fw-medium);
    color: var(--text-color1);
}

.online-N10 .schedule {
    font-size: var(--fs-p2);
}

.online-N10 .time {
    color: var(--text-color2);
    font-weight: var(--fw-medium);
}

.online-N10 .price {
    font-weight: var(--fw-medium);
    color: var(--text-color1);
}

/* 상태별 색상 */
.online-N10 .capacity.available,
.online-N10 .status.available {
    color: #004E36;
    font-weight: var(--fw-medium);
}

.online-N10 .capacity.warning,
.online-N10 .status.warning {
    color: #FF404B;
    font-weight: var(--fw-medium);
}

.online-N10 .capacity.closed,
.online-N10 .status.closed {
    color: #dc3545;
    font-weight: var(--fw-medium);
}

/* 모바일 테이블 */
.online-N10 .mobile-table-wrapper {
    display: none;
}

.online-N10 .table-scroll-wrapper {
    position: relative;
    overflow-x: auto;
    border: 0.1rem solid #dee2e6;
    border-radius: 0.8rem;
    background: white;
    box-shadow: 0 0.4rem 0.6rem rgba(0, 0, 0, 0.1);
}

.online-N10 .table-scroll-wrapper::-webkit-scrollbar {
    height: 0.6rem;
}

.online-N10 .table-scroll-wrapper::-webkit-scrollbar-track {
    background: #f1f1f1;
}

.online-N10 .table-scroll-wrapper::-webkit-scrollbar-thumb {
    background: var(--primary);
    border-radius: 0.3rem;
}

.online-N10 .mobile-scroll-table {
    min-width: 70rem;
    margin: 0;
}

.online-N10 .mobile-scroll-table th:first-child,
.online-N10 .mobile-scroll-table td:first-child {
    position: sticky;
    left: 0;
    background: white;
    z-index: 2;
    border-right: 0.2rem solid var(--primary);
    box-shadow: 0.2rem 0 0.4rem rgba(0, 0, 0, 0.1);
    min-width: 6rem;
}

.online-N10 .mobile-scroll-table thead th {
    position: sticky;
    top: 0;
    z-index: 3;
    background: #F7F7FB;
}

.online-N10 .mobile-scroll-table thead th:first-child {
    z-index: 4;
}

/* 안내 섹션 */
.online-N10 .info-section {
    margin-top: 4rem;
}

.online-N10 .info-group h4 {
    font-size: var(--fs-h6);
    font-weight: var(--fw-bold);
    color: var(--primary);
    margin-bottom: 1.6rem;
}

.online-N10 .info-desc {
    background: #f8f8fa;
    border-radius: 0.6rem;
    padding: 2.4rem;
}

.online-N10 .info-list {
    margin: 0;
    padding-left: 2rem;
}

.online-N10 .info-list li {
    margin-bottom: 1.2rem;
    font-size: var(--fs-p1);
    color: var(--text-color1);
}

.online-N10 .info-list em {
    font-style: normal;
    font-weight: var(--fw-medium);
    color: var(--primary);
}

/* 반응형 */
@media (max-width: 992px) {
    .online-N10 {
        padding-top: 0rem;
        padding-bottom: 5rem;
    }

    .online-N10 .title-area {
        flex-direction: column;
        gap: 0.6rem;
        margin-bottom: 3rem;
    }

    .online-N10 .ico-dot {
        width: 1.2rem;
        height: 1.2rem;
    }

    .online-N10 .notice-box {
        padding: 2rem;
        margin-bottom: 3rem;
    }

    .online-N10 .search-section {
        padding: 2.4rem;
        margin-bottom: 3rem;
    }

    .online-N10 .filter-row {
        flex-direction: column;
        gap: 1.6rem;
    }

    .online-N10 .form-box {
        min-width: auto;
    }

    .online-N10 .checkset-wrap {
        gap: 0.8rem 2.4rem;
    }

    .online-N10 .form-btn {
        flex-direction: column;
        align-items: center;
        gap: 1.2rem;
    }

    .online-N10 .btnset {
        width: 100%;
    }

    /* PC 테이블 숨김 */
    .online-N10 .desktop-table {
        display: none;
    }

    /* 모바일 테이블 표시 */
    .online-N10 .mobile-table-wrapper {
        display: block;
    }

    .online-N10 .mobile-scroll-table th,
    .online-N10 .mobile-scroll-table td {
        padding: 1.2rem 0.8rem;
        font-size: var(--fs-p2);
        white-space: nowrap;
    }

    .online-N10 .mobile-scroll-table td:nth-child(3) {
        white-space: normal;
        min-width: 12rem;
    }

    .online-N10 .mobile-scroll-table td:nth-child(4) {
        white-space: normal;
        line-height: 1.4;
        min-width: 10rem;
    }

    .online-N10 .mobile-scroll-table td:nth-child(6) {
        white-space: normal;
        line-height: 1.4;
        min-width: 12rem;
    }

    .online-N10 .info-desc {
        padding: 2rem;
    }

    .btnset+.btnset {
        margin-left: 0rem;
    }

    .online-N10 .btnset-line-light {
        padding-top: 0.5rem;
    }


    .online-N10 .btnset-primary {
        padding-top: 0.5rem;
    }

}

@media (max-width: 576px) {

    .online-N10 .notice-box,
    .online-N10 .search-section {
        margin-left: -1rem;
        margin-right: -1rem;
        border-radius: 0;
    }

    .online-N10 .checkset-wrap {
        gap: 0.8rem 1.6rem;
    }

    .online-N10 .mobile-scroll-table {
        min-width: 60rem;
    }
}


/* 기본: 모바일 카드 목록 숨김, PC 테이블 표시 */
.online-N10 .mobile-card-list {
    display: none;
}

.online-N10 .desktop-table {
    display: block;
}

/* 기존 모바일 테이블 래퍼 제거 */
.online-N10 .mobile-table-wrapper {
    display: none;
}

/* 모바일에서 카드 목록 표시, PC 테이블 숨김 */
@media (max-width: 768px) {
    .online-N10 .desktop-table {
        display: none;
    }

    .online-N10 .mobile-card-list {
        display: block;
    }
}

/* 모바일 카드 스타일 */
.online-N10 .mobile-card-list {
    gap: 1.6rem;
}

.online-N10 .program-card {
    background: white;
    border-radius: 1.2rem;
    box-shadow: 0 0.4rem 0.8rem rgba(0, 0, 0, 0.1);
    border: 0.1rem solid #e5e5e5;
    overflow: hidden;
    margin-bottom: 1.6rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.online-N10 .program-card:hover {
    transform: translateY(-0.2rem);
    box-shadow: 0 0.6rem 1.2rem rgba(0, 0, 0, 0.15);
}

.online-N10 .program-card:last-child {
    margin-bottom: 0;
}

/* 카드 헤더 */
.online-N10 .card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.6rem 2rem;
    background-color: #F7F7FB;
    border-bottom: 0.1rem solid #e5e5e5;
}

.online-N10 .card-category {
    font-size: var(--fs-p1);
    font-weight: var(--fw-medium);
    color: var(--primary);
    padding: 0.4rem 1rem;
    background-color: rgba(0, 86, 179, 0.1);
    /* border-radius: 2rem; */
}

.online-N10 .card-status {
    font-size: var(--fs-p2);
    font-weight: var(--fw-medium);
    padding: 0.6rem 1.2rem;
    /* border-radius: 2rem; */
    text-align: center;
}

.online-N10 .card-status.available {
    background-color: #e8f5e8;
    color: #2e7d32;
}

.online-N10 .card-status.warning {
    background-color: #fff3e0;
    color: #ef6c00;
}

.online-N10 .card-status.closed {
    background-color: #ffebee;
    color: #d32f2f;
}

/* 카드 바디 */
.online-N10 .card-body {
    padding: 2rem;
}

.online-N10 .card-title {
    font-size: var(--fs-h6);
    font-weight: var(--fw-semibold);
    color: var(--text-color1);
    margin-bottom: 1.6rem;
    line-height: 1.4;
}

.online-N10 .card-info {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.online-N10 .info-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.8rem 0;
    border-bottom: 0.1rem solid #f0f0f0;
}

.online-N10 .info-item:last-child {
    border-bottom: none;
}

.online-N10 .info-label {
    font-size: var(--fs-p2);
    color: var(--text-color2);
    font-weight: var(--fw-medium);
    flex-shrink: 0;
}

.online-N10 .info-value {
    font-size: var(--fs-p1);
    color: var(--text-color1);
    font-weight: var(--fw-medium);
    text-align: right;
}

.online-N10 .info-value.price {
    color: #e91e63;
    font-weight: var(--fw-semibold);
}

.online-N10 .info-value.capacity.available {
    color: #2e7d32;
}

.online-N10 .info-value.capacity.warning {
    color: #ef6c00;
}

.online-N10 .info-value.capacity.closed {
    color: #d32f2f;
}

/* 카드 푸터 */
.online-N10 .card-footer {
    padding: 1.6rem 2rem;
    background-color: #F7F7FB;
    border-top: 0.1rem solid #e5e5e5;
}

.online-N10 .card-btn {
    width: 100%;
    padding: 0.8rem 2rem;
    font-size: var(--fs-p1);
    font-weight: var(--fw-semibold);
    /* border-radius: 0.8rem; */
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    text-align: center;
}

.online-N10 .card-btn.btnset-success {
    background-color: #0056b3;
    color: white;
}

.online-N10 .card-btn.btnset-success:hover {
    background-color: #004494;
}

.online-N10 .card-btn.btnset-warning {
    background-color: #FF404B;
    color: white;
}

.online-N10 .card-btn.btnset-warning:hover {
    background-color: #e6363f;
}

.online-N10 .card-btn.btnset-secondary {
    background-color: #6c757d;
    color: white;
}

.online-N10 .card-btn.btnset-secondary:hover {
    background-color: #545b62;
}

/* 작은 모바일 화면 최적화 */
@media (max-width: 576px) {
    .online-N10 .program-card {
        border-radius: 0;
        /* margin-left: -1rem; */
        /* margin-right: -1rem; */
        box-shadow: none;
        border-left: none;
        border-right: none;
    }

    .online-N10 .card-header,
    .online-N10 .card-body,
    .online-N10 .card-footer {
        padding-left: 1.6rem;
        padding-right: 1.6rem;
    }

    .online-N10 .card-category {
        font-size: var(--fs-p2);
        padding: 0.4rem 0.8rem;
    }

    .online-N10 .card-status {
        font-size: var(--fs-p3);
        padding: 0.4rem 0.8rem;
    }

    .online-N10 .card-title {
        font-size: var(--fs-h6);
    }

    .online-N10 .info-item {
        padding: 0.6rem 0;
    }

    .online-N10 .info-label {
        font-size: var(--fs-p3);
    }

    .online-N10 .info-value {
        font-size: var(--fs-p2);
    }
}


/* 아코디언 스타일 검색 필터 - online-N10 섹션 */

/* PC에서는 아코디언 토글 버튼 숨김 */
.online-N10 .filter-accordion-toggle {
    display: none;
}

/* 기본적으로 필터 내용 표시 (PC) */
.online-N10 .filter-accordion-content {
    display: block;
}

/* 모바일에서 아코디언 적용 */
@media (max-width: 768px) {

    /* 기존 search-section 배경 제거 */
    .online-N10 .search-section {
        background: transparent;
        border-radius: 0;
        padding: 0;
        margin-bottom: 2rem;
    }

    /* 아코디언 토글 버튼 표시 */
    .online-N10 .filter-accordion-toggle {
        display: block;
        /* margin-bottom: 1rem; */
    }

    .online-N10 .accordion-btn {
        width: 100%;
        display: flex;
        justify-content: space-between;
        align-items: center;
        background: white;
        border: 0.1rem solid #e5e5e5;
        border-radius: 0.8rem;
        padding: 1.6rem 2rem;
        cursor: pointer;
        transition: all 0.3s ease;
        box-shadow: 0 0.2rem 0.4rem rgba(0, 0, 0, 0.08);
    }

    .online-N10 .accordion-btn:hover {
        border-color: var(--primary);
        box-shadow: 0 0.4rem 0.8rem rgba(0, 0, 0, 0.12);
    }

    .online-N10 .accordion-btn-content {
        display: flex;
        align-items: center;
        gap: 1rem;
        font-size: var(--fs-p1);
        font-weight: var(--fw-medium);
        color: var(--text-color1);
    }

    .online-N10 .accordion-btn-content i {
        color: var(--primary);
        font-size: var(--fs-h6);
    }

    .online-N10 .accordion-icon {
        color: var(--text-color2);
        font-size: var(--fs-p1);
        transition: transform 0.3s ease, color 0.3s ease;
    }

    .online-N10 .search-section.accordion-expanded .accordion-icon {
        color: var(--primary);
    }

    /* 아코디언 내용 */
    .online-N10 .filter-accordion-content {
        max-height: 0;
        opacity: 0;
        overflow: hidden;
        background: white;
        border: 0.1rem solid #e5e5e5;
        border-top: none;
        border-radius: 0 0 0.8rem 0.8rem;
        transition: max-height 0.4s ease, opacity 0.3s ease, padding 0.3s ease;
        margin-top: -0.1rem;
    }

    .online-N10 .filter-accordion-content.active {
        max-height: 800px;
        opacity: 1;
        padding: 2.4rem;
        box-shadow: 0 0.4rem 0.8rem rgba(0, 0, 0, 0.08);
    }

    /* 펼쳐진 상태에서 토글 버튼 스타일 변경 */
    .online-N10 .search-section.accordion-expanded .accordion-btn {
        border-bottom: none;
        border-radius: 0.8rem 0.8rem 0 0;
        background: #F7F7FB;
        border-color: var(--primary);
    }
}

/* 작은 모바일 화면 최적화 */
@media (max-width: 576px) {
    .online-N10 .search-section {
        margin-left: 0rem;
        margin-right: 0rem;
    }

    .online-N10 .accordion-btn {
        border-radius: 0;
        border-left: none;
        border-right: none;
        padding: 1.4rem 1.6rem;
    }

    .online-N10 .search-section.accordion-expanded .accordion-btn {
        border-radius: 0;
    }

    .online-N10 .filter-accordion-content {
        border-radius: 0;
        border-left: none;
        border-right: none;
    }

    .online-N10 .filter-accordion-content.active {
        padding: 2rem 1.6rem;
    }

    .online-N10 .accordion-btn-content {
        font-size: var(--fs-p1);
        gap: 0.8rem;
    }

    .online-N10 .accordion-btn-content span {
        font-size: var(--fs-p1);
    }
}

/* 아코디언 애니메이션 개선 */
.online-N10 .filter-accordion-content .form-group {
    transition: opacity 0.3s ease 0.1s, transform 0.3s ease 0.1s;
}

.online-N10 .filter-accordion-content:not(.active) .form-group {
    opacity: 0;
    transform: translateY(-10px);
}

.online-N10 .filter-accordion-content.active .form-group {
    opacity: 1;
    transform: translateY(0);
}

/* 아코디언이 닫힐 때 부드러운 효과 */
.online-N10 .accordion-btn:active {
    transform: scale(0.98);
}

/* 접근성을 위한 포커스 스타일 - 검은색 테두리 제거 */
.online-N10 .accordion-btn:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 0.2rem rgba(0, 86, 179, 0.15);
}

.online-N10 .accordion-btn:focus-visible {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 0.2rem rgba(0, 86, 179, 0.15);
}

/* 아코디언 상태 표시를 위한 추가 스타일 */
.online-N10 .search-section.accordion-expanded {
    margin-bottom: 3rem;
}



/* online-N11 CSS - 수강신청 상세화면 */
.online-N11 {
    overflow: hidden;
    position: relative;
    padding-top: 0rem;
    padding-bottom: 8rem;
}

.online-N11 .contents-inner {
    width: 100%;
}

/* 타이틀 영역 */
.online-N11 .title-area {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.2rem;
    margin-bottom: 4rem;
    text-align: center;
}

.online-N11 .ico-dot {
    width: 1.6rem;
    height: 1.6rem;
    background: url(../icons/ico_diamond.svg) no-repeat center/contain;
}

/* 안내 메시지 */
.online-N11 .guide-message {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.2rem;
    background: #F7F7FB;
    border-radius: 1.2rem;
    padding: 2rem;
    margin-bottom: 4rem;
    border: 0.1rem solid var(--primary);
}

.online-N11 .guide-icon i {
    font-size: 2.4rem;
    color: var(--primary);
}

.online-N11 .guide-text {
    font-size: var(--fs-h5);
    color: var(--text-color1);
}

.online-N11 .guide-text strong {
    color: var(--primary);
    font-weight: var(--fw-bold);
}

/* 메인 콘텐츠 */
.online-N11 .detail-content {
    width: 100%;
}

.online-N11 .detail-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
}

.online-N11 .detail-box {
    background: white;
    border-radius: 1.6rem;
    box-shadow: 0 0.4rem 2rem rgba(0, 0, 0, 0.08);
    overflow: hidden;
    border: 0.1rem solid #e5e5e5;
}

.online-N11 .detail-header {
    background-color: var(--primary);
    padding: 2rem;
    text-align: center;
}

.online-N11 .detail-header h3 {
    color: white;
    font-size: var(--fs-h6);
    font-weight: var(--fw-semibold);
    margin: 0;
}

.online-N11 .detail-header h3 i {
    margin-right: 0.8rem;
}

.online-N11 .detail-body {
    padding: 2.4rem;
}

/* 강습정보 */
.online-N11 .course-title {
    margin-bottom: 2rem;
    padding-bottom: 1.6rem;
    border-bottom: 0.2rem solid #f5f5f5;
}

.online-N11 .course-title h4 {
    font-size: var(--fs-h5);
    color: var(--primary);
    font-weight: var(--fw-semibold);
    margin: 0;
}

/* 테이블 스타일 */
.online-N11 .info-table table,
.online-N11 .time-selection table,
.online-N11 .payment-info table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 2rem;
}

.online-N11 .info-table th,
.online-N11 .info-table td,
.online-N11 .time-selection th,
.online-N11 .time-selection td,
.online-N11 .payment-info th,
.online-N11 .payment-info td {
    padding: 1.2rem 1.6rem;
    border-bottom: 0.1rem solid #f0f0f0;
    text-align: left;
}

.online-N11 .info-table th,
.online-N11 .time-selection th,
.online-N11 .payment-info th {
    background-color: #F7F7FB;
    font-weight: var(--fw-medium);
    color: var(--text-color1);
    width: 30%;
}

.online-N11 .info-table td.price strong,
.online-N11 .payment-info td.payment-amount strong {
    color: #e91e63;
    font-size: var(--fs-h6);
    font-weight: var(--fw-bold);
}

.online-N11 .info-table td.capacity strong {
    color: var(--primary);
    font-weight: var(--fw-medium);
}

/* 현재시간 */
.online-N11 .current-time {
    text-align: center;
    margin-top: 2rem;
    padding: 1.2rem;
    background: #F7F7FB;
    border-radius: 0.8rem;
    font-size: var(--fs-p1);
}

/* 시간 선택 */
.online-N11 .time-select {
    width: 100%;
    padding: 1rem 1.2rem;
    border: 0.1rem solid #ddd;
    border-radius: 0.8rem;
    font-size: var(--fs-p1);
    background-image: url("data:image/svg+xml;charset=UTF-8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6,9 12,15 18,9'></polyline></svg>");
    background-repeat: no-repeat;
    background-position: right 1.2rem center;
    background-size: 1.6rem;
    padding-right: 4rem;
    appearance: none;
}

.online-N11 .time-select:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

/* 등록 현황 */

.online-N11 .current-count {
    font-size: var(--fs-h6);
    font-weight: var(--fw-bold);
    color: var(--primary);
}

.online-N11 .status-text {
    padding: 0.4rem 1rem;
    border-radius: 2rem;
    font-size: var(--fs-p2);
    font-weight: var(--fw-medium);
}

.online-N11 .status-text.available {
    background-color: #e8f5e8;
    color: #2e7d32;
}

.online-N11 .status-text.warning {
    background-color: #fff3e0;
    color: #f57c00;
}

.online-N11 .status-text.closed {
    background-color: #ffebee;
    color: #d32f2f;
}

/* 안내사항 */
.online-N11 .notice-box {
    background: #F7F7FB;
    border-radius: 0.8rem;
    padding: 1.6rem;
    margin: 2rem 0;
}

.online-N11 .notice-box ul {
    margin: 0;
    padding-left: 1.6rem;
    list-style: none;
}

.online-N11 .notice-box li {
    position: relative;
    padding-left: 1rem;
    margin-bottom: 0.8rem;
    color: var(--text-color2);
    font-size: var(--fs-p2);
    line-height: 1.5;
}

.online-N11 .notice-box li:before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.8rem;
    width: 0.4rem;
    height: 0.4rem;
    background: var(--primary);
    border-radius: 50%;
}

.online-N11 .notice-box li:last-child {
    margin-bottom: 0;
}

/* 버튼 영역 */
.online-N11 .action-buttons {
    display: flex;
    justify-content: space-between;
    gap: 1.6rem;
    margin-top: 3rem;
}

.online-N11 .btnset {
    flex: 1;
    padding: 1.4rem 2rem;
    border-radius: 0.8rem;
    font-size: var(--fs-p1);
    font-weight: var(--fw-medium);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    cursor: pointer;
    border: none;
    transition: all 0.3s ease;
    min-height: 5.2rem;
}

.online-N11 .btnset-primary {
    background-color: var(--primary);
    color: white;
}

.online-N11 .btnset-primary:hover {
    background-color: var(--primary-dark, #0056b3);
    transform: translateY(-0.2rem);
    box-shadow: 0 0.4rem 1.2rem rgba(0, 0, 0, 0.15);
}

.online-N11 .btnset-line-light {
    background-color: transparent;
    color: var(--text-color2);
    border: 0.1rem solid var(--text-color2);
}

.online-N11 .btnset-line-light:hover {
    background-color: var(--text-color2);
    color: white;
}

/* 결제금액 강조 */
.online-N11 .payment-info {
    border-top: 0.2rem solid var(--primary);
    padding-top: 2rem;
}

.online-N11 .payment-amount strong {
    font-size: var(--fs-h4);
}

/* 반응형 */
@media (max-width: 992px) {

    .online-N11 .container-md {
        padding: 0 0.8rem;
    }

    .online-N11 {
        padding-top: 0rem;
        padding-bottom: 5rem;
    }

    .online-N11 .title-area {
        flex-direction: column;
        gap: 0.6rem;
        margin-bottom: 3rem;
    }

    .online-N11 .ico-dot {
        width: 1.2rem;
        height: 1.2rem;
    }

    .online-N11 .guide-message {
        flex-direction: column;
        text-align: center;
        gap: 1rem;
        padding: 1.6rem;
    }

    .online-N11 .guide-icon i {
        font-size: 2rem;
    }

    .online-N11 .guide-text {
        font-size: var(--fs-p1);
    }

    .online-N11 .detail-row {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .online-N11 .detail-header {
        padding: 1.6rem;
    }

    .online-N11 .detail-body {
        padding-top: 2rem;
        padding-bottom: 2rem;
        padding-left: 0.5rem;
        padding-right: 0.5rem;
    }

    .online-N11 .info-table th,
    .online-N11 .info-table td,
    .online-N11 .time-selection th,
    .online-N11 .time-selection td,
    .online-N11 .payment-info th,
    .online-N11 .payment-info td {
        padding: 1rem;
        font-size: var(--fs-p2);
    }

    .online-N11 .action-buttons {
        flex-direction: column;
        gap: 1.2rem;
    }

    .online-N11 .enrollment-status {
        flex-direction: column;
        align-items: flex-start;
        gap: 0.8rem;
    }


}

@media (max-width: 576px) {

    .online-N11 .detail-box {
        border-radius: 0;
    }

    .online-N11 .guide-message {
        border-radius: 0;
    }

    .online-N11 .btnset+.btnset {
        margin-left: 0rem;
    }
}



/* online-N12 CSS - 수강내역 */
.online-N12 {
    overflow: hidden;
    position: relative;
    padding-top: 0rem;
    padding-bottom: 8rem;
}

.online-N12 .contents-inner {
    width: 100%;
}

/* 타이틀 영역 */
.online-N12 .title-area {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.2rem;
    margin-bottom: 4rem;
    text-align: center;
}

.online-N12 .ico-dot {
    width: 1.6rem;
    height: 1.6rem;
    background: url(../icons/ico_diamond.svg) no-repeat center/contain;
}

/* 안내 메시지 */
.online-N12 .guide-message {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.2rem;
    background: #F7F7FB;
    border-radius: 1.2rem;
    padding: 2rem;
    margin-bottom: 4rem;
    border: 0.1rem solid var(--primary);
}

.online-N12 .guide-icon i {
    font-size: 2.4rem;
    color: var(--primary);
}

.online-N12 .guide-text {
    font-size: var(--fs-h5);
    color: var(--text-color1);
}

.online-N12 .guide-text strong {
    color: var(--primary);
    font-weight: var(--fw-bold);
}

/* 섹션 타이틀 */
.online-N12 .section-title {
    font-size: var(--fs-h4);
    font-weight: var(--fw-semibold);
    color: var(--text-color1);
    margin-bottom: 2.4rem;
    padding-bottom: 1.2rem;
    border-bottom: 0.2rem solid var(--primary);
    display: inline-block;
}

.online-N12 .section-title i {
    margin-right: 0.8rem;
    color: var(--primary);
}

/* 필터 섹션 */
.online-N12 .filter-section {
    background: #F7F7FB;
    border-radius: 0.2rem;
    padding: 2.4rem;
    margin-bottom: 3rem;
}

.online-N12 .filter-options {
    display: flex;
    align-items: end;
    gap: 2rem;
    flex-wrap: wrap;
}

.online-N12 .filter-item {
    flex: 1;
    min-width: 15rem;
}

.online-N12 .filter-buttons {
    flex-shrink: 0;
}

.online-N12 .filter-label {
    display: block;
    font-weight: var(--fw-medium);
    color: var(--text-color1);
    margin-bottom: 0.8rem;
}

.online-N12 .filter-select {
    width: 100%;
    padding: 1rem 1.2rem;
    border: 0.1rem solid #ddd;
    border-radius: 0.8rem;
    font-size: var(--fs-p1);
    background-image: url("data:image/svg+xml;charset=UTF-8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6,9 12,15 18,9'></polyline></svg>");
    background-repeat: no-repeat;
    background-position: right 1.2rem center;
    background-size: 1.6rem;
    padding-right: 4rem;
    appearance: none;
}

.online-N12 .filter-select:focus {
    outline: none;
    border-color: var(--primary);
    box-shadow: 0 0 0 0.2rem rgba(0, 123, 255, 0.25);
}

.online-N12 .filter-buttons {
    flex-shrink: 0;
}

/* 수강내역 섹션 */
.online-N12 .history-section {
    margin-bottom: 4rem;
}

.online-N12 .section-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2.4rem;
    flex-wrap: wrap;
    gap: 1.6rem;
}

.online-N12 .summary-info {
    display: flex;
    gap: 2rem;
    flex-wrap: wrap;
}

.online-N12 .summary-item {
    font-size: var(--fs-p1);
    color: var(--text-color2);
}

.online-N12 .summary-item strong {
    font-weight: var(--fw-bold);
}

.online-N12 .summary-item.active strong {
    color: #28a745;
}

.online-N12 .summary-item.completed strong {
    color: var(--primary);
}

.online-N12 .summary-item.cancelled strong {
    color: #dc3545;
}

/* 테이블 스타일 */
.online-N12 .tableset {
    margin-bottom: 2rem;
}

.online-N12 .tableset-table>thead.thead-border-top>*>* {
    border-top: 1px solid var(--line-color3);
}

.online-N12 .table-wrapper {
    overflow-x: auto;
    /* border-radius: 0.8rem; */
    box-shadow: 0 0.4rem 0.6rem rgba(0, 0, 0, 0.1);
}

.online-N12 .tableset-table {
    width: 100%;
    border-collapse: collapse;
    background: white;
    min-width: 80rem;
}

.online-N12 .tableset-table th,
.online-N12 .tableset-table td {
    padding: 1.6rem 1.2rem;
    text-align: center;
    border-bottom: 0.1rem solid #e5e5e5;
    vertical-align: middle;
}

.online-N12 .tableset-table th {
    background-color: #F7F7FB;
    font-weight: var(--fw-semibold);
    color: var(--text-color1);
    font-size: var(--fs-p1);
    white-space: nowrap;
}

.online-N12 .tableset-table tbody tr:hover {
    background-color: #F7F7FB;
}

.online-N12 .course-name {
    text-align: left;
    font-weight: var(--fw-medium);
    color: var(--text-color1);
}

.online-N12 .schedule {
    font-size: var(--fs-p2);
    text-align: center;
}

.online-N12 .time {
    color: var(--text-color2);
    font-weight: var(--fw-medium);
}

.online-N12 .price {
    font-weight: var(--fw-medium);
    color: #e91e63;
}

/* 상태 배지 */
.online-N12 .status-badge {
    padding: 0.6rem 1.2rem;
    /*border-radius: 2rem;*/
    font-size: var(--fs-p2);
    font-weight: var(--fw-medium);
    display: inline-block;
}

.online-N12 .status-badge.active {
    background-color: #e8f5e8;
    color: #2e7d32;
}

.online-N12 .status-badge.completed {
    background-color: #e3f2fd;
    color: #1976d2;
}

.online-N12 .status-badge.cancelled {
    background-color: #ffebee;
    color: #d32f2f;
}

/* 버튼 스타일 */
.online-N12 .btnset {
    padding: 1rem 1.6rem;
    border-radius: 0.6rem;
    font-size: var(--fs-p2);
    font-weight: var(--fw-medium);
    text-decoration: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.6rem;
    cursor: pointer;
    border: none;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.online-N12 .btnset-sm {
    padding: 0.8rem 1.2rem;
    font-size: var(--fs-p2);
}

.online-N12 .btnset-primary {
    background-color: var(--primary);
    color: white;
}

.online-N12 .btnset-primary:hover {
    background-color: var(--primary-dark, #0056b3);
    transform: translateY(-0.1rem);
}

.online-N12 .btnset-danger {
    background-color: #dc3545;
    color: white;
}

.online-N12 .btnset-danger:hover {
    background-color: #c82333;
    transform: translateY(-0.1rem);
}

.online-N12 .btnset-secondary {
    background-color: #6c757d;
    color: white;
}

.online-N12 .btnset-secondary:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.online-N12 .btnset-secondary:disabled:hover {
    transform: none;
}

/* 모바일 카드 */
.online-N12 .mobile-cards {
    display: none;
    gap: 2rem;
    flex-direction: column;
}

.online-N12 .course-card {
    background: white;
    border-radius: 1.2rem;
    box-shadow: 0 0.4rem 1.2rem rgba(0, 0, 0, 0.1);
    overflow: hidden;
    border: 0.1rem solid #e5e5e5;
}

.online-N12 .course-card.active {
    border-left: 0.4rem solid #28a745;
}

.online-N12 .course-card.completed {
    border-left: 0.4rem solid var(--primary);
}

.online-N12 .course-card.cancelled {
    border-left: 0.4rem solid #dc3545;
}

.online-N12 .card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.6rem 2rem;
    background: #F7F7FB;
    border-bottom: 0.1rem solid #e5e5e5;
}

.online-N12 .card-date {
    font-size: var(--fs-p2);
    color: var(--text-color2);
    font-weight: var(--fw-medium);
}

.online-N12 .card-body {
    padding: 2rem;
}

.online-N12 .card-body .course-name {
    font-size: var(--fs-h5);
    color: var(--text-color1);
    font-weight: var(--fw-semibold);
    margin-bottom: 1.6rem;
}

.online-N12 .course-info {
    margin-bottom: 2rem;
}

.online-N12 .info-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.8rem 0;
    border-bottom: 0.1rem solid #f0f0f0;
}

.online-N12 .info-item:last-child {
    border-bottom: none;
}

.online-N12 .info-label {
    font-weight: var(--fw-medium);
    color: var(--text-color2);
    font-size: var(--fs-p2);
}

.online-N12 .info-value {
    font-size: var(--fs-p2);
    color: var(--text-color1);
}

.online-N12 .info-value.price {
    color: #e91e63;
    font-weight: var(--fw-medium);
}

.online-N12 .card-actions {
    text-align: center;
}

/* 안내 섹션 */
.online-N12 .info-section {
    margin-top: 4rem;
}

.online-N12 .info-group h4 {
    font-size: var(--fs-h5);
    font-weight: var(--fw-semibold);
    color: var(--primary);
    margin-bottom: 1.6rem;
}

.online-N12 .info-group h4 i {
    margin-right: 0.8rem;
}

.online-N12 .info-desc {
    background: #f8f8fa;
    border-radius: 1.2rem;
    padding: 2.4rem;
}

.online-N12 .info-list {
    margin: 0;
    padding-left: 2rem;
    list-style: none;
}

.online-N12 .info-list li {
    position: relative;
    padding-left: 1rem;
    margin-bottom: 1.2rem;
    font-size: var(--fs-p1);
    color: var(--text-color1);

}

/* 수강내역 모바일 카드 스타일 - online-N12 섹션 추가 */

/* 기본: 모바일 카드 목록 숨김, PC 테이블 표시 */
.online-N12 .mobile-card-list {
    display: none;
}

.online-N12 .desktop-table {
    display: block;
}

/* 기존 모바일 카드(.mobile-cards)는 숨김 */
.online-N12 .mobile-cards {
    display: none;
}

/* 모바일에서 카드 목록 표시, PC 테이블 숨김 */
@media (max-width: 768px) {
    .online-N12 .desktop-table {
        display: none;
    }

    .online-N12 .mobile-card-list {
        display: block;
    }

    /* 기존 모바일 카드도 숨김 */
    .online-N12 .mobile-cards {
        display: none;
    }

    .online-N12 {
        overflow: hidden;
        position: relative;
        padding-top: 0rem;
        padding-bottom: 0rem;
    }

    .online-N12 .filter-options {
        display: flex;
        flex-direction: column;
        gap: 1.6rem;
        align-items: stretch;
    }

    .online-N12 .filter-item {
        flex: none;
        min-width: auto;
        width: 100%;
    }

    .online-N12 .filter-buttons {
        flex-shrink: 0;
        width: 100%;
        margin-top: 0.8rem;
    }

    .online-N12 .filter-buttons .btnset {
        width: 100%;
        padding: 1.4rem 2rem;
        font-size: var(--fs-p1);
        text-align: center;
        justify-content: center;
    }

}

/* 모바일 카드 스타일 */
.online-N12 .mobile-card-list {
    gap: 1.6rem;
}

.online-N12 .history-card {
    background: white;
    border-radius: 1.2rem;
    box-shadow: 0 0.4rem 0.8rem rgba(0, 0, 0, 0.1);
    border: 0.1rem solid #e5e5e5;
    overflow: hidden;
    margin-bottom: 1.6rem;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.online-N12 .history-card:hover {
    transform: translateY(-0.2rem);
    box-shadow: 0 0.6rem 1.2rem rgba(0, 0, 0, 0.15);
}

.online-N12 .history-card:last-child {
    margin-bottom: 0;
}

/* 상태별 좌측 테두리 색상 
.online-N12 .history-card[data-status="active"] {
    border-left: 0.4rem solid #28a745;
}

.online-N12 .history-card[data-status="completed"] {
    border-left: 0.4rem solid var(--primary);
}

.online-N12 .history-card[data-status="cancelled"] {
    border-left: 0.4rem solid #dc3545;
}*/

/* 카드 헤더 */
.online-N12 .card-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1.6rem 2rem;
    background-color: #F7F7FB;
    border-bottom: 0.1rem solid #e5e5e5;
}

.online-N12 .card-date-category {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.online-N12 .card-date {
    font-size: var(--fs-p2);
    color: var(--text-color2);
    font-weight: var(--fw-medium);
}

.online-N12 .card-category {
    font-size: var(--fs-p3);
    font-weight: var(--fw-medium);
    color: var(--primary);
    padding: 0.2rem 0.8rem;
    background-color: rgba(0, 86, 179, 0.1);
    /*border-radius: 1rem;*/
    display: inline-block;
    width: fit-content;
}

/* 상태 배지 (기존 스타일 활용) */
.online-N12 .card-header .status-badge {
    padding: 0.6rem 1.2rem;
    /*border-radius: 2rem;*/
    font-size: var(--fs-p2);
    font-weight: var(--fw-medium);
}


.online-N12 .card-header .status-badge.active {
    background-color: #e8f5e8;
    color: #2e7d32;
}

.online-N12 .card-header .status-badge.completed {
    background-color: #e3f2fd;
    color: #1976d2;
}

.online-N12 .card-header .status-badge.cancelled {
    background-color: #ffebee;
    color: #d32f2f;
}

/* 카드 바디 */
.online-N12 .card-body {
    padding: 2rem;
}

.online-N12 .card-title {
    font-size: var(--fs-h6);
    font-weight: var(--fw-bold);
    color: var(--text-color1);
    margin-bottom: 1.6rem;
    line-height: 1.4;
}

.online-N12 .card-info {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.online-N12 .info-item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 0.8rem 0;
    border-bottom: 0.1rem solid #f0f0f0;
}

.online-N12 .info-item:last-child {
    border-bottom: none;
}

.online-N12 .info-label {
    font-size: var(--fs-p2);
    color: var(--text-color2);
    font-weight: var(--fw-medium);
    flex-shrink: 0;
    margin-right: 1rem;
}

.online-N12 .info-value {
    font-size: var(--fs-p2);
    color: var(--text-color1);
    font-weight: var(--fw-medium);
    text-align: right;
    line-height: 1.4;
}

.online-N12 .info-value.price {
    color: #e91e63;
    font-weight: var(--fw-semibold);
}

/* 카드 푸터 */
.online-N12 .card-footer {
    padding: 1.6rem 2rem;
    background-color: #F7F7FB;
    border-top: 0.1rem solid #e5e5e5;
}

.online-N12 .card-btn {
    width: 100%;
    padding: 1.2rem 2rem;
    font-size: var(--fs-p1);
    font-weight: var(--fw-medium);
    /*border-radius: 0.8rem;*/
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    text-align: center;
}

.online-N12 .card-btn.btnset-danger {
    background-color: #dc3545;
    color: white;
}

.online-N12 .card-btn.btnset-danger:hover {
    background-color: #c82333;
}

.online-N12 .card-btn.btnset-secondary {
    background-color: #6c757d;
    color: white;
}

.online-N12 .card-btn.btnset-secondary:disabled {
    opacity: 0.6;
    cursor: not-allowed;
}

.online-N12 .card-btn.btnset-secondary:disabled:hover {
    background-color: #6c757d;
}

/* 작은 모바일 화면 최적화 */
@media (max-width: 576px) {
    .online-N12 .history-card {
        border-radius: 0;
        /* margin-left: -1rem; */
        /* margin-right: -1rem; */
        box-shadow: none;
        border-left: none;
        border-right: none;
    }

    /* 상태별 좌측 테두리 
    .online-N12 .history-card[data-status="active"] {
        border-left: 0.4rem solid #28a745;
    }

    .online-N12 .history-card[data-status="completed"] {
        border-left: 0.4rem solid var(--primary);
    }

    .online-N12 .history-card[data-status="cancelled"] {
        border-left: 0.4rem solid #dc3545;
    }*/

    .online-N12 .card-header,
    .online-N12 .card-body,
    .online-N12 .card-footer {
        padding-left: 1.6rem;
        padding-right: 1.6rem;
    }

    .online-N12 .card-date {
        font-size: var(--fs-p3);
    }

    .online-N12 .card-category {
        font-size: var(--fs-p3);
        padding: 0.2rem 0.6rem;
    }

    .online-N12 .card-header .status-badge {
        font-size: var(--fs-p3);
        padding: 0.4rem 0.8rem;
    }

    .online-N12 .card-title {
        font-size: var(--fs-h6);
        margin-bottom: 1.2rem;
    }

    .online-N12 .info-item {
        padding: 0.6rem 0;
    }

    .online-N12 .info-label,
    .online-N12 .info-value {
        font-size: var(--fs-p2);
    }

    .online-N12 .filter-section {
        margin-left: -1rem;
        margin-right: -1rem;
        border-radius: 0;
        padding: 2rem 1.6rem;
    }

    .online-N12 .filter-buttons .btnset {
        padding: 1.6rem 2rem;
        font-size: var(--fs-h6);
        font-weight: var(--fw-semibold);
        border-radius: 0.8rem;
    }
}


/* 준수/안전수칙 CSS - safety-N13 섹션 */

.safety-N13 {
    overflow: hidden;
    position: relative;
    padding-top: 0rem;
    padding-bottom: 6rem;
}

.safety-N13 .contents-inner {
    width: 100%;
}

/* 섹션 구분 */
.safety-N13 .safety-section {
    margin-bottom: 6rem;
}

.safety-N13 .safety-section:last-child {
    margin-bottom: 4rem;
}

/* 섹션 타이틀 */
.safety-N13 .section-title {
    font-size: var(--fs-h4);
    font-weight: var(--fw-semibold);
    color: var(--text-color1);
    margin-bottom: 3rem;
    padding-bottom: 1.2rem;
    border-bottom: 0.2rem solid var(--primary);
    display: inline-block;
}

/* 일반 안전수칙 카드 그리드 */
.safety-N13 .safety-card-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(350px, 1fr));
    gap: 2.4rem;
}

.safety-N13 .safety-card {
    background: white;
    border-radius: 1.2rem;
    box-shadow: 0 0.4rem 1.2rem rgba(0, 0, 0, 0.1);
    border: 0.1rem solid #e5e5e5;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.safety-N13 .safety-card:hover {
    transform: translateY(-0.3rem);
    box-shadow: 0 0.8rem 2rem rgba(0, 0, 0, 0.15);
}

/* 카드 헤더 */
.safety-N13 .card-header {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    padding: 2rem;
    background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
    border-bottom: 0.1rem solid #e5e5e5;
}

.safety-N13 .card-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    font-size: 1.6rem;
    color: white;
}

.safety-N13 .card-icon.preparation {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}

.safety-N13 .card-icon.health {
    background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);
}

.safety-N13 .card-icon.behavior {
    background: linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);
}

.safety-N13 .card-icon.emergency {
    background: linear-gradient(135deg, #f5576c 0%, #f093fb 100%);
}

.safety-N13 .card-icon.etiquette {
    background: linear-gradient(135deg, #96ceb4 0%, #feca57 100%);
}

.safety-N13 .card-title {
    font-size: var(--fs-h6);
    font-weight: var(--fw-semibold);
    color: var(--text-color1);
    margin: 0;
}

/* 카드 바디 */
.safety-N13 .card-body {
    padding: 2rem;
}

.safety-N13 .safety-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.safety-N13 .safety-list li {
    position: relative;
    padding-left: 2.4rem;
    margin-bottom: 1.6rem;
    font-size: var(--fs-p1);
    line-height: 1.6;
    color: var(--text-color1);
}

.safety-N13 .safety-list li:last-child {
    margin-bottom: 0;
}

.safety-N13 .safety-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.8rem;
    width: 0.8rem;
    height: 0.8rem;
    background: linear-gradient(135deg, var(--primary) 0%, #4facfe 100%);
    border-radius: 50%;
}

/* 자유수영 안전수칙 */
.safety-N13 .free-swimming-rules {
    display: grid;
    gap: 1.6rem;
}

.safety-N13 .rule-card {
    display: flex;
    align-items: flex-start;
    gap: 2rem;
    background: white;
    border-radius: 1rem;
    padding: 2rem;
    box-shadow: 0 0.2rem 0.8rem rgba(0, 0, 0, 0.08);
    border-left: 0.4rem solid var(--primary);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.safety-N13 .rule-card:hover {
    transform: translateX(0.5rem);
    box-shadow: 0 0.4rem 1.2rem rgba(0, 0, 0, 0.12);
}

.safety-N13 .rule-number {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3rem;
    height: 3rem;
    background: linear-gradient(135deg, var(--primary) 0%, #4facfe 100%);
    color: white;
    border-radius: 50%;
    font-size: var(--fs-h6);
    font-weight: var(--fw-bold);
}

.safety-N13 .rule-content h5 {
    font-size: var(--fs-p1);
    font-weight: var(--fw-medium);
    color: var(--text-color1);
    line-height: 1.6;
    margin: 0;
}

/* 어린이 수영 안전수칙 */
.safety-N13 .children-safety {
    display: flex;
    flex-direction: column;
    gap: 2.4rem;
}

.safety-N13 .age-group-card {
    background: white;
    border-radius: 1.2rem;
    box-shadow: 0 0.4rem 1.2rem rgba(0, 0, 0, 0.1);
    border: 0.1rem solid #e5e5e5;
    overflow: hidden;
}

.safety-N13 .age-header {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    padding: 2rem;
    background: linear-gradient(135deg, #feca57 0%, #ff9ff3 100%);
    color: white;
}

.safety-N13 .age-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 3.5rem;
    height: 3.5rem;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 50%;
    font-size: 1.4rem;
}

.safety-N13 .age-header h4 {
    font-size: var(--fs-h6);
    font-weight: var(--fw-semibold);
    margin: 0;
}

.safety-N13 .age-content {
    padding: 2rem;
}

.safety-N13 .age-rules {
    list-style: none;
    margin: 0;
    padding: 0;
}

.safety-N13 .age-rules li {
    position: relative;
    padding-left: 2.4rem;
    margin-bottom: 1.2rem;
    font-size: var(--fs-p1);
    line-height: 1.6;
    color: var(--text-color1);
}

.safety-N13 .age-rules li:last-child {
    margin-bottom: 0;
}

.safety-N13 .age-rules li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.8rem;
    width: 0.6rem;
    height: 0.6rem;
    background: linear-gradient(135deg, #feca57 0%, #ff9ff3 100%);
    border-radius: 50%;
}

/* 중요 안내사항 */
.safety-N13 .important-notice {
    background: linear-gradient(135deg, #fff3e0 0%, #ffecb3 100%);
    border: 0.1rem solid #ffb74d;
    border-radius: 1rem;
    padding: 2rem;
}

.safety-N13 .notice-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 1rem;
}

.safety-N13 .notice-header i {
    font-size: 1.6rem;
    color: #ff9800;
}

.safety-N13 .notice-header h5 {
    font-size: var(--fs-h6);
    font-weight: var(--fw-semibold);
    color: #e65100;
    margin: 0;
}

.safety-N13 .important-notice p {
    font-size: var(--fs-p1);
    font-weight: var(--fw-medium);
    color: #bf360c;
    margin: 0;
    line-height: 1.6;
}

/* 문의 정보 섹션 */
.safety-N13 .contact-section {
    margin-top: 4rem;
}

.safety-N13 .contact-card {
    background: linear-gradient(135deg, var(--primary) 0%, #4facfe 100%);
    color: white;
    border-radius: 1.2rem;
    overflow: hidden;
}

.safety-N13 .contact-header {
    display: flex;
    align-items: center;
    gap: 1.2rem;
    padding: 2rem 2rem 1rem 2rem;
}

.safety-N13 .contact-header i {
    font-size: 1.8rem;
}

.safety-N13 .contact-header h4 {
    font-size: var(--fs-h5);
    font-weight: var(--fw-semibold);
    margin: 0;
}

.safety-N13 .contact-body {
    padding: 0 2rem 2rem 2rem;
}

.safety-N13 .contact-body p {
    font-size: var(--fs-p1);
    margin-bottom: 1.6rem;
    opacity: 0.9;
}

.safety-N13 .contact-info {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.safety-N13 .contact-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: rgba(255, 255, 255, 0.1);
    padding: 1rem 1.6rem;
    border-radius: 0.8rem;
}

.safety-N13 .contact-item .label {
    font-size: var(--fs-p2);
    font-weight: var(--fw-medium);
}

.safety-N13 .contact-item .value {
    font-size: var(--fs-p1);
    font-weight: var(--fw-semibold);
}

/* 반응형 디자인 */
@media (max-width: 992px) {
    .safety-N13 .safety-card-grid {
        grid-template-columns: 1fr;
        gap: 2rem;
    }

    .safety-N13 .safety-section {
        margin-bottom: 4rem;
    }
}

@media (max-width: 768px) {
    .safety-N13 {
        padding-top: 1rem;
        padding-bottom: 6rem;
    }

    .safety-N13 .section-title {
        font-size: var(--fs-h5);
        margin-bottom: 2rem;
    }

    .safety-N13 .rule-card {
        flex-direction: column;
        gap: 1.2rem;
        text-align: center;
    }

    .safety-N13 .rule-card:hover {
        transform: translateY(-0.2rem);
        box-shadow: 0 0.4rem 1.2rem rgba(0, 0, 0, 0.12);
    }

    .safety-N13 .contact-info {
        gap: 0.8rem;
    }

    .safety-N13 .contact-item {
        flex-direction: column;
        gap: 0.4rem;
        text-align: center;
    }
}

@media (max-width: 576px) {

    .safety-N13 .card-header,
    .safety-N13 .card-body,
    .safety-N13 .age-content,
    .safety-N13 .rule-card {
        padding: 1.6rem;
    }

    .safety-N13 .safety-list li,
    .safety-N13 .rule-content h5 {
        font-size: var(--fs-p2);
    }

    .safety-N13 .important-notice,
    .safety-N13 .contact-body {
        padding: 1.6rem;
    }
}


/**  오시는 길 **/
.hooms-N35 {
    overflow: hidden;
    position: relative;
    padding-top: 5rem;
    padding-bottom: 20rem;
}


.hooms-N35 .contents-inner {
    width: 100%;
}

.hooms-N35 .title-area {
    margin-bottom: 4rem;
}

.hooms-N35 .title-area h2 {
    color: #111;
}

.hooms-N35 .title-area p {
    margin-top: 2.6rem;
    color: #111;
}

.hooms-N35 .map-area {
    width: 100%;
}

.hooms-N35 .map-area iframe {
    width: 100%;
    height: 40rem;
}

.hooms-N35 .addr-area {
    margin-top: 4rem;
    padding: 4rem 0;
    border-top: 1px solid #111;
}

.hooms-N35 .addr-area .list {
    display: flex;
    align-items: center;
}

.hooms-N35 .addr-area .list li:first-child {
    flex: 2;
}

.hooms-N35 .addr-area .list li {
    flex: 1;
    padding-right: 6rem;
}

.hooms-N35 .addr-area figure,
.hooms-N35 .transport-list figure {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    margin: 0;
}

.hooms-N35 .addr-area dt img,
.hooms-N35 .transport-list dt img {
    width: 2.4rem;
    height: 2.4rem;
}

.hooms-N35 .addr-area dd,
.hooms-N35 .transport-list dd {
    margin: 1.2rem 0 0 0;
    color: #666;
}

.hooms-N35 .transportation-info {
    padding: 4rem 0;
    border-top: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
}

.hooms-N35 .transport-list li+li {
    margin-top: 4rem;
}

.hooms-N35 .transport-list figure {
    gap: 0.8rem;
}

.hooms-N35 .btn-wrap {
    margin: 4rem auto 0;
    text-align: center;
}

@media (max-width: 992px) {
    .hooms-N35 {
        padding-top: 3rem;
        padding-bottom: 12rem;
    }

    .hooms-N35 .title-area {
        margin-bottom: 2.4rem;
    }

    .hooms-N35 .title-area p {
        margin-top: 2.5rem;
    }

    .hooms-N35 .map-area iframe {
        height: 25rem;
    }

    .hooms-N35 .addr-area {
        margin-top: 2.5rem;
        padding: 2.5rem 0;
    }

    .hooms-N35 .addr-area .list {
        flex-direction: column;
    }

    .hooms-N35 .addr-area .list li {
        flex: none;
        padding: 1.2rem 0;
        width: 100%;
    }

    .hooms-N35 .addr-area .list li:first-child {
        flex: none;
        padding-top: 0;
    }

    .hooms-N35 .addr-area .list li:last-child {
        padding-bottom: 0;
    }

    .hooms-N35 .addr-area dt img,
    .hooms-N35 .transport-list dt img {
        width: 2rem;
        height: 2rem;
    }

    .hooms-N35 .addr-area dd,
    .hooms-N35 .transport-list dd {
        margin-top: 0.4rem;
    }

    .hooms-N35 .transportation-info {
        padding: 2.4rem 0;
    }

    .hooms-N35 .transport-list li+li {
        margin-top: 2.4rem;
    }

    .hooms-N35 .transport-list figure {
        gap: 0.4rem;
    }
}


/* skin-N39 */
.skin-N39 {
    overflow: hidden;
    position: relative;
    padding-top: 5rem;
    padding-bottom: 5rem;
}

.skin-N39 .list-area {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    margin: 0 auto;
}

.skin-N39 .item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 2rem;
    padding: 4rem 3.2rem;
    border: 1px solid var(--border-color);
    transition: border 0.3s;
}

.skin-N39 .item:hover,
.skin-N39 .item:nth-child(2n):hover {
    border-color: var(--primary);
}

.skin-N39 .item:nth-child(2n) {
    border-left-color: transparent;
    border-right-color: transparent;
}

.skin-N39 .wrap {
    display: flex;
    align-items: center;
    gap: 2rem;
}

.skin-N39 .item img {
    width: 6rem;
    height: 6rem;
}

.skin-N39 .item strong {
    font-weight: var(--fw-bold);
}

.skin-N39 .btnset {
    font-weight: var(--fw-medium);
}

@media (max-width: 992px) {
    .skin-N39 {
        padding-top: 8rem;
        padding-bottom: 8rem;
    }

    .skin-N39 .list-area {
        grid-template-columns: 1fr;
    }

    .skin-N39 .item {
        gap: 1.4rem;
        padding: 2.4rem;
    }

    .skin-N39 .item:nth-child(2n) {
        border-left-color: var(--border-color);
        border-right-color: var(--border-color);
        border-top-color: transparent;
        border-bottom-color: transparent;
    }

    .skin-N39 .item img {
        width: 4.6rem;
        height: 4.64rem;
    }
}

/* temhamain3-N3 */
.temhamain3-N3 {
    position: relative;
    overflow: hidden;
}

.temhamain3-N3 .contents-container {
    height: 80rem;
}

.temhamain3-N3 .container-lg .swiper-controls,
.temhamain3-N3 .container-lg .contents-body {
    max-width: calc(1440px + 16rem);
}

.temhamain3-N3 .container-md .swiper-controls,
.temhamain3-N3 .container-md .contents-body {
    max-width: calc(1280px + 16rem);
}

.temhamain3-N3 .container-sm .swiper-controls,
.temhamain3-N3 .container-sm .contents-body {
    max-width: calc(1024px + 16rem);
}

.temhamain3-N3 .contents-inner {
    width: 100%;
    height: 100%;
}

.temhamain3-N3 .contents-swiper {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 100vw;
    height: 100%;
}

.temhamain3-N3 .contents-swiper .textset {
    display: none;
}

.temhamain3-N3 .contents-visual {
    width: 100%;
    height: 100%;
}

.temhamain3-N3 .contents-visual img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.temhamain3-N3 .swiper-controls,
.temhamain3-N3 .contents-body {
    padding: 0 8rem;
}

.temhamain3-N3 .contents-body {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 2;
    width: 100%;
}

.temhamain3-N3 .textset {
    text-align: center;
    margin-bottom: 4rem;
}

.temhamain3-N3 .textset .textset-tit {
    color: var(--white);
}

.temhamain3-N3 .textset .textset-desc {
    color: rgba(var(--white-rgb), 0.8);
}

.temhamain3-N3 .contents-metro .metro-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    width: 100%;
}

.temhamain3-N3 .contents-metro .metro-list.metro-sm {
    flex-wrap: wrap;
}

.temhamain3-N3 .contents-metro .metro-list.metro-sm .metro-item {
    width: 50%;
    min-height: 11rem;
}

.temhamain3-N3 .contents-metro .metro-list.metro-sm .metro-item::before {
    content: none;
}

.temhamain3-N3 .contents-metro .metro-list.metro-sm .metro-link {
    justify-content: center;
    padding: 1rem;
}

.temhamain3-N3 .contents-metro .metro-list.metro-sm .metro-item:hover .metro-figure {
    height: 0;
    opacity: 0;
}

.temhamain3-N3 .contents-metro .metro-list.metro-sm .metro-item:hover .metro-tit {
    height: auto;
    opacity: 1;
}

.temhamain3-N3 .contents-metro .metro-list.metro-sm .metro-item .metro-tit {
    height: 0;
    opacity: 0;
    transition: 0.3s;
}

.temhamain3-N3 .contents-metro .metro-item {
    position: relative;
    width: calc(100% / 4);
    min-height: 22rem;
}

.temhamain3-N3 .contents-metro .metro-item:hover::before {
    transform: translateX(-50%) rotate(180deg);
}

.temhamain3-N3 .contents-metro .metro-item::before {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 2rem;
    transform: translateX(-50%);
    width: 3rem;
    height: 3rem;
    background: transparent url(/theme/zigger-hyangnam/layout/resources/icons/ico_plus_gray.svg) no-repeat center/contain;
    transition: all 0.7s ease 0s;
}

.temhamain3-N3 .contents-metro .metro-item.bg-color01 {
    background: rgba(76, 76, 76, 0.9);
}

.temhamain3-N3 .contents-metro .metro-item.bg-color02 {
    background: rgba(var(--primary-rgb), 0.9);
}

.temhamain3-N3 .contents-metro .metro-item.bg-color03 {
    background: rgba(var(--secondary-rgb), 0.9);
}

.temhamain3-N3 .contents-metro .metro-item.bg-color04 {
    background: #4c4c4c;
}

.temhamain3-N3 .contents-metro .metro-item.bg-color05 {
    background: #807f7d;
}

.temhamain3-N3 .contents-metro .metro-item.bg-hidden {
    background: transparent;
}

.temhamain3-N3 .contents-metro .metro-item.bg-hidden::before {
    content: none;
}

.temhamain3-N3 .contents-metro .metro-link {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    width: 100%;
    height: 100%;
    padding: 4rem 1rem 5rem 1rem;
    text-align: center;
}

.temhamain3-N3 .contents-metro .metro-figure {
    width: 5rem;
    height: 5rem;
    margin: 0 auto;
    transition: 0.6s;
}

.temhamain3-N3 .contents-metro .metro-icon {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.temhamain3-N3 .contents-metro .metro-tit {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--white);
}

.temhamain3-N3 .contents-metro .metro-tit+.metro-desc {
    margin-top: 1.4rem;
}

.temhamain3-N3 .contents-metro .metro-desc {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    color: var(--white);
    opacity: 0.7;
}

.temhamain3-N3 .swiper-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    left: 50%;
    bottom: 2rem;
    transform: translateX(-50%);
    z-index: 2;
    width: 100%;
}

.temhamain3-N3 .swiper-pagination {
    position: static;
    width: auto;
}

.temhamain3-N3 .swiper-pagination-bullet {
    width: 1.2rem;
    height: 1.2rem;
    background: transparent;
    border: 1px solid var(--white);
    opacity: 1;
}

.temhamain3-N3 .swiper-pagination-bullet-active {
    background: var(--white);
}

.temhamain3-N3 .swiper-button-pause,
.temhamain3-N3 .swiper-button-play {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 3.2rem;
    height: 3.2rem;
    opacity: 0.5;
    cursor: pointer;
    transition: 0.3s;
}

.temhamain3-N3 .swiper-button-pause:hover,
.temhamain3-N3 .swiper-button-play:hover {
    opacity: 1;
}

.temhamain3-N3 .swiper-button-pause img,
.temhamain3-N3 .swiper-button-play img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

@media (max-width: 1200px) {

    .temhamain3-N3 .swiper-controls,
    .temhamain3-N3 .contents-body {
        padding: 0 4rem;
    }
}

@media (max-width: 992px) {
    .temhamain3-N3 .contents-container {
        height: auto;
    }

    .temhamain3-N3 .swiper-controls,
    .temhamain3-N3 .contents-body {
        padding: 0 1.6rem;
    }

    .temhamain3-N3 .contents-visual {
        position: relative;
    }

    .temhamain3-N3 .contents-visual::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background: rgba(var(--black-rgb), 0.4);
    }

    .temhamain3-N3 .contents-swiper {
        position: relative;
        top: 0;
        left: 0;
        transform: none;
        width: calc(100% + 3.2rem);
        height: 50rem;
        margin-left: -1.6rem;
        z-index: 1;
    }

    .temhamain3-N3 .contents-swiper .textset {
        display: block;
    }

    .temhamain3-N3 .textset {
        position: absolute;
        left: 50%;
        top: 50%;
        transform: translate(-50%, -50%);
        z-index: 2;
        width: calc(100% - 3.2rem);
        margin-bottom: 0;
    }

    .temhamain3-N3 .textset .textset-tit {
        display: -webkit-box;
        -webkit-line-clamp: 4;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .temhamain3-N3 .textset .textset-desc {
        display: -webkit-box;
        -webkit-line-clamp: 6;
        -webkit-box-orient: vertical;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .temhamain3-N3 .contents-body {
        position: relative;
        left: -1.6rem;
        top: 0;
        transform: none;
        width: calc(100% + 3.2rem);
        padding: 0;
    }

    .temhamain3-N3 .contents-body .textset {
        display: none;
    }

    .temhamain3-N3 .contents-metro .metro-list {
        flex-wrap: wrap;
    }

    .temhamain3-N3 .contents-metro .metro-item {
        width: 50%;
        min-height: 22rem;
    }

    .temhamain3-N3 .contents-metro .metro-item::before {
        width: 2rem;
        height: 2rem;
    }

    .temhamain3-N3 .contents-metro .metro-item.pc-view {
        display: none;
    }

    .temhamain3-N3 .contents-metro .metro-link {
        justify-content: center;
        padding: 2rem 1rem 4rem 1rem;
    }

    .temhamain3-N3 .contents-metro .metro-tit+.metro-desc {
        margin-top: 0.8rem;
    }

    .temhamain3-N3 .contents-metro .metro-desc {
        -webkit-line-clamp: 3;
    }
}


.basic-N24 {
    position: relative;
    padding-top: 0rem;
    padding-bottom: 8rem;
    overflow: hidden;
}

.basic-N24 .contents-inner {
    width: 100%;
    padding: 10rem 4rem;
    border-radius: 2rem;
    background: #f7f7fb;
}

.basic-N24 .textset {
    margin-bottom: 4rem;
    text-align: center;
}

.basic-N24 .form-box {
    max-width: 96rem;
    margin: 0 auto;
}

.basic-N24 .form-box+.form-box {
    margin-top: 2.4rem;
}

.basic-N24 .form-tit {
    margin-bottom: 1.2rem;
}

.basic-N24 .radioset-wrap,
.basic-N24 .checkset-wrap {
    flex-wrap: wrap;
}

.basic-N24 .contents-agree {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin: 3rem auto 0;
    max-width: 96rem;
    line-height: 1;
}

.basic-N24 .contents-agree .btnset {
    color: var(--text-color3);
}

.basic-N24 .contents-agree .btnset::after {
    content: "";
    width: 2rem;
    height: 2rem;
    background-image: url("/api/t-a/57/1757052000/resources/icons/ico_chevron_gray.svg");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

.basic-N24 .form-btn {
    margin: 4rem auto 0;
    max-width: 96rem;
    text-align: center;
}

.basic-N24 .form-btn .btnset {
    min-width: 18rem;
    padding: 0 2rem;
}

.basic-N24 .info-area {
    overflow-y: auto;
}

.basic-N24 .info-group+.info-group {
    margin-top: 2.4rem;
}

.basic-N24 .info-group strong {
    padding-bottom: 1.2rem;
    display: block;
}

.basic-N24 .info-desc {
    max-height: 20.7rem;
    padding: 1.6rem;
    background: #f8f8fa;
    border-radius: 1.6rem;
    overflow-y: auto;
    scrollbar-width: none;
}

.basic-N24 .info-desc p.fw-medium {
    font-weight: var(--fw-medium);
}

.basic-N24 .info-desc .mtb {
    margin: 2.4rem 0;
}

.basic-N24 .info-desc em {
    font-style: normal;
    font-weight: 600;
    margin: 2.4rem 0 1rem;
    position: relative;
    display: flex;
    align-items: center;
}

.basic-N24 .info-list em::before {
    content: "";
    width: 0.4rem;
    height: 0.4rem;
    background: var(--black);
    border-radius: 50%;
    margin-right: 0.8rem;
}

.basic-N24 .info-list p {
    padding-left: 1.2rem;
}

@media (max-width: 992px) {
    .basic-N24 {
        padding-top: 5rem;
        padding-bottom: 5rem;
    }

    .basic-N24 .contents-inner {
        padding: 8rem 2.4rem;
    }

    .basic-N24 .contents-agree {
        margin-top: 1.2rem;
    }

    .basic-N24 .form-box+.form-box {
        margin-top: 2rem;
    }

    .basic-N24 .form-btn {
        margin-top: 2rem;
    }

    .basic-N24 .form-btn .btnset {
        min-width: 16rem;
        padding: 0 1.6rem;
        width: 100%;
    }
}