@charset "UTF-8";

html {
    font-size: 16px;
    -webkit-text-size-adjust:none;
    color:#303030;
}
@media screen and (max-width: 640px) {
    html {
        font-size: 2.5vw;
    }
}
body {
    background: #fff;
	font-size:12px;
    font-family:Helvetica,Arial,'Noto Sans TC',"Microsoft JhengHei",sans-serif;
    background: #f7f0f4;
}

img {
    position: relative;
    display: block;
    border: 0;
    width: 100%;
    height: auto;
}
.wrap {
    position: absolute;
    display: block;
    width: 100%;
    overflow: hidden;
}
.wrap .preload {
    display: none;
}

.wrap .footerBox {
    position: relative;
    display: block;
    width: 100%;
    padding: 1rem 0 1rem 0;
    background: #000;
    z-index: 2;
}

.wrap .footerBox .socialmedia {
    position: relative;
    display: block;
    width: 100%;
    font-size: 0;
    text-align: center;
    padding: 15px 0 15px 0;
}
.wrap .footerBox .socialmedia li {
    position: relative;
    display: inline-block;
    width: 6rem;
    max-width: 55px;
    margin: 0 1rem 0 1rem;
}
.wrap .footerBox .copyright {
    position: relative;
    display: block;
    text-align: center;
    font-size: 12px;
    padding: 15px 0 0 0;
    font-family:Helvetica,Arial,"微軟正黑體","Microsoft JhengHei",sans-serif;
    color: #fff;
}
.wrap .footerBox .copyright br {
    display: none;
}
@media screen and (max-width: 1000px) {
    .wrap .footerBox .copyright br {
        display: block;
    }
}

.stage-container {
    position: relative;
    display: block;
    width: 100%;
    overflow: hidden;
}
.stage-container .logo {
    position: absolute;
    display: block;
    width: 6rem;
    left: calc(50% - 18rem);
    top:2rem;
    z-index: 10;
}
.stage-container .stagebox {
    position: relative;
    display: block;
    width: 40rem;
    margin: 0 auto;
    overflow: hidden;
}
.stage-container-kv {
    background: url(../images/kv_bg.jpg) no-repeat center top;
    background-size: 120rem auto;
    z-index: 9;
}
.stage-container .stage-kv {
    height: 100vh;
    min-height: 70rem;
    max-height: 80rem;
    background: url(../images/kv_bg1.jpg) repeat center center;
    overflow: hidden;
    box-shadow: 0 0 2rem rgba(0,0,0,0.2);
}

.kv-title {
    position: absolute;
    display: block;
    width: 23rem;
    left: 8.5rem;
    top:5rem;
}
.kv-text1 {
    position: absolute;
    display: block;
    width: 20rem;
    left: 9.5rem;
    top:26rem;
}
.kv-text2 {
    position: absolute;
    display: block;
    width: 3.5rem;
    right: 1rem;
    bottom:1rem;
}
.kv-bg {
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
    background: url(../images/kv_bg2.jpg) no-repeat center top;
    background-size: 40rem auto;
    -webkit-clip-path:inset(40% 20% 5% 20% round 15rem 15rem 0 0);
    clip-path:inset(40% 20% 5% 20% round 15rem 15rem 0 0);
}
.kv-icon1 {
    position: absolute;
    display: block;
    width: 5.3rem;
    left: 8rem;
    top:6rem;
}
.kv-icon2 {
    position: absolute;
    display: block;
    width: 7.6rem;
    right: 4rem;
    top:10rem;
}
.kv-icon3 {
    position: absolute;
    display: block;
    width: 9.5rem;
    left: 0.5rem;
    top:23rem;
}
.stage-container-main {
    background: url(../images/main_bg.jpg) repeat-x center center;
    background-size: auto 100%;
}
.intro-title {
    position: relative;
    display: block;
    width: 33rem;
    margin: 0 auto;
    padding: 4rem 0 4rem 0;    
}
.intro-text {
    position: relative;
    display: block;
    width: 85%;
    margin: 0 auto;
}
.intro-text span {
    position: relative;
    display: block;
    text-align: left;
    font-family:'Noto Serif TC',"Microsoft JhengHei",sans-serif;
    font-size: 1.7rem;
    line-height: 3.5rem;
    color: #000;
    font-weight: 700;
}
.intro-dot {
    position: relative;
    display: block;
    width: 4.8rem;
    margin: -2rem 0 0 30rem;
}
.side-btn {
    position: fixed;
    display: block;
    width: 8rem;
    top:3rem;
    left: calc(50% + 10rem);
    z-index: 2;
    cursor: pointer;
}
.product-container {
    position: relative;
    display: block;
    width: 100%;
    padding: 5rem 0 3rem 0;
}
.product-list {
    position: relative;
    display: block;
    width: 100%;
}
.product-list li {
    position: relative;
    display: block;
    width: 100%;
}
.product-list .item {
    position: relative;
    display: block;
    width: 34rem;
    margin: 0 auto;
}
.product-list .item .imgbox {
    position: relative;
    display: block;
    width: 100%;
}
.product-list .item .imgbox .pic {
    position: relative;
    display: block;
    width: 100%;
    height: 50rem;
    overflow: hidden;
    border-radius: 17rem;
}
.product-list .item .imgbox .t1 {
    position: absolute;
    display: block;
    width: 100%;
    text-align: center;
    top:2rem;
}
.product-list .item .imgbox .t1 span {
    position: relative;
    display: inline-block;
    font-size: 3rem;
    line-height: 3rem;
    padding: 1rem 3rem;
    background: #fff;
    border:2px #e16989 solid;
    color:#e16989;
    font-family:'Noto Serif TC',"Microsoft JhengHei",sans-serif;
    font-weight: 700;
}
.product-list .item .imgbox .t2 {
    position: absolute;
    display: block;
    width: 100%;
    text-align: center;
    top:8.5rem;
}
.product-list .item .imgbox .t2 span {
    position: relative;
    display: inline-block;
    font-size: 2rem;
    line-height: 2rem;
    padding: 1rem 2rem;
    background: #fff;
    border:2px #e16989 solid;
    color:#e16989;
    font-family:'Noto Sans TC',"Microsoft JhengHei",sans-serif;
    font-weight: 500;
}
.product-list .item .textbox {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
}
.product-list .item .textbox span {
    position: relative;
    display: block;
    font-size: 1.8rem;
    line-height: 2.4rem;
    color:#e16989;
    font-family:'Noto Sans TC',"Microsoft JhengHei",sans-serif;
    font-weight: 500;
    text-align: center;
    padding: 2rem 0;
}
.product-list .item .textbox .more-btn {
    position: relative;
    display: block;
    font-size: 2rem;
    line-height: 2rem;
    padding: 1rem 2rem;
    background: #fff;
    border:2px #e16989 solid;
    color:#e16989;
    font-family:'Noto Sans TC',"Microsoft JhengHei",sans-serif;
    font-weight: 700;
    border-radius: 3rem;
}
.product-list .item .textbox .more-btn:hover {
    background: #e16989;
    color: #fff;
}
.video-title {
    position: relative;
    display: block;
    width: 18.6rem;
    margin: 0 auto;
}
.video-text {
    position: relative;
    display: block;
    font-size: 1.6rem;
    line-height: 1.6rem;
    text-align: center;
    padding: 1.5rem 0;
}
.video-container {
    position: relative;
    display: block;
    width: 100%;
}
.video-list {
    position: relative;
    display: block;
    width: 100%;
}
.video-list li {
    position: relative;
    display: block;
    width: 100%;
}
.video-list .item {
    position: relative;
    display: block;
    width: 36rem;
    margin: 0 auto;
    cursor: pointer;
}
.video-list .item .top-bar {
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    height: 4.4rem;
    background: #f2f2f2;
    border:1px solid #000;
}
.video-list .item .top-bar span {
    position: relative;
    display: block;
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    margin: 0 0 0 1rem;
}
.video-list .item .top-bar span:nth-of-type(1) {
    background: #fc605b;
}
.video-list .item .top-bar span:nth-of-type(2) {
    background: #fdbe41;
}
.video-list .item .top-bar span:nth-of-type(3) {
    background: #33c648;
}
.video-list .item .imgbox {
    position: relative;
    display: block;
    width: 100%;
    border-radius: 0 0 1rem 1rem;
    overflow: hidden;
}
.video-list .item .imgbox img {
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: transform 0.3s ease;
    -webkit-transform:scale(1);
    transform:scale(1);
}
.video-list .item:hover .imgbox img {
    -webkit-transform:scale(1.05);
    transform:scale(1.05);
}
.popup {
    position: fixed;
    display: none;
    width: 100%;
    height: 100%;
    z-index: 99;
    background: rgba(0,0,0,0.9);
}
.popup.expand {
    display: block;
}
.popup.popup-video .close-btn {
    position: absolute;
    display: block;
    width: 4rem;
    height: 4rem;
    right: 1rem;
    top:1rem;
    background: #eee;
    cursor: pointer;
    z-index: 999;
}
.popup.popup-video .close-btn::before {
    content: "";
    position: absolute;
    display: block;
    width: 80%;
    height: 3px;
    background: #000;
    left: 10%;
    top:calc(50% - 1px);
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.popup.popup-video .close-btn::after {
    content: "";
    position: absolute;
    display: block;
    width: 80%;
    height: 3px;
    background: #000;
    left: 10%;
    top:calc(50% - 1px);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.popup.popup-video .video-player-list{
    position: absolute;
    display: block;
    width: calc(100vw - 12rem);
    height: calc(56vw - 6.75rem);
    top:calc(50vh - 28vw + 3.375rem);
    left: 5rem;
}
.popup.popup-video .video-player-list li {
    position: absolute;
    display: none;
    width: 100%;
    height: 100%;
}
.popup.popup-video .video-player-list li.current {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
}
.popup.popup-video .video-player-list li iframe {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
}
@media screen and (max-width: 900px) {
    .popup.popup-video .video-player-list{
        position: absolute;
        display: block;
        width: 100vw;
        height: 56vw;
        top:calc(50vh - 28vw);
        left: 0;
    }
}


.card-title {
    position: relative;
    display: block;
    width: 33.3rem;
    margin: 0 auto;
    padding: 2rem 0 0 0;
}
.card-text {
    position: relative;
    display: block;
    font-size: 1.3rem;
    line-height: 2rem;
    text-align: center;
    padding: 1.5rem 0;
}
.card-container {
    position: relative;
    display: block;
    width: 100%;
}
.card-list {
    position: relative;
    display: block;
    width: 100%;
}
.card-list li {
    position: relative;
    display: block;
    width: 100%;
}
.card-list li .item {
    position: relative;
    display: block;
    width: 23.5rem;
    margin: 0 auto;
}
.card-list li .item .imgbox {
    position: relative;
    display: block;
    width: 100%;
}
.card-list li .item .textbox {
    position: absolute;
    display: block;
    width: 100%;
    bottom: 2rem;
}
.card-list li .item .textbox img {
    display: none;
}
.card-list.card-t1 li .item .textbox img.t1,
.card-list.card-t2 li .item .textbox img.t2,
.card-list.card-t3 li .item .textbox img.t3,
.card-list.card-t4 li .item .textbox img.t4 {
    display: block;
}
.left-arrow {
    position: absolute;
    display: block;
    width: 3rem;
    left: 2rem;
    top:15rem;
    cursor: pointer;
    -webkit-transform: scale(0.95);
    transform: scale(0.95);
}
.left-arrow:hover {
    -webkit-transform: scale(1);
    transform: scale(1);
}
.right-arrow {
    position: absolute;
    display: block;
    width: 3rem;
    right: 2rem;
    top:15rem;
    -webkit-transform: scale(0.95);
    transform: scale(0.95);
}
.right-arrow:hover {
    -webkit-transform: scale(1);
    transform: scale(1);
}
.card-container ul.slick-dots {
    padding: 2rem 0;
}
.card-text-list {
    position: relative;
    display: block;
    width: 75%;
    margin: 0 auto;
}
.card-text-list li {
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    background: #fff;
    border:1px solid #000;
    border-radius: 3rem;
    margin: 0.5rem 0;
    padding: 0.5rem 0;
    cursor: pointer;
}
.card-text-list li:hover {
    background: #eee;
}
.card-text-list li span {
    position: relative;
    display: block;
    font-size: 1.8rem;
    line-height: 1.6rem;
    color: #000;
    text-align: left;
}
.card-text-list li .dot-icon {
    position: relative;
    display: block;
    width: 2.5rem;
    height: 2.5rem;
    border: 1px solid #000;
    border-radius: 50%;
    margin: 0 2rem 0 2rem;
}
.card-text-list li .dot-icon::after {
    content: "";
    position: absolute;
    display: block;
    width: 1.6rem;
    height: 1.6rem;
    background: #000;
    border-radius: 50%;
    top: calc(50% - 0.8rem);
    left: calc(50% - 0.8rem);
    opacity: 0;
}
.card-text-list.card-t1 li.item1 .dot-icon::after,
.card-text-list.card-t2 li.item2 .dot-icon::after,
.card-text-list.card-t3 li.item3 .dot-icon::after,
.card-text-list.card-t4 li.item4 .dot-icon::after{
    opacity: 1;
}
.card-btnbox {
    position: relative;
    display: block;
    width: 75%;
    margin: 2rem auto 4rem auto;
}
.card-btnbox li {
    position: relative;
    display: flex;
    justify-content:space-between;
    align-items: center;
    width: 100%;
    margin: 0 0 1rem 0;
}
.card-btnbox li .card-btn {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    background: #76adb9;
    border-radius: 0.5rem;
    padding: 1rem 0;
    cursor: pointer;
}
.card-btnbox li .card-btn:hover {
    background: #000;
}
.card-btnbox li .card-btn span {
    position: relative;
    display: block;
    font-size: 1.8rem;
    line-height: 2rem;
    color: #fff;
    font-weight: 500;
    text-align: center;
}
.card-btnbox li .card-btn2,
.card-btnbox li .card-btn3{
    width: 14.5rem;
}
.popup-rule {
    background: rgba(0,0,0,0.1);
}
.rule-container{
    position: relative;
    display: block;
    width: 35rem;
    height: calc(100vh - 8rem);
    top: 4rem;
    background: #fff;
    margin: 0 auto;
    box-shadow: 0 0.5rem 1rem rgba(0,0,0,0.5);
    border:1px solid #000;
}
.rule-container .top-bar {
    position: relative;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    width: 100%;
    height: 4.4rem;
    background: #f2f2f2;
    border-bottom:1px solid #000;
}
.rule-container .top-bar span {
    position: relative;
    display: block;
    width: 1rem;
    height: 1rem;
    border-radius: 50%;
    margin: 0 0 0 1rem;
}
.rule-container .top-bar span:nth-of-type(1) {
    background: #fc605b;
}
.rule-container .top-bar span:nth-of-type(2) {
    background: #fdbe41;
}
.rule-container .top-bar span:nth-of-type(3) {
    background: #33c648;
}
.rule-container .close-btn {
    position: absolute;
    display: block;
    width: 3rem;
    height: 3rem;
    right: 0.6rem;
    top:0.6rem;
    cursor: pointer;
    z-index: 999;
}
.rule-container .close-btn::before {
    content: "";
    position: absolute;
    display: block;
    width: 80%;
    height: 3px;
    background: #000;
    left: 10%;
    top:calc(50% - 1px);
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.rule-container .close-btn::after {
    content: "";
    position: absolute;
    display: block;
    width: 80%;
    height: 3px;
    background: #000;
    left: 10%;
    top:calc(50% - 1px);
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}
.rule-container .textbox {
    position: relative;
    display: block;
    width: 100%;
    height: calc(100% - 4.4rem);
    overflow: hidden;
    overflow-y: auto;
}
.rule-container .textbox ul {
    position: relative;
    display: block;
    width: 100%;
    padding: 2rem;
}
.rule-container .textbox ul li {
    position: relative;
    display: block;
    font-size: 1.6rem;
    line-height: 2.4rem;
    margin: 0 0 1rem 0;
    color: #000;
}
.rule-container .textbox ul li span {
    font-weight: 700;
}
/* Slider */

.slick-slider {
    position: relative;
    display: block;
    box-sizing: border-box;

/*    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;*/

    -webkit-touch-callout: none;
    -khtml-user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.slick-list {
    position: relative;
    display: block;
    /*overflow: hidden;*/
    margin: 0;
    padding: 0;
    height: 100%;
}

.slick-list:focus {
    outline: none;
}

.slick-list.dragging {
    cursor: pointer;
    cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}

.slick-track {
    position: relative;
    top: 0;
    left: 0;
    display: block;
    height: 100%;
}

.slick-track:before,
.slick-track:after {
    display: table;
    content: '';
}

.slick-track:after {
    clear: both;
}

.slick-loading .slick-track {
    visibility: hidden;
}

.slick-slide {
    /*display: none;*/
    float: left;
    outline: none;
    /*height: 47vw;*/
    min-height: 1px;
    position: relative;
}
.slick-slide > div{width: 100%;}
.slick-slide *:focus{
    outline: none;
}
[dir='rtl'] .slick-slide {
    float: right;
}

.slick-slide.slick-loading img {
    display: none;
}

.slick-slide.dragging img {
    pointer-events: none;
}

.slick-initialized .slick-slide {
    display: flex;
}

.slick-loading .slick-slide {
    visibility: hidden;
}

.slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
    display: none;
}


.slick-arrow {
    cursor: pointer;
/*    position: absolute;
    display: block;
    width: 41px;
    height: 81px;
    cursor: pointer;
    top: 50%;
    margin-top: -40px;
    background-position: top;
    z-index: 1;
    text-indent: -9999px;
    border: 0px;*/
}

.slick-arrow:focus {
    outline: none;
}

.slick-prev {
    left: 0;
}

.slick-prev::after {
    content: '';
    position: absolute;
    display: block;
    width: 41px;
    height: 81px;
    background-position: bottom;
    transition: all 0.3s ease;
    -webkit-transition: all 0.3s ease;
    opacity: 0;
    top: 0px;
    left: 0px;
}

.slick-next {
    right: 0;
}

.slick-next::after {
    content: '';
    position: absolute;
    display: block;
    width: 41px;
    height: 81px;
    background-position: bottom;
    transition: all 0.3s ease;
    -webkit-transition: all 0.3s ease;
    opacity: 0;
    top: 0px;
    left: 0px;
}

.slick-arrow:hover:after {
    opacity: 1;
}

ul.slick-dots {
    /*position: absolute;*/
    display: block;
    width: 100%;
    font-size: 0;
    line-height: 0;
    text-align: center;
    position: relative;
    padding: 3rem 0;
}


ul.slick-dots li,ul.slick-dots li{
    position: relative;
    display: inline-block;
    width: 25px;
    height: 25px;
    opacity: 1;
    border-radius:50%;
    margin: 0 10px 0 10px;
    padding: 0;
    cursor: pointer;
    box-sizing: content-box;
}

.slick-dots li button {
    font-size: 0;
    line-height: 0;
    position: relative;
    display: block;
    width: 25px;
    height: 25px;
    border:1px solid #000;
    border-radius:50%;
    padding: 0px;
    margin: 0;
    cursor: pointer;
    background: rgba(255,255,255,0);
}

.slick-dots li button:hover,
.slick-dots li button:focus {
    outline: none;
    background:#000;
/*    transform: scale(1.2);
    -webkit-transform: scale(1.2);*/
}

.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
    opacity: 1;
}

.slick-dots li button:before {
    content: none;

}

.slick-dots li button:before{
    background: none;
}

.slick-dots li.slick-active button{
    background: #000;
}

button:focus{
    outline: none;
}
/* slider end */

.wrap a{z-index: 1;}
/*.brand-list .slider{
    margin: 0 0 0 0%;
}
.stage5 .wallpaper-viewbox .slider .wallpaper-img{
    margin: 0;
}
.brand-list .slick-slide{
    display: flex;justify-content: center;align-items: center;
}
.brand-list .slider li{
    padding: 0 5px;
    margin: 0;
}*/