@charset "utf-8";
/*-----------------------------------------------
    共用common
-----------------------------------------------*/
/* 選單 */
.hc-offcanvas-nav .nav-content>.nav-close:first-child a:not(.has-label) {    
    width: 44px;
    height: 44px;
    line-height: 44px;
    left: 0;
}
.hc-offcanvas-nav .nav-close-button span::before, 
.hc-offcanvas-nav .nav-close-button span::after {    
    width: 15px;
    height: 15px;
    margin-top: -6px;
    border-top: 1px solid #fff;
    border-left: 1px solid #fff;
}
.hc-offcanvas-nav .nav-close-button span::before {
    margin-left: -20px;
}
.hc-offcanvas-nav.nav-open[class*='hc-nav-'] div.nav-container {
    transform: translate3d(0, 0, 0) !important;
}
.hc-offcanvas-nav.hc-nav-1.nav-levels-overlap.nav-position-left li.level-open > .nav-wrapper {
    transform: translate3d(280px, 0, 0) !important;
}
.hc-offcanvas-nav a.nav-next:before{
    width: 0;
}
.sticky{
    position: fixed; 
    width: 100%; 
    top: 0; 
    z-index: 1000; 
    /* height: 119px;   */
    height: 80px;  
    background: rgba(0,0,0,0.7);
}
/* 內頁pagebanner */
.pagebanner{
    height:calc(100vw * 355 / 1920);
    min-height: 200px; 
    background: #333 url("") bottom center no-repeat;
    background-size: cover;
    max-height: 240px;
}

.pagebanner.pagebannerHigh{
    height:calc(100vw * 600 / 1920);
    min-height: 350px; 
    background-position: bottom center;
}
.pb-about{
    background-image: url("../images/pagetop/aboutXavier02.jpg");
}
.pb-blog{
    background-image: url("../images/pagetop/blog.jpg");
}
.pb-news{
    background-image: url("../images/pagetop/news.jpg");
}
.pb-designers{
    background-image: url("../images/pagetop/designers02.jpg");
}
.pb-designersPage{
    background-image: url("../images/pagetop/designersPage.jpg");
}
.pb-designerWorks{
    background-image: url("../images/pagetop/designerWorks.jpg");
}
.pb-locations{
    background-image: url("../images/pagetop/locations.jpg");
}
.pb-serviceItems{
    background-image: url("../images/pagetop/serviceItems02.jpg");
}
.pb-serviceProcess{
    background-image: url("../images/pagetop/serviceProcess.jpg");
}
.pb-bookNow{
    background-image: url("../images/pagetop/bookNow.jpg");
}
.pb-franchising{
    /* background-image: url("../images/pagetop/franchising.jpg"); */
    background-color: #000000;
}
.pb-package{
    background-image: url("../images/pagetop/package.jpg");
}
.pb-products{
    background-image: url("../images/pagetop/products3.jpg");
}
.pb-members{
    background-image: url("../images/pagetop/members02.jpg");
}
.pb-carts{
    background-image: url("../images/pagetop/carts02.jpg");
}
/* .pageFrame{
    min-height: 700px;
} */
/* 上移開關================================================ */
.zindex-0{
    z-index: -1;
}
.pageFrame{
    /* margin-top: -50px; */
}
/* ======================================================== */
/*-----------------------------------------------
    首頁index
-----------------------------------------------*/
/*blog*/
.blog__header {
    padding: 32px 40px;
    background-color: #fff;
    position: absolute;
    right: -1px;
    bottom: -1px;
}

.box__body {
    margin-top: 12px;
}

.box__body .box__subtitle {
    color: #6c757d;
    margin-bottom: 8px;
}

.box__body .box__title {
    margin-bottom: 16px;
    font-size: 20px;
}

.box__body .box__text {
    font-family: "Noto Sans TC";
    font-size: 16px;
}

/*button*/
.cta {
    padding: 12px 16px;
    text-decoration: none;
    display: inline-block;
    transition: all 0.5s ease-out;
    -webkit-transition: all 0.5s ease-out;
    cursor: pointer;
}
.cta:hover{
    background-position: 0 0;
    transition: all 0.5s ease-out;
    -webkit-transition: all 0.5s ease-out;
}

.cta__white {
    background: -webkit-gradient(linear, left top, right top, color-stop(45%, #000), color-stop(45%, #fff)) -360px 0/600px auto;
    background: linear-gradient(90deg, #000 45%, #fff 45%) -360px 0/600px auto;    
}

.cta__white:hover {    
    color: #fff;    
}

.cta__outline--white {
    border: 1px solid #fff;
    color: #fff;
    background: -webkit-gradient(linear, left top, right top, color-stop(45%, #fff), color-stop(45%, rgba(255, 255, 255, 0))) -360px 0/600px auto;
    background: linear-gradient(90deg, #fff 45%, rgba(255, 255, 255, 0) 45%) -360px 0/600px auto;
}

.cta__outline--white:hover {    
    color: #000;    
}

.cta__black {
    color: #fff;
    background: -webkit-gradient(linear, left top, right top, color-stop(45%, #fff), color-stop(45%, #000)) -360px 0/600px auto;
    background: linear-gradient(90deg, #fff 45%, #000 45%) -360px 0/600px auto;    
}

.cta__black:hover {    
    color: #000;    
}
.cta__black2 {
    color: #fff;
    background: -webkit-gradient(linear, left top, right top, color-stop(45%, #333), color-stop(45%, #000)) -360px 0/600px auto;
    background: linear-gradient(90deg, #333 45%, #000 45%) -360px 0/600px auto;    
}

.cta__black2:hover {    
    color: #fff;    
}
.cta__outline--black {
    border: 1px solid #000;
    color: #000;
    background: -webkit-gradient(linear, left top, right top, color-stop(45%, #000), color-stop(45%, rgba(0, 0, 0, 0))) -360px 0/600px auto;
    background: linear-gradient(90deg, #000 45%, rgba(0, 0, 0, 0) 45%) -360px 0/600px auto;
}

.cta__outline--black:hover {    
    color: #fff;    
}
.cta__outline--black.active {    
    color: #fff;
    background-color: #000;
}
.cta__red {
    color: #fff;
    background: -webkit-gradient(linear, left top, right top, color-stop(45%, #aa0909), color-stop(45%, #f00)) -360px 0/600px auto;
    background: linear-gradient(90deg, #aa0909 45%, #f00 45%) -360px 0/600px auto;    
}

.cta__red:hover {    
    color: #fff;    
}
.cta__gray {
    color: #fff;
    background: -webkit-gradient(linear, left top, right top, color-stop(45%, #333), color-stop(45%, #000)) -360px 0/600px auto;
    background: linear-gradient(90deg, #333 45%, #999 45%) -360px 0/600px auto;    
}

.cta__gray:hover {    
    color: #fff;    
}


.link {
    position: relative;
    display: inline-block;
    padding-left: 28px;
    margin-left: 1px;
    transition: padding-left .5s ease, right .5s ease, opacity .5s ease;
    -webkit-transition: padding-left .5s ease, right .5s ease, opacity .5s ease;
    color: #000;
}

.link--white::before {
    background-color: rgba(255, 255, 255, 0.4);
}

.link--black::before,
.link--black::after {
    background-color: rgba(0, 0, 0, 0.3);
}

.link::before,
.link::after {
    content: "";
    display: block;
    position: absolute;
    height: 1px;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    transition: width .5s ease;
    -webkit-transition: width .5s ease;
}

.link::before {
    left: 0;
    width: 18px;
}

.link::after {
    left: calc(100% + 9px);
    width: 56px;
}

.link:hover {
    padding-left: 64px;
}

.link:hover::before {
    width: 56px;
}

.link:hover::after {
    width: 8px;
}

/*header__carousel*/
.header__carousel .owl-item {
    overflow: hidden;
}

.header__carousel .owl-dots {
    position: absolute;
    bottom: 6vh;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

.header__carousel .owl-dots .owl-dot span {
    width: 100%;
    height: 1px;
    background-color: #fff;
    display: block;
    opacity: 0.5;
    position: relative;
}

.header__carousel .owl-dots .owl-dot span::before {
    content: "";
    position: absolute;
    right: 0;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    padding: 20px 0;
}

.header__carousel .owl-dots .owl-dot.active span {
    opacity: 1;
}
/* 選單右側 123 start */
/* .header__carousel .owl-dots .owl-dot::after {
    font-family: "Times New Roman";
    font-style: italic;
    font-weight: 200;
    color: #fff;
    right: calc(0px - calc((99vw - 1296px)/2));
    position: absolute;
    opacity: 0.5;
    font-size: 24px;
}

.header__carousel .owl-dots .owl-dot:first-child::after {
    content: "01 \2015";
    bottom: 53vh;
}

.header__carousel .owl-dots .owl-dot:nth-child(2)::after {
    content: "02 \2015";
    bottom: 47vh;
}

.header__carousel .owl-dots .owl-dot:nth-child(3)::after {
    content: "03 \2015";
    bottom: 41vh;
}

.header__carousel .owl-dots .owl-dot:nth-child(4)::after {
    content: "04 \2015";
    bottom: 35vh;
}

.header__carousel .owl-dots .owl-dot.active::after {
    opacity: 1;
} */
/* 選單右側 123 end */
/* 選單右側 圓形 start */
/* .header__carousel .owl-dots .owl-dot::after {
    content: "";
    font-family: "Times New Roman";
    font-weight: 200;
    color: #fff;
    right: calc(80px - calc((99vw - 1296px)/2));
    position: absolute;
    opacity: 0.5;
    font-size: 24px;
    background-color: #fff;
    width: 8px;
    height: 8px;
    border-radius: 50%;
}

.header__carousel .owl-dots .owl-dot:first-child::after {
    bottom: 53vh;
}

.header__carousel .owl-dots .owl-dot:nth-child(2)::after {
    bottom: 47vh;
}

.header__carousel .owl-dots .owl-dot:nth-child(3)::after {
    bottom: 41vh;
}

.header__carousel .owl-dots .owl-dot:nth-child(4)::after {
    bottom: 35vh;
}
.header__carousel .owl-dots .owl-dot:nth-child(5)::after {
    bottom: 29vh;
}
.header__carousel .owl-dots .owl-dot:nth-child(6)::after {
    bottom: 23vh;
}

.header__carousel .owl-dots .owl-dot.active::after {
    opacity: 1;
} */
/* 選單右側 圓形 end */

/*card__carousel*/
.card__outer {
    text-decoration: none;
    display: block;
}

.card__outer .card__img {
    position: relative;
    width: 100%;
    height: 0;
}

.card__outer .card__img .card__img--top {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
}

.card__outer .card__title {
    font-size: 20px;
    margin-top: 12px;
}

.card__carousel__outer {
    /* position: absolute; */
    /* width: calc(100vw - ((100% - 1320px)/2)); */
    position: relative;
}

.card__carousel .owl-dots {
    position: absolute;
    bottom: -40px;
}

.card__carousel .owl-dot span {
    width: 100%;
    height: 1px;
    background-color: #0F2540;
    display: block;
    opacity: 0.2;
    position: relative;
}

.card__carousel .owl-dot span::before {
    content: "";
    position: absolute;
    right: 0;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    padding: 20px 0;
}

.card__carousel .owl-dot.active span {
    opacity: 1;
}

/* .card__more {
    padding-top: 600px;
} */

/*blog__carousel*/
.blog__carousel .owl-nav {
    text-align: end;
}

.blog__carousel .owl-nav .owl-prev {
    margin-right: 24px;
}

.blog__carousel .owl-nav .owl-prev,
.blog__carousel .owl-nav .owl-next {
    width: 60px;
    height: 60px;
    position: relative;
}

.blog__carousel .owl-nav .owl-prev span,
.blog__carousel .owl-nav .owl-next span {
    display: none;
}

.blog__carousel .owl-nav .owl-prev:hover::before,
.blog__carousel .owl-nav .owl-next:hover::before {
    opacity: 1;
}

.blog__carousel .owl-nav .owl-prev::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    background: url(../images/arrow-left.svg) no-repeat center center;
    opacity: 0.6;
}

.blog__carousel .owl-nav .owl-next::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    background: url(../images/arrow-right.svg) no-repeat center center;
    opacity: 0.6;
}

.fs-7 {
    font-size: 0.75rem;
}

/*brand*/
.brand {
    margin-bottom: 0;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.brand__logo {
    text-indent: 101%;
    overflow: hidden;
    white-space: nowrap;
    background: url(../images/Xavier_logo-02.png) no-repeat center center;
    /* width: 60px;
    height: 60px; */
    display: block;
    background-size: contain;
}

.navbar-toggler {
    /* padding: 49px 39px; */
    /* background-color: #000; */
    padding: 30px 20px;
    border-radius: 0;
}

.navbar-toggler span {
    width: 40px;
    height: 1px;
    background-color: #fff;
    margin-bottom: 8px;
    display: block;
}

.navbar-toggler span:last-child {
    margin-bottom: 0;
    width: 24px;
}

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

/*footer*/
.footer {
    background-color: #1e1e1e;
    color: #fff;
    padding-top: 80px;
    padding-bottom: 32px;
    font-family: Lato, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
}

.footer__nav__link {
    /* color: #fff; */
    text-decoration: none;
    display: block;
    padding: 8px 0;
    position: relative;
}

/* .footer__nav__link::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 80%;
    height: 1px;
    background-color: rgba(255, 255, 255, 0.8);
} */
.social-link img{
    width: 24px;
    /* height: 35px; */
}

/*top banner*/
.fTitle {
    font-size: 40px;
    text-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

.social {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    left: 40px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    z-index: 1;
}

.social__btn {
    padding: 10px;
    text-decoration: none;
    color: #fff;
}

.social__btn:hover {
    color: #fff;
}

@-webkit-keyframes zoomBanner {
    from {
        -webkit-transform: scale3d(1, 1, 1);
        transform: scale3d(1, 1, 1);
    }

    100% {
        -webkit-transform: scale3d(1.15, 1.15, 1.15);
        transform: scale3d(1.15, 1.15, 1.15);
    }
}

@keyframes zoomBanner {
    from {
        -webkit-transform: scale3d(1, 1, 1);
        transform: scale3d(1, 1, 1);
    }

    100% {
        -webkit-transform: scale3d(1.15, 1.15, 1.15);
        transform: scale3d(1.15, 1.15, 1.15);
    }
}

.header__carousel .header__carousel__item {
    -webkit-animation: zoomBanner 15s linear infinite forwards;
    animation: zoomBanner 15s linear infinite forwards;
    -webkit-animation-delay: 500ms;
    animation-delay: 500ms;
}

.header__carousel .header__carousel__video {
    width: 100vw;
    height: 100vh;
    -o-object-fit: cover;
    object-fit: cover;
}

/*about*/
.about__logo {
    position: absolute;
    width: 17%;
    height: 30%;
    right: -8%;
    top: 10%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    background-color: #000;
    background: url(../images/Xavier_logo.svg) #000 no-repeat center center;
    background-size: 40%;
}

@media (max-width: 767px) {
    .about__logo {
        width: 20.5%;
        height: 35.29%;
        top: 80%;
        background-size: 50%;
    }
}

/*fixed btn*/
.goTop {
    width: 60px;
    height: 60px;
    background: url(../images/goTop.svg) no-repeat center center;
    position: fixed;
    right: 50px;
    bottom: 40px;
    background-color: #fff;
}


.btn--fixed {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background-color: #9B8C6C;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    position: fixed;
    text-decoration: none;
    right: 50px;
    bottom: 130px;
    font-size: 0.81rem;
}
.btn--fixed-line {
    /* bottom: 250px; */
    /* background-color: #06C655; */
    background: url(../images/float_line02.png) no-repeat center center;
    background-size: contain;
}

.btn--fixed:hover {
    background-color: #766C57;
    transition: all 0.2s ease-in-out;
    -webkit-transition: all 0.2s ease-in-out;
}
/* .btn--fixed.btn--fixed-line:hover {
    background-color: #08aa4b;
} */


/*-----------------------------------------------
    內頁index
-----------------------------------------------*/

/* blog */
.cat_link{   
    color: var(--colorGray3);
    border-bottom: 1px solid var(--linkLine);
}
.cat_link.active,
.cat_link:hover,
.cat_link:focus{
    color: var(--linkFocus);
    border-bottom: 1px solid var(--linkFocus);
}
.blogTop{
    margin-left:-12px;
    margin-right:-12px;
    height: calc( 100vw * 560 / 1290 );
    min-height:220px;
    max-height:560px;
}
.blogTitle{
    width: 70%;
    margin: 0 auto;
    background-color: rgba(255,255,255,0.8);
}
.blogRightlistImg{
    width: 150px;
    overflow: hidden;
}
.blogRightlistTxt{
    width: calc( 100% - 150px );
}
.btn_share:hover{
    background-color: #efefef;
}
/* designerworks */
.designerworks{
    
}
.designerworksTop{
    margin-left:-12px;
    margin-right:-12px;
    height: calc( 100vw * 560 / 1290 );
    min-height:380px;
    max-height:560px;
}
.designerworksTitle{
    width: 70%;
    margin: 0 auto;
    background-color: rgba(255,255,255,0.8);
}
.designerworks_box{
    margin-left:-12px;
    margin-right:-12px;  
    height: 100px;
    background-color: #efefef;
}

.designerworks_list{
    margin-left:-12px;
    margin-right:-12px;
}
.designerBtn{
    color: #fff;
    background-color: var(--Gray3);
    padding: 2px 10px;
    display: inline-block;
}
/* booknow */
.booknow_bg{
    background-image:url("../images/booknow_bg.jpg");
    background-position: center top;
    background-repeat: no-repeat;
}
/* locations */
.locations_txtbox{
    /* background-color: var(--ground); */
    color: #fff;
}
.locations_txtbox p{
    margin-bottom: 0;
    margin-right: 8px;
}
.locations_listbox{
    background:url("../images/location_bg2.jpg") right top no-repeat;
}
/* designers */
.tag{
    background-color: rgba(155,140,108,0.7);
    border-radius: 3px;
}
.bookNowBtn{
    display: block;
    height: calc( 100% * 250 / 1000 );
    min-height: 150px;
    position: relative;
    overflow: hidden;
    transition: all 0.5s ease-out;
}
.bookNowBtnTxt {
    position: absolute;
    left: 0;
    top: 45%;
    text-align: center;
    width: 100%;
    pointer-events: none;
}
.bookNowBtnImg img{
    min-height: 150px;
}
.bookNowBtn:hover{
    transition: all 0.5s ease-out;
}
.bookNowBtn:hover .bookNowBtnTxt{
    color: #ffff00;
}

.caseTitle{
    border-left: 1px solid var(--linkFocus);
    padding-left: 1rem;
    line-height: 1.5rem;
}
.designersPageTop.pageFrame{
    margin-top: -100px;
}
.motto{
    width: 50%;
}
.avatar{   
    border-radius: 50%;
}
.avatarborder{   
    border:1px solid #fff;
}
.avatar16 {
    height: 16px;
    width: 16px;
}
.avatar32 {
    height: 32px;
    width: 32px;
}
.avatar64 {
    height: 64px;
    width: 64px;
}
.avatar128 {
    height: 128px;
    width: 128px;
}
.avatar300 {
    height: 300px;
    width: 300px;
    object-fit: cover;
}
.quotetop i{
    line-height: 1rem;
}
.quotebtm i{
    line-height: 1rem;
    transform: rotate(180deg);
}
/* package */
.packbg{
    height: 100%;
    /* background-color: rgba(155,140,108,0.1); */
    /* background: linear-gradient(90deg, rgba(155,140,108,0.1) 0%, rgba(155,140,108,0.1) 33%, rgba(255,255,255,1) 33%); */
}
.typeTxt{
    border-left: 1px solid var(--linkFocus);
    padding-left: 1rem;
    padding-bottom: 1rem;
}
.btnBooknow{    
    padding: 10px 20px;
    color: var(--linkFocus);
    border: 1px solid var(--linkFocus);
    /* background-color: var(--linkFocus); */
}
.btnBooknow:hover{
    color: #fff;
    border: 1px solid var(--linkFocus);
    /* background-color: var(--Gray6); */
    background-color: var(--linkFocus);
}
/* serviceItems */
.serviceItems_list:nth-child(odd){
    background-color:#E8E2D1;
}
.serviceItems_list:nth-child(even){
    margin-top: -40px;
}
.serviceItems_txtbox{
    position: relative;
}
.serviceItems_Num{
    position: absolute;
    left:-90px;
    top:-10px;
    color: #000;
}
.serviceItems_list:nth-child(even) .serviceItems_Num{
    left:-120px;
}
.serviceItems_list:nth-child(odd) .serviceItems_Num{
    color:#fff;
    left:-110px;
}
.btnBooknow_outline{
    border: 1px solid var(--Gray6);
    color: var(--Gray6);
    background-color: transparent;
    padding: 10px 20px;
}
.btnBooknow_outline:hover{
    border: 1px solid var(--linkFocus);
    color: #fff;
    background-color: var(--linkFocus);
}
/* serviceProcess */
.serviceProcess_bg.pageFrame{
    background:url("../images/service/service_process_bg.png") center bottom no-repeat;
    padding-bottom: 100px;
    margin-top:-75px;
}
.bookNowBtn.serviceProcess_bookNowBtn{   
    /* background:url("../images/service/service_process_button.jpg") center center no-repeat; */
}
.processNum{
    font-style: italic;
}
.processTxt{
    padding-left: 20px;
    border-left: 2px solid var(--linkFocus);
    margin-left: 20px;
}
.flowCheck li{
    padding-left: 26px;
}
.flowCheck li::before{
    content: "\f272";
    font-size: 1.2rem;
    color:#9B9A98;
    text-indent: -26px;
    display: inline-block;
    font-family: bootstrap-icons !important;
    font-style: normal;
    font-weight: normal !important;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    vertical-align: -4px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
.flowCheck ul{
    margin-left: 15px;
}
.flowCheck ul li::before{
    content: "\f309";
    font-size: 2.5rem;
    line-height: 0.6;
    margin-right: -6px;
    vertical-align: -15px;
}
/* policy */
.policy .modal-header{
    border-bottom: none;
}
.policy .modal-header .btn-close{
    border-bottom: none;
    color: #fff;
    width: 3rem;
    height: 3rem;
    opacity: 0.8;
    background: #000;    
    border-radius: 0;
    padding: 14px;
}
.policy .modal-header .btn-close:hover{
    opacity: 1;
}
/* about */
.abouttop_bg{
    height:calc(100vw * 560 / 1920);
    min-height: 400px;
    background:url("../images/aboutXavier/about_big.jpg") center top no-repeat;
    background-size: cover;
}
.about_bg{
    background:url("../images/aboutXavier/about_bg1.png") center top no-repeat;
    background-size: contain;
}
.about_bookNowBtn{
    background-color: #e5e5e5;
}
.about_diff{
    background-color: rgba(0,0,0,0.8);
}
.about_diff_desc{
    height: 150px;
}
.about_build_title{
    border-right: 1px solid #999;
}
/* .about_build_txt{
    padding-left: 3rem;
} */
.about_how_img{
    width: 95px;
}

/* contact */
.contact_bg{
    background-size: cover;
    background-position: center;
    position: relative;
    z-index: 1;
    /* height: calc(100vh - (100vw * 355 / 1920)); */
    height: 300px;
}
/* .contact_bg::before{
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    background: rgba(0,0,0,0.5);
    z-index: -1;
} */
.franchisTxt{      
    border-left: 1px solid #fff;
}

.franchFrame .swiper-pagination{
    position: initial;
    transform: translate3d(0, 0, 0);
}
.franchList{
    width:18%;
    max-width: 230px;
}
.franchSlider{
    overflow: hidden;
    width: 60%;
    max-width: 700px;
    margin-left: 30px;    
}
.franchSlider .swiper{
    height: 100%;
}
.franchSlider .swiper-slide{
    position: relative;
}
.franchSlider .franchTitle{    
    margin-right: 30px;
}
.franchSlider .franchTitle h3{   
    padding-top: 20px;
    display: inline-block;
    border-top: 5px solid var(--Gray3);
    color: var(--Gray3);
    font-size: 1.25rem;    
}
.franchImg{
    margin-top: 80px;
    max-width: 350px;
}
.franchFlowlist{
    margin-left: 15px;
}
.franchFlowlist li{
    list-style-type: decimal;
}
.franchFrame .franchList{
    margin-right: 30px;
}
.franchList .swiper-pagination{
    border-top: 1px solid #cecece;
}
.franchFrame .franchList .swiper-pagination-bullet{
    display: block;
    width: 100%;    
    height: auto;
    margin: 0;
    padding: 10px 20px 5px;  
    text-align: left;
    border-radius:0;
    border-bottom: 1px solid #cecece;
    opacity: 1;
    font-size: 1rem;
    color: var(--Gray2);
    background: none;
}
.franchFrame .franchList .swiper-pagination-bullet .panNo{
    font-size: 3.25rem;
    line-height: 1.1;
    color: var(--Gray6);
}
.franchFrame .franchList .swiper-pagination-bullet.swiper-pagination-bullet-active{
    color: #fff;    
    background: var(--Gray2);
}
.franchising_build_title{
    text-align: center;
}
.franchising_build_txt{
    text-align: center;
    border-left: 1px solid #666;
}

/* products */
.shop_slider{
    position: relative;
}
/* 篩選 按鈕顏色58D9AB */
.swiper-button-prev,
.swiper-button-next {  
  color: #fff !important;
  width: calc(var(--swiper-navigation-size) / 44 * 42);
  height:calc(var(--swiper-navigation-size) / 44 * 60);
  display: none;
}
.swiper-button-prev:after,
.swiper-button-next:after {
  font-size: 1.875rem;
  margin: 10px;
  padding: 10px;
}
.swiper-button-prev,
.swiper-rtl .swiper-button-next {
  left: 10px;
  right: auto;
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
  right: 10px;
  left: auto;
}
.my-pagination{
    /* position: initial !important; */
    position: absolute;
    margin: 20px auto;
    display: flex;
    padding-left: calc((100vw - 1320px)/2);
    padding-right: calc((100vw - 1320px)/2);
}
.my-bullet{
    /* width: 16px; */
    width: 100%;
    max-width: 100%;
    /* height: 16px; */
    height: 1px;
    display: inline-block;
    /* border-radius: 50%; */
    /* opacity: 0.5; */
    opacity: 0.2;
    /* margin: 0 8px; */
    background-color:#fff;
    /* border:1px solid var(--Gray2); */
    border:1px solid #fff;
    flex: 1 0 0%;
    position: relative;
}
.my-bullet::before {
    content: "";
    position: absolute;
    right: 0;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    padding: 10px 0;
}
.my-bullet-active{
    opacity: 1;
    /* background-color:var(--Gray9); */
    /* border:1px solid var(--Gray6); */
    border:1px solid #fff;
}
/* nav-tabs */
.productsNavtabs .nav-tabs .nav-link{
    font-size: 1.125rem;
    color: var(--Gray9);
}
.productsNavtabs .nav-tabs .nav-link:hover,
.productsNavtabs .nav-tabs .nav-link:focus {
    color: var(--Gray6);
    border-color: #fff #fff var(--Gray6);
    isolation: isolate;
}
.productsNavtabs .nav-tabs .nav-link.active,
.productsNavtabs .nav-tabs .nav-item.show .nav-link {
    color: var(--Gray3);
    background-color: #fff;
    border-color: #fff #fff var(--Gray3);
}
/* login */
.registerLogin,
.loginLogin{
    height: 100%;
    background-size: cover !important;
}
.registerLogin{
    border-right: 1px solid #dee2e6;
}
/* m_order */
.status_success{
    color: #fff;
    background-color: #198754;
}
.status_fail{
    color: #fff;
    background-color: #f00;
}
.status_normal{
    color: #333;
    background-color: #f8f9fa;
}
.item-proname{
    width: 220px;
}
.item-proname a{
    display: inline-block;
}
.item-size{
    width: 100px;
}
.shop_content_price{
    line-height: 14px;
}
/* cart */
.cartbadge {
    position: relative;
}
.cartbadgenum {
    position: absolute;
    right: 8px;
    top: -3px;
    display: block;
    width: 23px;
    height: 23px;
    line-height: 23px;
    font-family:Arial, Helvetica, sans-serif;
    font-size: 12px;
    text-align: center;
    color: #fefefe;
    /* background-color: rgb(206, 4, 4); */
    background-color: #000;
    border-radius: 50%;
    z-index: 10;
    letter-spacing: 0;
    width: 8px;
    height: 8px;
    right: -8px;
}
.shoplist-title {
    padding-top: 10px;
    width: 140px;
    text-align: center;
}
.stepper {
    width: calc(100% - 280px);
}
.stepper-label {
    width: 80px;
}
.stepper-line {
    width: 70px;
    height: 1px;
    background-color: #666;
}
.stepper-circle {
    width: 60px;
    height: 60px;
    font-family: Arial, Helvetica, sans-serif;
    border-radius: 50%;
    line-height: 60px;
    background-color: #fff;
    color: #333;
    border:1px solid #666;
}
.stepper-circle.active {
    color: #fff;
    background-color: #333;
}
.loginf .select select{
    font-size: 14px;    
}
ul.num{
    margin-left: 16px;
}
ul.num li{
    list-style-type:decimal;
}
.addressShowA,
.addressShowC {
    display: none;
    transition: all 0.3s linear;
}
.addressShowA.active,
.addressShowC.active  {
    display: block;
    transition: all 0.3s linear;
}
.cart-img{
    width: 120px;
}
/* faq */
.accordion-button:not(.collapsed){
    background-color: transparent;
    color: var(--linkFocus);
}
.accordion-flush .accordion-item:last-child{
    border-bottom: 1px solid rgba(0, 0, 0, 0.125);
}
.accordion-collapse{
    background: none;
}
/* counter */
.counter {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    position: relative;
    display: inline-block;
    padding: 0 30px;
    border-radius: 10rem;
}
.counter .counter-minus {
    left: 0;
    border: 1px solid #999;
    color: #999;
    display: flex;
    justify-content: center;
    align-items: center;
}
.counter .counter-minus, .counter .counter-plus {
    -webkit-transition: all 0.2s;
    -moz-transition: all 0.2s;
    transition: all 0.2s;
    -webkit-transition-delay: 0s;
    -moz-transition-delay: 0s;
    transition-delay: 0s;
    position: absolute;
    top: 0;
    /* display: block; */
    width: 30px;
    height: 30px;
    line-height: 30px;
    border-radius: 50%;
    cursor: pointer;
}
/* .counter .counter-minus.active, .counter .counter-plus.active {
    cursor: pointer;
} */
.counter-value {
    width: 30px;
    line-height: 30px;
    text-align: center;
    color: #000;
    background: transparent;
    border: 0;
}
.counter .counter-plus {
    right: 0;
    border: 1px solid #999;
    color: #999;
    display: flex;
    align-items: center;
    justify-content: center;
}
.cart_divider{
    position: relative;
}
.cart_divider::before{
    content: "";
    width: 1px;
    height: 100%;
    background-color: rgba(33, 37, 41, 0.25);
    position: absolute;
    left: 12px;
    top: 0;
    bottom: 0;
}
.cartListTrigger{
    cursor: pointer;
}
.offcanvas .offcanvas-header .nav-close-button{
    width: 44px;
    height: 44px;
    line-height: 44px;
    right: 16px;
    position: absolute;
    background: none;
    border: none;
}
.offcanvas .offcanvas-header .nav-close-button span{
    width: 44px;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    text-align: center;
    cursor: pointer;
    transition: background .2s ease;
}
.offcanvas .offcanvas-header .nav-close-button span::before,
.offcanvas .offcanvas-header .nav-close-button span::after{
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 15px;
    height: 15px;
    margin-top: -3px;
    border-top: 1px solid #000;
    border-left: 1px solid #000;
    margin-top: -6px;
}
.offcanvas .offcanvas-header .nav-close-button span::before{
    transform: rotate(135deg);
    margin-left: -20px;
}
.offcanvas .offcanvas-header .nav-close-button span::after{
    transform: rotate(-45deg);
}
.offcanvas .offcanvas-footer{
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    background: #fff;
    border-top: 1px solid #DEE2E6;
    padding: 24px;
    text-align: center;
}
.offcanvas .offcanvas-body{
    padding-bottom: 100px;
}

/* header 右上會員中心 */
.dropdown-toggle::after{
    display: none;
}
.dropdown_menu{
    position: absolute;
    z-index: 1000;
    display: none;
    padding: 0.5rem 0;
    margin: 0;
    font-size: 0.875rem;
    color: #212529;
    list-style: none;
    background-clip: padding-box;
    border-radius: 0.25rem;
    right: 0;
    /* transition: cubic-bezier(0.075, 0.82, 0.165, 1);
    -webkit-transition: cubic-bezier(0.075, 0.82, 0.165, 1); */
}
.dropdown_menu_dark{
    color: #dee2e6;
    background-color: #202225;
    border-color: rgba(0, 0, 0, 0.15);
}
.dropdown_menu.show{
    display: block;
    /* transition: cubic-bezier(0.075, 0.82, 0.165, 1);
    -webkit-transition: cubic-bezier(0.075, 0.82, 0.165, 1); */
}
.dropdown-item:hover, .dropdown-item:focus{
    background-color: #272a2d;
}

/* instafeed */
.instafeed-img{
    position: relative;
}
.instafeed-img .instafeed-overlay{
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    transition: all 0.5s;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    background: rgba(0,0,0,0.3);
    opacity: 0;
}
.instafeed-img:hover .instafeed-overlay{
    opacity: 1;
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
    transition: all 0.5s;
}
/* .modal-dialog-scrollable .modal-content{
    overflow-y: scroll;
}
.modal-dialog-scrollable .modal-content .modal-body{
    max-height: 758px;
    overflow-y: scroll;
} */
/* instafeed with carousel */
.carousel-control-next-icon,
.carousel-control-prev-icon{
  background-color: rgba(0,0,0,.5);
  border-radius: 50%;
  background-size: 60%;
  background-position: center;
}
.carousel-control-next, .carousel-control-prev{
  width: 10%;
}
.btn-close{
  z-index: 9;
}

/* helpCenter nav-link */
.hc_nav .nav-link{
    position: relative;
}
.hc_nav .nav-link-text{
    background-position: 100% 100%;
    background-size: 0% 2px;
    background-repeat: no-repeat;
    -webkit-transition: background-size .5s cubic-bezier(.165, .84, .44, 1);
    transition: background-size .5s cubic-bezier(.165, .84, .44, 1);
    background-image: linear-gradient(var(--bs-dark), var(--bs-dark));
}

.hc_nav .nav-link-text:hover,
.hc_nav .nav-link.active .nav-link-text{
    background-position: 0 100%;
    background-size: 100% 2px;
    text-decoration: none;
}
.accordion-button::after{
    width: 1rem;
    height: 1rem;
    background-size: contain;
}