/*
Theme Name: M8 Latest
*/

body {
    margin: 0;
}

* {
    box-sizing: border-box;
}

body {
    font-family: 'Roboto', 'Helvetica', 'Arial', 'sans-serif';
    line-height: 1.8;
}

.hide {
    display: none;
}

body.tc {
    font-family:  'Roboto', 'Helvetica','Noto Sans TC', 'PingFang TC', 'Microsoft JHengHei', 'Arial', 'sans-serif', 'PMingLiU';
}

body.sc {
    font-family: 'Roboto', 'Helvetica', 'Noto Sans SC', 'PingFang SC', 'Microsoft YaHei', 'Arial', 'sans-serif', 'PMingLiU';
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: 400;
    font-size: 100%;
    line-height: 1.375;
}

h1 {

    font-weight: 300;
}

img {}

a {
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

.cta-btn {
    display: inline-block;
    padding: 0.4em 1.2em;
    border: 1px solid var(--c-gold);
    cursor: pointer;
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
    color: var(--c-gold);
}

.cta-btn:hover {
    background-color: var(--c-gold-50);
    text-decoration: none;
}



.dark-overlay {
    position: fixed;
    z-index: 99;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    display: none;
    background-color: var(--c-gold-light);
    opacity: 0.9;

}

.popup-container {
    position: fixed;
    z-index: 100;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    display: none;

}

.popup-container>.close {
    display: block;
    width: 2em;
    height: 2em;
    background-image: url(images/nav-toggle_close_white.svg);
    background-repeat: no-repeat;
    background-size: 1.25em;
    background-position: center;
    cursor: pointer;
    margin: 0;
    position: absolute;
    top: -2.5em;
    right: -0.5em;
    z-index: 999;
}

.popup {
    background: #fff;
    clear: both;
    overflow-y: auto;

    transition-duration: 0.4s;
    transition-timing-function: ease-out;
    padding: 1em;

}






.ui-selectmenu-button {
    outline: none;
    border: 1px solid var(--c-gold);
    color: var(--c-gold);
    background: none;
    padding: 0.5em 1em;
    cursor: pointer;
    text-align: left;
    position: relative;
}

.ui-selectmenu-button:after {
    content: '';
    background-image: url(images/swiper_arrow_gold.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    width: 1em;
    height: 1em;
    transform: rotate(90deg);
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
    position: absolute;
    top: 50%;
    right: 1em;
    margin-top: -0.5em;
}

.ui-selectmenu-text {
    margin-right: 1.5em;
}

.ui-selectmenu-button:hover {

    background-color: var(--c-gold-50);
}

.ui-selectmenu-button[aria-expanded="true"]:after {
    transform: rotate(270deg);
}

.ui-selectmenu-menu {
    border: 1px solid var(--c-gold);
    border-radius: 0;
    margin: -1px 0 0 0;
    padding: 0;
    box-sizing: border-box;
    background-color: var(--c-grey-light);
}

.ui-menu-item-wrapper {
    color: var(--c-gold) !important;

    padding: 0.5em 1em;
    cursor: pointer;
}

/*
    .ui-menu-item-wrapper.ui-state-active {
        opacity: 0.5;
        background-color: var(--c-gold-50);
    }*/

.ui-menu-item-wrapper.ui-state-active {
    background-color: var(--c-gold-50);
    color: var(--c-gold) !important;
}

.ui-menu-item-wrapper:active {
    background-color: var(--c-gold);
    color: #fff !important;
}

/*
    .pagetitle {
        position: absolute;
        clip: rect(1px, 1px, 1px, 1px);
        clip-path: inset(0px 0px 99.9% 99.9%);
        overflow: hidden;
        height: 1px;
        width: 1px;
        padding: 0;
        border: 0;
    }
    */
:root {
    --c-gold: rgba(136, 113, 87, 1);
    --c-gold-50: rgba(136, 113, 87, 0.5);
    --c-gold-37: rgba(136, 113, 87, 0.37);
    --c-gold-light: rgba(202, 196, 184, 1);
    --c-green: rgba(39, 69, 54, 1);
    --c-txt: rgba(0, 0, 0, 1);
    --c-grey-light: rgba(248, 248, 247, 1);
    --space-v: 5em;
    --space-h: 5vw;

}

@media screen and (min-width:90em) {
    :root {
        --space-v: 5vw;
    }
}

main {
    width: 100%;
    overflow-x: hidden;
    overflow-y: hidden;
}

.home .award .headline,
.content-wrap {
    padding: 0 5vw;
    max-width: 108em;
    margin: auto;
    
}

header {
    background-color: var(--c-gold-50);
    border-bottom: 1px solid #fff;
    position: fixed;
    top: -150%;
    left: 0;
    width: 100%;
    z-index: 10;
    line-height: 1;
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
}

header.appear {
    top: 0;

}

header.white {

    background-color: rgba(255, 255, 255, 1);
    border: none;
}

body.nav-on {
    overflow: hidden;
}

.nav-on header {
    border: none;

    background: none;
}

.a-item {
    transition-duration: 0.8s;
    transition-timing-function: ease-out;
    opacity: 0;
}

.a-item.a-zoom-out {
    transform: scale(1.1);
}

.a-item.a-bottom-top {
    transform: translate(0, 50%);
}

.a-item.a-left-right {
    transform: translate(-100%, 0);
}

.a-item.a-right-left {
    transform: translate(100%, 0);
}

.a-full {
    opacity: 1 !important;
    transform: scale(1) translate(0%, 0%) !important;

}

.a-done {
    transition-delay: 0s !important;
}

header,
header a {
    color: #fff;
}

header.white,
header.white a {
    color: var(--c-gold);
}

header .brand {
    text-align: center;
}

header .brand a {
    background-image: url(images/logo_white.svg);
    background-size: 85%;
    background-position: center;
    background-repeat: no-repeat;
    width: 6em;
    height: 6em;
    display: inline-block;
    text-indent: -99999em;
    text-align: left;
}


.nav-on header .brand a {
    background-image: url(images/logo_gold.svg);
}

header.white .brand a {
    background-image: url(images/logo_gold.svg);
}

header .navs .content-wrap {
    position: relative;
}

header nav {
    right: 5vw;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    align-items: center;
}

header .nav-toggle {
    padding: 1.25em;
    margin-right: -1.25em;
    cursor: pointer;
}

header .nav-toggle:before {
    content: '';
    width: 1.5em;
    background-image: url(images/nav-toggle_white.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    display: block;
    height: 1.5em;
}

header.white .nav-toggle:before {
    background-image: url(images/nav-toggle_gold.svg);
}

.nav-on header .nav-toggle:before {
    background-image: url(images/nav-toggle_close_white.svg);
}

.nav-on header.white .nav-toggle:before {
    background-image: url(images/nav-toggle_close_gold.svg);
}

header .language-chooser {
    border-right: 1px solid #fff;
    display: flex;
    margin: 0;
    padding: 0;
    align-items: center;
    padding: 0 0.5em;

}

header.white .language-chooser {
    border-right: 1px solid var(--c-gold);
}

header .language-chooser li {
    list-style: none;
}

header .language-chooser li a {
    display: block;
    text-decoration: none;
    padding: 0.5em;
}

header .language-chooser li.active {
    display: none;
}

header .notice,
header .breadcrumb {
    border-top: 1px solid #fff;
}

header.white .notice,
header.white .breadcrumb {
    border-top: 1px solid var(--c-gold);
}

.nav-on header .notice,
.nav-on header .breadcrumb {
    display: none;
}

header .notice .swiper {
    position: relative;
    width: 100%;
    overflow: hidden;
}

header .notice .swiper-wrapper {
    -webkit-transition-timing-function: linear !important;
    -o-transition-timing-function: linear !important;
    transition-timing-function: linear !important;
}

header .notice .swiper-slide {
    width: auto;
    height: 100%;
    padding: 0.5em 5vw;
}


header .notice .swiper-slide {}

header .breadcrumb {}

header .breadcrumb a.back {
    text-decoration: none;
    padding: 0.5em 0;
    display: block;
}

header .breadcrumb a.back:before {
    content: '';
    width: 1em;
    height: 1em;
    display: inline-block;
    vertical-align: middle;
    background-image: url(images/swiper_arrow_white.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    transform: rotate(180deg);
    margin-right: 0.25em;
}

header.white .breadcrumb a.back:before {
    background-image: url(images/swiper_arrow_gold.svg);
}

nav.main {
    position: fixed;
    z-index: 9;
    top: -200%;
    left: 0;
    width: 100%;
    height: 100%;
    color: #fff;
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
    padding-top: 8.5em;
    box-sizing: border-box;
    background-color: var(--c-green);
    background-image: url(images/bg_nav.jpg);
    background-repeat: repeat;
    background-position: center;
}

/*
    @media screen and (min-width:48em) {
      nav.main:before {
        content:'';
        background-image: url(images/nav_deco.png);
        background-size: contain;
        background-position: bottom center;
        background-repeat: no-repeat;
        position: absolute;
        bottom:0;
        left:50%;
        right:0;
        height:50%;
        width:30%;
        transform:translateX(-50%);
      }  
    }*/
.nav-on nav.main {
    top: 0;
}


nav.main a {
    color: #fff;
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
}

footer nav.primary a:hover,
footer nav.primary .current_page_parent>a,
footer nav.primary .current-menu-item>a,
nav.main a:hover,
nav.main .current_page_parent>a,
nav.main .current-menu-item>a {
    color: var(--c-gold);
}

nav.main .menu-primary-container {
    padding: 0 5vw;
    margin: 0 auto;
    max-width: 88em;
}

nav.main .primary {
    position: relative;
    margin: 0;
    padding: 0;
}

nav.main .primary li {
    list-style: none;
}

nav.main .primary>li>a {
    font-size: 2.5em;
    font-weight: 300;
    text-decoration: none;
    line-height: 1.5;
}

@media screen and (min-width:48em) {

    nav.main .primary>li>a {
        font-size: 3.75em;
    }

}


nav.main .primary .sub-menu {
    position: absolute;
    top: 0;
    left: 12em;
    margin: 0;
    padding: 0;
    bottom: 0;
}

body.en nav.main .primary .sub-menu {
    left: 16em;
}

nav.main .primary .sub-menu>li {}

nav.main .primary .sub-menu>li>a {
    font-size: 1.25em;
    text-decoration: none;
}

@media screen and (min-width:48em) {


    nav.main .primary .sub-menu {
        left: 18em;
    }


    body.en nav.main .primary .sub-menu {
        left: 24em;
    }

    nav.main .primary .sub-menu>li>a {
        font-size: 1.875em;
        text-decoration: none;

        font-weight: 300;
    }



}

nav.main .info-social-wrap {
    position: absolute;
    bottom: 3.5em;
    left: 0;
    width: 100%;
}

nav.main .company-info {
    display: none;
}


@media screen and (min-width:48em) {

    nav.main .company-info {
        display: block;
        margin: 4em 0;
        display: flex;
        flex-direction: column;
        gap: 2em;
    }

    nav.main .company-info .value {
        font-size: 0.75em;
        margin-top: 0.5em;
    }

}

nav.main .social {

    display: flex;
    justify-content: center;
    gap: 1em;
    margin: 0;
    padding: 0;
}


@media screen and (min-width:48em) {

    nav.main .info-social-wrap {

        padding: 0 5vw;
        width: AUTO;
        left: auto;
        right: 0;
    }

    nav.main .social {

        justify-content: end;
        gap: 2em;
    }

}

nav.main .social li {
    list-style: none;
    ;
}

nav.main .social li a {
    display: block;
    width: 3.125em;
    height: 3.125em;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    text-align: left;
    text-indent: -99999em;
}


nav.main .social li.fb a {

    background-image: url(images/social_icon_fb_gold.svg);
}

nav.main .social li.ig a {

    background-image: url(images/social_icon_ig_gold.svg);
}

nav.main .social li.wechat a {
    background-image: url(images/social_icon_wechat_gold.svg);
}

nav.main .social li.weibo a {
    background-image: url(images/social_icon_weibo_gold.svg);
}

nav.main .social li.xhs a {
    background-image: url(images/social_icon_xhs_gold.svg);
}

footer {
    padding: 4em 0;
    color: #fff;
    background-color: var(--c-green);
    background-image: url(images/bg_nav.jpg);
    background-repeat: repeat;
    background-position: center;
}

footer a {
    color: #fff;
    text-decoration: none;
}

footer .brand-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 1em;
}

footer .brand a {
    background-image: url(images/logo_gold.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    width: 10.24em;
    height: 6.25em;
    display: block;
    text-indent: -99999em;
    text-align: left;
}

footer .nav-wrap {

    display: flex;
    padding: 10em 0 4em 0;
    justify-content: space-between;
    align-items: end;
    position: relative;
    margin-top: 2em;
    flex-direction: column;
    gap: 5em;
}

footer .nav-wrap .primary {

    width: 100%;
}


@media screen and (min-width:48em) {
    footer .slogan-social-wrap {
        display: flex;
        flex-direction: column;
        /* justify-content: end; */
        align-items: end;
    }
}

footer .slogan {
    width: 100%;
    height: 4.75em;
    display: block;
    text-indent: -99999em;
    text-align: left;

    background-image: url(images/slogan_gold.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;

    position: absolute;
    top: 0;
    right: 0;
}

footer .slogan-social-wrap {
    width: 100%;
}

footer nav ul {
    margin: 0;
    padding: 0;
}

footer nav ul li {
    list-style: none;
}

footer nav ul li .sub-menu {
    display: none;
}

footer nav.social ul {

    display: flex;

    justify-content: space-between;
}

@media screen and (min-width:48em) {
    footer nav.social ul {


        gap: 1.5em;
        flex-wrap: nowrap;
    }

}

footer nav.social ul li a {
    display: block;
    width: 3.125em;
    height: 3.125em;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    text-align: left;
    text-indent: -99999em;
}


footer nav.social ul li.fb a {

    background-image: url(images/social_icon_fb_gold.svg);
}

footer nav.social ul li.ig a {

    background-image: url(images/social_icon_ig_gold.svg);
}

footer nav.social ul li.wechat a {
    background-image: url(images/social_icon_wechat_gold.svg);
}

footer nav.social ul li.weibo a {
    background-image: url(images/social_icon_weibo_gold.svg);
}

footer nav.social ul li.xhs a {
    background-image: url(images/social_icon_xhs_gold.svg);
}



footer nav.policy {
    margin: 1.5em 0;
}

footer nav.policy ul {
    display: flex;
    justify-content: center;
    gap: 1em;
}

footer nav.policy ul li a {
    font-size: 0.75em;
}

footer .copyright {
    text-align: center;
    font-size: 0.75em;
}

@media screen and (min-width:48em) {
    footer .brand-nav-wrap {

        display: flex;
        align-items: stretch;
        justify-content: space-between;
    }

    footer .brand {
        margin-right: 5vw;
    }

    /*
        footer .brand a{
            width:17.3125em;
            height:10.5625em;
        }
            */
    footer .nav-wrap {

        padding: 0;
        width: 100%;
        align-items: start;
        margin: 0;

        flex-direction: row;
        gap: 1em;
    }

    footer .slogan {
        transform: none;
        width: 14em;
        position: relative;
        top: auto;
        right: auto;
    }

    footer .policy-wrap {
        display: flex;
        align-items: center;
        justify-content: space-between;
        flex-direction: row-reverse;
        margin-top: 2em;
    }

    footer nav.policy {
        margin: 0;
    }

    footer nav.social {
        margin-top: 2.8em;
    }
}

main section.listing.ajax {
    padding-top: 0;
}

main section {
    margin-bottom: var(--space-v);
}

/*
    main section.cover {
        margin-bottom:5em;
    }
    
    .home main section.cover {
        margin-bottom:0;
    }*/

.headline {
    color: var(--c-gold);

    line-height: 1;

}

.headline h2 {
    margin: 0;
    font-weight: 300;
}

.headline h2,
.txt-wrap .title {
    font-size: 1.875em;
    line-height: 1.25;
}

.intro {
    color: var(--c-gold);
    text-align: center;
    padding: var(--space-v) 0;
    margin-top: calc(1px - var(--space-v));
}

.home .intro,
.page.about .intro ,
.page.membership .intro {
    background-color: var(--c-grey-light);
    background-image: url(images/bg_intro.jpg);
    background-repeat: repeat;
    background-position: center;
}

.intro .content-wrap {
    max-width: 60em;
    margin: auto;
}

.intro .headline {
    margin: 2em auto;
}

.headline h2 {
    font-size: 2.5em;
}

@media screen and (min-width:48em) {
    .intro .headline h2 {

        font-size: 3.75em;
    }
}

.intro .content {
    font-size: 1.25em;

}

.intro .content p {
    margin: 2em auto;
}

.intro .cta {
    margin: 2em auto;
}

/*
    @media screen and (min-width:48em) {
        .home .intro {
            position: relative;
        }
        .home .intro:before {
            content:'';
            width:28vw;
            max-width:28em;
            height:29.5em;
            display: block;
            background-image: url(images/brand_deco.png);
            background-size:contain;
            background-position: bottom left;
            background-repeat: no-repeat;
            position: absolute;
            bottom:0;
            right:0;
            transform:rotateY(180deg);
        }
    }
    
    */
.cover {
    position: relative;
    overflow: hidden;
}

.cover figure {
    width: 100%;
    margin: 0;
    padding-bottom: 160%;
    z-index: 1;
    position: relative;
}
@media screen and (min-width:48em) {
.cover figure {
padding-bottom:50%;
}
}

.single-news .cover figure {
    padding-bottom: 50%;
}

.home .cover figure {
    padding-bottom: 100dvh;
}

.cover img {
    width: 100%;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    object-fit: cover;
}

.cover .swiper-container {
    position: relative;
}

.cover .swiper-container .swiper-nav {
    position: absolute;
    bottom: 1em;
    right: 1em;
    z-index: 2;
}

@media screen and (min-width:48em) {
    .cover .swiper-container .swiper-nav {

        bottom: 2em;
        right: 2em;

    }

}

.cover .swiper-container .swiper-arrows>div {
    border: 1px solid #fff;
    background-color: var(--c-gold-50);
}

.cover .swiper-container .swiper-arrows>div:before {
    background-image: url(images/swiper_arrow_white.svg);
}

.cover .swiper-container .swiper-arrows>div:hover {

    background-color: var(--c-gold);
}

.cover .swiper-container .swiper-pagination {
    color: #fff;
    text-align: right;
    position: relative;
    bottom: auto;
    top: auto;
    left: auto;
    margin-bottom: 1em;
    line-height: 1;
}

.cover .page-title {
    background-color: var(--c-gold-50);
    padding: 1em 1em 1em 5vw;
    z-index: 2;
    position: absolute;
    top: 15em;
    left: 0;
}

.cover .page-title h1 {
    font-size: 2.5em;
    color: #fff;
    margin: 0;
    line-height: 1;
    font-weight: 300;
}


@media screen and (min-width:48em) {
    .cover .page-title h1 {
        font-size: 3.75em;
    }
}

/*
    .about .intro,
    .home .intro {
        background-image: url(images/bg_grey.jpg);
        background-size:cover;
        background-repeat: no-repeat;
    }
    */
.about-nav ul {
    margin: 0;
    padding: 0;
    display: grid;
    gap: 1.5em;

    grid-template-columns: repeat(1, 1fr);
}

@media screen and (min-width:48em) {
    .about-nav ul {
        gap: 1.875em;
        grid-template-columns: repeat(2, 1fr);
    }
}

.about-nav ul li {
    list-style: none;
    position: relative;
}

.about-nav ul li a {
    color: #fff;
    text-decoration: none;
}

.about-nav ul li figure {
    position: relative;
    width: 100%;
    padding-bottom: 70%;
    margin: 0;
    background-color: #000;
    z-index: 1;
}

.about-nav ul li figure img {
    width: 100%;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    object-fit: cover;
    opacity: 0.95;
}

.about-nav ul li .txt-wrap {
    position: absolute;
    z-index: 2;
    padding: 1em;
    top: 0;
    left: 0;
}

.about-nav ul li .txt-wrap hgroup {}

.about-nav ul li .txt-wrap hgroup h3 {
    font-size: 2.5em;
    margin: 0;
    line-height: 1.25;

    font-weight: 300;
}

.home .cover .pagetitle-nav-wrap {
    position: absolute;
    top: 50%;
    left: 50%;
    /* width: 100%; */
    /* height: 100%; */
    display: flex;
    flex-direction: column;
    z-index: 2;
    justify-content: center;
    align-items: center;
    gap: 3em;
    transform: translate(-50%, -50%);
    text-align: center;
    width: 90%;
    max-width: 64em;
}

.home .cover .cover-nav {
    display: flex;
    margin: 0;
    padding: 0;
flex-wrap: wrap;
justify-content:center;
}

.home .cover .cover-nav li {
    list-style: none;
    margin: 0 -1px;
}

.home .cover .cover-nav li a {
    white-space: nowrap;
    padding: 0.4em 3.5vw;
    ;
    color: #fff;
    background-color: var(--c-gold-50);
    text-decoration: none;

    transition-duration: 0.4s;
    transition-timing-function: ease-out;
    display: block;
}

.home .cover .cover-nav li a:hover {

    background-color: var(--c-gold);
}

.home .cover .cover-nav li {
    border: 1px solid #fff;
}

.home .cover .page-title {

    position: relative;
    top: auto;
    left: auto;
    padding: 1em;
}

.home .shop-dine .headline h2 {
    display: flex;
}

.home .shop-dine .headline a {
    display: block;
    cursor: pointer;
}

.home .shop-dine .headline a:nth-child(n+2) {
    margin-left: 1em;
    padding-left: 1em;
    border-left: 1px solid var(--c-gold);
}

.home .shop-dine .headline a:not(.active) {
    opacity: 0.5;
}

.home .shop-dine .swiper-container:not(.active) {
    display: none;
}

.listing.hor .swiper-container {
    margin-top: 2em;
}


.home .award .swiper-container figure {
    background-color: var(--c-grey-light);
}



.home .award .swiper-container .swiper-slide a {
    text-decoration: none;
    color: #000;
}

.home .award .headline {
    padding: 0 5vw;
}

.home .award .swiper-container {
    background-color: var(--c-gold-37);
}

.home .award .swiper-container .swiper-slide .txt-wrap {
    padding: 10vw 5vw;
}

.home .award.listing.hor .swiper-container figure img {

    height: auto;
    object-fit: unset;
    position: relative;
    top: auto;
    left: auto;

    display: block;
}

.home .award .swiper-container .swiper-arrows {

    padding: 0 5vw 5vw 5vw;

}

.home .award .swiper-container .swiper-slide h3 {
    color: var(--c-gold);
    margin-top: 0;
}

.home .award .swiper-container .swiper-slide .item a>div {
    flex: 1;


}

.home .award .swiper-container .swiper-nav {
    padding: 0;
    margin-top: 0;
}

.home .award .swiper-container {
    border-bottom: 2px solid var(--c-green);
}


.home .award .swiper-container .swiper-slide .item .img-wrap {
    background-color: var(--c-grey-light);
}

@media screen and (min-width:48em) {
    .home .award .swiper-container .swiper-wrapper {
        align-items: stretch;
    }

    .home .award .swiper-container .swiper-wrapper .swiper-slide {

        display: flex;
        height: auto;
    }

    .home .award .swiper-container .swiper-slide .item {
        display: flex;

        align-items: stretch;
        width: 100%;
    }

    .home .award .swiper-container .swiper-slide .item>div {
        width: 50%;
        box-sizing: border-box;
    }

    .home .award.listing.hor .swiper-container figure {
        height: 100%;
    }

    .home .award.listing.hor .swiper-container figure img {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 100%;
        height: 100%;
        object-fit: contain;

    }

    .home .award .swiper-container .swiper-slide .item .txt-wrap {

        padding: 5vw 5vw calc(5vw + 4em) 5vw;

    }

    .home .award .swiper-container .swiper-slide .item figure {}

    .home .award .swiper-container .swiper-arrows {

        top: auto;
        right: auto;
        bottom: 0;
        right: 0;
        z-index: 2;
    }
}


/*
    .home .award .swiper-container .swiper-slide .txt-wrap>* {
        max-width:28em;
    } */

.m8-shops-offer .item figure a
.listing.dine .item,
.listing.shop .item,
.listing .dine .item a,
.listing .shop .item a {
    line-height: 1;
    display: block;
}


.m8-shops-offer .item figure a,
.listing.dine .item figure a,
.listing.shop .item figure a,
.listing .dine .item figure a,
.listing .shop .item figure a {
    display: block;
    width: 100%;
    position: relative;
    padding-bottom: 100%;
    margin: 0;
    border: 1px solid var(--c-gold-light);
}

.listing.dine .item figure img,
.listing.shop .item figure img,
.listing.hor .dine .item figure img,
.listing.hor .shop .item figure img {

    width: 100%;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    object-fit: contain;
}



.m8-shops-offer .item figure a img,
.listing.dine .item figure img,
.listing.shop .item figure img,
.listing.hor .dine .item figure img,
.listing.hor .shop .item figure img {
    width: 60%;
    margin: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    height: 100%;
    object-fit: contain;
    transform: translate(-50%, -50%);
}


.swiper-arrows {
    display: flex;
}

.listing .swiper-container {
    position: relative;
}

.listing.hor .swiper-nav {
    margin-top: 2em;
}

.listing.hor .swiper-arrows {
    justify-content: end;
}

@media screen and (min-width:48em) {
    .listing.hor .swiper-nav {
        margin: 0;
    }

    .listing.hor .swiper-arrows {
        position: absolute;
        top: -4.625em;
        right: 0;
    }
}


.listing .swiper-pagination {
    display: none;
}

.swiper-arrows>div {
    padding: 0.625em;
    border: 1px solid var(--c-gold);
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
    cursor: pointer;

}

.swiper-arrows>div:before {
    content: '';
    display: block;
    width: 1.25em;
    height: 1.25em;
    background-image: url(images/swiper_arrow_gold.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
}


.swiper-arrows>div:hover {
    background-color: var(--c-gold-50);
}

.swiper-arrows .swiper-prev:before {
    transform: rotate(-180deg);
}

.swiper-arrows .swiper-next {
    margin-left: -1px;
}

.swiper-button-disabled {
    opacity: 0.3;
}

.home .news .headline-typenav-wrap {
    display: flex;
    align-items: center;

    justify-content: space-between;


}

.home .news .type-nav-container.desktop {
    display: none;
}

@media screen and (min-width:48em) {
    .home .news .headline-typenav-wrap {
        justify-content: start;
    }

    .home .news .type-nav-container.mobile {
        display: none;
    }

    .home .news .type-nav-container.desktop {
        display: block;
    }
}

.home .news .type-nav-container.mobile .ui-selectmenu-button.ui-button {
    width: auto;
}

.home .news .type-nav {
    margin: 0;
    padding: 0;
    margin-left: 1.5em;
    padding-left: 1.5em;
    border-left: 1px solid var(--c-gold);
    display: flex;
    gap: 1em;
    align-items: center;
    justify-content: start;
}

.home .news .type-nav li {
    list-style: none;
    color: var(--c-gold);
    cursor: pointer;
}

.home .news .type-nav li:not(.active) {
    opacity: 0.5;
}

.home .news .swiper-container {
    margin-top: 2em;
}


.home .news .swiper-container:not(.active) {
    display: none;
}

.listing .item figure {
    position: relative;
    width: 100%;
    overflow: hidden;
    margin: 0;

}
.listing .item figure a {
    position: relative;
    width: 100%;
    overflow: hidden;
    margin: 0;display: block;
    padding-bottom: 100%;
}
/*
.listing.news .item figure,
.listing.shops-offer .item figure {
    padding-bottom: 100%;
}


.listing.shops-offer .item figure { 
    border: 1px solid var(--c-gold-light);
}
*/
.listing .item figure img {

    width: 100%;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    object-fit: cover;
}


.listing.news .item figure img {
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
}

.listing.news .item a:hover figure img {
    transform: scale(1.05);
}

.listing.news .item a {
    color: #000;
    text-decoration: none;
}
.listing.news .item a figure {
    width: 100%;
    padding-bottom: 100%;
    position: relative;
}
.listing.news .item a figure img {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.listing.news .item .title {
    font-size: 1.25em;
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
}



.listing.news .item a:hover {
    color: var(--c-gold);
}

.single-news main {
    margin-top: 10em;
}

.single-news {
    margin: 0;
    padding: 0;
}

.single-news .date {
    color: var(--c-gold-light);
    text-align: center;
}


.single-news .page-title h1 {
    font-size: 2.5em;
    color: var(--c-gold);
    text-align: center;
    margin: 0.25em auto;
}

@media screen and (min-width:48em) {

    .single-news .page-title h1 {
        font-size: 3.75em;
    }
}

.single-news .date,
.single-news .page-title {
    max-width: 48em;
    margin: auto;
}

.component.share {
    display: flex;
    gap: 0.5em;
    align-items: center;
    justify-content: end;
    margin: 2em auto;
}

.component.share,
.component.share a {
    color: var(--c-gold);
    white-space: nowrap;
}

.component.share a {
    display: block;
    text-align: left;
    text-indent: -99999em;
    width: 1.625em;
    height: 1.625em;
    background-size: contain;
    background-repeat: no-repeat;
    cursor: pointer;
}

.component.share a.fb {

    background-image: url(images/social_icon_fb_gold.svg);
}

.component.share a.wechat {

    background-image: url(images/social_icon_wechat_gold.svg);
}

.component.share a.copylink {

    background-image: url(images/social_icon_link_gold.svg);
}

.component.share a.copylink.done {
    text-indent: 0;
    background-color: var(--c-gold);
    color: #fff;
    background-image: none;
    width: auto;
    white-space: nowrap;
    line-height: 1;
    cursor: default;
    opacity: 0.5;
    padding: 0.7em 1em;
    text-decoration: none;
    font-size: 0.75em;
    border-radius: 1.5em;
    height: auto;
}

.single-news .cover {
    margin: 0 auto;
}

.single-news .intro {
    margin: 0em auto;

    padding: calc(var(--space-v) - 2em) 0;
}


.single-news section.content {
    max-width: 48em;
    margin: 0 auto var(--space-v) auto;
}


.award .listing.ver ul {
    margin: 0;
    padding: 0;
}

.award .listing.ver ul li {
    display: flex;
    align-items: start;
    gap: 2em;
    flex-direction: column;
    list-style: none;
    margin: var(--space-v) auto;
}

.award .listing.ver ul li>div {
    width: 100%;
}

@media screen and (min-width:48em) {
    .award .listing.ver ul li {

        flex-direction: row;
    }

    .award .listing.ver ul li:nth-child(2n+2) {
        flex-direction: row-reverse;
    }

    .award .listing.ver ul li>div {
        flex: 1;
        width: calc((100% - 2em) / 2);
    }

}


.award .listing.ver ul li .title {
    color: var(--c-gold);
}

.award .listing.ver ul li figure {
    width: 100%;
    padding-bottom: 62.5%;
    position: relative;
    margin: 0;
    background-color: var(--c-grey-light);
}

.award .listing.ver ul li figure img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    max-width: 100%;
    max-height: 100%;

    object-fit: contain;

}

.award .listing.ver ul li figure img {}

.single-shop .info .images .swiper-arrows>div,
.award .listing.ver .swiper-arrows>div {
    border: 1px solid #fff;
    background-color: rgba(169, 158, 142, 0.5);
    position: absolute;
    top: 50%;
    margin-top: -1.3125em;
    z-index: 2;
    cursor: pointer;

    transition-duration: 0.4s;
    transition-timing-function: ease-out;
}

.single-shop .info .images .swiper-arrows>div:hover,
.award .listing.ver .swiper-arrows>div:hover {
    background-color: var(--c-gold-50);
}

.single-shop .info .images .swiper-arrows>div:before,
.award .listing.ver .swiper-arrows>div:before {
    background-image: url(images/swiper_arrow_white.svg);
}

.single-shop .info .images .swiper-prev,
.award .listing.ver .swiper-prev {
    left: -1px;
}

.single-shop .info .images .swiper-next,
.award .listing.ver .swiper-next {
    margin: 0;
    right: -1px;
}


.award .listing.ver ul li .txt-wrap h3 {
    margin-top: 0;
}

.shop-info {}

.shop-info .content-wrap {
    display: flex;
    flex-direction: column;
    gap: 0em;
}

@media screen and (min-width:48em) {

    .shop-info .content-wrap {
        flex-direction: row;
        gap: 5vw;
    }

    .shop-info .logo {
        max-width: 23em;
        flex: 1;
        width: 30%;
    }

    .shop-info .info {
        flex: 2;
        width: 70%;
    }
}


.shop-info .logo figure {
    width: 100%;
    position: relative;
    padding-bottom: 100%;
    overflow: hidden;
    border: 1px solid var(--c-gold-light);
}


.shop-info .logo figure img {

    width: 60%;
    margin: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    height: 100%;
    object-fit: contain;
    transform: translate(-50%, -50%);
}

.shop-info .info>div {
    margin: 3em auto 0 auto;
}

.shop-info .info>.description p:first-child {
    margin-top: 0;
}


@media screen and (min-width:48em) {

    .shop-info .info>div:first-of-type {
        margin: 0 auto 3em auto;
    }


}

.shop-info .info .images {
    width: 100%;
}

.shop-info .info .images .swiper-pagination {
    display: none;
}

.shop-info .info .images figure img {
    width: 100%;
}

.shop-info .info .video {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
}

.shop-info .info .video iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.shop-info .info .detail {
    border-top: 1px solid var(--c-gold-light); 
    display: grid;
    gap: 1em;
    grid-template-columns: repeat(1, 1fr);
    padding: 3em 0 0 0;
}



@media screen and (min-width:48em) {

    .shop-info .info .detail {

        grid-template-columns: repeat(2, 1fr);
        padding: 3em 0 0 0;
    }


}


@media screen and (min-width:90em) {

    .shop-info .info .detail {

        grid-template-columns: repeat(4, 1fr);

    }
}

.single-experience .detail .label,
.shop-info .info .detail .label {
    color: var(--c-gold);
}

.single-experience .detail .value,
.shop-info .info .detail .value {
    font-size: 0.75em; 
}


.single-experience .detail .value a,
.shop-info .info .detail .value a {
    color: #000;
    text-decoration: none;
}

.single-experience .detail>div,
.shop-info .info .detail>div {
    padding-left: 4em;
    position: relative;
}

.single-experience .detail>div:before,
.shop-info .info .detail>div:before {
    content: '';
    display: block;
    width: 3.125em;
    height: 3.125em;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
    left: 0;
}



.shop-info .info .detail>div.location:before {
    background-image: url(images/shop_info_location.svg);
}

.shop-info .info .detail>div.working-hour:before {
    background-image: url(images/shop_info_working-hour.svg);
}

.shop-info .info .detail>div.phone:before {
    background-image: url(images/shop_info_phone.svg);
}

.shop-info .info .detail>div.website:before {
    background-image: url(images/shop_info_website.svg);
}

.listing .filters .type-nav {
    display: flex;
    gap: 1em;
    justify-content: end;
    color: var(--c-gold);
    margin: 0;
    padding: 0;
    ;
}

.listing .filters .type-nav li {
    list-style: none;
}

.listing .filters .type-nav li:not(.active) {

    opacity: 0.5;
    cursor: pointer;
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
}

.listing .filters .type-nav li:not(.active):hover {
    opacity: 1;
}


@media screen and (min-width:48em) {

    .listing .filters .type-nav {
        font-size: 1.875em;
    }
}

.listing.grid .listing-wrap .items {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 5em;
}


.listing .listing-wrap .msg {
    text-align: center;
    margin: var(--space-v) auto 0 auto;

}


.listing .listing-wrap .loading {
    width: 4em;
    height: 4em;
    margin: var(--space-v) auto;
    background-image: url(images/icon_loading.gif);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
}




.page.news .listing .listing-wrap .msg {
    margin: calc(1px - var(--space-v)) auto 0 auto;
}

@media screen and (min-width:48em) {


    .listing.grid.news .listing-wrap .items {

        grid-template-columns: repeat(3, 1fr);
        gap: 5vw;
    }

}


.listing.ver.experience .listing-wrap .items {
    display: flex;
    ;
    flex-direction: column;
    gap: var(--space-v);
    margin: 0 auto;
}

@media screen and (min-width:48em) {

    .listing.ver.experience .listing-wrap .items {
        margin: 0 auto;
    }

}

.listing.ver.experience .listing-wrap .item {
    display: flex;
    ;
    flex-direction: column;
    gap: 2em;
}

.listing.ver.experience .listing-wrap .item figure {
    padding-bottom: 63%;
}

.listing.ver.experience .listing-wrap .item a {
    color: var(--c-gold);

    transition-duration: 0.4s;
    transition-timing-function: ease-out;
}

.listing.ver.experience .listing-wrap .item h3 {
    margin-top: 0;
    margin-bottom: 1em;
}

.single-experience .type-date-wrap,
.listing.ver.experience .listing-wrap .item .type-date-wrap {
    margin-bottom: 0.5em;
    color: var(--c-gold-light);
    display: flex;
    gap: 1em;
}

.single-experience .type-date-wrap a,
.listing.ver.experience .listing-wrap .item .type-date-wrap a {
    color: var(--c-gold-light);
}


.single-experience .type-date-wrap a:hover,
.listing.ver.experience .listing-wrap .item .type-date-wrap a:hover {
    color: var(--c-gold);
}

.listing.ver.experience .listing-wrap .item .cta {
    margin-top: 2em;
}



@media screen and (min-width:48em) {



    .listing.ver.experience .listing-wrap .item {
        display: flex;
        align-items: start;
        flex-direction: row;
        gap: 0;
        width: 100%;
    }

    .listing.ver.experience .listing-wrap .item:nth-child(2n+1) {
        flex-direction: row-reverse;
    }

    .listing.ver.experience .listing-wrap .item>div {

        box-sizing: border-box;
        width: 50%;
    }


    .listing.ver.experience .listing-wrap .item .txt-wrap {
        padding-left: 5vw;
    }

    .listing.ver.experience .listing-wrap .item:nth-child(2n+1) .txt-wrap {
        padding-left: 0;
        padding-right: 5vw;
    }
}

.single-experience .content-wrap .label {
    color: var(--c-gold);
}


@media screen and (min-width:48em) {

    .single-experience .content-container {
        position: relative;
        padding: 5em 0;
        margin: -5em auto 0 auto;
    }

    .single-experience .content-container:before {
        content: '';
        display: block;
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        width: 68%;
        z-index: 1;
        background-color: var(--c-grey-light);
    }

    .single-experience main .content-wrap {
        position: relative;
        z-index: 2;
        display: flex;
    }


    .single-experience .content-wrap .main {
        width: 70%;
        box-sizing: border-box;
        padding-right: 5vw;

    }


    .single-experience .content-wrap .info {
        width: 30%;
        padding-left: 5vw;
        box-sizing: border-box;
    }
}


.single-experience .content-nav {

    display: flex;
    align-items: center;
}

.single-experience .content-nav div {
    color: var(--c-gold);
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
}

.single-experience .content-nav div.active {
    font-size: 1.875em;
}

.single-experience .content-nav div:not(.active) {
    cursor: pointer;
    opacity: 0.5;
}

.single-experience .content-nav div:not(.active):hover {
    opacity: 1;
}

.single-experience .content-nav span.divider {
    margin: 0 2em;
    border-left: 1px solid var(--c-gold);
    width: 1px;
    height: 3em;
}


.single-experience .content-tnc-wrap {
    margin-top: 5em;
}

.single-experience .info .share {
    display: none;
}


@media screen and (min-width:48em) {
    .single-experience .content .share {
        display: none;
    }

    .single-experience .info .share {
        display: flex;
    }



}


.single-experience .info {
    margin-top: 5em;
}



@media screen and (min-width:48em) {

    .single-experience .info {
        margin-top: 0;
    }

}

.single-experience .detail {
    display: grid;
    gap: 1.5em;
    grid-template-columns: repeat(1, 1fr);
    padding: 3em 0;
}

.single-experience .detail>div.location:before {
    background-image: url(images/exp_info_location.svg);
}

.single-experience .detail>div.price:before {
    background-image: url(images/exp_info_price.svg);
}

.single-experience .detail>div.date:before {
    background-image: url(images/exp_info_date.svg);
}

.single-experience .detail>div.time:before {
    background-image: url(images/exp_info_time.svg);
}

.single-experience .main .tnc {
    display: none;
}

.filters {
    text-align: center;
}

.filters .keyword input {
    border: none;
    padding: 0.25em 1em;
    border-bottom: 1px solid var(--c-gold);
    padding-left: 2em;
    font-size: 2em;
    width: 100%;
    outline: none;
    background: none;
    box-sizing: border-box;
}

.filters .keyword input::placeholder {
    color: var(--c-gold);
}

.filters .keyword {
    position: relative;
}

.filters .keyword:before {
    content: '';
    position: absolute;
    top: 50%;

    background-image: url(images/search_icon.svg);

    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    width: 2.5em;
    height: 2.5em;
    margin-top: -1.25em;
}

.shop .filters>div,
.dine .filters>div {}

.listing.ajax .filters {
    padding: var(--space-v) 0;
    margin-top: calc(1px - var(--space-v));
}

.shop .filters,
.dine .filters {
    background-color: var(--c-grey-light);
}

.shop .filters .dropdown,
.dine .filters .dropdown {
    display: inline-block;
    margin: 5em auto 0 auto;
    width: 66%;
}

.shop .filters .dropdown button,
.dine .filters .dropdown button {
    width: 100%;
}

@media screen and (min-width:48em) {

    .shop .filters form,
    .dine .filters form {
        display: flex;
        justify-content: space-between;
    }

    .shop .filters form .keyword,
    .dine .filters form .keyword {
        width: 40%;
    }

    .shop .filters form .dropdown,
    .dine .filters form .dropdown {
        margin: 0;
        width: 25%;
        text-align: right;
    }
}


.listing.dine .item .txt-wrap,
.listing.shop .item .txt-wrap {
    display: none;
}

.listing.grid .item .txt-wrap {
    margin-top: 1em;
}

.listing.dine.grid .listing-wrap .items,
.listing.shop.grid .listing-wrap .items {
    grid-template-columns: repeat(2, 1fr);
    margin-top: 5em;

    gap: 5vw;
}


.listing.dine.grid .listing-wrap,
.listing.shop.grid .listing-wrap {}

@media screen and (min-width:64em) {

    .listing.dine.grid .listing-wrap .items,
    .listing.shop.grid .listing-wrap .items {
        grid-template-columns: repeat(4, 1fr);
    }

}

.listing.related {
    background-color: var(--c-grey-light);
    margin-bottom: 0;
    padding: 5em 0;
}

.brand-list .ui-selectmenu-button {
    width: 100%;
}

.brand-list .category-container {
    margin-top: 2em;
}

.brand-list .category-nav {
    display: none;
}



.brand-list .brands {
    display: grid;
    padding: 2em 0 0 0;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5em;
}

.brand-list .brands-container {
    width: 100%;
}

.brand-list .brands .brand {
    font-size: 0.75em;
}
.brand-list  {
    border-top: 1px solid var(--c-gold-light);
    padding-top: 3em;
}

@media screen and (min-width:64em) {


    .brand-list .category-container {
        display: flex;
        align-items: start;

    }

    .brand-list select,
    .brand-list .ui-selectmenu-button {
        display: none;
    }

    .brand-list .category-nav {
        display: block;
        width: 35%;

        border-top: 1px solid var(--c-gold-light);
    }

    .brand-list .category-nav>div {
        padding: 0.4em 0.6em;
        color: var(--c-gold);
        transition-duration: 0.4s;
        transition-timing-function: ease-out;
        border-bottom: 1px solid var(--c-gold-light);
        cursor: pointer;
        position: relative;
    }

    .brand-list .category-nav>div.active,
    .brand-list .category-nav>div:hover {
        background-color: var(--c-gold-50);
    }

    .brand-list .category-nav>div:after {
        content: '';
        background-image: url(images/swiper_arrow_gold.svg);
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
        width: 1em;
        height: 1em;
        transition-duration: 0.4s;
        transition-timing-function: ease-out;
        position: absolute;
        top: 50%;
        right: 0.5em;
        margin-top: -0.5em;

    }

    .brand-list .brands {

        padding: 0em 5vw 0 2em;
        grid-template-columns: repeat(2, 1fr);
    }
}


@media screen and (min-width:90em) {
    .brand-list .brands {

        padding: 0em 0 0em 5vw;
        grid-template-columns: repeat(3, 1fr);
    }

}


.single-shop .membership-offers {
    border-top: 1px solid var(--c-gold-light);
    padding: 3em 0em;

}
.ending {
    color: var(--c-gold);
    text-align: center;
}

.ending .content-wrap {

    max-width: 62em;
}

@media screen and (min-width:48em) {
    .ending {
        font-size: 1.25em;
    }
}

.timeline .items {
    position: relative;
    max-width: 72em;
    margin: 10em auto 0 auto;
}

.timeline .line {
    display: block;
    border-right: 1px dashed var(--c-gold-light);
    width: 1em;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
}

.timeline .line:after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    width: 1.875em;
    height: 1.875em;
    background-color: #fff;
    border: 1px solid var(--c-gold-light);
    border-radius: 100%;
}


.timeline .line:after {
    bottom: 0;
}

.timeline .item {
    padding-left: 5vw;
    position: relative;
    border-top: 1px solid var(--c-gold-light);
    padding-bottom: 5em;
}

.timeline .item:before {
    content: '';
    display: block;
    position: absolute;
    top: -0.9375em;
    left: 0;
    width: 1.875em;
    height: 1.875em;
    background-color: #fff;
    border: 1px solid var(--c-gold-light);
    border-radius: 100%;
}

.timeline .item .year {
    font-size: 3.75em;
    background-color: #fff;
    padding-left: 1em;
    margin-top: -0.5em;
    float: right;
    font-weight: 300;
    color: var(--c-gold);
    line-height: 1;
}

.timeline .item .title {
    margin-top: 3em;
}

.timeline .item .title h3 {
    color: var(--c-gold);
    font-size: 1.875em;
}

.timeline .item .description {}

@media screen and (min-width:48em) {
    .timeline .line {
        left: calc(50% - 1em);
    }

    .timeline .item:nth-child(2n+2) {
        margin-right: calc(50% - 1em);
    }

    .timeline .item:nth-child(2n+2):before {
        left: auto;
        right: 0;
    }

    .timeline .item:nth-child(2n+2) .year {
        float: left;
        padding-left: 0;
        padding-right: 1em;
    }

    .timeline .item:nth-child(2n+2) .title {
        margin-top: 4em;
    }

    .timeline .item:nth-child(2n+2) {
        padding-left: 0;
        padding-right: 5vw;
    }

    .timeline .item:nth-child(2n+2) .year {}

    .timeline .item:nth-child(2n+1) {
        margin-left: calc(50% - 1em);
    }

}
.m8-shops-offer .intro .content p,
.community-shops-offer .intro .content p {
    font-size:1.875em;
}

.listing.shops-offer {
    margin-top: -5em;
}

.listing.shops-offer.grid .listing-wrap .item {
    grid-template-columns: repeat(1, 1fr);
    gap: 0;
    display: grid;
}

@media screen and (min-width:64em) {
    .listing.shops-offer.grid .listing-wrap .items {
        display: grid;
        gap: 5vw;
        grid-template-columns: repeat(2, 1fr);
    }
}

.listing.shops-offer.grid .listing-wrap .item {
    display: flex;
    gap: 2em;
    flex-direction: column;
}



@media screen and (min-width:36em) {


.listing.shops-offer.grid .listing-wrap .item {

    flex-direction: row;
    }


    .listing.shops-offer .item>div {
        flex: 1;
    }

}

.popup-container.tnc {
    width:90%;
    max-width: 48em;
}
/*
.listing.shops-offer .item .img-wrap figure {
    padding-bottom: 100%;
    border:1px solid var(--c-gold-light);
}*/


.listing.shops-offer .item .img-wrap .tnc {
    padding:1.5em;
    background-color: var(--c-grey-light);
}
.listing.shops-offer .item .img-wrap .tnc .title {
    font-size:0.75em;
    color:var(--c-gold);
}
.listing.shops-offer .item .img-wrap .tnc .content {
}
.listing.shops-offer .item .img-wrap .tnc ul {
    margin:0.5em 0 0 0;
    padding:0 0 0 1em;
    font-size:0.75em;
}

.listing.shops-offer .item .tnc .cta a{
    font-size:0.75em;
}

.listing.shops-offer .item .tnc .content {
display: none;
}

.listing.shops-offer .item .txt-wrap {
 display: block;
}
@media screen and (min-width:36em) {

    .listing.shops-offer .item .txt-wrap {
        margin-top: 0;
    }
}

.listing.shops-offer .item .txt-wrap .title {
    color: var(--c-gold);
}

.listing.shops-offer .item .txt-wrap h3 {
    margin-top: 0;
    margin-bottom: 0.5em;
}

.listing.shops-offer .item .txt-wrap h3 a {
    color: var(--c-gold);
}
.listing.shops-offer .item .txt-wrap .title {
    border-bottom: 1px solid var(--c-gold-light);
}


.listing.shops-offer .item .txt-wrap .info {}


.listing.shops-offer .detail {
    margin-top: 0em;
    display: grid;
    gap: 1em;
    grid-template-columns: repeat(1, 1fr);
    padding: 1.25em 0;

    line-height: 1.5;
}

.listing.shops-offer .detail .label {
    color: var(--c-gold);
}

/*
.listing.shops-offer .detail .value {
    font-size: 0.75em;
    margin-top: 0.25em;
}*/


.listing.shops-offer .detail .value a {
    color: #000;
    text-decoration: none;
}

.listing.shops-offer .detail>div {
    padding-left: 4em;
    position: relative;
}

.listing.shops-offer .detail>div:before {
    content: '';
    display: block;
    width: 3.125em;
    height: 3.125em;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    position: absolute;
    top: 0;
    left: 0;
}



.listing.shops-offer .detail>div.location:before {
    background-image: url(images/shop_offer_info_location.svg);
}

.listing.shops-offer .detail>div.desc:before {
    background-image: url(images/shop_offer_info_offer.svg);
}

.listing.shops-offer .detail>div.phone:before {
    background-image: url(images/shop_offer_info_phone.svg);
}

.listing.shops-offer .detail>div.opening:before {
    background-image: url(images/shop_offer_info_opening.svg);
}



section.design-concept .headline {
    border-top: 1px solid var(--c-gold-light);
    padding: var(--space-v) 0;
    text-align: center;

    margin-top: calc(1px - var(--space-v));
}


@media screen and (min-width:48em) {
    section.design-concept .headline h2 {
        font-size: 3.75em;
    }

}

section.design-concept .concepts {
    display: grid;

    grid-template-columns: repeat(1, 1fr);
    gap: var(--space-h);
}

@media screen and (min-width:40em) {
    section.design-concept .concepts {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media screen and (min-width:64em) {
    section.design-concept .concepts {
        grid-template-columns: repeat(4, 1fr);
    }
}

section.design-concept .item figure {
    width: 100%;
    padding-bottom: 100%;
    position: relative;
    margin: auto;
    overflow: hidden;
    border-radius: 100%;
}

section.design-concept .item figure img {
    width: 100%;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    object-fit: cover;
}

section.design-concept .item .title {
    color: var(--c-gold);
    text-align: center;
}


section.design-concept .item .subtitle {
    color: #fff;
    background-color: var(--c-gold);
    text-align: center;
    font-size: 1.25em;
    padding: 0.1em;
    margin: 1.5em 0;
}

.home .map {
    margin-bottom: 0;
}

.home .gmap-container {
    position: relative;
    width: 100%;
    height: 20em;
}


@media screen and (min-width:48em) {
    .home .gmap-container {
        height: 42em;
    }

}

.single.how-to-go .map {
    background-color: var(--c-grey-light);
    margin-top: calc(1px - var(--space-v));
    padding: var(--space-h) 0;
}


.single.how-to-go .gmap-container {
    position: relative;
    width: 100%;
    padding-bottom: 70%;
}

@media screen and (min-width:48em) {
    .single.how-to-go .gmap-container {
        height: 32em;
        padding-bottom: 0;
    }
}

.single.how-to-go .info .content-wrap {
    display: grid;
    gap: var(--space-v);
    grid-template-columns: repeat(1, 1fr);
    text-align: center;
}


@media screen and (min-width:48em) {
    .single.how-to-go .info .content-wrap {
        grid-template-columns: repeat(3, 1fr);
        gap: var(--space-h);
    }
}

.single.how-to-go .info figure,
.single.how-to-go .info figure img {
    margin: 0;
}

.single.how-to-go .info .title {
    color: var(--c-gold);
    font-size: 1.25em;
    margin: 0.5em auto;
}


.single.how-to-go .info .value a {
    color: #000;
}

.single.how-to-go .public-transport {
    margin-bottom: 0;
}


.single .attachments {
display:flex;
flex-direction: column;
gap:1em;
}

.single .attachments .cta-btn {
    text-align: center;
}
@media screen and (min-width:48em) {
    
.single .attachments {
    display:flex;
    flex-direction: row;
    gap:1em;
    align-items: center;
    justify-content: start;
    }
}
.public-transport {
    padding: var(--space-v) 0;
    background-color: var(--c-grey-light);
    text-align: center;
}


.public-transport .headline {
    text-align: center;
}


.public-transport .taxi-info a {
    margin-top: 1.5em;
    background-color: #fff;
    border: 1px solid var(--c-gold-light);
    color: var(--c-gold);
    text-align: center;
    padding: 0.25em 5vw;
    border-radius: 2em;
    display: inline-block;
    transition-duration: 0.2s;
    transition-timing-function: ease-out;

}

.public-transport .taxi-info a {
    color: var(--c-gold);
    text-decoration: none;
}

.public-transport .taxi-info a:hover {
    background-color: var(--c-gold-light);
}

.public-transport .guide {
    margin-top: 1.5em;
    text-align: left;
}

.public-transport .guide .subheadline {
    color: #fff;
    background-color: var(--c-gold);
    padding: 0.1em 1em;
    font-size: 1.25em;
}


.public-transport .guide .route .from-text {
    background-color: #fff;
    color: var(--c-gold);
    padding: 0.2em 1em;
    position: relative;
    transition-duration: 0.2s;
    transition-timing-function: ease-out;
    cursor: pointer;
}

.public-transport .guide .route:not(.active) .from-text:hover {
    transform: scale(1.01);
}


.public-transport .guide .route .from-text:after {
    content: '';
    position: absolute;
    top: 50%;
    right: 0.5em;
    width: 1em;
    height: 1em;
    margin-top: -0.5em;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
    background-image: url(images/swiper_arrow_gold.svg);
    line-height: 1;
}

.public-transport .guide .route.active .from-text:after {
    transform: rotate(90deg);
}

.public-transport .guide .route .methods {
    clip-path: inset(0px 0px 99.9% 0);
    height: 1px;
    transition-duration: 0.4s;
    transition-timing-function: ease-out;
}

.public-transport .guide .route .method {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-columns: 1fr 1fr 6fr;
    gap: 1px;
    background-color: #fff;
    padding: 1px;
}

.public-transport .guide .route.active .methods {
    clip-path: inset(0px 0px 0 0);
    height: auto;
}

.public-transport .guide .route .method>div {
    background-color: var(--c-grey-light);
    padding: 0.2em 1em;

}


.public-transport .guide .route .method .type,
.public-transport .guide .route .method .number {
    white-space: nowrap;
}

.public-transport .guide .route .method .detail {
    width: 100%;
}

.single.culture {
    background-color: var(--c-grey-light);
}

.single.culture .intro {
    margin-bottom: 0;
}

section.veins .content-wrap {
    display: grid;
    gap: var(--space-v);
    grid-template-columns: repeat(1, 1fr);
}

section.veins .content-wrap .img-desc-wrap {

    margin: auto;
}

section.veins .content-wrap .img-desc-wrap figure {
    width: 16em;
    height: 16em;
    border-radius: 100%;
    margin: auto;
    overflow: hidden;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

section.veins .content-wrap .img-desc-wrap figure img {
    width: 100%;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    object-fit: cover;
}

section.veins .content-wrap .img-desc-wrap figure figcaption {
    position: relative;

    z-index: 2;
    background-color: var(--c-gold-50);
    color: #fff;
    font-size: 1.875em;
    line-height: 1.25;
    text-align: center;
    display: inline-block;
    padding: 0.2em;
}

section.veins .content-wrap .img-desc-wrap .credit {
    font-size: 0.75em;
    margin-top: 1em;
    text-align: center;
}

section.veins .content-wrap .img-desc-wrap .desc {


    margin: auto;
    margin-top: 2em;
}

/*
    section.veins .content-wrap  .attraction {
        margin-top:2em;
    }*/
section.veins .content-wrap .attraction .title {

    color: #fff;
    background-color: var(--c-gold);
    padding: 0.1em 1em;
    font-size: 1.25em;
}

section.veins .content-wrap .attraction .desc {
    background: #fff;
    padding: 1em 2em;
}


@media screen and (min-width:48em) {
    section.veins .content-wrap .img-desc-wrap {
        display: flex;
        align-items: center;
    }

    section.veins .content-wrap .img-desc-wrap .desc {
        width: 100%;
        padding-left: 2em;
        margin: auto;
    }
}


@media screen and (min-width:90em) {

    section.veins .content-wrap {
        display: grid;
        gap: var(--space-v);
        grid-template-rows: repeat(2, 1fr);
        grid-auto-flow: column;
        gap: 0;
        grid-template-columns: unset;
    }

    section.veins .content-wrap>div {
        padding: 0 var(--space-h);
    }

    section.veins .content-wrap [data-item="1"] {
        border-right: 1px solid rgba(204, 195, 184, 1);
    }

    section.veins .content-wrap .img-desc-wrap {
        padding-top: 1em;
        padding-bottom: 2em;
    }

    section.veins .content-wrap .attraction {
        margin-top: -1em;
    }
}

.culture .heritages {
    margin-bottom: 0;
}

.heritages #gmap-container {
    position: relative;
    width: 100%;
    padding-bottom: 150%;
}

.heritages .list {
    background-color: #fff;
    padding: var(--space-v) var(--space-h);
}

.heritages .list .items {}


.heritages .list .item {
    margin-top: 3em;
    display: flex;
    align-items: start;
}


.heritages .list .item .number span {
    display: block;
    border-radius: 100%;
    width: 3.125em;
    height: 3.125em;
    line-height: 3.125;
    text-align: center;
    color: var(--c-gold);
    border: 1px solid var(--c-gold-light);
}

.heritages .list .item .img-txt-wrap {
    width: 100%;
    padding-left: 2em;
}



.heritages .list .item .img-wrap figure {
    position: relative;
    width: 100%;
    padding-bottom: 70%;
    margin: 0;
}

.heritages .list .item .img-wrap figure img {

    width: 100%;
    margin: 0;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    object-fit: cover;
}

.heritages .list .item .txt-wrap .title {
    color: var(--c-gold);
    font-size: 1.25em;
}

.heritages .list .item .txt-wrap .title,
.heritages .list .item .txt-wrap .desc {
    margin-top: 1em;
}

@media screen and (min-width:90em) {
    .heritages .list .item .img-txt-wrap {
        display: flex;
        align-items: start;
        gap: 2em;
    }

    .heritages .list .item .img-wrap {
        flex: 1;
    }

    .heritages .list .item .txt-wrap {
        flex: 2;
    }

    .heritages .list .item .txt-wrap .title {
        margin-top: 0;
    }
}



.heritages .map .number-pin {
    font-size: 16px;
    display: block;
    border-radius: 100%;
    width: 3.125em;
    height: 3.125em;
    line-height: 3.125;
    text-align: center;
    color: #fff;
    background: var(--c-gold);
    border: 1px solid #fff;
    transform: translate(-50%, -50%);
    position: absolute;
    z-index: 1;
}

.heritages .map .number-pin:hover {
    z-index: 2;
}



.heritages .map {
    position: relative;
    overflow: hidden;
    height: 80vh;
}

.heritages .map-pins {
    background-image: url(images/map_macau.jpg);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 80vh;
    height: 80vh;
}

.heritages .m8-pin {
    position: absolute;
    z-index: 2;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -100%);
}


@media screen and (min-width:48em) {
    .heritages .map-pins {

        min-width: 100vh;
        min-height: 100vh;
        height: auto;
        width: auto;
    }

    .heritages .map {

        height: 100vh;
    }

    .heritages {
        display: flex;
        align-items: stretch;
        height: 100vh;
    }

    .heritages>div {
        width: 50%;
    }

    .heritages #gmap-container {
        padding-bottom: 0;
        height: 100%;
    }

    .heritages .list {
        overflow-y: auto;
    }
}

.popup-container.wechat .popup {
    max-width: 18em;
}

.popup-container.wechat .img-wrap img {
    display: block;
    width: 16em;
    height: 16em;
    margin: auto;
}


.popup-container.wechat .txt-wrap {
    text-align: center;
    font-size: 0.875em;
    margin-top: 0.5em;
    line-height: 1.25;
}

body.terms-and-conditions main .headline {
    text-align: center;
}

body.terms-and-conditions main {
    margin-top: 4em;
    padding: var(--space-v) 0;
}

.popup-container.ad figure {
    display: block;
    margin: 0;
}

.popup-container.ad .popup {
    padding: 0;
}

.popup-container.ad img {
    width: 90vw;
    max-width: 64em;
    display: block;
    margin: 0;
}

.popup-ad-code {
    display: none;
}

.page.membership .signup-now {
    text-align: center;
}
.page.membership .signup-now .cta-btn {
    display: inline-block;

    min-width: 21em;
}


.page.membership .offers .desktop {
    display: none;
}
.page.membership .type-nav-container.mobile {
    text-align: center;
}

.page.membership .type-nav-container.mobile .ui-selectmenu-button {
    min-width: 21em;
}
.page.membership .offers-list .offer-item {
 margin-top:2em;
}
.page.membership .offers-list .item-label { 
    background-color: var(--c-grey-light);
    color: var(--c-gold);
    padding: 0.5em 1em;
    font-size: 1.25em;
}
.page.membership .offers-list .offer-item>div {
 padding:0.75em 1em;
}
.page.membership .offers-list .offer-item>div:not(.item-label) {
 padding:1em 1.25em;
}
.page.membership .offers-list .shop-logo {
    text-align: center;

    line-height: 1;
}
.page.membership .offers-list .shop-logo figure {
    display: inline-block;
   
    margin:0.5em auto;

    padding: 2em;
}
.page.membership .offers-list .shop-logo img {
    display: block;
    width: 10em;
    height: auto;
    margin:auto;
}


.page.membership .offers-list .terms ul {
    margin:0;
    padding-left:1em;
}


.page.membership .offers-list .terms p {
    margin-top:0;
}
@media screen and (min-width:48em) {
    .page.membership .offers .desktop {
        display: block;
    }
    .page.membership .offers .mobile {
        display: none;
    }
    
.page.membership .type-nav-container.desktop ul {
    margin:0;
    padding:0;
    display: flex;
    gap: 1em;
    align-items: center;
    justify-content: start;

    height: calc(3.425em + 2px);
}

.page.membership .type-nav-container.desktop ul li {

    list-style: none;
    padding: 0.4em 0.6em;
    color: var(--c-gold-light);
    cursor: pointer;
    transition-duration: 0.2s;
    transition-timing-function: ease-out;
    border: 1px solid var(--c-gold-light);
    opacity: 0.5;
    line-height: 1;
    cursor: pointer;
}
/*
.page.membership .type-nav-container.desktop ul li:nth-child(n+2) {
    border-left:1px solid var(--c-gold);
   
}*/
.page.membership .type-nav-container.desktop ul li:not(.active):hover {
    color:var(--c-gold);
    font-size:1em;
    line-height: 1;
    opacity: 1;
}
.page.membership .type-nav-container.desktop ul li.active {
    color:var(--c-gold);
    font-size:1.5em; 
    line-height: 1;
    opacity: 1;
    cursor: default;
}

.page.membership .offers-list .mobile {
    display: none;
}
.page.membership .offers-list .desktop {
    display: block;
    position: relative;
    overflow-x: auto;
    width: 100%;    margin-top:2em;
    border-spacing: 0;
    
}

}
.page.membership .offers-list table,
.single-shop .offers-list table {

    border-spacing: 0;
    table-layout: fixed;
    width: 100%;
}
.page.membership .offers-list table th,
.single-shop .offers-list table th {
    width:8em;
    text-align: left;
    background-color: #fff;
}

.page.membership .offers-list table th,
.page.membership .offers-list table td,
.single-shop .offers-list table th,
.single-shop .offers-list table td {
    border-right:1px solid var(--c-gold-light);
    vertical-align: top;
    padding:1em;
    }

.page.membership .offers-list table tr:nth-child(2n+2) th,
.page.membership .offers-list table tr:nth-child(2n+2) td,
.single-shop .offers-list table tr:nth-child(2n+1) th,
.single-shop .offers-list table tr:nth-child(2n+1) td {
    background-color: var(--c-grey-light);
}

.page.membership .offers-list table td,
.single-shop .offers-list table td {
    position: relative;

    width: 21em;
}

.page.membership .offers-list table th,
.single-shop .offers-list table th {
    position: sticky; /* Make the first column sticky */
    left: 0; /* Align it to the left */
    z-index: 1; /*  */
}

.single-shop .offers-list {
    margin: 2em 0 4em 0;

    display: block;
    position: relative;
    overflow-x: auto;
    width: 100%;
    border-spacing: 0;
}
    .single-shop .offers-list table td p,
    .single-shop .offers-list table td ul {
    margin-top:0;
}

.single-shop .offers-list table td ul {
    padding-left:1em;
}
.page.membership .signup .popup {
    text-align: center;
    padding:1em;
    color:var(--c-gold);
}

@media screen and (min-width:48em) {
    .page.membership .signup .popup {
         
        padding:2em;
  
    }
}
.page.membership .signup .popup .img-wrap img {
    width: 100%;
    height: auto;
    max-width: 20em;
    width: 100%;
    margin: 2em auto 0 auto;
}
