@charset "UTF-8";

/**************************************

                通用格式

**************************************/

body {
    padding: 0;
    margin: 0;
    font-family: "Noto Sans TC", sans-serif, "微軟正黑體", Arial, Helvetica, sans-serif;
    background-color: #fff;
    font-weight: 500;
}

img {
    width: 100%;
    display: block;
}

ul,
li {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

a {
    text-decoration: none;
    color: #000;
}


/**************************************

            全域使用設定

**************************************/

.wrapBg {
    background-color: #fff;
}

.wrapBg .mainArea{
    width: 100%;
    max-width: 970px;
    margin: 0 auto;
    position: relative;
}

.navBg{
    position: fixed;
    z-index: 999;
    width: 100%;
    background-color: #304286;
    box-shadow: 0 0 10px 0px #b7b7b7;    
}

.navBg .nav {

}

.navBg .navBar {
    display: flex;
    max-width: 1000px;
    margin: 0 auto;
    justify-content: center;
    align-items: center;
}

.navBg .btn_area {
    display: inline-flex;
    list-style-type: none;
    margin-block-start: 0;
    margin-block-end: 0;
    margin-inline-start: 0;
    margin-inline-end: 0;
    padding-inline-start: 0;
    width: 100%;
}

.navBg .btn_area li {
    font-family: "Noto Sans TC", sans-serif, "微軟正黑體", Arial, Helvetica, sans-serif;
    font-size: 29px;
    font-weight: 800;
    width: 106px;
    text-align: center;
    text-decoration: unset;
    flex: 1 1 20%;
}

.navBg .btn_area li a {
    display: flex;
    align-items: center;
    height: 100%;
    justify-content: center;
    color: #fff;
}

.navBg .btn_area li a.logo {
    margin: auto;
    cursor: pointer;
    width: 112px;
    margin: 0 auto;
}

.navBg .btn_area li a span {
    font-weight: bold;
    width: 100%;
    border-left: 1px solid rgba(255,255,255,0.4);
}

.navBg .btn_area li a.menu_buy {
    padding: 12px 0;
    box-sizing: border-box;
    background-color: #b4ddf3;
    color:#304286 
}

.navBg .btn_area li a.menu_buy span {
    border-bottom: none;
}

.navBg .btn_area li a:hover{
    color:#304286 ;
    background-color: #b4ddf3;
}

.navBg .btn_area li a.logo:hover {
    background-color: transparent;
}

.navBg .btn_area li a:hover span {

}


/**************************************
  
              內容設定
  
  **************************************/
.wrapBg .fvBg{
    background: url(../images/fv_bg.jpg) center top no-repeat;
    animation-name: fadeInAction;
    animation-duration: 2s;
    animation-fill-mode: forwards;
}

.wrapBg .fvBg .mainArea{
    height: 1039px;
}

.wrapBg .fvBg .mainArea .info{
    position: absolute;
    top: 86%;
    left: 50%;
    transform: translate(-50%,0);
    width: 900px;
    opacity: 0;
}

.wrapBg .fvBg .mainArea .info.addAction,
.wrapBg .fvBg .mainArea .info.mobAction{
    animation-name: fadeBottomAction;
    animation-duration: 0.6s;
    animation-fill-mode: forwards;
}

.wrapBg .fvBg .mainArea .movie{
    background: url(../images/fv_movie.png) center center no-repeat;
    background-size: 100% auto;
    position: absolute;
    top: 58%;
    right: 4%;
    width: 228px;
    height: 250px;
    opacity: 0;
}

.wrapBg .fvBg .mainArea .movie img{
    width: 85%;
    display: block;
    position: absolute;
    top: 20%;
    left: 3%;
}

.wrapBg .fvBg .mainArea .movie.addAction,
.wrapBg .fvBg .mainArea .movie.mobAction{
    animation-name: fadeRightAction;
    animation-duration: 0.6s;
    animation-fill-mode: forwards;
    animation-delay: 0.3s;
}


.wrapBg .hotBg{
    background-color: #b4dbf2;
    max-width: 1920px;
    width: 100%;
    margin: 0 auto;
    pointer-events: none;
}

.wrapBg .hotBg .mainArea{
    padding: 300px 0 100px 0;
    box-sizing: border-box;
}

.wrapBg .movieBg{
    background-color: #4e83c9;
    max-width: 1920px;
    width: 100%;
    margin: 0 auto;
}

.wrapBg .movieBg .mainArea{
    padding: 60px 0 30px 0;
    box-sizing: border-box;    
}

.wrapBg .movieBg .mainArea .video{
    position: absolute;
    top: 30.4%;
    left: 50%;
    transform: translate(-50%,0);
    width: 762px;
}

.wrapBg .contentBg{

}

.wrapBg .contentBg .mainArea.topPadding{
    padding-top: 40px;
}

.wrapBg .contentBg .mainArea.bottomPadding{
    padding-bottom: 40px;
}

.wrapBg .contentBg .offerBox{
    position: relative;
}

.wrapBg .contentBg .offerBox .btn{
    position: absolute;
    top: 83%;
    left: 50%;
    transform: translate(-50%,0);
    width: 85%;
    animation-name: btnAction;
    animation-duration: 0.8s;
    animation-iteration-count: infinite;
}

.wrapBg .contentBg .slickBox{
    position: relative;
}

.wrapBg .contentBg .slickSet{
    position: absolute;
    top: 31.5%;
    left: 50%;
    transform: translate(-50%,0);
    width: 94%;
}

.wrapBg .contentBg .byeBox{
    position: relative;
}

.wrapBg .contentBg .byeBox .icon1{
    position: absolute;
    top: 25%;
    left: 6%;
    width: 241px;
    height: 156px;
    opacity: 0;
}
.wrapBg .contentBg .byeBox .icon2{
    position: absolute;
    top: 30%;
    left: 71%;
    width: 241px;
    height: 156px;
    opacity: 0;
}
.wrapBg .contentBg .byeBox .icon3{
    position: absolute;
    top: 67%;
    left: 57%;
    width: 246px;
    height: 150px;
    opacity: 0;
}
.wrapBg .contentBg .byeBox .icon1.addAction,
.wrapBg .contentBg .byeBox .icon1.mobAction{
    animation-name: iconBottomAction;
    animation-duration: 0.6s;
    animation-fill-mode: forwards;
}
.wrapBg .contentBg .byeBox .icon2.addAction,
.wrapBg .contentBg .byeBox .icon2.mobAction{
    animation-name: iconBottomAction;
    animation-duration: 0.6s;
    animation-fill-mode: forwards;
    animation-delay: 0.2s;
}
.wrapBg .contentBg .byeBox .icon3.addAction,
.wrapBg .contentBg .byeBox .icon3.mobAction{
    animation-name: iconBottomAction;
    animation-duration: 0.6s;
    animation-fill-mode: forwards;
}

.wrapBg .isoBg{
    background: url(../images/page_img09.jpg) center top no-repeat;
    height: 1409px;
}

.wrapBg .stepBg{
    background: url(../images/page_img10.jpg) center top no-repeat;
    height: 1680px;
}

.wrapBg .qaBg{
    background-color: #4e83c9;
}

.wrapBg .qaBg .mainArea{
    padding-bottom: 40px;
}

.wrapBg .qaBg .qaList{}
.wrapBg .qaBg .qaList li{
    margin-bottom: 40px;
}
.wrapBg .qaBg .qaList li .question{
    position: relative;
    cursor: pointer;
}
.wrapBg .qaBg .qaList li .question .icon{
    position: absolute;
    top: 50%;
    transform: translate(0, -50%) rotate(0deg);
    transition: 0.4s;
    right: 3%;
    width: 60px;
    height: 34px;
}
.wrapBg .qaBg .qaList li .answer{
    display: none;
}

.wrapBg .qaBg .qaList li.open .question .icon{
    transform: translate(0, -50%) rotate(180deg); 
    transition: 0.4s;  
}

.wrapBg .contactBg{
    background-color: #b4dbf2;   
}

.flotBtnBg{
    position: fixed;
    bottom: 0;
    left: 50%;
    transform: translate(-50%,0);
    width: 760px;
    opacity: 0;
    pointer-events: none;
    transition: all .5s ease-in-out;
}

.flotBtnBg.scrollDown{
    transition: all .5s ease-in-out;
    transform: translate(-50%,0);
    opacity: 1;
    pointer-events: initial;
    visibility: visible;
    filter: drop-shadow(2px 4px 6px rgba(0,0,0,0.5));
}

.slick-dots li button:before {
    font-size: 78px;
    color: #4e83c9
}

.slick-dots li.slick-active button:before {
    color: #304286
}

.wrapBg footer .mainArea{
    padding-bottom: 200px;
}



@keyframes btnAction {
    0% {
        transform:translate(-50%,0) scale(1);
    }
    50% {
        transform:translate(-50%,0) scale(1.1);
    }
    100% {
        transform:translate(-50%,0) scale(1);
    }
}

@keyframes fadeRightAction {
    0% {
      transform: translate(150px, 0);
      opacity: 0;
    }
    100% {
      transform: translate(0, 0px);
      opacity: 1;
    }
}
@keyframes fadeBottomAction {
    0% {
      transform: translate(-50%, 150px);
      opacity: 0;
    }
    100% {
      transform: translate(-50%, 0px);
      opacity: 1;
    }
}

@keyframes fadeInAction {
    0% {
      opacity: 0;
    }
    100% {
      opacity: 1;
    }
}

@keyframes iconBottomAction {
    0% {
      transform: translate(0, 150px);
      opacity: 0;
    }
    100% {
      transform: translate(0, 0px);
      opacity: 1;
    }
}




@media only screen and (max-width: 970px) {
    .wrapBg {
        width: 100%;
    }
    .navBg .btn_area li a.logo{
        width: 15vw;
    }
    .wrapBg .fvBg{
        background: url(../images/fv_bg_mob.jpg) center bottom no-repeat;
        background-size: 100% auto;
    }
    .wrapBg .fvBg .mainArea{
        height: 112vw;
    }
    .wrapBg .fvBg .mainArea .info{
        width: 96%;
    }
    .wrapBg .fvBg .mainArea .movie{
        top: 55%;
        right: 3%;
        width: 25vw;
        height: 34vw;
    }
    .wrapBg .fvBg .mainArea .movie img{
        width: 84%;
        top: 26.4%;
        left: 3%;
    }
    .wrapBg .hotBg .mainArea{
        padding: 30vw 0 8vw 0;
    }
    .wrapBg .contentBg .mainArea.topPadding{
        padding-top: 1vw;
    }
    .wrapBg .contentBg .mainArea.bottomPadding{
        padding-bottom: 0;
    }
    .wrapBg .contentBg .slickSet{
        width: 90%;
    }
    .wrapBg .movieBg .mainArea{
        padding: 8vw 0 8vw 0;
    }
    .wrapBg .movieBg .mainArea .video{
        width: 78vw;
        height: 43.8vw;
    }
    .wrapBg .isoBg{
        background: url(../images/page_img09_mob.jpg) center top no-repeat;
        background-size: 100% auto;
        height: 145vw;
    }
    .wrapBg .stepBg{
        background: url(../images/page_img10_mob.jpg) center top no-repeat;
        background-size: 100% auto;
        height: 173vw;
    }
    .wrapBg .qaBg .qaList{
        margin: 0 2vw;
    }
    .wrapBg .qaBg .qaList li{
        margin-bottom: 3vw;
    }
    .wrapBg .qaBg .qaList li .question .icon{
        width: 7vw;
        height: 4vw;
    }
    .flotBtnBg{
        width: 86%;
    }
    .wrapBg .contentBg .byeBox .icon1{
        top: 26%;
        left: 4%;
        width: 24vw;
        height: 16vw;
    }
    .wrapBg .contentBg .byeBox .icon2{
        top: 30%;
        left: 71%;
        width: 26vw;
        height: 15vw;
    }
    .wrapBg .contentBg .byeBox .icon3{
        top: 67%;
        left: 56%;
        width: 28vw;
        height: 22vw;
    }
    .wrapBg footer .mainArea{
        padding-bottom: 22vw;
    }

}

@media only screen and (max-width: 468px) {
    .navBg .btn_area li a {
        font-size: 4.1vw;
    }
}
