@charset "utf-8";
/* TOURMUCH // Maker : H.J Jeon // E-Mail : jinia21@naver.com // Site : tourmuch.com */

html::-webkit-scrollbar {width: 8px;}
html::-webkit-scrollbar-thumb {background-color: var(--color-point); border-radius: 10px;}

html, body {
    word-break: keep-all;

    --max-width-xs: 1024px;
    --max-width-sm: 1240px;
    --max-width-md: 1440px;
    --max-width-lg: 1720px;
    --max-width-full: 1920px;

    --padding-basic: 1rem;
    --padding-lg: 2rem;
}

img { max-width: 100%; object-fit: cover; }

#wrapper {
    --header-height: 60px;
    padding-top: var(--header-height);
}

.max-width-xs { max-width: var(--max-width-xs); margin: 0 auto; }
.max-width-sm { max-width: var(--max-width-sm); margin: 0 auto; }
.max-width-md { max-width: var(--max-width-md); margin: 0 auto; }
.max-width-lg { max-width: var(--max-width-lg); margin: 0 auto; }

.dark-overlay {
    visibility: hidden;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background-color: rgba(var(--color-black-rgb),0.5);
    backdrop-filter: blur(5px);
    z-index: 1800;
    opacity: 0;
    transition: opacity 0.25s ease-in-out, visibility 0.25s;
    content: '';
}

.dark-overlay.open {
    visibility: visible;
    opacity: 1;
}

@media screen and (min-width: 767px) {
    html, body {
        --padding-basic: 1.5rem;
    }
}

@media screen and (min-width: 1023px) {
    #wrapper {
        --header-height: 80px;
    }
}

@media screen and (min-width: 1439px) {
    #wrapper {
        --header-height: 100px;
    }
}


/* Header */
#header {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background-color: var(--color-background);
    transition: .3s;
    z-index: 2000;
}

.scrollOn #header {
    background-color: rgba(var(--color-background-rgb),0.8);
    backdrop-filter: blur(5px);
}

#header .inner {
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    max-width: var(--max-width-lg);
    height: var(--header-height);
    padding: 0 20px;
    margin: 0 auto;
    z-index: 2000;
}

#header h1 {
    flex-grow: 1;
    padding-right: 33px;
    font-size: 0;
}

#header h1 a {
    display: block;
    height: 40px;
    background-position: center;
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-image: url("../img/logo.png");
    transition: 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.site-nav-burger {
    flex-shrink: 0;
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 4px;
    width: 33px;
    height: 30px;
    padding: 0 5px;
}

.site-nav-burger span {
    width: 100%;
    height: 3px;
    background-color: var(--color-basic);
    border-radius: 2px;
    transform-origin: 0% 0px;
    transition: 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
    opacity: 1;
}

.site-nav-burger span:nth-child(2) {
    width: 74%;
}

.site-nav-burger span:nth-child(3) {
    width: 50%;
}

.site-nav-burger.on span:nth-child(1) {
    transform: rotate(45deg) translate3d(0px, -3px, 0);
}

.site-nav-burger.on span:nth-child(2) {
    width: 0;
    opacity: 0;
}

.site-nav-burger.on span:nth-child(3) {
    width: 100%;
    transform: rotate(-45deg) translate3d(0px, 0, 0);
}

#header .gnb {
    visibility: hidden;
    overflow-y: auto;
    position: absolute;
    top: var(--header-height);
    left: 0;
    width: 100%;
    max-height: calc(100vh - var(--header-height));
    border-top: 1px solid var(--color-line-basic);
    background-color: var(--color-background);
    transition: .3s ease-in-out;
    opacity: 0;
    z-index: 1900;
}

#header.gnb-open .gnb {
    visibility: visible;
    opacity: 1;
}

#header .gnb .gnb-1a {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 10px;
    height: 50px;
    padding: 0 20px;
    font-size: 120%;
    font-weight: var(--font-weight-medium);
    transition: .2s;
}

#header .gnb .gnb-1a .arrow {
    flex-shrink: 0;
    width: 30px;
    text-align: center;
    opacity: 0.5;
    transition: .2s;
}

#header .gnb .gnb-1a.open {
    background-color: var(--color-point);
    color: var(--color-white);
}

#header .gnb .gnb-1a.open .arrow {
    transform: rotate(180deg);
}

#header .gnb .gnb-2ul {
    display: none;
    background-color: var(--color-brown);
}

#header .gnb .gnb-2a {
    display: block;
    padding: 10px 20px;
    color: var(--color-white);
    opacity: 0.7;
}

#header .sitemap-btn {
    display: none;
    flex-shrink: 0;
    width: 50px;
    height: 50px;
    background-color: var(--color-point);
    color: var(--color-white);
    font-size: 1.5rem;
    border-radius: 50%;
}

@media screen and (min-width: 1023px) {
    #header .inner {
        gap: 30px;
        /* padding-right: 80px; */
    }

    #header h1 {
        padding-right: 0px;
    }

    #header h1 a {
        background-position: center left;
    }

    .site-nav-burger {
        display: none;
        position: absolute;
        top: 50%;
        right: 20px;
        transform: translateY(-50%);
    }

    #header .gnb {
        flex-grow: 1;
        visibility: visible;
        overflow: visible;
        position: relative;
        top: auto;
        left: auto;
        width: auto;
        border-top: none;
        background-color: transparent;
        opacity: 1;
    }

    #header .gnb .gnb-1ul {
        display: flex;
        justify-content: flex-end;
        align-items: center;
    }

    #header .gnb .gnb-1li {
        position: relative;
    }

    #header .gnb .gnb-1a {
        font-size: 100%;
    }

    #header .gnb .gnb-1a:after {
        position: absolute;
        bottom: 0;
        left: 49%;
        width: 2%;
        height: 6px;
        background-color: var(--color-point);
        border-radius: 6px 6px 0 0;
        transition: .3s cubic-bezier(0.65, 0.05, 0.36, 1);
        opacity: 0;
        content: '';
    }

    #header .gnb .selected .gnb-1a,
    #header .gnb .gnb-1a:hover {
        color: var(--color-point);
    }

    #header .gnb .selected .gnb-1a:after,
    #header .gnb .gnb-1a:hover:after {
        left: 5%;
        width: 90%;
        opacity: 1;
    }

    #header .gnb .gnb-1a .arrow {
        display: none;
    }

    #header .gnb .gnb-2ul {
        display: block;
        visibility: hidden;
        position: absolute;
        top: 100%;
        left: 50%;
        width: 200px;
        padding: 10px 0;
        border: 1px solid var(--color-line-light);
        background-color: var(--color-background);
        box-shadow: 0 5px 10px -3px rgba(var(--color-black-rgb),0.2);
        transition: 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
        transform: translate(-50%, -20px);
        border-radius: 0 0 5px 5px;
        opacity: 0;
    }

    #header .gnb .gnb-1li:hover .gnb-2ul {
        visibility: visible;
        opacity: 1;
        transform: translate(-50%, 0);
    }

    #header .gnb .gnb-2a {
        color: var(--color-basic);
        opacity: 1;
    }

    #header .gnb .gnb-2a:hover {
        color: var(--color-blue);
    }

    #header .sitemap-btn {
        display: flex;
    }

    .scrollDown #header {
        transform: translateY(calc(var(--header-height) * -1));
    }
}

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

@media screen and (min-width: 1439px) {
    #header h1 a {
        width: 230px;
        height: 55px;
    }

    #header .gnb .gnb-1a {
        height: var(--header-height);
        padding: 0 40px;
        font-size: 110%;
    }
}



/* Footer */
#footer {
    position: relative;
    background-color: var(--color-brown);
    color: var(--color-white);
}

#footer * {
    transition: .3s;
}

.footer-mark {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    padding: var(--padding-basic);
    background-color: var(--color-point);
}

.footer-mark h1 {
    font-size: 0;
    width: 200px;
}

.footer-mark .social-mnu {
    display: none !important;
    gap: 0.5rem;
    padding-left: 60px;
}

.footer-mark .social-mnu li .basic-link {
    display: block;
    padding-inline: 0.5rem;
    font-size: 2rem;
    color: var(--color-white);
}

.footer-info {
    padding: var(--padding-lg) var(--padding-basic);
}

.footer-info .foot-gnb .gnb-1ul {
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 2rem 2%;
}

.footer-info .foot-gnb .gnb-1ul .gnb-1li {
    width: 49%;
}

.footer-info .foot-gnb .gnb-1ul .gnb-1li .gnb-1a {
    display: block;
    color: var(--color-pink);
    font-size: clamp(1rem, 3vw, 1.25rem);
    font-weight: var(--font-weight-medium);
}

.footer-info .foot-gnb .gnb-1ul .gnb-1li .gnb-1a .arrow {
    display: none;
}

.footer-info .foot-gnb .gnb-2ul {
    margin-top: 1rem;
}

.footer-info .foot-gnb .gnb-2ul .gnb-2li:not(:first-child) {
    margin-top: 10px;
}

.footer-info .foot-gnb .gnb-2ul .gnb-2li .gnb-2a {
    display: block;
    color: var(--color-pink);
    opacity: 0.5;
}

.footer-info p.copyright {
    margin-top: 2rem;
    opacity: 0.5;
}

@media screen and (min-width: 767px) {
    .footer-info .foot-gnb .gnb-1ul {
        flex-wrap: nowrap;
        gap: 0 2%;
    }

    .footer-info .foot-gnb .gnb-1ul .gnb-1li {
        width: 23.5%;
    }
}

@media screen and (min-width: 1023px) {
    #footer .inner {
        display: flex;
        justify-content: space-between;
        align-items: stretch;
        gap: 2rem;
    }

    .footer-mark {
        flex-shrink: 0;
        justify-content: center;
        align-items: center;
        width: 300px;
    }

    .footer-mark:after {
        position: absolute;
        bottom: 100%;
        left: 0;
        right: 0;
        height: 40px;
        background-color: var(--color-point);
        content: '';
    }

    .footer-info {
        flex-grow: 1;
        padding-block: 3rem;
    }

    .footer-info p.copyright {
        margin-top: 4rem;
    }
}

@media screen and (min-width: 1239px) {
    .footer-mark {
        width: 400px;
        padding-right: 3rem;
    }

    .footer-mark h1 {
        width: 230px;
    }

    .footer-mark .social-mnu {
        width: 230px;
        padding-left: 70px;
    }

    .footer-info {
        padding-block: 4rem;
    }

    .footer-info .foot-gnb .gnb-2ul {
        margin-top: 1.5rem;
    }

    .footer-info .foot-gnb .gnb-2ul .gnb-2li .gnb-2a:hover {
        opacity: 0.7;
    }

    .footer-info p.copyright {
        margin-top: 5rem;
    }
}

@media screen and (min-width: 1439px) {
    #footer .inner {
        gap: 4rem;
    }

    .footer-mark {
        width: 550px;
    }
}

@media screen and (min-width: 1639px) {
    .footer-info {
        padding-inline: 0;
    }
}


/* 팝업 리스트 */
.popup-zone {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    justify-content: center;
    align-items: center;
    padding: 20px;
    background-color: rgba(var(--color-black-rgb),0.7);
    backdrop-filter: blur(5px);
    color: var(--color-white);
    z-index: 8000;
}

.popup-zone.open {
    display: flex;
}

.popup-zone .popup-dialog {
    position: relative;
    max-width: 800px;
    overflow: hidden;
}

.popup-zone .popup-head,
.popup-zone .popup-foot {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.popup-zone .popup-head h1 {
    font-size: clamp(1.25rem, 3vw, 2rem);
}

.popup-zone .popup-head .swiper-pagination {
    position: relative;
    bottom: auto;
    top: auto;
    left: auto;
    width: auto;
}

.popup-zone .popup-content {
    padding-block: 20px;
    margin-block: 20px;
    border-top: 1px solid rgba(var(--color-white-rgb),0.2);
    border-bottom: 1px solid rgba(var(--color-white-rgb),0.2);
}

.popup-zone .popup-content .popup-slide a,
.popup-zone .popup-content .popup-slide figure {
    display: block;
    overflow: hidden;
    font-size: 0;
    border-radius: 5px;
}

.popup-zone .popup-foot .popup-btn {
    border-radius: 3px;
}

.popup-zone .popup-foot .swiper-button {
    background-color: transparent;
    border: 1px solid rgba(var(--color-white-rgb),0.3);
    color: var(--color-white);
}

.popup-zone .popup-foot .swiper-button:not(.swiper-button-disabled):hover {
    border: 1px solid rgba(var(--color-white-rgb),1);
    background-color: rgba(var(--color-black-rgb),0.2);
}

.popup-zone .popup-foot .swiper-button.swiper-button-disabled {
    opacity: 0.5;
    cursor: default;
}



/* 준비중 페이지 */
.waiting-page {
    padding: 50px 20px;
}

.waiting-page h3 {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.waiting-page h3 figure {
    width: 50%;
    max-width: 250px;
    font-size: 0;
}

.waiting-page h3 em {
    font-size: clamp(2rem, 6vw, 5rem);
    text-transform: uppercase;
    font-weight: var(--font-weight-medium);
    background: linear-gradient(45deg, var(--color-point), var(--color-blue));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.waiting-page p {
    position: relative;
    margin-top: 20px;
    color: var(--color-gray);
    font-size: clamp(1rem, 2.5vw, 1.5rem);
    text-align: center;
}

.waiting-page p br {
    display: none;
}

@media screen and (min-width: 767px) {
    .waiting-page p br {
        display: block;
    }
}

@media screen and (min-width: 1023px) {
    .waiting-page {
        padding: 100px 20px;
    }

    .waiting-page h3 em {
        font-weight: var(--font-weight-light);
    }

    .waiting-page p {
        padding-top: 180px;
        margin-top: 30px;
    }

    .waiting-page p:after {
        position: absolute;
        top: 0;
        left: 50%;
        width: 1px;
        height: 150px;
        background-color: var(--color-line-basic);
        content: '';
    }
}




/* ------------------------------------------------------------ */




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

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

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

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

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

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

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

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

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