@charset "UTF-8";
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/variable/pretendardvariable.css');
@import url('https://fonts.googleapis.com/css?family=Play:400,700&display=swap');

/* Pretendard */
@font-face {
    font-family: 'Pretendard';
    font-weight: 100;
    font-style: normal;
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Thin.eot');
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Thin.eot?#iefix') format('embedded-opentype'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Thin.woff') format('woff'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Thin.ttf') format("truetype");
    font-display: swap
}
@font-face {
    font-family: 'Pretendard';
    font-weight: 200;
    font-style: normal;
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-ExtraLight.eot');
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-ExtraLight.eot?#iefix') format('embedded-opentype'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-ExtraLight.woff') format('woff'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-ExtraLight.ttf') format("truetype");
    font-display: swap
}

@font-face {
    font-family: 'Pretendard';
    font-weight: 300;
    font-style: normal;
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Light.eot');
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Light.eot?#iefix') format('embedded-opentype'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Light.woff') format('woff'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Light.ttf') format("truetype");
    font-display: swap
}

@font-face {
    font-family: 'Pretendard';
    font-weight: 400;
    font-style: normal;
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Regular.eot');
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Regular.eot?#iefix') format('embedded-opentype'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Regular.woff') format('woff'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Regular.ttf') format("truetype");
    font-display: swap
}

@font-face {
    font-family: 'Pretendard';
    font-weight: 500;
    font-style: normal;
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Medium.eot');
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Medium.eot?#iefix') format('embedded-opentype'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Medium.woff') format('woff'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Medium.ttf') format("truetype");
    font-display: swap
}

@font-face {
    font-family: 'Pretendard';
    font-weight: 600;
    font-style: normal;
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-SemiBold.eot');
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-SemiBold.eot?#iefix') format('embedded-opentype'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-SemiBold.woff') format('woff'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-SemiBold.ttf') format("truetype");
    font-display: swap
}

@font-face {
    font-family: 'Pretendard';
    font-weight: 700;
    font-style: normal;
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Bold.eot');
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Bold.eot?#iefix') format('embedded-opentype'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Bold.woff') format('woff'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Bold.ttf') format("truetype");
    font-display: swap
}

@font-face {
    font-family: 'Pretendard';
    font-weight: 800;
    font-style: normal;
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-ExtraBold.eot');
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-ExtraBold.eot?#iefix') format('embedded-opentype'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-ExtraBold.woff') format('woff'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-ExtraBold.ttf') format("truetype");
    font-display: swap
}

@font-face {
    font-family: 'Pretendard';
    font-weight: 900;
    font-style: normal;
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Black.eot');
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Black.eot?#iefix') format('embedded-opentype'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Black.woff') format('woff'),
        url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Black.ttf') format("truetype");
    font-display: swap
}

/* GmarketSans */
@font-face {
    font-family: 'GmarketSansLight';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2001@1.1/GmarketSansLight.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'GmarketSansMedium';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2001@1.1/GmarketSansMedium.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}
@font-face {
    font-family: 'GmarketSansBold';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2001@1.1/GmarketSansBold.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

/* Cafe24 */
@font-face {
    font-family: 'Cafe24Ohsquare';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2001@1.1/Cafe24Ohsquare.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'Cafe24Ohsquareair';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2202@1.0/Cafe24Ohsquareair.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

body {
    overflow-y: scroll !important;
    overflow-x: hidden;
    background-color: #fff;
}

body, div, dl, dt, dd, ul, ol, li, i, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, legend, button, select, p, blockquote, th, td, table {
    font-family: 'Pretendard', 'Noto Sans KR', '맑은 고딕', 'Malgun Gothic', sans-serif !important;
    font-size: 100%;
    padding: 0;
    margin: 0;
    word-break: keep-all;
    -webkit-text-size-adjust: none;
    color: #181818;
}

a {
    text-decoration: none !important;
    cursor: pointer !important;
}

li {
    list-style: none;
}

caption { display: none;}

.py-6 {
    padding-top: 6rem!important;
    padding-bottom: 6rem!important
}

.py-7 {
    padding-top: 7rem!important;
    padding-bottom: 7rem!important
}

.py-8 {
    padding-top: 8rem!important;
    padding-bottom: 8rem!important
}

.px-10 {
    padding-right: 10rem !important;
    padding-left: 10rem !important
}

.me-2s {
    margin-right: 2rem!important
}

.ms-2s {
    margin-left: 2rem!important
}

.mb-5-s {
    margin-bottom: 5rem!important
}

.mb-6 {
    margin-bottom: 6rem!important
}

@media all and (min-width: 1025px) and (max-width: 1440px) {
    .px-10-m {
        padding-right: 3rem !important;
        padding-left: 3rem !important
    }
}

@media all and (max-width: 1024px) {
    .ms-0-m {
        margin-left: 0rem!important
    }

    .pb-2-m {
        padding-bottom: 2rem!important
    }

    .py-3-m {
        padding-top: 0rem!important;
        padding-bottom: 0rem!important
    }

    .py-7-m {
        padding-top: 3rem!important;
        padding-bottom: 3rem!important
    }

    .px-10-m {
        padding-right: 3rem !important;
        padding-left: 3rem !important
    }

    .mt-2-m {
        margin-top: 2rem!important
    }

    .mt-5-m {
        margin-top: 3rem!important
    }

    .me-2s {
        margin-right: 0rem!important
    }

    .ms-2s {
        margin-left: 0rem!important
    }

    .my-2-m {
        margin-top: 2rem!important;
        margin-bottom: 2rem!important
    }
}

.clear:after {
    content: "";
    display: block;
    clear: both;
}

.con-pc {
    display: block;
}

.con-m {
    display: none;
}

.br-pc {
    display: block !important;
}

@media all and (max-width: 767px) {
    .br-m {
        display: block !important;
    }

    .br-pc {
        display: inline-block !important;
    }
}

.p-relative {
    position: relative;
}

.container-1400 {
    width: 1400px;
    margin: 0 auto;
}

.container-1350 {
    width: 1350px;
    margin: 0 auto;
}

.container-1200 {
    width: 1200px;
    margin: 0 auto;
}

@media all and (min-width: 768px) and (max-width: 1440px) {
    .container-1400, .container-1350 {
        width: 90%;
    }

    .container-1200 {
        width: 100%;
    }

    .container-m {
        width: 100% !important;
    }
}

@media all and (max-width: 767px) {
    .container-1400, .container-1350 {
        width: 90%;
    }

    .container-1200 {
        width: 100%;
    }

    .container-m {
        width: 100% !important;
    }

    .img-m {
        width: 100% !important;
    }
}

#header {
    z-index: 50;
    position: fixed;
    width: 100%;
    box-sizing: border-box;
}

#header h1 {
    margin-top: -1rem;
 }

#header h1 img {
    width: 280px;
 }

#header .navi-wrap a {
    color: #fff;
}

.dropdown a {
    font-family: 'GmarketSansMedium', sans-serif !important;
    font-size: 1.2rem;
    line-height: 3rem;
    color: #fff;
}

.dropdown:hover .dropdown-menu {
    display: block;
}

.dropdown-menu {
    top: 63px;
    left: 50%;
    margin-left: -76px;
    min-width: 150px !important;
    text-align: center !important;
    border: 0 !important;
    border-radius: 1rem !important;
    /* background: linear-gradient(-200deg,#eab526,#e98706) !important; */
    background: #fff;
    padding: 1.2rem 0 1rem;
    box-shadow : rgba(0,0,0,.1) 0 0 10px;
}

.dropdown-menu a {
    color: #fff !important;
    font-size: 1rem;
    line-height: 2rem;
    font-weight: 700 !important;
}

.dropdown-menu a.sub01 {
    color: #eab626 !important;
}

.dropdown-menu a.sub01:hover {
    background: #eab626 !important;
 }

.dropdown-menu a.sub02 {
    color: #c31c1f !important;
}

.dropdown-menu a.sub02:hover {
    background: #c31c1f !important;
 }

.dropdown-menu a.sub03 {
    color: #27549c !important;
}

.dropdown-menu a.sub03:hover {
    background: #27549c !important;
}

.dropdown-menu a.sub04 {
    color: #1e7b3a !important;
}

.dropdown-menu a.sub04:hover {
    background: #1e7b3a !important;
}

.dropdown-menu a.sub06 {
    color: #5a3588 !important;
}

.dropdown-menu a.sub06:hover {
    background: #5a3588 !important;
}

.dropdown-menu a span {
    display: block;
    line-height: 1.25rem;
}

.dropdown-toggle::after {
    display: none !important;
}

.dropdown-menu a:hover {
    background: none !important;
    color: #fff !important;
    font-weight: 500 !important;
    transition: all 0.4s;
    -webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
 }

.lnb-pc > li > a {
    position: relative !important;
    display: inline-block !important;
}

.lnb-pc > li > a:hover {
    color: #eab526 !important;
}

.lnb-pc > li > a:before {
    content: "" !important;
    position: absolute !important;
    bottom: 13px !important;
    left: 14% !important;
    width: 70% !important;
    height: 1px !important;
    background: #eab526 !important;
    transform: scaleX(0) !important;
    transition: transform .3s cubic-bezier(.25,.85,.57,1) !important ;
}

.lnb-pc > li > a:hover:before,
.lnb-pc > li.on > a:before {
    transform: scaleX(1) !important;
}

.lnb-pc > li > a:hover,
.lnb-pc > li.focus > a,
.lnb-pc > li.on > a {
    color: #eab526 !important;
}

#header.scroll-top {
    height: 97px;
    background: rgba(0,0,0,.7);
    box-shadow : rgba(0,0,0,.1) 0 0 10px;
}

#header.scroll-top .dropdown-menu {
    top: 60px;
}

.m-navi {
    display: none !important;
}

@media all and (min-width: 992px) and (max-width: 1024px) {
    #header h1 img {
        width: 220px;
    }

    #header.scroll-top {
        height: 80px;
        padding: 0 !important;
    }
}

@media all and (min-width: 768px) and (max-width: 991px) {
    .navbar-toggler-m i {
        font-size: 2.7rem !important;
        line-height: 3.7rem !important;
    }
}

@media all and (max-width: 991px) {
    #header h1 {
        margin-top: 0;
    }

    #header h1 img {
        width: 190px;
    }

    #header.scroll-top {
        height: 73px;
    }

    .m-navi {
        display: block !important;
    }

    .navbar-toggler-m {
        padding: 0 !important;
    }

    .navbar-toggler-m i {
        display: inline-block;
        font-size: 3.5rem;
        font-weight: 700;
        margin-top: 0;
        color: #fff;
    }

    .navbar-toggler-m:focus {
        box-shadow: none;
    }

    .menu-m {
        width: 80% !important;
        background-color: rgba(255, 255, 255, 1);
    }

    .navi-wrap-m {
        width: 80%;
        margin: 5.5rem auto 0;
    }

    .navi-wrap-m li a {
        font-weight: 700;
        font-size: 1.6rem;
        color: #000;
        line-height: 3rem;
    }

    .dropdown-menu {
        width: 90%;
        margin-left: 0 !important;
    }

    .dropdown-menu a:hover {
        color: #5a350a !important;
        font-weight: 700 !important;
    }

    .dropdown-menu a span {
        display: inline-block !important;
    }

    .navi-wrap-m .m-drop {
        background: none !important;
    }

    .dropdown-menu .dropdown-item {
        font-size: 1.5rem;
        font-weight: 500;
        text-align: left;
        color: #666 !important;
        line-height: 2.5rem !important;
        padding-left: 0 !important
    }

    .dropdown-menu ul {
        margin-top: -0.7rem !important;
    }

    .btn-close {
        position: absolute;
        right: 1.5rem !important;
        top: 1.5rem !important;
        font-size: 1.5rem;
    }

    .bg-off {
        background: #aaa !important;
    }
}

.title-box {
    text-align: center;
    margin-bottom: 4rem;
    letter-spacing: -0.03em;
}

.title-box h3 {
    font-family: 'GmarketSansBold', sans-serif !important;
    font-size: 2.8rem;
    padding-bottom: 1rem;
}

.title-box p {
    font-family: 'GmarketSansLight', sans-serif !important;
    font-size: 1.3rem;
    font-weight: 600;
}

@media all and (min-width: 768px) and (max-width: 1024px) {
    .title-box h3 {
        font-size: 2rem;
    }

    .title-box p {
        font-size: 1rem;
    }
}

@media all and (max-width: 767px) {
    .title-box {
        margin-bottom: 2rem;
    }
}

.main-visual {
    height: 100vh;
}

.visual-cont {
    position: relative;
    height: 100%;
}

.visual-cont .visual-bg {
    position: relative;
    overflow: hidden;
}

.visual-cont .visual-bg figure {
    display: block;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center center;
}

.visual-cont .visual-bg figure {
    background-position: 100% center center;
}

.visual-bg-01 figure {
    background: #f3f7ff url(../images/main/img-visual-main01.jpg) no-repeat;
}

.visual-bg-02 figure {
    background: #f3f7ff url(../images/main/img-visual-main02.jpg) no-repeat;
}

.visual-bg-03 figure {
    background: #f3f7ff url(../images/main/img-visual-main03.jpg) no-repeat;
}

.visual-bg-04 figure {
    background: #f3f7ff url(../images/main/img-visual-main04.jpg) no-repeat;
}

.visual-bg-05 figure {
    background: #f3f7ff url(../images/main/img-visual-main05.jpg) no-repeat;
}

.visual-tit {
    bottom: 20rem;
    position: absolute;
    right: 0;
    transform: translateX(-50%);
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
    z-index: 10;
    text-align: right;
}

.visual-tit p {
    font-family: 'Play', sans-serif !important;
    font-size: 2.5rem;
    font-weight: 700;
    line-height: 3.8rem;
    color: #fff !important;
    padding-bottom: 1.5rem;
    letter-spacing: -0.03em;
}

.visual-tit p + p {
    font-family: 'Cafe24Ohsquare', sans-serif !important;
    font-size: 4.7rem;
    font-weight: 700;
    line-height: 5.3rem
}

.visual-cont .swiper-pagination {
    z-index: 1;
    text-align: center;
    bottom: 5rem
}

.visual-cont .swiper-pagination-bullet {
    margin: 0 5px !important;
    background: #fff;
    width: 40px;
    height: 5px;
    border-radius: 2px !important
}

@media all and (min-width: 768px) and (max-width: 1024px) {
    .visual-tit {
        bottom: 13rem;
        right: 0;
        left: 0%;
        transform: translateX(0%);
        padding-top: 1.25rem;
        padding-bottom: 1.25rem;
        text-align: center;
    }
}

@media screen and (max-width: 767px) {
    .main-visual {
        height: 500px
    }

    .visual-tit {
        bottom: 13rem;
        right: 0;
        left: 0%;
        transform: translateX(0%);
        padding-top: 1.25rem;
        padding-bottom: 1.25rem;
        text-align: center;
        width: 100%;
    }

    .visual-tit p {
        font-size: 2rem;
        line-height: 2.6rem;
        padding-bottom: 1rem
    }

    .visual-tit p + p {
        font-size: 3rem;
        line-height: 3.5rem
    }

    .visual-cont .visual-dot .swiper-pagination-bullet.swiper-pagination-bullet-active {
        width: 50px
    }

    .visual-cont .visual-dot svg {
        width: 50px
    }

    .b_stop_btn {
        left: 50px;
        bottom: 20px
    }

    .visual-cont .swiper-pagination {
        bottom: 3rem
    }
}

.text-motion .move-left {
    transform: translateX(25px);
    opacity: 0;
    transition: transform 1s ease, opacity .6s
}

.text-motion.on .move-left {
    transform: translateX(0);
    opacity: 1
}

.text-motion .move-up {
    transform: translateY(25px);
    opacity: 0;
    transition: transform .8s ease, opacity .4s
}

.text-motion.on .move-up {
    transform: translateY(0);
    opacity: 1
}

@keyframes mv_up {
    0% {
        transform: scale(1.1);
    }

    100% {
        transform: scale(1);
    }
}

@-webkit-keyframes mv_up {
    0% {
        transform: scale(1.1);
    }

    100% {
        transform: scale(1);
    }
}

.main-maul-info {
    width: 100%;
    background: #fff url(../images/main/bg-gray.gif) repeat-y top right;
}

.main-maul-info .info-cont .left-part {
    background: url(../images/main/tit-bg-maul.png) no-repeat top -1rem left -1.5rem;
    background-size: 580px;
}

.main-maul-info .info-cont .left-part .text-box {
    margin-top: 17.5rem;
}

.main-maul-info .info-cont .left-part .text-box p {
    font-family: 'GmarketSansMedium', sans-serif !important;
    font-size: 1.4rem;
    letter-spacing: -0.02em;
}

.main-maul-info .info-cont .left-part .text-box p + p {
    font-family: 'Pretendard', sans-serif !important;
    font-weight: 500;
    font-size: 1.05rem;
    color: #666;
    padding: 1rem 7rem 2.5rem 0;
}

.main-maul-info .info-cont .left-part .text-box a {
    display: inline-block;
    color: #505f62;
    font-size: 1rem;
    font-weight: 500;
    background: url(../images/main/icon-arrow.png) no-repeat center right;
    padding: 0.6rem 5.5rem 0.6rem 0;
}

.main-maul-info .info-cont .left-part .text-box a:hover {
    background: #08b68c url(../images/main/icon-arrow-on.png) no-repeat center right 1rem;
    border-radius: 3rem;
    padding: 0.6rem 6.5rem 0.6rem 1.5rem;
    color: #fff;
    font-weight: 700;
}

.main-maul-info .info-cont img {
    width: 95%;
    border-radius: 2rem;
}

@media all and (min-width: 1025px) and (max-width: 1440px) {
    .main-maul-info {
        background-position: top center;
    }

    .main-maul-info .info-cont .left-part {
        background-position: top -0.7rem center;
        background-size: 450px;
    }

    .main-maul-info .info-cont .left-part .text-box {
        margin-top: 15rem;
    }

    .main-maul-info .info-cont .left-part .text-box p + p {
        padding: 1rem 1rem 0rem 0;
    }
}

@media all and (min-width: 1025px) and (max-width: 1200px) {
    .main-maul-info {
        background-position: top center;
    }

    .main-maul-info .info-cont .left-part {
        background-position: top -0.7rem center;
        background-size: 350px;
    }

    .main-maul-info .info-cont .left-part .text-box {
        margin-top: 11rem;
    }

    .main-maul-info .info-cont .left-part .text-box p {
        font-size: 1.2rem;
    }

    .main-maul-info .info-cont .left-part .text-box p + p {
        font-size: 1rem;
        padding: 1rem 1rem 1rem 0;
    }
}

@media all and (min-width: 641px) and (max-width: 1024px) {
    .main-maul-info {
        width: 100%;
        background: none;
    }

    .main-maul-info .info-cont .left-part {
        background-position: top -0.5rem center !important;
        background-size: 250px !important;
    }

    .main-maul-info .info-cont .left-part .text-box {
        margin: 10rem 0 1.5rem;
    }

    .main-maul-info .info-cont .left-part .text-box p {
        font-size: 1.5rem;
    }

    .main-maul-info .info-cont .left-part .text-box p + p {
        font-size: 1.3rem;
        padding: 1rem 5rem !important;
        text-align: center !important;
    }

    .main-maul-info .info-cont .left-part .text-box a {
        font-size: 1.3rem;
        padding: 0.6rem 7rem 0.6rem 0;
    }
}

@media screen and (max-width: 640px) {
    .main-maul-info {
        background: none;
    }

    .main-maul-info .info-cont .left-part {
        background-position: top -30px right 20px !important;
        background-size: 300px;
    }

    .main-maul-info .info-cont .left-part .text-box {
        margin-top: 12rem;
        text-align: center;
    }

    .main-maul-info .info-cont .left-part .text-box p {
        font-size: 1.6rem;
    }

    .main-maul-info .info-cont .left-part .text-box p + p {
        font-size: 1.4rem;
        text-align: center;
        padding: 1rem;
    }

    .main-maul-info .info-cont .left-part .text-box a {
        font-size: 1.4rem;
        padding: 0.6rem 7rem 0.6rem 0;
    }

    .main-maul-info .info-cont img {
        width: 100%;
        margin-top: 3rem;
    }
}

.main-facility {
    padding: 7rem 0 4rem;
}

.main-facility .text-box {
    text-align: center;
    margin: 2.3rem 0;
}

.main-facility .text-box h4 {
    font-family: 'Cafe24Ohsquare', sans-serif !important;
    font-size: 2.3rem;
    padding-bottom: 1.5rem;
}

.main-facility .text-box p {
    font-size: 1.05rem;
    color: #3e3e3e;
    padding: 0 4rem;
}

.main-facility img {
    width: 100%;
    border-top-right-radius: 3rem;
    border-bottom-left-radius: 3rem;
}

.main-facility .btn-style {
    position: relative;
    width: 320px;
    margin: 0 auto;
    border-radius: 0.3rem;
    padding: 0.7rem 1.5rem;
    box-sizing: border-box;
    font-family: 'GmarketSansMedium', sans-serif !important;
    font-size: 1.2rem;
    line-height: 2rem;
    letter-spacing: -0.03em;
}

.main-facility .btn-style i {
    position: absolute;
    right: 1rem;
    top: 0.9rem;
    font-size: 1.6rem;
    color: #fff;
}

.main-facility .btn-style a {
    display: block;
    color: #fff;
}

.main-facility .btn-reserv {
    background: #08b68c;
    border: 1px solid #08b68c;
}

.main-facility .btn-reserv:hover {
    background: #fff;
    border: 1px solid #08b68c;
}

.main-facility .btn-reserv:hover a,
.main-facility .btn-reserv:hover i {
    color: #01ad85;
}

.main-facility .btn-design {
    background: #06bfcb;
    border: 1px solid #06bfcb;
}

.main-facility .btn-design:hover {
    background: #fff;
    border: 1px solid #06bfcb;
}

.main-facility .btn-design:hover a,
.main-facility .btn-design:hover i {
    color: #06bfcb;
}

@media all and (min-width: 768px) and (max-width: 1024px) {
    .main-facility .text-box h4 {
        font-size: 1.7rem;
        padding-bottom: 1rem;
    }

    .main-facility .text-box p {
        font-size: 1rem !important;
        padding: 0 1.5rem;
        line-height: 1.5rem;
    }
}

@media screen and (max-width: 767px) {
    .main-facility .text-box {
        margin: 2rem 0 1.5rem;
    }

    .main-facility .text-box h4 {
        font-size: 2.2rem;
    }

    .main-facility .text-box p {
        font-size: 1.4rem;
        padding: 0 0.5rem;
    }

    .main-facility img {
        border-radius: 2rem;
    }

    .main-facility .btn-style {
        width: 70%;
        margin: 0 auto 4rem;
        font-size: 1.4rem;
        line-height: 3rem;
    }
}

.main-program {
    background: url(../images/main/bg-program.png) no-repeat top right;
    background-size: 500px;
    padding: 10rem 0 6rem;
}

.main-program a {
    display: block !important;
}

.main-program .bg-box {
    position: relative;
    border-radius: 1.5rem;
    padding: 3.5rem 3.5rem;
    background-position: bottom 1.5rem right 1.5rem !important;
    background-size: 90px !important;
}

.main-program .bg-box .text-box h4 {
    font-family: 'GmarketSansBold', sans-serif !important;
    font-size: 2rem;
    color: #fff ;
    padding-bottom: 0.7rem;
}

.main-program .bg-box .text-box p {
    font-family: 'GmarketSansMedium', sans-serif !important;
    font-size: 1.1rem;
    color: #fff ;
}

.main-program .program01 {
    background: #ffba00 url(../images/main/icon-program01.png) no-repeat;
    border: 2px solid #ffba00
}

.main-program .program02 {
    background: #08b68c url(../images/main/icon-program02.png) no-repeat;
    border: 2px solid #08b68c;
}

.main-program .program03 {
    background: #ff7c1d url(../images/main/icon-program03.png) no-repeat;
    border: 2px solid #ff7c1d;
}

.main-program a:hover .program01 {
    background: #fff;
    border: 2px solid #ff9100;
}

.main-program a:hover .program02 {
    background: #fff;
    border: 2px solid #08b68c;
}

.main-program a:hover .program03 {
    background: #fff;
    border: 2px solid #ff591d;
}

.main-program a:hover .program01 .text-box h4,
.main-program a:hover .program01 .text-box p {
    color: #ff9100;
}

.main-program a:hover .program02 .text-box h4,
.main-program a:hover .program02 .text-box p {
    color: #02aa83;
}

.main-program a:hover .program03 .text-box h4,
.main-program a:hover .program03 .text-box p {
    color: #ff591d;
}

.main-program .bg-box .btn-go {
    position: relative;
    width: 140px;
    border: 2px solid #fff;
    box-sizing: border-box;
    border-radius: 1.5rem;
    padding: 0.4rem 1.3rem 0.3rem;
    margin-top: 2.5rem;
    font-family: 'GmarketSansMedium', sans-serif !important;
    font-size: 1rem;
    line-height: 1.7rem;
    color: #fff;
}

.main-program .bg-box .btn-go i {
    position: absolute;
    right: 0.5rem;
    top: 0.3rem;
    color: #fff;
    font-size: 1.8rem;
}

.main-program a:hover .program01 .btn-go {
    border: 2px solid #ff9100;
    background: #ff9100;
}

.main-program a:hover .program02 .btn-go {
    border: 2px solid #08b68c;
    background: #08b68c;
}

.main-program a:hover .program03 .btn-go {
    border: 2px solid #ff591d;
    background: #ff591d;
}

@media all and (min-width: 1025px) and (max-width: 1440px) {
    .main-program {
        background-size: 350px;
    }

    .main-program .bg-box {
        padding: 2.5rem 2rem;
        background-position: bottom 1rem right 1rem !important;
        background-size: 50px !important;
    }

    .main-program .bg-box .text-box h4 {
        font-size: 1.5rem;
    }
}

@media all and (min-width: 768px) and (max-width: 1024px) {
    .main-program {
        background-size: 330px;
    }

    .main-program .bg-box {
        padding: 2.5rem 1.5rem;
        background-position: bottom 1rem right 0.5rem !important;
        background-size: 50px !important;
    }

    .main-program .bg-box .text-box h4 {
        font-size: 1.3rem;
    }

    .main-program .bg-box .text-box p {
        font-size: 0.9rem;
        line-height: 1.1rem;
    }

    .main-program .bg-box .btn-go {
        width: 130px;
        padding: 0.4rem 1.3rem 0.2rem;
        margin-top: 1.5rem;
    }
}

@media screen and (max-width: 767px) {
    .main-program {
        background: none;
        padding: 0rem 0 1rem;
    }

    .main-program .bg-box {
        padding: 2.5rem;
        background-position: bottom 0.5rem right 0.5rem !important;
        background-size: 90px !important;
        margin-bottom: 1rem;
    }

    .main-program .bg-box .text-box p {
        font-size: 1.4rem;
        line-height: 2rem;
    }

    .main-program .bg-box .btn-go {
        width: 160px;
        padding: 0.6rem 1.3rem 0.5rem;
        font-size: 1.3rem;
        line-height: 2.2rem;
        border-radius: 3rem;
    }

    .main-program .bg-box .btn-go i {
        top: 0.5rem;
        font-size: 2rem;
    }
}

.main-tour {
    overflow:hidden !important;
}

.main-tour .tour-list {
    position: relative;
}

.main-tour .tour-list .swiper-slide {
    padding: 0 0;
}

.main-tour .tour-list .swiper-slide .thumb {
    position: relative;
    overflow: hidden;
    background: #f5f5f5;
    border-radius: 1.5rem;
}

.main-tour .tour-list .swiper-slide .thumb img {
    transform: scale(1);
    width: 100%;
    height: 100%;
    transition: all 0.6s;
}

.main-tour .tour-list .swiper-slide:hover .thumb img {
    transform: scale(1.05);
}

.main-tour .tour-list .swiper-slide .time {
    position: absolute;
    bottom: 1rem;
    right: 1rem;
    background: #1f2222;
    border-radius: 1.5rem;
    color: #fff;
    padding: 0.4rem 1.2rem;
    font-family: 'GmarketSansMedium', sans-serif !important;
    font-size: 0.8rem;
}

.main-tour .tour-list .swiper-slide .time i {
    display: inline;
    color: #fff;
    font-size: 0.8rem;
}

.main-tour .tour-list .info {
    margin-top: 2rem;
    letter-spacing: -0.03em;
    text-align: center;
}

.main-tour .tour-list .info .sbj {
    font-family: 'GmarketSansMedium', sans-serif !important;
    font-size: 1.3rem;
    color: #2c2c2c;
}

.main-tour .tour-list .info .cont {
    font-size: 1rem;
    color: #666;
    font-weight: 500;
    padding: 0.5rem 1.5rem 0;
}

.main-tour .tour-list .swiper-button-prev {
    top: 430px;
    left: 20px;
}

.main-tour .tour-list .swiper-button-next {
    top: 430px !important;
    left: 90px;
}

.main-tour .tour-list .swiper-button-prev:after, .main-tour .tour-list .swiper-button-next:after {
    font-family: bootstrap-icons !important;
    font-size: 3rem;
    text-transform: none!important;
    letter-spacing: 0;
    font-variant: initial;
    line-height: 1;
    color: #c0c0c0 !important;
}

.main-tour .tour-list .swiper-button-prev:after {
    left: 0;
    content: "\F129";
}

.main-tour .tour-list .swiper-button-next:after {
    right: 0;
    content: "\F133";
}

.main-tour .tour-list .tour-tit {
    background: url(../images/main/bg-tour.png) no-repeat top left;
    padding-top: 12rem;
    box-sizing: border-box;
}

@media all and (min-width: 1025px) and (max-width: 1200px) {
    .main-tour .tour-list .tour-tit {
        background-size: 100% !important;
        padding-top: 9rem;
    }
}

@media all and (min-width: 900px) and (max-width: 1024px) {
    .main-tour .tour-list .tour-tit {
        background-size: 100% !important;
        padding-top: 9rem;
    }

    .main-tour .tour-list .swiper-button-prev, .main-tour .tour-list .swiper-button-next  {
        top: 360px !important;
    }
}

@media all and (min-width: 641px) and (max-width: 899px) {
    .l-box, .r-box {
        width: 100% !important;
    }

    .main-tour .tour-list .tour-tit {
        background-size: 280px !important;
        background-position: top center;
        padding-top: 10rem;
        text-align: center !important;
    }

    .text-start-m {
        text-align: center !important;
    }

    .main-tour .tour-list .swiper-button-prev:after, .main-tour .tour-list .swiper-button-next:after {
        font-size: 2.5rem;
    }

    .main-tour .tour-list .swiper-button-prev {
        top: 95%;
        left: -10px;
    }

    .main-tour .tour-list .swiper-button-next {
        top: 95% !important;
        left: 99%;
    }

    .main-tour .tour-list .info {
        margin-top: 2rem;
    }

    .main-tour .tour-list .info .cont {
        padding: 0.5rem 1rem 0;
    }

    .main-tour .tour-list .info .sbj {
        font-size: 1.6rem;
    }

    .main-tour .tour-list .info .cont {
        font-size: 1.2rem;
        padding: 0.5rem 3rem 0;
    }
}

@media screen and (max-width: 640px) {
    .l-box, .r-box {
        width: 100% !important;
    }

    .text-start-m {
        text-align: center !important;
    }

    .main-tour .tour-list .tour-tit {
        background: url(../images/main/bg-tour.png) no-repeat top center;
        background-size: 200px;
        padding-top: 7rem;
    }

    .main-tour .tour-list .swiper-slide {
        margin-bottom: 3rem;
     }

    .main-tour .tour-list .swiper-slide .time {
        border-radius: 5rem;
        padding: 0.7rem 1.5rem;
        font-size: 1.2rem;
    }

    .main-tour .tour-list .swiper-slide .time i {
        font-size: 1.2rem;
    }

    .main-tour .tour-list .swiper-button-prev:after, .main-tour .tour-list .swiper-button-next:after {
        font-size: 3.5rem;
    }

    .main-tour .tour-list .swiper-button-prev {
        top: 79%;
        left: 37%;
    }

    .main-tour .tour-list .swiper-button-next {
        top: 79% !important;
        left: 55%;
    }

    .main-tour .tour-list .info {
        margin-top: 6.5rem;
        letter-spacing: -0.03em;
        text-align: center;
    }

    .main-tour .tour-list .info .sbj {
        font-size: 1.8rem;
        line-height: 2rem;
        color: #000;
    }

    .main-tour .tour-list .info .cont {
        font-size: 1.4rem;
    }
}

.main-cscenter {
    background: url(../images/main/bg-cscenter.jpg) no-repeat bottom center;
    background-size: cover;
    padding: 8rem 0 13rem;
    box-sizing: border-box;
}

.main-cscenter .cs-title p {
    font-family: 'GmarketSansBold', sans-serif !important;
    font-size: 3rem;
    line-height: 4rem;
    padding-top: 1.3rem;
}

.main-cscenter .cs-title p + p {
    font-family: 'GmarketSansLight', sans-serif !important;
    font-size: 1.1rem;
    font-weight: 600;
    color:#393935;
    line-height: 1.8rem;
}

.main-cscenter .cs-cont {
    border-radius: 1rem;
    padding: 3rem 2.5rem 6rem;
    box-shadow : rgba(0,0,0,.2) 0 0 10px;
    box-sizing: border-box;
    background-position: right bottom !important;
    margin-bottom: 1.5rem;
}

.main-cscenter .cs-cont h4 {
    font-family: 'GmarketSansBold', sans-serif !important;
    font-size: 1.6rem;
    color: #fff;
}

.main-cscenter .cs-cont p {
    font-size: 1.1rem;
    color: #fff;
    padding-top: 1rem;
}

.main-cscenter .cs01 {
    background: #008ce5 url(../images/main/icon-cscenter01.png) no-repeat;
    border: 2px solid #008ce5;
}

.main-cscenter .cs02 {
    background: #06bfcb url(../images/main/icon-cscenter02.png) no-repeat;
    border: 2px solid #06bfcb;
}

.main-cscenter .cs03 {
    background: #1b63c4 url(../images/main/icon-cscenter03.png) no-repeat;
    border: 2px solid #1b63c4;
}

.main-cscenter .cs04 {
    background: #4f72d6 url(../images/main/icon-cscenter04.png) no-repeat;
    border: 2px solid #4f72d6;
}

.main-cscenter a:hover .cs01 {
    background: #fff url(../images/main/icon-cscenter01.png) no-repeat;
}

.main-cscenter a:hover .cs02 {
    background: #fff url(../images/main/icon-cscenter02.png) no-repeat;
}

.main-cscenter a:hover .cs03 {
    background: #fff url(../images/main/icon-cscenter03.png) no-repeat;
}

.main-cscenter a:hover .cs04 {
    background: #fff url(../images/main/icon-cscenter04.png) no-repeat;
}

.main-cscenter a:hover .cs01 h4,
.main-cscenter a:hover .cs01 p {
    color: #0067e5;
}

.main-cscenter a:hover .cs02 h4,
.main-cscenter a:hover .cs02 p {
    color: #01b4c8;
}

.main-cscenter a:hover .cs03 h4,
.main-cscenter a:hover .cs03 p {
    color: #105dc3;
}

.main-cscenter a:hover .cs04 h4,
.main-cscenter a:hover .cs04 p {
    color: #3a64d7;
}

@media all and (min-width: 1101px) and (max-width: 1400px) {
    .main-cscenter .cs-cont {
        padding: 2.5rem 2.5rem 6rem;
    }

    .cs-img {
        background-size: 100px !important;
    }
}

@media all and (min-width: 1025px) and (max-width: 1200px) {
    .main-cscenter .cs-cont {
        padding: 2.5rem 2rem 6rem;
    }

    .main-cscenter .cs-cont h4 {
        font-size: 1.5rem;
    }

    .main-cscenter .cs-cont p {
        font-size: 1rem;
    }

    .cs-img {
        background-size: 100px !important;
    }
}

@media all and (min-width: 768px) and (max-width: 1024px) {
    .br-pc {
        display: inline-block !important;
    }

    .m-col {
        width: 100% !important;
    }

    .main-cscenter .cs-title {
        margin-bottom: 2rem;
    }

    .main-cscenter .cs-title p {
        font-size: 2.5rem;
        line-height: 4rem;
        text-align: center;
    }

    .main-cscenter .cs-title p + p {
        font-size: 1rem;
    }

    .cs-img {
        background-size: 100px !important;
    }
}

@media screen and (max-width: 767px) {
    .main-cscenter {
        padding: 3rem 0 13rem;
    }

    .main-cscenter .cs-title p {
        font-size: 2.3rem;
        line-height: 3rem;
        padding-top: 1.3rem;
        text-align: center;
    }

    .main-cscenter .cs-title p img {
        width: 160px;
        margin-bottom: 0.5rem;
    }

    .main-cscenter .cs-title p + p, .main-cscenter .cs-cont p {
        font-size: 1.4rem;
        line-height: 1.7rem;
    }

    .main-cscenter .cs-cont {
        padding: 2rem 1.5rem 0rem;
        min-height: 200px;
        background-size: 70px;
    }

    .main-cscenter a:hover .cs01, .main-cscenter a:hover .cs02, .main-cscenter a:hover .cs03, .main-cscenter a:hover .cs04 {
        background-size: 70px !important;
    }
}

.sub-visual {
    position: relative;
    width: 100%;
    text-align: center;
    height: 500px;
}

.sub-visual .bg {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.sub-visual .bg:after {
    content: '';
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background-color: #000;
    background-repeat: no-repeat;
    background-position: center top;
    background-size: cover;
    animation-duration: 5s;
    animation-name: visualScale;
    animation-timing-function: all 2.5s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.sub-visual .bg-greeting:after {
    background-image: url('../images/sub/bg-greeting.jpg');
}

.sub-visual .bg-tour:after {
    background-image: url('../images/sub/bg-tour.jpg');
}

.sub-visual .bg-facility:after {
    background-image: url('../images/sub/bg-facility.jpg');
}

.sub-visual .bg-program:after {
    background-image: url('../images/sub/bg-program.jpg');
}

.sub-visual .bg-reservation:after {
    background-image: url('../images/sub/bg-reservation.jpg');
}

.sub-visual .bg-community:after {
    background-image: url('../images/sub/bg-community.jpg');
}

.sub-visual .bg-etc:after {
    background-image: url('../images/sub/bg-etc.jpg');
}

.sub-visual .visual-in {
    position: absolute;
    left: 50%;
    top: 60%;
    transform: translate(-50%, -60%);
    max-width: 1280px;
    box-sizing: border-box;
    width: 100%;
    text-align: left;
}

.sub-visual .visual-in strong {
    font-family: 'Play', sans-serif !important;
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    color: #fff;
    line-height: 120%;
    opacity: 0;
    transition: all .5s linear;
}

.sub-visual .visual-in.action strong {
    opacity: 1;
}

.sub-visual .visual-in h2 {
    font-size: 4.5rem;
    color: #fff;
    font-weight: 700;
    line-height: 120%;
}

@keyframes visualScale {
    0% {
        transform: scale(1.15);
        -ms-transform: scale(1.15);
        -webkit-transform: scale(1.15)
    }

    100% {
        transform: scale(1);
        -ms-transform: scale(1);
        -webkit-transform: scale(1)
    }
}

.sub-visual-tit {
    overflow: hidden;
    opacity: 0;
}

.sub-visual-tit .char {
    display: inline-block;
    opacity: 0;
    transform: translateY(125%);
}

.sub-visual-tit.splitting {
    opacity: 1.0;
}

.sub-visual-tit.splitting .char {
    animation: slide-up 1s cubic-bezier(.5, .2, 0, 1);
    animation-fill-mode: both;
    animation-delay: calc(.3s + (.05s * var(--char-index)));
}

.sub-visual-tit .char {
    font-family: 'Cafe24Ohsquare', sans-serif !important;
    letter-spacing: -0.2em;
    line-height: 120%;
}

.whitespace {
    line-height: 0;
}

@keyframes slide-up {
    from {
        opacity: 0;
        transform: translateY(125%);
    }

    to {
        opacity: 1.0;
        transform: translateY(0);
    }
}

@media all and (min-width: 768px) and (max-width: 1399px) {
    .sub-visual .visual-in {
        text-align: center;
    }
}

@media screen and (max-width: 767px) {
    .sub-visual {
        height: 300px;
    }

    .sub-visual .visual-in {
        text-align: center;
    }

    .sub-visual .visual-in h2 {
        font-size: 3.7rem;
    }
}

.sub-navi {
    margin: 3rem 0;
}

.sub-navi .flex {
    display: flex;
    flex-flow: row wrap;
    -webkit-flex-flow: row wrap;
    -ms-flex-flow: row wrap;
    -moz-flex-flow: row wrap;
    -o-flex-flow: row wrap;
}

.sub-navi .navi-list {
    margin: 0 auto;
    justify-content: center;
}

.sub-navi .navi-list li {
    float: left;
    background: #eee;
    border-radius: 5rem;
    margin: 0 0.3rem 0.5rem;
}

.sub-navi .navi-list li a {
    position: relative;
    display: inline-block;
    font-family: 'GmarketSansMedium', sans-serif !important;
    font-size: 1.2rem;
    padding: 0.3rem 2rem 0;
    letter-spacing: -0.04em;
    color: #767676;
    text-align: center;
    line-height: 3.5rem;
}

.sub-navi .navi-list li a:before {
    content: "";
    position: absolute;
    top: 60%;
    right: 23px;
    width: 5px;
    height: 5px;
    background: #eab526;
    border-radius: 2rem;
    transform: scaleX(0);
    transition: transform .3s cubic-bezier(.25,.85,.57,1);
}

.sub-navi .navi-list li.on a {
    color: #fff;
    background: linear-gradient(-200deg,#eab526,#f89412) !important;
    border-radius: 5rem;
    padding: 0.3rem 2rem 0;
}

.sub-navi .navi-list li a:hover:before {
    transform: scaleX(1);
}

@media screen and (max-width: 767px) {
	html { font-size: 75% !important;}

    .sub-navi {
        margin: 2rem auto;
    }

    .sub-navi .navi-list li a {
        line-height: 3.2rem;
    }

    .sub-navi .navi-list li a:before {
        right: 18px;
    }
}

.sub-cont {
    margin-top: 6rem;
}

.sub-title-box {
    letter-spacing: -0.05em;
    color: #181818;
    text-align: center;
    margin-bottom: 5rem;
}

.sub-title-box h3 {
    font-family: 'GmarketSansBold', sans-serif !important;
    font-size: 2.7rem;
}

.sub-title-box p {
    font-family: 'GmarketSansLight', sans-serif !important;
    font-size: 1.2rem;
    font-weight: 600;
    color: #313131;
    padding-top: 0.5rem;
}

@media screen and (max-width: 767px) {
    .sub-cont {
        margin-top: 3rem;
    }

    .sub-title-box {
        margin-bottom: 3rem;
    }

    .sub-title-box p {
        padding: 0.5rem 2em 0;
    }
}

.greeting-bottom {
    background: url('../images/sub/bg-bottom.png') no-repeat right bottom;
}

.greeting-cont {
    text-align: center;
}

.greeting-cont .tit {
    font-family: 'GmarketSansBold', sans-serif !important;
    font-size: 2rem;
    color: #231815;
    letter-spacing: -0.04em;
    padding: 0;
}

.greeting-cont .tit img {
    width: 200px;
    margin-bottom: 0.5rem;
}

.greeting-cont .tit02 {
    font-family: 'GmarketSansBold', sans-serif !important;
    font-size: 1.7rem;
    color: #231815;
    letter-spacing: -0.04em;
    padding: 0;
}

.greeting-cont p {
    font-size: 1.2rem;
    color: #646464;
    padding: 4rem 7rem 5rem;
}

.greeting-cont p.cont {
    font-size: 1.2rem;
    color: #646464;
    padding: 1.5rem 7rem 10rem;
}

.maul-photo {
    width: 70%;
    margin: 0 auto;
}

.maul-photo img {
    width: 100%;
    border-radius: 2rem;
}

@media all and (min-width: 768px) and (max-width: 1440px) {
    .greeting-bottom {
        background-size: 300px;
    }
}

@media all and (max-width: 767px) {
    .greeting-bottom {
        background-size: 170px;
    }

    .greeting-cont .tit img {
        width: 150px;
    }

    .greeting-cont p {
        font-size: 1.4rem;
        padding: 3rem 1rem 4rem;
    }

    .greeting-cont p.cont {
        font-size: 1.4rem;
        padding: 1.5rem 1rem 8rem;
    }

    .maul-photo {
        width: 100%;
    }
}

.special-wrap {
    z-index: 9999;
    position: absolute;
    width: 500px;
    top: 3.5rem;
    right: 3.5rem;
    background-color: rgb(0, 0, 0, .7);
    border-radius: 0.5rem;
    padding: 1.5rem 2.5rem;
}

.special-wrap .text-box p {
    font-family: 'Play', sans-serif !important;
    font-size: 3em;
    color: #fff;
    font-weight: 700;
    letter-spacing: -0.04em;
    text-align: right;
}

.special-wrap .text-box p + p {
    font-family: 'Pretendard', sans-serif !important;
    font-size: 1.15em;
    font-weight: 500;
    line-height: 1.9rem;
    padding-top: 0.5rem;
}

@media all and (min-width: 991px) and (max-width: 1200px) {
    .special-wrap {
        width: 500px;
        top: 2rem;
        right: 2rem;
        padding: 1rem 2rem;
    }
}

@media(max-width: 990px) {
    .special-wrap {
        position: static;
        width: 100%;
        top: 0;
        right: 0;
        background-color: #fff;
        border-radius: 0;
        padding: 1.5rem 1rem;
    }

    .special-wrap .text-box p {
        font-size: 2.5em;
        color: #000;
        text-align: center;
    }

    .special-wrap .text-box p span {
        color: #c31b1f;
    }

    .special-wrap .text-box p + p {
        font-size: 1.4em;;
        line-height: 2.3rem;
        color: #646464;
    }
}

.location-wrap .map-box {
    margin-bottom: 6rem;
    border: none;
}

.location-wrap .map-box .map {
    width: 100%;
    height: 633px
}

.kakaomap {
    border: 1px solid #eab526;
    border-left: none;
}

.location-wrap .map-box .map-info {
    width: 100%;
    padding: 4rem 3rem;
    box-sizing: border-box;
    border: 0;
    border-radius: 2rem 0 0 2rem;
    background: #eab526;
}

.location-wrap .map-box .map-info .logo {
    display: block !important;
    width: 295px;
    height: 155px;
    margin-bottom: 14px;
    background: url('../images/sub/logo-map.png') no-repeat;
}

.location-wrap .map-box .map-info .map-list {
    margin-top: 35px;
    padding-top: 40px;
    border-top: 1px dashed rgba(255, 255, 255, 0.4);
}

.location-wrap .map-box .map-info .map-list li {
    display: block;
    margin-bottom: 25px;
    font-family: 'GmarketSansMedium', sans-serif !important;
    color: #fff !important;
    text-align: left;
    font-size: 1.1rem;
}

.location-wrap .map-box .map-info .map-list li span {
    display: block;
    font-size: 1.1rem;
}

.location-wrap .map-box .map-info .map-list li span i {
    color: #fff !important;
}

.location-wrap .map-box .map-info .map-list li p {
    font-family: 'Play', sans-serif !important;
    font-size: 2.5em;
    color: #fff;
    font-weight: 700;
    line-height: 2.2rem;
    letter-spacing: -0.04em;
}

.location-wrap .map-box .btn-map {
    display: flex;
    margin-top: 50px;
    text-align: center;
}

.location-wrap .map-box .btn-map a {
    width: 100%;
    padding: 0.8rem 0 0.7rem;
    border-radius: 100px;
    background-color: #eab526;
    border: 2px solid #fff;
    color: #fff;
    font-family: 'GmarketSansBold', sans-serif !important;
    font-size: 1.2rem;
}

.location-wrap .map-box .btn-map a i {
    display: inline-block;
    margin-right: 8px;
    font-size: 1rem;
    color: #fff;
}

.location-wrap .map-box .btn-map a:hover, .location-wrap .map-box .btn-map a:focus {
    background-color: #fff;
    color: #eab526;
}

.location-wrap .map-box .btn-map a:hover i {
    color: #eab526;
}

.traffic-info {
    width: 90%;
    margin: 0 auto 6rem;
}

.traffic-info .tit-box h4 {
    font-weight: 800;
    font-size: 1.7rem;
    margin-left: 1.2rem;
}

.traffic-info .tit-box p {
    margin-left: 1.2rem;
    color: #646464;
    padding-top: 1rem;
}

.traffic-info .tit-box .icon-box {
    position: relative;
    text-align: left !important;
    margin-top: 1rem;
}

.traffic-info .text-box p {
    font-family: 'GmarketSansMedium', sans-serif !important;
    font-size: 1.1rem;
    font-weight: 700;
    padding-bottom: 0.5rem;
}

.traffic-info .text-box p + p {
    font-family: 'Pretendard', sans-serif !important;
    font-size: 1rem;
    color: #646464;
    font-weight: 500;
}

.traffic-info .add-item, .traffic-info .tit-box .icon-box  {
    position: relative;
    text-align: center;
}

.traffic-info .add-item .icon, .traffic-info .tit-box .icon-box .icon {
    width: 8rem;
    height: 8rem;
    border-radius: 50%;
    background: #fcf8f4;
    margin-bottom: 0.9rem;
}

.traffic-info .add-item p {
    font-size: 1.1rem;
    font-weight: 600;
}

.hr-line {
    border-bottom: 1px dashed #cdd6e4;
    padding-bottom: 3rem;
}

@media all and (min-width: 1025px) and (max-width: 1440px) {
    .location-wrap .map-box .map {
        height: 549px;
    }

    .col-sm-left {
        width: 40%;
    }

    .col-sm-right {
        width: 60%;
    }

    .location-wrap .map-box .map-info {
        padding: 3rem 2rem;
    }

    .location-wrap .map-box .map-info .logo {
        width: 100%;
        height: 90px;
        margin-bottom: 0;
        background-size: 170px;
        background-position: top center;
    }

    .location-wrap .map-box .map-info .map-list li p {
        font-size: 1.9em;
    }
}

@media all and (min-width: 768px) and (max-width: 1024px) {
    .location-wrap .map-box {
        margin-bottom: 3rem;
    }

    .location-wrap .map-box .map {
        width: 100%;
        height: 855px;
        border-radius: 0;
        border: none;
    }

    .root_daum_roughmap .wrap_map {
        position: relative;
        height: 450px !important;
    }

    .location-wrap .map-box .map-info {
        width: 100%;
        padding: 1rem 2.5rem 1.5rem;
        border-radius: 0 0 2rem 2rem;
        text-align: center !important;
    }

    .location-wrap .map-box .map-info .logo {
        width: 100%;
        height: 130px;
        margin-bottom: 0;
        background-size: 180px;
        background-position: top center;
    }

    .location-wrap .map-box .map-info .map-list {
        margin-top: 0px;
        padding-top: 20px;
    }

    .location-wrap .map-box .map-info .map-list li {
        margin-bottom: 0.5rem;
        text-align: center;
    }

    .location-wrap .map-box .map-info .map-list li span {
        display: inline-block;
        margin-right: 0.5rem;
    }

    .location-wrap .map-box .map-info .map-list li p {
        display: inline-block;
        font-size: 1.7em;
    }

    .col-sm-left, .col-sm-right {
        width: 100% !important
    }

    .traffic-info {
        width: 100%;
    }
}

@media(max-width: 767px) {
    .location-wrap .map-box {
        flex-direction: column;
        border-radius: 0 0 30px 30px;
    }

    .location-wrap .map-box .map {
        width: 100%;
        height: auto;
        min-height: 350px;
        border-radius: 0;
        border: none;
    }

    .location-wrap .map-box .map-info {
        width: 100%;
        padding: 2rem 2.5rem;
        border-radius: 0 0 2rem 2rem;
    }

    .location-wrap .map-box .map-info .logo {
        display: none !important;
    }

    .location-wrap .map-box .map-info .map-list {
        margin-top: 0;
        padding-top: 0;
        border-top: none !important;
    }

    .location-wrap .map-box .map-info .map-list li {
        flex-direction: column;
        margin-bottom: 20px;
        font-size: 1.3rem;
    }

    .location-wrap .map-box .map-info .map-list li span {
        font-size: 1.3rem;
        display: block !important;
        margin-right: 0;
        padding-bottom: 0.3rem;
    }

    .location-wrap .map-box .btn-map a {
        padding: 1.1rem 0 1rem;
        font-size: 1.3rem;
    }

    .kakaomap {
        width: 100%;
        height: 38%;
    }

    .traffic-info {
        margin: 0 auto 3rem;
    }

    .traffic-info .tit-box h4 {
        margin-left: 0;
    }

    .traffic-info .tit-box p {
        margin-left: 0;
        font-size: 1.3rem
    }

    .traffic-info .tit-box .icon-box {
        position: absolute;
        text-align: left !important;
        margin-top: 1rem;
        top: -2rem;
        right: 0;
    }

    .traffic-info .tit-box .icon-box img, .traffic-info .add-item img {
        width: 70%;
    }

    .traffic-info .text-box p {
        font-size: 1.3rem;
    }

    .traffic-info .text-box p + p {
        font-size: 1.25rem;
    }

    .traffic-info .add-item {
        margin-bottom: 1rem;
    }

    .traffic-info .add-item p {
        font-size: 1.25rem;
    }

    .hr-line {
        padding-bottom: 4rem;
    }
}

@media (min-width: 576px) {
    .col-sm-left {
        flex: 0 0 auto;
        width: 30%;
    }

    .col-sm-right {
        flex: 0 0 auto;
        width: 70%;
    }
}

.photo-slide, .community-slide {
    width: 100%;
}

.photo-slide img, .community-slide img {
    width: 100%;
    border-radius: 2rem;
}

.photo-slide .swiper-button-prev, .photo-slide .swiper-button-next {
    top: 50% !important;
}

.community-slide .swiper-button-prev, .community-slide .swiper-button-next {
    top: 55% !important;
}

.photo-slide .swiper-button-prev:after, .photo-slide .swiper-button-next:after,
.community-slide .swiper-button-prev:after, .community-slide .swiper-button-next:after {
    font-family: bootstrap-icons !important;
    font-size: 2.8rem;
    text-transform: none!important;
    letter-spacing: 0;
    font-variant: initial;
    line-height: 1;
    color: #ffffff !important;
}

.photo-slide .swiper-button-prev, .community-slide .swiper-button-prev {
    left: 2rem;
}

.photo-slide .swiper-button-next, .community-slide .swiper-button-next {
    right: 2rem;
}

.photo-slide .swiper-button-prev:after, .community-slide .swiper-button-prev:after {
    left: 0;
    content: "\F129";
}

.photo-slide .swiper-button-next:after, .community-slide .swiper-button-next:after {
    right: 0;
    content: "\F133";
}

@media(max-width: 767px) {
    .photo-slide .swiper-button-prev {
        left: 1rem;
    }

    .photo-slide .swiper-button-next {
        right: 1rem;
    }

    .special-m .swiper-button-prev, .special-m .swiper-button-next {
        top: 30% !important;
    }
}

.design-wrap {
    position: relative;
    width: 100%;
}

.design-wrap .design-cont {
    padding: 7rem 0 4rem;
    background: #fcf8f4;
	width: 100vw;
	margin-left: calc(-50vw + 50%);
    margin-bottom: 12rem;
}

.design-wrap .design-cont .text-box img {
    width: 250px;
    margin-bottom: 1.5rem;
}

.design-wrap .design-cont .text-box h3 {
    font-family: 'GmarketSansMedium', sans-serif !important;
    font-size: 2.2rem;
    color: #00274e;
    padding-bottom: 0.5rem;
    letter-spacing: -0.05em;
}

.point-line {
    display: inline-block;
    z-index: 1;
    position: relative;
    margin-bottom: 0px;
    padding-bottom: 0px;
}

.point-line span {
    position: absolute;
    bottom: 3px;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 15px;
}

.point-line span.bg-pink {
    background: #f1e2d2;
}

.design-wrap .design-cont .text-box p {
    letter-spacing: -0.02em;
    font-size: 1.4rem;
    color: #00274e;
    font-weight: 600;
}

.design-wrap .design-cont .text-box p + p {
    font-size: 1.1rem;
    color: #646464;
    padding: 2rem 0;
    font-weight: 500;
}

.design-wrap .design-cont .img-box {
    position: absolute;
    top: 0;
    right: 0;
}

.design-wrap .design-cont .img-box img {
    width: 100%;
    border-radius: 2.7rem 0 2.7rem 0rem;
}

.design-list {
    margin: 6rem 0;
}

.design-list img{
    border-radius: 1.5rem;
    width: 100%;
}

@media all and (min-width: 1101px) and (max-width: 1400px) {
    .design-wrap .design-cont {
        padding: 5rem 0 2rem;
    }

    .design-wrap .design-cont .img-box {
        overflow: hidden;
        top: 0px;
    }
}

@media all and (min-width: 1025px) and (max-width: 1100px) {
    .design-wrap .design-cont {
        padding: 5rem 0 2rem;
        margin-bottom: 0;
    }

    .design-wrap .design-cont .img-box {
        overflow: hidden;
        top: -10px;
        right: -50px;
    }

    .design-wrap .design-cont .img-box img {
        width: 80%;
    }
}

@media all and (min-width: 768px) and (max-width: 1024px) {
    .design-wrap .design-cont {
        margin-bottom: 6rem;
    }

    .design-wrap .design-cont .text-box {
        text-align: center;
    }

    .design-wrap .design-cont .img-box {
        position: static;
    }

    .design-wrap .design-cont .img-box {
        text-align: center;
    }

    .design-wrap .design-cont .img-box img {
        width: 50%;
        border-radius: 2rem;
    }

    .design-list {
        margin: 4rem 0;
    }

    .my-2t {
        margin-top: 0rem!important;
        margin-bottom: 0rem!important
    }
}

@media(max-width: 767px) {
    .design-wrap .design-cont {
        padding: 4rem 0;
        margin-bottom: 4rem;
    }

    .design-wrap .design-cont .text-box {
        text-align: center;
    }

    .design-wrap .design-cont .text-box h3 {
        font-size: 2.5rem;
    }

    .design-wrap .design-cont .text-box p {
        font-size: 1.6rem;
    }

    .design-wrap .design-cont .text-box p + p {
        font-size: 1.3rem;
    }

    .design-wrap .design-cont .img-box {
        position: static;
    }

    .design-wrap .design-cont .img-box img {
        border-radius: 2rem;
    }
}

.camp-wrap {
    width: 90%;
    margin: 0 auto 5rem;
}

.camp-wrap .img-box img {
    width: 100%;
    border-radius: 2.5rem 2.5rem 0 0;
}

.camp-wrap .camp-cont .camp-info {
    position: relative;
    background: #eab526;
    padding: 3rem 5rem;
    border-radius: 0 0 2.5rem 2.5rem;
}

.camp-wrap .camp-cont .camp-info .camp-title {
    display: inline-block;
    vertical-align: middle;
    width: auto;
    margin-right: 3rem;
}

.camp-wrap .camp-cont .camp-info .camp-title strong {
    font-family: 'GmarketSansMedium', sans-serif !important;
    color: #fff;
    font-size: 1.5rem;
    line-height: 2rem;
}

.camp-wrap .camp-cont .camp-info .camp-list {
    display: inline-block;
    vertical-align: top;
    padding-left: 2.5rem;
    border-left: 1px solid #fff;
    width: calc(100% - 214px);
}

.camp-wrap .camp-cont .camp-info .camp-list ul li {
    position: relative;
    color: #fff;
    font-size: 1.2rem;
    line-height: 1.1;
    padding-left: 4.5rem;
    font-weight: 600;
}

.camp-wrap .camp-cont .camp-info .camp-list ul li + li {
    margin-top: 1rem;
}

.camp-wrap .camp-cont .camp-info .camp-list ul li b {
    position: absolute;
    left: 0;
    font-weight: 800;
    line-height: 1.2;
}

.camp-wrap .camp-cont .camp-info .camp-list ul li b i {
    display: inline-block;
    margin-right: 0.3rem;
    font-size: 1rem;
    color: #fff !important
}

.camp-wrap .camp-cont .camp-info .brn-reserv {
    position: absolute;
    right: 49px;
    top: 50%;
    transform: translateY(-50%);
}

.camp-wrap .camp-cont .camp-info .brn-reserv a {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    width: 100px;
    height: 100px;
    border: 3px solid #fff;
    background: #127b3a;
    border-radius: 20px;
    color: #fff !important;
    font-weight: 700;
    transition: 0.3s;
    text-align: center;
    font-size: 1.0rem;
}

.camp-wrap .camp-cont .camp-info .brn-reserv a i {
    font-size: 2.2rem;
    color: #fff !important;
}

.camp-wrap .camp-cont .camp-info .brn-reserv a:hover, .camp-wrap .camp-cont .camp-info .brn-reserv a:focus {
    background: #fff;
    color: #127b3a !important;
    font-weight: 700 !important;
}

.camp-wrap .camp-cont .camp-info .brn-reserv a:hover i {
    color: #127b3a !important;
}

@media all and (min-width: 1025px) and (max-width: 1100px) {
    .camp-wrap .camp-cont .camp-info {
        padding: 2rem 3rem;
    }
}

@media all and (min-width: 768px) and (max-width: 1024px) {
    .camp-wrap {
        width: 100%;
    }

    .camp-wrap .camp-cont .camp-info {
        padding: 2rem 3rem;
    }

    .camp-wrap .camp-cont .camp-info .camp-list {
        display: block;
        width: 100%;
        border: 0;
        padding: 0;
        padding-right: 0;
        margin: 20px auto 0;
    }

    .camp-wrap .camp-cont .camp-info .camp-list ul li {
        font-size: 1.1rem;
    }

    .col-t-100 {
        width: 100%;
    }
}

@media(max-width: 767px) {
    .camp-wrap {
        width: 100%;
        margin: 0 auto 3rem;
    }

    .camp-wrap .camp-cont .camp-info {
        padding: 2.5rem;
    }

    .camp-wrap .camp-cont .camp-info .camp-title {
        display: block;
        width: auto;
        margin-right: 0;
    }

    .camp-wrap .camp-cont .camp-info .camp-title strong {
        font-size: 1.7rem;
    }

    .camp-wrap .camp-cont .camp-info .camp-list {
        display: block;
        width: 100%;
        border: 0;
        padding: 0;
        padding-right: 0;
        margin: 20px auto 30px;
    }

    .camp-wrap .camp-cont .camp-info .camp-list ul li {
        font-size: 1.3rem;
    }

    .camp-wrap .camp-cont .camp-info .brn-reserv a {
        width: 100%;
        border: 1px solid #fff;
        font-size: 1.5rem;
    }

    .camp-wrap .camp-cont .camp-info .brn-reserv a i {
        display: inline-block;
        margin-right: 0.5rem;
        font-size: 1.8rem;
    }

    .col-t-100 {
        width: 100%;
    }
}

@media(max-width: 599px) {
    .camp-wrap .camp-cont .camp-info .camp-list {
        padding-right:0;
    }

    .camp-wrap .camp-cont .camp-info .brn-reserv {
        position: relative;
        right: auto;
        top: auto;
        transform: none;
    }

    .camp-wrap .camp-cont .camp-info .brn-reserv a {
        flex-direction: row;
        margin: 0 auto;
        padding: 13.82px 10px;
        border-radius: 8px;
        width: 100%;
        height: 100%;
    }

    .camp-wrap .camp-cont .camp-info .brn-reserv a:hover, .camp-wrap .camp-cont .camp-info .brn-reserv a:focus {
        border-radius: 0;
    }

    .camp-wrap .camp-cont .camp-info .brn-reserv a em {
        margin: 0;
        margin-right: 9px;
        width: 17px;
        height: 21px;
    }
}

.tour-wrap {
    position: relative;
    width: 100%;
    margin-bottom: 6rem;
}

.tour-wrap .tour-photo img {
    border-radius: 2rem;
}

.tour-wrap .tour-cont {
    padding: 17rem 0 0;
    background: #f8faf9;
    margin-top: -190px;
    margin-bottom: 6rem;
	width: 100vw;
	margin-left: calc(-50vw + 50%);
}

.tour-wrap .tour-cont .tour-title-box h3 {
    font-family: 'Cafe24Ohsquare', sans-serif !important;
    font-size: 2.7rem;
    color: #161616;
    height: 300px;
}

.tour-wrap .tour-cont p {
    font-size: 1.1rem;
    font-weight: 500;
    color: #646464 !important;
}

.tour-wrap .tour-cont .h-70 {
    height: 70px !important;
}

.tour-wrap .tour-cont .img-box {
    position: absolute;
    bottom: -20px;
}

.tour-wrap .tour-cont .img-box img {
    width: 350px;
}

.tour-wrap .tour-cont02 p {
    font-size: 1.7rem;
    font-weight: 700;
    padding: 0 1.5rem 0.5rem;
}

.tour-wrap .tour-cont02 p.text-box {
    font-size: 1rem;
    font-weight: 500;
    color: #646464 !important;
    padding: 0 1.5rem;
}

.tour-wrap .tour-etc {
    margin: 2.5rem 0;
}

.tour-wrap .tour-etc img {
    width: 100%;
    border-radius: 1rem;
}

.tour-wrap .tour-info {
    margin-top: 6rem
}

.tour-wrap .tour-info .item {
    position: relative;
    background: #f5f5f5;
    border-radius: 1.5rem;
    padding: 2.2em 2.1rem 0rem;
    box-sizing: border-box;
    min-height: 180px;
}

.tour-wrap .tour-info .item .icon-box {
    position: absolute;
    bottom: 1rem;
    right: 1.3rem;
}

.tour-wrap .tour-info .item p {
    color: #6f6f6f;
    font-size: 1.1rem;
    font-weight: 800;
}

.tour-wrap .tour-info .item p + p {
    color: #3d3d3d;
    font-size: 1.1rem;
    letter-spacing: -0.02em;
}

.tour-wrap .tour-info .tell {
    font-size: 1.5rem !important;
    letter-spacing: -0.04em !important;
}

.tour-wrap .tour-info .link a {
    font-size: 0.95rem !important;
    font-weight: 500 !important;
    color: #000;
}

.tour-wrap .tour-info .link a:hover {
    text-decoration: underline !important;
}

.tour-wrap .tour-info .map {
    margin-top: 0.5rem;
}

.tour-wrap .tour-info .map a {
    display: inline-block;
    background: #81c172;
    border: 1px solid #6db15e;
    padding: 0.2rem 0.7rem;
    border-radius: 0.3rem;
    font-size: 0.9rem !important;
    font-weight: 500 !important;
    color: #fff;
}

.tour-wrap .tour-info .map a i {
    display: inline-block;
    font-size: 0.8rem !important;
    color: #fff;
    margin-right: 0.3rem;
}

.tour-wrap .tour-info .map a:hover {
    background: #fff;
    color: #6db15e;
}

.tour-wrap .tour-info .map a:hover i {
    color: #6db15e;
}

@media all and (min-width: 1025px) and (max-width: 1300px) {
    .tour-wrap .tour-photo img {
        width: 100%;
    }

    .tour-wrap .tour-info .item {
        padding: 1.5em 1.8rem 0rem;
        min-height: 170px;
    }

    .tour-wrap .tour-info .item .icon-box {
        bottom: 0.8rem;
        right: 1rem;
    }

    .tour-wrap .tour-info .item .icon-box img {
        width: 55px;
    }

    .tour-wrap .tour-info .item p + p {
        font-size: 1rem;
    }

    .tour-wrap .tour-info .tell {
        font-size: 1.3rem !important;
    }

    .tour-wrap .tour-info .link a {
        font-size: 0.9rem !important;
    }
}

@media all and (min-width: 768px) and (max-width: 1024px) {
    .tour-wrap .tour-photo img {
        width: 100%;
    }

    .tour-wrap .tour-cont .img-box img {
        width: 250px;
    }

    .tour-wrap .tour-cont .tour-title-box h3 {
        font-size: 2.3rem;
    }

    .tour-wrap .tour-cont p {
        font-size: 1rem;
    }

    .tour-wrap .tour-info .item {
        min-height: 140px;
        margin-bottom: 1rem;
    }

    .col-t {
        width: 50%;
    }
}

@media screen and (max-width: 767px) {
    .tour-wrap {
        margin-bottom: 3rem;
    }

    .tour-wrap .tour-photo img {
        width: 100%;
        height: 200px;
    }

    .tour-wrap .tour-cont {
        padding: 3rem 0 0;
        background: none;
        margin-top: 0;
        margin-bottom: 0rem;
    }

    .tour-wrap .tour-cont .tour-title-box h3 {
        font-size: 2.5rem;
        height: 100%;
    }

    .tour-wrap .tour-cont .tour-title-box h3.s-tit {
        font-size: 2rem !important;
    }

    .tour-wrap .tour-cont .img-box {
        top: -10px;
        right: 0;
    }

    .tour-wrap .tour-cont .img-box img {
        width: 120px;
    }

    .tour-wrap .tour-cont p {
        font-size: 1.4rem;
        padding-top: 1rem;
    }

    .tour-wrap .tour-cont p.pt-30 {
        padding-top: 3rem;
    }

    .tour-wrap .tour-cont .h-70 {
        height: 0px !important;
    }

    .tour-wrap .tour-cont02 p {
        font-size: 1.7rem;
        padding: 2rem 0.5rem 0.5rem;
    }

    .tour-wrap .tour-cont02 p.text-box {
        font-size: 1.4rem;
        padding: 0 0.5rem;
    }

    .tour-wrap .tour-etc img {
        margin-bottom: 1rem;
    }

    .tour-wrap .tour-info {
        margin-top: 3rem
    }

    .tour-wrap .tour-info .item {
        padding: 2.5em 2.5rem 1.5rem;
        min-height: 130px;
        margin-bottom: 1rem;
    }

    .tour-wrap .tour-info .item .icon-box {
        bottom: 1.5rem;
        right: 1.5rem;
    }

    .tour-wrap .tour-info .item .icon-box img {
        width: 50px;
    }

    .tour-wrap .tour-info .item p, .tour-wrap .tour-info .item p + p, .tour-wrap .tour-info .tell {
        font-size: 1.5rem !important;
    }

    .tour-wrap .tour-info .link a {
        font-size: 1.4rem !important;
    }

    .tour-wrap .tour-info .map a {
        padding: 0rem 0.7rem 0.1rem;
        font-size: 1.2rem !important;
    }
}

.program-photo {
    width: 90%;
    margin: 4rem auto 6rem;
}

.program-photo .thumb {
    margin-bottom: 1.4rem;
}

.program-photo .thumb img {
    width: 100%;
    border-radius: 1.5rem;
}

.reserve-slide {
    width: 1100px;
    margin: 0 auto 6rem;
    padding: 0 4rem;
}

.reserve-slide img {
    width: 100%;
    height: 600px;
    border-radius: 1rem;
}

.reserve-slide .swiper-button-prev:after, .reserve-slide .swiper-button-next:after {
    font-family: bootstrap-icons !important;
    font-size: 2.8rem;
    text-transform: none!important;
    letter-spacing: 0;
    font-variant: initial;
    line-height: 1;
    color: #a1a1a1 !important;
}

.reserve-slide .swiper-button-prev:after {
    left: 0;
    content: "\F129";
}

.reserve-slide .swiper-button-next:after {
    right: 0;
    content: "\F133";
}

.reserve-slide .swiper-button-prev, .reserve-slide .swiper-button-next {
    top: 50% !important;
}

.reserve-slide .swiper-button-prev {
    left: 1%;
}

.reserve-slide .swiper-button-next {
    right: 1%;
}

@media all and (min-width: 1025px) and (max-width: 1279px) {
    .reserve-slide .swiper-button-prev {
        left: 40%;
    }

    .reserve-slide .swiper-button-next {
        right: 40%;
    }
}

@media all and (min-width: 768px) and (max-width: 1200px) {
    .program-photo {
        width: 100%;
        margin: 4rem auto 3rem;
    }

    .reserve-slide {
        width: 100%;
        margin: 0 auto 3rem;
        padding: 0 0 5rem 0;
    }

    .reserve-slide .swiper-button-prev {
        left: 2%;
    }

    .reserve-slide .swiper-button-next {
        right: 2%;
    }
}

@media screen and (max-width: 767px) {
    .program-photo {
        width: 100%;
        margin: 4rem auto 3rem;
    }

    .reserve-slide {
        width: 100%;
        margin: 0 auto 3rem;
        padding: 0 0 5rem 0;
    }

    .reserve-slide img {
        height: auto;
    }

    .reserve-slide .swiper-button-prev, .reserve-slide .swiper-button-next {
        top: 90% !important;
    }

    .reserve-slide .swiper-button-prev {
        left: 37%;
    }

    .reserve-slide .swiper-button-next {
        right: 37%;
    }
}

.tbl-top {
    width: 90%;
    margin: 0 auto;
    border-top: solid 2px #555;
}

.tbl-charge {
    width: 100% !important;
    border-top: solid 1px #555 !important;
    margin-top: 1rem;
}

.tbl-top thead th {
    padding: 0.7rem;
    background: #F8F8F8;
    font-size: 1rem;
    font-weight: 800;
    border-bottom: solid 1px #e5e5e5;
    border-right: solid 1px #e5e5e5;
    text-align: center;
}

.tbl-top tbody td {
    padding: 0.7rem;
    background: #fff;
    border-bottom: solid 1px #e5e5e5;
    border-right: solid 1px #e5e5e5;
    font-size: 0.95rem;
    font-weight: 600;
    color: #333;
    line-height: 1.4em;
    text-align: center;
    letter-spacing: -0.03em;
}

.tbl-charge th {
    padding: 0.4rem !important;
    font-size: 0.9rem !important;
    border-right: none !important;
}

.tbl-charge tbody td {
    padding: 0.5rem !important;
    font-size: 0.9rem !important;
}

.tbl-top .bdr-none {
    border-right: none !important;
}

.tbl-top tbody td.price {
    font-weight: 700;
    font-size: 1.1rem;
}

.tbl-charge tbody td.price {
    font-size: 0.9rem !important;
    font-weight: 400 !important;
}

.tbl-top tbody td.price span {
    font-family: 'Play', sans-serif !important;
    font-weight: 700;
    color: #333;
}

.tbl-top tbody td .mobile {
    font-family: 'Play', sans-serif !important;
    font-weight: 700;
    color: #333;
    font-size: 1.1rem;
}

.tbl-top tbody td .mobile i {
    display: inline-block;
    margin-right: 0.5rem;
}

.tbl-top tbody td.price span.weekend {
    color: #c51c21;
}

.tbl-top tbody td.type {
    background: #fafbff;
}

@media all and (max-width: 990px) {
    .div-tbl { overflow-x: scroll; padding-bottom: 10px;}
    .div-tbl::-webkit-scrollbar-track { border-radius: 10px; background-color: #ddd;}
	.div-tbl::-webkit-scrollbar { height: 7px; background: #f5f5f5;}
	.div-tbl::-webkit-scrollbar-thumb { border-radius: 10px; -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.3); background: #555;}
    .div-tbl .tbl-top { width: 990px;}

}

@media all and (min-width: 768px) and (max-width: 1024px) {
    .tbl-top {
        width: 95%;
    }
}

@media all and (max-width: 767px) {
    .tbl-top {
        width: 100%;
    }

    .tbl-top thead th, .tbl-top tbody td, .tbl-top tbody td.price, .tbl-charge tbody td.price {
        font-size: 1.2rem !important;
    }

    .tbl-charge th, .tbl-charge tbody td {
        font-size: 1.15rem !important;
        padding: 0.7rem 0 !important;
    }
}

.guide-wrap {
    position: relative;
    width: 100%;
}

.guide-wrap .guide-cont {
    padding: 5rem 0 3rem;
    background: #f3f3f3;
	width: 100vw;
	margin-left: calc(-50vw + 50%);
}

.guide-wrap .guide-cont .h-280 {
    min-height: 280px !important;
}

.guide-wrap .guide-cont .item-box {
    position: relative;
    display: flex;
    min-height: 190px;
    border-radius: 20px;
    background-color: #fff;
    padding: 2rem 2.5rem;
    margin-bottom: 2rem;
}

.guide-wrap .guide-cont .item-box .icon {
    position: absolute;
    width: 6rem;
    height: 6rem;
    border-radius: 50%;
}

.guide-wrap .guide-cont .item-box .icon i {
    font-size: 2.7rem;
    color: #fff !important;
}

.bg-yellow {
    background: #ffc62e !important;
}

.bg-light-red {
    background: #fe5357 !important;
}

.bg-light-green {
    background: #37b562 !important;
}

.guide-wrap .guide-cont .item-box .item-cont {
    margin: 1.1rem 0 0 8rem;
    width: 100%;
}

.guide-wrap .guide-cont .item-box .item-cont h4 {
    font-size: 1.3rem;
    font-weight: 700;
}

.guide-wrap .guide-cont .item-box .item-cont p.tell {
    font-family: 'Play', sans-serif !important;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: -0.03em;
    color: #646464;
}

.guide-wrap .guide-cont .item-box .item-cont p.add {
    font-size: 1.4rem;
    font-weight: 600;
    color: #646464;
    padding-top: 0.5rem;
    letter-spacing: -0.05em;
}


@media all and (min-width: 1025px) and (max-width: 1400px) {
    .guide-wrap .guide-cont {
        padding: 3rem 2rem 1rem;
    }

    .guide-wrap .guide-cont .item-box {
        min-height: 170px;
    }

    .guide-wrap .guide-cont .item-box .item-cont p.add {
        font-size: 1.2rem;
    }
}

@media all and (min-width: 768px) and (max-width: 1024px) {
    .guide-wrap .guide-cont {
        padding: 3rem 2rem 3rem;
    }

    .guide-wrap .guide-cont .item-box {
        min-height: 140px;
    }

    .guide-wrap .guide-cont .item-box .icon {
        width: 5rem;
        height: 5rem;
    }

    .guide-wrap .guide-cont .item-box .icon i {
        font-size: 2rem;
    }

    .guide-wrap .guide-cont .item-box .item-cont {
        margin: 0.5rem 0 0 8rem;
    }
}

@media all and (max-width: 767px) {
    .guide-wrap .guide-cont {
        padding: 3rem 2rem 3rem;
    }

    .guide-wrap .guide-cont .item-box {
        min-height: 130px;
        padding: 1.5rem 2rem;
    }

    .guide-wrap .guide-cont .h-280 {
        min-height: 200px !important;
    }

    .guide-wrap .guide-cont .item-box .icon {
        width: 4.5rem;
        height: 4.5rem;
    }

    .guide-wrap .guide-cont .item-box .icon i {
        font-size: 2rem;
    }

    .guide-wrap .guide-cont .item-box .item-cont {
        margin: 0.7rem 0 0 7rem;
    }

    .guide-wrap .guide-cont .item-box .item-cont h4 {
        font-size: 1.5rem;
    }
}

.privacy-box {
    width: 85%;
    margin: 0 auto 8rem
}

.privacy-anchor-box {
    padding: 2.5rem 3.5rem;
    background: #fafafa;
    text-align: left;
    font-size: 1rem;
    line-height: 1.7;
    box-sizing: border-box;
    overflow: hidden
}

.privacy-anchor-box strong {
    font-weight: 700
}

.privacy-terms-content {
    padding: 0 2rem
}

.privacy-terms-content h3 {
    padding: 60px 0 20px;
    font-size: 1.3rem;
    font-weight: 700;
    color: #111
}

.privacy-terms-content p {
    font-size: 0.95rem;
    color: #444;
    line-height: 1.7em
}

.privacy-terms-content p.align-center {
    width: 80%;
    margin: 0 auto
}

.privacy-terms-content .bu-list {
    padding-top: 15px
}

.privacy-terms-content .bu-list>li {
    position: relative;
    margin-left: 1rem;
    font-size: 0.95rem;
    color: #333;
    line-height: 1.5rem;
    list-style: none;
    padding-bottom: 0.7rem
}

.privacy-terms-content .bu-list>li:before {
    content: '-';
    position: absolute;
    margin-left: -1rem;
    font-size: 1.5rem;
    color: #333;
    font-weight: 200
}

.privacy-terms-content .bu-list>li ul li {
    position: relative;
    margin-left: 0.8rem;
    font-size: 0.9rem;
    color: #333;
    line-height: 1.5rem;
    list-style: none;
    padding-top: 0.4rem
}

.privacy-terms-content .bu-list>li ul li:before {
    content: 'ㆍ';
    position: absolute;
    margin-left: -0.8rem;
    font-size: 0.9rem;
    color: #333
}

.privacy-terms-content hr {
    margin-top: 50px;
    border-top: solid 1px #dbdbdb;
    position: static;
    width: 100%;
    visibility: visible
}

@media all and (max-width: 767px) {
    .privacy-box {
        width: 100%;
        margin: 2rem auto 4rem;
    }

    .privacy-anchor-box {
        padding: 2em 1.5rem;
        font-size: 1.2rem;
    }

    .privacy-terms-content {
        padding: 0 1rem;
    }

    .privacy-terms-content h3 {
        padding: 40px 0 20px;
        font-size: 1.6rem;
    }

    .privacy-terms-content p, .privacy-terms-content .bu-list>li, .privacy-terms-content .bu-list>li ul li {
        font-size: 1.3rem;
        line-height: 2rem;
    }
}

.foot-cont {
    background-color: #333;
    padding: 3rem 0;
}

.foot-cont .foot-logo img {
    width: 230px;
    padding-top: 1rem
}

.foot-cont .etc-menu {
    margin-top: 1rem;
}

.foot-cont .etc-menu li {
    display: inline;
    font-size: 1rem;
    font-weight: 700;
}

.foot-cont .etc-menu li a {
    color: #d7d7d7;
}

.foot-cont .etc-menu li a:hover {
    color: #d5191c;
}

.foot-cont .etc-menu .btn-modal {
    background: transparent;
    font-size: 1rem;
    font-weight: 700;
    color: #d7d7d7;
    padding: 0 0 0.1rem !important;
    border: 0 !important;
}

.foot-cont .bdr-bot {
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid #474747;
}

.foot-cont .biz-info li {
    font-size: 0.8rem;
    color: #bcbcbc !important;
    padding-bottom: 0.4rem;
}

.foot-cont .biz-info li span {
    display: inline-block;
    padding-right: 0.5rem;
    color: #848484 !important;
    font-weight: 700;
}

.foot-cont .copy-txt {
    font-family: 'Play', sans-serif !important;
    font-size: 0.8rem;
    color: #bcbcbc !important;
    padding-top: 0.8rem;
}

.custom-modal {
    max-width: 650px !important
}

.custom-modal .h-500 {
    max-height: 540px !important
}

.custom-modal h5 {
    font-size: 1.4rem;
    font-weight: 600;
    letter-spacing: -0.05em;
}

.custom-modal .con-style p {
    padding-bottom: 20px;
    font-size: 1rem;
    color: #333;
    line-height: 1.5em;
}

.custom-modal .con-style img {
    width: 70%;
}

@media all and (min-width: 768px) and (max-width: 1024) {
    .foot-cont .etc-menu li {
        font-size: 0.8rem;
    }
    .btn-modal {
        font-size: 0.8rem !important;
    }

    .foot-cont .biz-tell li {
        font-size: 0.8rem;
    }
}

@media all and (max-width: 767px) {
    .foot-cont {
        padding: 1rem 0rem 3rem;
    }

    .foot-cont .etc-menu li, .btn-modal {
        font-size: 1.2rem !important;
    }

    .foot-cont .biz-info li, .foot-cont .copy-txt {
        font-size: 1rem;
    }

    .foot-cont .foot-logo {
        text-align: left !important;
    }

    .foot-cont .foot-logo img {
        width: 100px;
        padding-top: 1rem
    }
}

.text-yellow {
    color: #eab526;
}

.text-blue {
    color: #23529a;
}

.text-red {
    color: #c31b1f;
}

.text-green {
    color: #187b3a;
}

.btn-top {
    position: fixed;
    z-index: 999;
    right: 1.5rem;
    bottom: 5%;
}

.btn-top button {
    border: 0 !important;
    background: none !important;

}

.btn-top button i  {
    color: rgba(134, 134, 134, 0.5) !important;
    font-size: 3rem;
}

.btn-effect {
    text-transform: uppercase;
    transition: all 0.4s;
    -webkit-transition: all 0.4s;
    -moz-transition: all 0.4s;
}

.animate {
    animation-duration: 0.3s;
    -webkit-animation-duration: 0.3s;
    animation-fill-mode: both;
    -webkit-animation-fill-mode: both;
}

.slideIn {
    -webkit-animation-name: slideIn;
    animation-name: slideIn;
}

.scrollright {
    -webkit-animation-name: scrollright;
    animation-name: scrollright;
}

@media all and (max-width: 767px) {
    .btn-top {
        bottom: 3%;
    }
}

@keyframes slideIn {
    0% {
        transform: translateY(1rem);
        opacity: 0;
    }

    100% {
        transform: translateY(0rem);
        opacity: 1;
    }

    0% {
        transform: translateY(1rem);
        opacity: 0;
    }
}

@-webkit-keyframes slideIn {
    0% {
        -webkit-transform: transform;
        -webkit-opacity: 0;
    }

    100% {
        -webkit-transform: translateY(0);
        -webkit-opacity: 1;
    }

    0% {
        -webkit-transform: translateY(1rem);
        -webkit-opacity: 0;
    }
}

@keyframes slideDown {
    0% {
        transform:translateY(-100%);
    }
    100% {
        transform:translateY(0);
    }
}

@-webkit-keyframes slideDown {
    0% {
        transform:translateY(-100%);
    }
    100% {
        transform:translateY(0);
    }
}

@-moz-keyframes slideDown {
    0% {
        transform:translateY(-100%);
    }
    100% {
        transform:translateY(0);
    }
}

@-ms-keyframes slideDown {
    0% {
        transform:translateY(-100%);
    }
    100% {
        transform:translateY(0);
    }
}

@-o-keyframes slideDown {
    0% {
        transform:translateY(-100%);
    }
    100% {
        transform:translateY(0);
    }
}