* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

html {
    color: #333;
    font-size: 100%;
    -webkit-text-size-adjust: 100%;
    height: 100%;
}

body {
    background-color: white;
    font-family: "Helvetica-Neue", "HelveticaNeueLTPro-Roman", 微軟正黑體修正, 微軟正黑體, Arial, Helvetica, sans-serif;
    width: 1110px;
    height: 100%;
    margin: 0 auto;
    padding: 0;
    -ms-transform-origin:50% 0;
    -webkit-transform-origin:50% 0;
    -moz-transform-origin:50% 0;
    transform-origin:50% 0;
}

@media (min-width: 1110px) {
    body {
        width: auto;
    }
    
}
@media (max-width: 1109px & min-width: 768px) {
    body {
        width: auto;
        transform:scale(1);
        transform-origin:0 0;
    }
}
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary,
a,
img {
    display: block;
    margin: 0px;
    padding: 0px;
}

.clear {
    clear: both;
}

sup {
    font-size: 16px;
}
.desktop {
    display: block!important;
}
.mobile {
    display: none!important;
}
.text-align-left {
    text-align: left;
}

.text-align-center {
    text-align: center;
}

.text-align-right {
    text-align: right;
}

.float-left {
    float: left;
}

.float-right {
    float: right;
}

.float-none {
    float: none;
}

.margin-auto {
    margin: 0 auto;
}

.gap-20 {
    height: 20px;
    width: 100%;
}

.gap-30 {
    height: 30px;
    width: 100%;
}

.gap-60 {
    height: 60px;
    width: 100%;
}

.gap-80 {
    height: 80px;
    width: 100%;
}

.gap-90 {
    height: 90px;
    width: 100%;
}

.container {
    width: 1110px;
    margin: 0 auto;
}

.top-banner {
    background: url("../images/NCB_Element5-02.jpg") no-repeat #005093 top center;
    width: 100%;
    height: 586px;
    position: relative;
    animation: 1.5s banner-zoom ease;
}
.top-banner .star-area {
    width: 100%;
    height: 586px;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 10000;
}
/* .top-banner.desktop {
    background: url("../images/NCB_Element5-02.jpg") no-repeat center center;
    width: 100%;
    height: 586px;
    position: relative;
    animation: 1.5s banner-zoom;
} */

@keyframes banner-zoom {
    0% {
        background-size: 120%;
        opacity: 0;
    }

    100% {
        background-size: 100%;
        opacity: 1;
    }
}

.title {
    padding-left: 10px;
    position: absolute;
    animation: 1s title-fade ease;
    animation-delay: 800ms;
}

@keyframes title-fade {
    80% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

.action {
    float: right;
    padding: 25px 20px 0 0;
    position: relative;
    animation-delay: 2s;
}

.action .arrow {
    position: absolute;
    top: 130px;
    right: 140px;
    width: 30px;
    height: 30px;
    background: url(../images/arrow.png) no-repeat;
    background-size: 15px 30px;
    background-position: 15px 0px;
    -webkit-animation: 0.7s arrow-left ease-in-out infinite forwards;
    animation: 0.7s arrow-left ease-in-out infinite forwards;
}

@keyframes arrow-left {
    0% {
        background-position: 6px 0;
    }

    50% {
        background-position: 11px 0;
    }

    100% {
        background-position: 6px 0;
    }
}

.slogan {
    padding-top: 45px;
    padding-left: 210px;
}

.slogan div:last-child {
    padding-top: 20px;
    padding-left: 55px;
}

.intro-content {
    font-size: 30px;
    padding: 0 45px;
    line-height: 42px;
    font-weight: bold;
}

.benefits {
    padding: 0 165px;
    display: flex!important;
    justify-content: space-between;
}
.benefits.mobile {
    display: none!important;
}
.subheadline {
    color: #E11921;
    font-size: 30px;
    font-weight: bold;
    line-height: 1.5;
}

.content {
    font-size: 24px;
    line-height: 26px;
    font-weight: bold;
}

.steps {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
}
.steps.desktop {
    display: flex!important;
}
.steps-four {
    padding-left: 60px;
    background: url("../images/steps-background.png") no-repeat 60px top;
    width: 990px;
    height: 400px;
    padding-top: 84px;
    display: flex;
}

.steps-four .subheadline {
    color: #524FA1;
    font-size: 24px;
    line-height: 26px;
    font-weight: bold;
    padding-left: 35px;
}

.steps-four .content {
    padding-left: 35px;
    line-height: 26px;
    padding-top: 5px;
}

.steps-four>div {
    padding-left: 25px;
    display: inline-block;
}

.steps-five {
    padding-right: 45px;
}

.steps-five .subheadline {
    color: #E11921;
    font-size: 24px;
    line-height: 26px;
    font-weight: bold;
    padding-top: 15px;
}

.steps-five .content {
    padding-top: 5px;
}

.documents {
    padding-left: 80px;
}

.documents .content img {
    padding-right: 10px;
}

.documents .content {
    font-size: 30px;
    line-height: 30px;
}

.documents .content div {
    padding: 5px;
    display: flex;
    align-items: baseline;
}

.statement {
    padding: 0 80px;
}

.statement .subheadline {
    font-size: 21px;
    line-height: 24px;
    color: #00539E;
    font-weight: bold;
}

.statement .content {
    font-size: 30px;
    line-height: 30px;
    padding-top: 20px;
}
.statement .content a {
    font-size: 30px;
    line-height: 40px;
    color: #333;
    border-bottom: 1px solid #333;
    text-decoration: none;
    display: inline-block;
}
.enquiry {
    padding: 0 80px;
}

.enquiry .subheadline {
    color: #333;
    font-size: 36px;
    line-height: 40px;
}

.enquiry .content {
    font-size: 26px;
    line-height: 26px;
    padding-top: 15px;
}

.enquiry .content img {
    display: inline-block;
    vertical-align: middle;
}

.enquiry .content span {
    color: #44207A;
    font-size: 40px;
    font-weight: bold;
    vertical-align: text-top;
}

.services {
    padding: 0 80px;
}

.services .subheadline {
    color: #524FA1;
    font-size: 24px;
    line-height: 24px;
    font-weight: bold;
}

.services .content ul {
    padding-top: 10px;
    font-size: 16px;
    list-style-type: decimal;
    margin-left: 20px;
    text-align: justify;
}

.services .content ul li {
    padding: 3px 0;
}

.terms {
    padding: 0 80px;
}

.terms .subheadline {
    color: #524FA1;
    font-size: 24px;
    line-height: 24px;
    font-weight: bold;
}

.terms .content ul {
    padding-top: 10px;
    font-size: 16px;
    list-style: url("../images/square.png");
    margin-left: 20px;
    text-align: justify;
}

.terms .content ul li {
    padding: 3px 0;
}

/* STAR */
.stars {
    position: absolute;
    background: url("../images/spark.png") no-repeat;
    animation-duration: 5s;
    animation-name: my-sparkle;
    animation-iteration-count: 1;
    opacity: 0;
}

.star-1 {
    top: 285px;
    left: 190px;
    animation-delay: 1.5s;
    background-size: 110px;
    height: 110px;
    width: 110px;
}

.star-2 {
    top: 275px;
    left: 295px;
    animation-delay: 2s;
    background-size: 120px;
    height: 120px;
    width: 120px;
}

.star-3 {
    top: 235px;
    left: 490px;
    animation-delay: 2.5s;
    background-size: 160px;
    height: 160px;
    width: 160px;
}

.star-4 {
    top: 178px;
    left: 652px;
    animation-delay: 3s;
    background-size: 180px;
    height: 180px;
    width: 180px;
}

.star-5 {
    top: 132px;
    left: 795px;
    animation-iteration-count: infinite;
    animation-delay: 4s;
    background-size: 130px;
    height: 130px;
    width: 130px;
}

@keyframes my-sparkle {
    0% {
        opacity: 0;
        transform: rotate(0deg) scale(0);
    }

    50% {
        opacity: 1;
        transform: rotate(360deg) scale(1);
    }

    100% {
        opacity: 0;
        transform: rotate(720deg) scale(0);
    }
}

@keyframes twinkle-1 {
    0% {
        transform: scale(0);
        opacity: 0;
    }

    50% {
        transform: scale(0.3);
        opacity: 0.3;
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

@keyframes twinkle-2 {
    0% {
        transform: scale(0);
        opacity: 0;
    }

    20% {
        transform: scale(0.5);
        opacity: 0.5;
    }

    100% {
        transform: scale(1);
        opacity: 1;
    }
}

.footer-mobile {
    width: 100%;
    padding: 20px 0;
    background-color: #bababc;
}

.footer {
    width: 100%;
    padding: 20px 0;
    background-color: #bababc;
}

.footer-menu {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 235px;
    padding: 0 25%;
}

.footer-menu a {
    color: #333;
    font-size: 21px;
    line-height: 24px;
    font-size: 16px;
    line-height: 21px;
    font-weight: bold;
    text-decoration: none;
}

.footer-menu a:hover {
    text-decoration: underline;
}

.copyright {
    padding-top: 10px;
    width: 100%;
    font-size: 14px;
    line-height: 21px;
    font-size: 12px;
    line-height: 16px;
    font-weight: bold;
    text-align: center;
}

/* Responsive */
/* @media (max-width: 1199px) {
    .container {
        width: 100%;
    }
    .top-banner {
        width: 100%;
        height: 500px;
        background-size: cover;
    }
    .gradient img {
        width: 100%;
    }
    .slogan {
        padding: 30px 10% 0;
    }
} */

@media (max-width: 767px) {
    .desktop {
        display: none!important;
    }
    .mobile {
        display: block!important;
    }
    .gap-20 {
        height: 10px;
    }
    .gap-30 {
        height: 15px;
    }
    .gap-60 {
        height: 30px;
    }
    .gap-80 {
        height: 40px;
    }
    .gap-90 {
        height: 45px;
    }
}

@media (min-width: 1110px) {
    .footer {
        display: block;
        /* transform: scale(1.25); */
    }

    .footer-mobile {
        display: none;
    }
}

@media (max-width: 1109px) {
    .footer {
        display: none;
    }

    .footer-mobile {
        display: block;
    }
}
/* @media (max-width: 414px) {
    .intro-content {
        font-size: 44px;
        line-height: 57px;
    }
    .subheadline {
        font-size: 42px;
        line-height: 56px;
    }
    .content {
        font-size: 36px;
        line-height: 48px;
        font-weight: bold;
    }
    .benefits {
        padding: 0 12%;
        display: block;
        text-align: center;
    }
    .benefits img {
        width: 40%;
        margin: 0 auto;
    }
    .benefits-left {
        margin-bottom: 60px;
    }
} */
.top-banner-img {
    height: 586px;
}
.gradient, .gradient img {
    width: 100%;
}
/* new responsive */

/* @media (max-width: 1023px) {
    .star-1 {
        top: 32vw;
        left: 22vw;
        animation-delay: 1.5s;
        background-size: 8vw;
        height: 8vw;
        width: 8vw;
    }
    .star-2 {
        top: 29vw;
        left: 31vw;
        animation-delay: 2s;
        background-size: 13vw;
        height: 13vw;
        width: 13vw;
    }
    .star-3 {
        top: 26vw;
        left: 53vw;
        animation-delay: 2.5s;
        background-size: 15vw;
        height: 15vw;
        width: 15vw;
    }
    .star-4 {
        top: 21vw;
        left: 71vw;
        animation-delay: 3s;
        background-size: 15vw;
        height: 15vw;
        width: 15vw;
    }
    .star-5 {
        top: 14vw;
        left: 84vw;
        animation-iteration-count: infinite;
        animation-delay: 4s;
        background-size: 14vw;
        height: 14vw;
        width: 14vw;
    }
} */
@media (max-width: 767px) {
    body {
        width: 100%;
    }
    sup {
        font-size: 12px;
    }
    .container {
        width: 100%;
    }
    .top-banner {
        position: relative;
        width: 100%;
        height: 53vw;
        background-size: cover;
    }
    .top-banner-img {
        width: 100%;
        height: auto;
    }
    .top-banner-img img, .top-banner-img video {
        width: 100%;
        height: auto;
    }
    .top-banner .star-area {
        width: 100%;
        height: auto;
        height: 53vw;
    }
    .gradient, .gradient img {
        width: 100%;
        height: 5px;
    }
    .title {
        width: 58vw;
        top: 0;
    }
    .title img {
        width: 100%;
    }
    .action {
        position: absolute;
        bottom: 0;
        right: 0;
        padding: 0 20px 10px 0;
        animation-delay: 2s;
        width: 33vw;
        z-index: 50;
    }
    .action img {
        width: 100%;
    }
    .slogan {
        padding-top: 20px;
        padding-left: 7%;
    }
    .slogan div:last-child {
        padding-top: 13px;
        padding-left: 45px;
    }
    .slogan img {
        width: 69vw;
    }
    .slogan div:last-child img {
        width: 75vw;
    }
    .intro-content {
        font-size: 20px;
        padding: 0 5%;
        line-height: 1.5;
    }
    img.margin-auto {
        width: 90%;
    }
    .content-item {
        display: flex;
        align-items: center;
    }
    .content-item img {
        margin-right: 5px;
    }
    .subtitle img {
        width: 50vw;
    }
    .benefits {
        padding: 0;
        text-align: center;
    }
    .benefits.mobile {
        display: block !important;
    }
    .benefits img {
        width: 40vw;
        margin: 0 auto;
    }
    .subheadline {
        font-size: 22px;
        line-height: 1.5;
    }
    .content {
        font-size: 20px;
        line-height: 1.2;
    }
    .steps.desktop {
        display: none!important;
    }
    .steps.mobile .four-steps {
        background: url("../images/steps-background-m.png") no-repeat top center;
        background-size: 96%;
        padding-top: 20px;
    }
    .steps.mobile .four-steps .subheadline {
        color: #524FA1;
    }
    .steps.mobile .four-steps .steps-four .subheadline {
        color: #E11921;
        font-size: 22px;
        line-height: 1.5;
    }
    .steps-row {
        display: flex;
        width: 76%;
        margin: 0 auto;
        margin-bottom: 10px;
    }
    .steps-row > div {
        text-align: center;
        width: 50%;
    }
    .steps-row img {
        max-width: 150px;
        width: 38vw;
        margin: 0 auto;
    }
    .steps-row:last-child {
        margin-bottom: 0;
    }
    .steps-five .content {
        padding-top: 0;
    }
    .steps.mobile .last-step {
        position: relative;
        background: url("../images/steps-arrow-m.png") no-repeat top center;
        background-size: 96%;
        margin-top: -2px;
        padding-top: 20px;
    }
    .steps-five {
        padding-right: 0;
        width: 38vw;
        margin: 0 auto;
        text-align: center;
        background: white;
    }
    .steps-five img {
        margin: 0 auto;
        max-width: 90%;
    }
    .steps-five .subheadline {
        color: #E11921;
        font-size: 22px;
        line-height: 1.5;
        padding-top: 10px;
    }
    .documents {
        padding: 0 4%;
    }
    .documents .content {
        font-size: 20px;
        line-height: 1.2;
    }
    .documents .content div {
        padding-left: 0;
        padding-right: 0;
    }
    .documents .content img {
        padding-right: 5px;
        width: 8vw;
    }
    .statement {
        padding: 0 5%;
    }
    .statement img {
        width: 100%;
    }
    .statement .content {
        font-size: 20px;
        line-height: 1.2;
        padding-top: 10px;
    }
    .statement .content a {
        font-size: 20px;
        line-height: 1.2;
    }
    .enquiry {
        padding: 0 5%;
    }
    .enquiry img {
        width: 30%;
        margin: 0 auto;
    }
    .enquiry .content {
        font-size: 20px;
        line-height: 1.3;
        padding-top: 10px;
    }
    .enquiry .content img {
        vertical-align: middle;
    }
    .enquiry .content img.icon-tel {
        width: 25px;
        vertical-align: top;
    }
    .enquiry .content img:last-child {
        width: 145px;
    }
    .services {
        padding: 0 5%;
    }
    .terms {
        padding: 0 5%;
    }
    /* Style for accordion */

    .accordion input[type="checkbox"] {
        display: none;
    }
    .accordion label {
        display: flex;
        align-items: center;
        font-size: 22px;
        line-height: 1.5;
        font-weight: bold;
        margin: 10px 0;
        cursor: pointer;
        transition: background 0.3s ease;
    }
    .accordion label:after {
        content: "";
        width: 0px;
        height: 0px;
        border-style: solid;
        border-width: 10px 8px 0 8px;
        border-color: #333 transparent transparent transparent;
        transform: rotate(0deg);
        margin-left: 8px;
     }
    .accordion input[type="checkbox"]:checked + label {
        color: #524FA1;
    }
    .accordion input[type="checkbox"]:checked + label:after {
        border-color: #524FA1 transparent transparent transparent;
    }
    .accordion .content {
        display: none;
        border-top: none;
    }
    .accordion input[type="checkbox"]:checked + label + .content {
        display: block;
    }
    .services .content ul {
        font-size: 16px;
        line-height: 1.2;
    }
    .terms .content ul {
        font-size: 16px;
        line-height: 1.2;
    }
    .services.accordion .content {
        padding-bottom: 10px;
        border-bottom: 1px solid #524FA1;
    }
    .footer-menu {
        padding: 0 5%;
        display: block;
    }
    .footer-menu a {
        padding: 5px 0;
    }
    /* 5 stars */
    .star-1 {
        top: 27vw;
        left: 18vw;
        animation-delay: 1.5s;
        background-size: 8vw;
        height: 8vw;
        width: 8vw;
    }
    .star-2 {
        top: 25vw;
        left: 26vw;
        animation-delay: 2s;
        background-size: 12vw;
        height: 12vw;
        width: 12vw;
    }
    .star-3 {
        top: 22vw;
        left: 44vw;
        animation-delay: 2.5s;
        background-size: 14vw;
        height: 14vw;
        width: 14vw;
    }
    .star-4 {
        top: 17vw;
        left: 59vw;
        animation-delay: 3s;
        background-size: 15vw;
        height: 15vw;
        width: 15vw;
    }
    .star-5 {
        top: 11vw;
        left: 71vw;
        animation-iteration-count: infinite;
        animation-delay: 4s;
        background-size: 14vw;
        height: 14vw;
        width: 14vw;
    }
}