@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100;300;400;500;700;900&display=swap');

* {
    margin: 0;
    padding: 0;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    font-family: 'Noto Sans TC', "Font Awesome 5 Free", sans-serif !important;
}

a:hover {
    text-decoration: none !important;
}

ul,
li {
    list-style-type: none;
    padding: 0px;
}

p {
    margin: 0px !important;
    padding: 0px !important;
}


@font-face {
    font-family: "MElle HK Xbold";
    src: url("../MElle HK Xbold/dd75c1a8cc825b46ec20f7f24344f573.eot");
    /* IE9*/
    src:
        url("../MElle HK Xbold/dd75c1a8cc825b46ec20f7f24344f573.woff2") format("woff2"),
        /* chrome、firefox */
        url("../MElle HK Xbold/dd75c1a8cc825b46ec20f7f24344f573.woff") format("woff"),
        /* chrome、firefox */
        url("../MElle HK Xbold/dd75c1a8cc825b46ec20f7f24344f573.ttf") format("truetype"),
        /* chrome、firefox、opera、Safari, Android, iOS 4.2+*/
        url("../MElle HK Xbold/dd75c1a8cc825b46ec20f7f24344f573.svg#MElle HK Xbold") format("svg");
    /* iOS 4.1- */
}

/*--------------topnav---------------*/
.topnav {
    overflow: hidden;
    background-color: #2f213e;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 1000;
}

.topnav a {
    width: 400px;
    margin: 1em auto;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
}

@media all and (max-width:1024px) {}

@media all and (max-width:768px) {}

@media all and (max-width:576px) {}

@media all and (max-width:425px) {

    .topnav a {
        width: 280px;
    }
}

@media all and (max-width:375px) {}

/*--------------#topnav---------------*/


/*--------------header---------------*/
.maxline {
    padding: 1em 0em;
    max-width: 1000px;
    margin: 0 auto;
}

.bg_banner {
    background: url(../img/header-1.jpg) center bottom/cover no-repeat;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-top: 68px;
    overflow: hidden;
}


.bg_banner .headerimg {
    width: 70%;
    margin: 4% 0;
}

@media all and (max-width:1200px) {
    .bg_banner .headerimg {
        width: 85%;
    }
}

@media all and (max-width:768px) {
    .bg_banner .headerimg {
        width: 90%;
    }
}

@media all and (max-width:425px) {
    .bg_banner {
        margin-top: 56px;
    }
}

/*--------------#header---------------*/

/*--------------------------------------title-------------------------------------------------*/
.title1 {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 2em auto;
}

.titletext {
    position: relative;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 1em auto;
    text-align: center;
    color: #503a56;
    background: #fff;
    padding: 0 2em;
    border-radius: 5px;
    z-index: 1;
}

.titletext::before {
    content: '';
    position: absolute;
    top: 50%;
    left: -.5em;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 2.5em;
    height: 2.5em;
    border-radius: 50%;
    background: #fff;
    z-index: -1;
}

.titletext::after {
    content: '';
    position: absolute;
    top: 50%;
    right: -.5em;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 2.5em;
    height: 2.5em;
    border-radius: 50%;
    background: #fff;
    z-index: -1;
}

.titletext h2 {
    font-size: 3em;
    font-family: "MElle HK Xbold" !important;
    margin-bottom: 0px;
}

.titletext h2 span {
    color: #c30d23;
    font-family: "MElle HK Xbold" !important;
}

.titletext h2 br {
    display: none;
}

@media all and (max-width:1280px) {
    .titletext h2 {
        font-size: 2.5em;
    }
}

@media all and (max-width:1024px) {}

@media all and (max-width:768px) {
    .titletext h2 br {
        display: block;
    }
}

@media all and (max-width:576px) {}

@media all and (max-width:425px) {
    .title1 {
        width: 90%;
    }
}

@media all and (max-width:375px) {}

/*--------------------------------------#title-------------------------------------------------*/

/*--------------------------------------pt1-------------------------------------------------*/
.pt1 {
    background-color: #f2b519;
    overflow: hidden;
}

.a01box {
    width: 80%;
    margin: 1em auto;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: space-between;
       -moz-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-align-items: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
}

.a01box a {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 1em 0em;
    background: #fff;
    text-align: center;
    padding: .5em 3em;
    border-radius: 5px;
    margin-top: 3em;
    -webkit-transition: all .15s;
    -moz-transition: all .15s;
    transition: all .15s;
}

.a01box a:hover {
    -webkit-transform: translate(0.25em, 0.1em) scale(0.9);
       -moz-transform: translate(0.25em, 0.1em) scale(0.9);
        -ms-transform: translate(0.25em, 0.1em) scale(0.9);
            transform: translate(0.25em, 0.1em) scale(0.9);
}

.a01box a h4 {
    font-size: 2.5em;
    font-family: "MElle HK Xbold" !important;
    margin-bottom: 0px;
    z-index: 5;
}

.a01box .a01-1 {
    position: relative;
    color: #204964;
}

.a01box .a01-2 {
    position: relative;
    color: #ae1e28;
}

.a01box .a01-1::before,
.a01box .a01-2::before {
    content: '';
    position: absolute;
    top: -4em;
    left: 50%;
    -webkit-transform: translateX(-50%);
       -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    width: 80px;
    height: 80px;
    background: url(../img/a01-1.png) center/cover no-repeat, #fff;
    border-radius: 50%;
}

.a01box .a01-2::before {
    background: url(../img/a01-2.png) center/cover no-repeat, #fff;
}

.a01box a::after,
.a01box a::after {
    content: '';
    position: absolute;
    bottom: -1em;
    right: -1em;
    background: url(../img/point.png) center/cover no-repeat;
    width: 48px;
    height: 50px;
    -webkit-transition: all .15s;
    -moz-transition: all .15s;
    transition: all .15s;
}

.a01box a:hover::after {
    -webkit-transform: scale(0);
       -moz-transform: scale(0);
        -ms-transform: scale(0);
            transform: scale(0);
}

@media all and (max-width:1024px) {}

@media all and (max-width:768px) {
    .a01box {
        width: 90%;
    }
}

@media all and (max-width:576px) {
    .a01box {
        -webkit-justify-content: center;
           -moz-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
    }

    .a01box .a01-1::before,
    .a01box .a01-2::before {
        top: 50%;
        left: -3em;
        -webkit-transform: translateY(-50%);
           -moz-transform: translateY(-50%);
            -ms-transform: translateY(-50%);
                transform: translateY(-50%);
    }

    .a01box a {
        margin-top: 0em;
    }
}

@media all and (max-width:425px) {}

@media all and (max-width:375px) {

    .a01box .a01-1::before,
    .a01box .a01-2::before {
        width: 70px;
        height: 70px;
    }
}

/* --------------------------------- */

.a02box {
    width: 80%;
    margin: 1em auto;
    background: #fff;
    border-radius: 5px;
    border: 3px solid #2f213e;
}

.a02box h3 {
    text-align: center;
    padding: 0.2em 0;
    margin-bottom: 0px;
    font-size: 2.5em;
    color: #443657;
    font-family: "MElle HK Xbold" !important;
}

.a02-but {
    background: #2f213e;
    padding: 1em .5em;
    color: #fff;

}

.a02-1 {
    width: 90%;
    margin: 0 auto;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-justify-content: flex-start;
       -moz-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-align-items: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
}

.a02-1 small {
    padding-left: 2.5em;
}

.a02-1 .R {
    color: #fff100;
}

@media all and (max-width:1024px) {}

@media all and (max-width:768px) {
    .a02box {
        width: 90%;
    }
}

@media all and (max-width:576px) {
    .a02-1 {
        width: 100%;
        font-size: .8em;
    }
}

@media all and (max-width:425px) {
    .a02-1 {
        font-size: 1.2em;
    }

    .a02-1 small {
        padding-left: 0em;
    }
}

@media all and (max-width:375px) {}

/*--------------------------------------#pt1-------------------------------------------------*/


/*--------------------------------------pt2-------------------------------------------------*/
.pt2 {
    background-color: #bcaac9;
    overflow: hidden;
}

.b01box {
    width: 80%;
    margin: 0 auto;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-align-items: center;
       -moz-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-justify-content: center;
       -moz-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-flex-wrap: wrap;
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
}

.b01-1 {
    position: relative;
    width: 80%;
    margin-top: 3em;
    background: #fff;
    padding: 2em .5em 1em;
    border: 3px solid #d75c41;
    border-radius: 5px;

}

.b01-1 h3 {
    position: absolute;
    top: -1em;
    left: 50%;
    -webkit-transform: translateX(-50%);
       -moz-transform: translateX(-50%);
        -ms-transform: translateX(-50%);
            transform: translateX(-50%);
    text-align: center;
    background: #e35e41;
    color: #fff;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    padding: .3em .5em;
    border-radius: 6px;
    font-size: 1.75em;
}

.b01-1 h3 span {
    font-size: .8em;
}

.b01-t h4 {
    position: relative;
    text-align: center;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0 auto;
    color: #c30d23;
    font-weight: 600;
}

.b01-t h4::before {
    content: '';
    position: absolute;
    top: 50%;
    left: -4em;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 80px;
    height: 2px;
    background: #c30d23;
}

.b01-t h4::after {
    content: '';
    position: absolute;
    top: 50%;
    right: -4em;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 80px;
    height: 2px;
    background: #c30d23;
}

.b01-t p {
    font-size: 1.5em;
}

@media all and (max-width:1024px) {}

@media all and (max-width:768px) {}

@media all and (max-width:576px) {
    .b01box {
        width: 90%;
    }

    .b01-1 {
        width: 100%;
        font-size: 13px;
    }
}

@media all and (max-width:425px) {
    .b01-1 {
        font-size: 11px;
    }
}

@media all and (max-width:375px) {
    .b01-t h4::before {
        left: -5em;
    }

    .b01-t h4::after {
        right: -5em;
    }
}

/* ---------------------------------- */
.b02box {
    position: relative;
    width: 80%;
    margin: 3em auto;
}

.b01-bg {
    width: 100%;
    margin: 0 auto;
    -webkit-filter: drop-shadow(4px 5px 0px #FFF);
            filter: drop-shadow(4px 5px 0px #FFF);
}

.b01-img {
    position: absolute;
    top: 50%;
    left: -4em;
    -webkit-transform: translateY(-50%);
       -moz-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 150px;
    z-index: 5;
}

.b02box h4 {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
       -moz-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    margin-bottom: 0px;
    color: #fff;
    text-shadow: 2px 2px 2px #000;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    font-size: 2em;
}

.b02box h4 span:first-child {
    color: #fffabc;
}

.b02box h4 span:last-child {
    color: #fff100;
}

@media all and (max-width:1024px) {}

@media all and (max-width:768px) {
    .b02box h4 {
        left: 55%;
        font-size: 1.8em;
    }
}

@media all and (max-width:576px) {
    .b02box {
        width: 90%;
        margin: 2em auto;
    }
}

@media all and (max-width:425px) {}

@media all and (max-width:375px) {}


/* ----------------------------------- */
.linebut {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 1em auto;
    -webkit-transition: all .15s;
    -moz-transition: all .15s;
    transition: all .15s;
}

.linebut:hover {
    -webkit-transform: translate(0.25em, 0.1em) scale(0.9);
       -moz-transform: translate(0.25em, 0.1em) scale(0.9);
        -ms-transform: translate(0.25em, 0.1em) scale(0.9);
            transform: translate(0.25em, 0.1em) scale(0.9);
}

.linebut:hover a {
    box-shadow: 0px 0px 0px 2px #d8b3ff, 0px 0px 5px 2px #ab5cff;
}

.linebut a {
    position: relative;
    background: #2f213e;
    color: #fff;
    padding: 0.2em 2em 0.2em 1em;
    font-size: 1.5em;
    border-radius: 0px 15px;
    cursor: pointer;
}

.linebut a:hover {
    color: #fff;
}

.linebut a::before {
    content: '';
    position: absolute;
    bottom: -1em;
    right: -1em;
    background: url(../img/point.png) center/cover no-repeat;
    width: 48px;
    height: 50px;
    -webkit-transition: all .15s;
    -moz-transition: all .15s;
    transition: all .15s;
}

.linebut:hover a::before {
    -webkit-transform: scale(0);
       -moz-transform: scale(0);
        -ms-transform: scale(0);
            transform: scale(0);
}

/*--------------------------------------#pt2-------------------------------------------------*/


.FOOTER img {
    width: 100%;
    display: block;
    margin: auto;
}

.FOOTER a {
    color: white;
}

.FOOTER a:hover {
    color: rgb(214, 214, 214);
}

@media all and (max-width: 425px) {
    .FOOTERbut {
        padding-bottom: 6em;
    }
}


/*---------------- BAR-social_address_浮動社群連結 --------------*/
.social-icon a {
    width: 75%;
}

.social-icon img {
    width: 100%;
}

.hide {
    /* 隱藏 */
    display: none !important;
}

/*---------一個 浮動式按鈕 LINE 手機版-----------*/
@media all and (max-width: 575px) {
    .social-icon a {
        width: 100% !important;
    }

    .social-icon a p {
        margin-bottom: 0px;
    }

    #line_line,
    #act_act {
        padding: 0em 15px 3em !important;
    }

    .social_btn {
        background-image: -webkit-linear-gradient(bottom, #b48305 0%, #f2b519 100%) !important;
        background-image: -moz-linear-gradient(bottom, #b48305 0%, #f2b519 100%) !important;
        background-image: linear-gradient(to top, #b48305 0%, #f2b519 100%) !important;
    }
}

/*--------#-一個浮動式按鈕 LINE 手機版----------*/
/*---------------- BAR-social_address_浮動社群連結 --------------*/


/*-----------TOP按鈕------------------*/
#goTop {
    position: fixed;
    bottom: 1em;
    right: 1em;
    width: 3em;
    height: 3em;
    padding: 0.5em;
    z-index: 999;
}

#goTop .fas {
    font-family: "Font Awesome 5 Free" !important;
}

@media all and (max-width: 575px) {
    #goTop {
        bottom: 4em;
    }
}

/*-----------TOP按鈕------------------*/