@charset "utf-8";

body {
    margin: 0;
    padding: 0;
}

@media(max-width: 800px) {
    .pc {
        display: none;
    }
}

@media(min-width: 1024px) {
    .mb {
        display: none;
    }
}

figure {
    margin-block-start: 0;
    margin-block-end: 0;
    margin-inline-start: 0;
    margin-inline-end: 0;
}


.js-collection-filter.de-collection-filter, .de-sorting-wrapper.sort-by {
    display: none !important
}

@media(min-width: 768px) {
    .de-page-collection:not(.drunk-life-page-wrapper) .product-list-container {
        margin: 0 !important
    }
}

.de-page-collection:not(.drunk-life-page-wrapper) .product-list-container .plp-right-section {
    -webkit-box-flex: 0 !important;
    -webkit-flex: 0 0 100% !important;
    -ms-flex: 0 0 100% !important;
    flex: 0 0 100% !important;
    max-width: 100% !important
}

@media(min-width: 1200px) {
    .de-page-collection:not(.drunk-life-page-wrapper) .product-list-container .plp-right-section {
        -webkit-box-flex: 0 !important;
        -webkit-flex: 0 0 100% !important;
        -ms-flex: 0 0 100% !important;
        flex: 0 0 100% !important;
        max-width: 100% !important
    }
}

.c-orange {
    color: #ff780b
}

.c-green {
    color: #00d500
}

.c-purple {
    color: #f0f
}

.c-light-purple {
    color: #ff7fd3
}

.c-yellow {
    color: #ffb802
}

.text-regular {
    /*font-family: "BrownRegular";*/
    font-weight: 400
}

.uppercase {
    text-transform: uppercase
}

.de-vitc-lp {
    font-size: 4vw;
    color: #5a5c60;
    /*font-family: "Century Gothic", "Arial", "微軟正黑體", "Microsoft JhengHei", "Noto Sans", sans-serif;*/
}

/*
.de-vitc-lp h1,
.de-vitc-lp .h1,
.de-vitc-lp h2,
.de-vitc-lp .h2,
.de-vitc-lp h3,
.de-vitc-lp .h3,
.de-vitc-lp h4,
.de-vitc-lp .h4,
.de-vitc-lp h5,
.de-vitc-lp .h5,
.de-vitc-lp h6,
.de-vitc-lp .h6 {
    font-family: "BrownBold"
}
*/

.de-vitc-lp h2,
.de-vitc-lp .h2 {
    font-size: 4.6vw;
    letter-spacing: 0;
    margin-block-start: 0;
    margin-block-end: 0;
}

.de-vitc-lp h3,
.de-vitc-lp .h3 {
    font-size: 15px;
}

@media(min-width: 768px) {
    .de-vitc-lp {
        font-size: 18px
    }

    .de-vitc-lp h2,
    .de-vitc-lp .h2 {
        font-size: 28px
    }

    .de-vitc-lp h3,
    .de-vitc-lp .h3 {
        font-size: 24px
    }
}

@media(min-width: 1024px) {
    .de-vitc-lp {
        font-size: 1.8vw
    }

    .de-vitc-lp h2,
    .de-vitc-lp .h2 {
        font-size: 36px
    }

    .de-vitc-lp h3,
    .de-vitc-lp .h3 {
        font-size: 36px;
    }
}

@media(min-width: 1280px) {
    .de-vitc-lp h2,
    .de-vitc-lp .h2 {
        font-size: 42px
    }
}

.shell {
    /*max-width: 1364px;*/
    margin: 0 auto;
    padding: 0 3vw
}

.shell--small-padding {
    width: 95%;
    padding-inline: 20px
}

.shell--small {
    max-width: 1210px;
    padding-inline: 20px
}

.shell--medium {
    max-width: 1470px;
    padding-inline: 20px
}

.shell--fluid {
    max-width: none
}

.hero {
    color: #fff;
    font-family: "BrownBold", sans-serif;
    font-size: 12px;
    line-height: 1.2;
    overflow: hidden
}

.hero .hero__nav {
    background-color: #8eb9ff;
    padding: 10px 0;
}

.hero .hero__inner {
    position: relative;
    padding: 1vw 0;
    isolation: isolate;
    height: 59vw;
    min-height: 260px
}

.hero .hero__content {
    width: 96%;
    margin-top: 5%;
    margin-left: 4%;
}

/*
    .hero .hero__shell {
        height: 100%
    }*/

.hero .hero__wrapper {
    display: flex;
    align-items: center;
    height: 100%
}

.hero .hero__image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1
}

.hero .hero__image img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

.hero .h1 {
    font-size: 10vw;
    color: #fff;
    font-family: "BrownBold", sans-serif;
    line-height: 1;
    margin-bottom: 2vw;
    font-weight: 500;
    position: relative;
    z-index: 0;
    letter-spacing: 0.07em;
}

.hero .h1 span, .hero .h1 sup {
    font-size: 96px;
    -webkit-text-stroke: 1px #ff780b
}

.hero em {
    font-style: italic;
    position: relative;
    top: 5px
}

.hero .h1 sup {
    font-size: 50px;
    position: relative;
    left: -18px;
    top: -22px
}

.hero p {
    font-weight: 400;
    font-size: 4.8vw;
    letter-spacing: 0.05em;
    margin-block-start: 0.5vw;
    margin-block-end: 0;
    width: 68%;
}

@media(min-width: 768px) {
    .hero .hero__content {
        width: 60%;
    }

    .hero {
        font-size: 20px
    }

    .hero h1 {
        font-size: 60px;
        line-height: .8
    }

    .hero h1 span {
        font-size: 120px
    }

    .hero h1 sup {
        font-size: 60px;
        left: -28px
    }

}



.hero .h1:after {
    content: " 透亮好點子";
    font-size: 100%;
    position: absolute;
    top: 0;
    left: 0;
    color: #fff;
    -webkit-text-stroke: 0.03em #ff780b;
    z-index: -1;
}

.hero .hero__inner {
    height: 61vw
}

.hero .hero__wrapper {
    align-items: flex-start
}

.hero .h1 sup {
    font-size: 94px;
    top: -34px;
    left: -45px
}


@media(min-width: 1024px) {
    .hero {
        font-size: 30px
    }

    .hero .hero__inner {
        padding: 7vw 0;
    }

    .hero .h1 {
        font-size: 7vw;
        margin-bottom: 12px
    }

    .hero p {
        width: 100%;
        font-size: 3vw;
    }

    .shell--small-padding {
        width: 90%;
    }
}

@media(min-width: 1400px) {

    .de-vitc-lp h2,
    .de-vitc-lp .h2 {
        font-size: 48px
    }

    .de-vitc-lp {
        font-size: 24px;
    }

    .shell--small-padding {
        width: 85%;
    }

    .hero {
        font-size: 37px
    }

    .hero .hero__inner {
        padding: 8% 0
    }

    .hero .h1 {
        line-height: .73;
        margin-bottom: 32px
    }

    .hero .h1 sup {
        font-size: 172px;
        top: -91px;
        left: -72px
    }

    .hero .h1 em {
        top: 17px;
        left: -5px
    }

}

.nav-secondary {
    color: #fff;
    text-transform: uppercase;
    font-family: "BrownBold";
    font-size: 3.2vw;
    letter-spacing: .13em
}

.nav-secondary a {
    color: #fff;
    text-decoration: none;
}

.nav-secondary ul {
    display: flex;
    flex-wrap: wrap;
    gap: 5vw 5vw;
    justify-content: center;
    list-style: none;
}

@media(min-width: 768px) {
    .nav-secondary {
        font-size: 14px
    }

    .nav-secondary ul {
        gap: 5px 49px;
    }
}

@media(min-width: 1024px) {
    .nav-secondary {
        font-size: 24px
    }

    .nav-secondary ul {
        gap: 22px 171px
    }
}

@media(min-width: 1400px) {
    .nav-secondary {
        font-size: 24px
    }


}

.section-primary.section-primary--offset {
    padding-top: 8vw;
}

.section-primary .section__entry {
    max-width: 85%;
    margin-inline: auto;
    margin-bottom: 50px;
    line-height: 1.13;
    padding-inline: 10px 2px
}

.section-primary .section__entry--small {
    max-width: none;
    text-align: center;
    margin-bottom: 30px;
    line-height: 1.2
}

.section-primary .section__entry--offset {
    padding-inline: 0;
    line-height: 1.2;
    margin-inline: -10px;
    margin-bottom: 44px
}

.section-primary .section__entry p {
    margin-bottom: 20px;
    font-size: 4.6vw;
    line-height: 1.5;
}

.section-primary .h3 {
    margin-bottom: 9px
}

.section-primary .section__entry h5 {
    font-size: 4.2vw;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: .15em;
    margin-bottom: 10px;
    line-height: 1.2
}

.section-primary .section__entry--small h5 {
    margin-bottom: 4px
}

.section-primary .h2 {
    margin-bottom:5vw;
}

.section-primary {
    padding: 10vw 2vw;
    overflow: hidden
}

@media(min-width: 768px) {

    .section-primary .section__entry {
        max-width: 80%;
        margin-inline: auto
    }

    .section-primary.section-primary--offset {
        padding-top: 36px
    }

    .section-primary .section__entry--offset {
        margin-block: 50px;
        max-width: 900px
    }
}


@media(min-width: 1024px) {
    .section-primary {
        padding: 6vw 5vw;
    }

    .section-primary.section-primary--offset {
        padding-top: 73px
    }

    .section-primary .section__entry {
        width: 80%;
        max-width: 1010px;
        font-size: 56px;
        line-height: 1.5;
        margin-bottom: 112px
    }

    .section-primary .h3 {
        margin-bottom: 5%;
    }

    .section-primary .h2 {
        margin-bottom: 5%;
    }

    .section-primary .section__entry p {
        margin-bottom: 5%;
        font-size: 2.6vw;
    }

    .section-primary .section__entry p:last-child {
        margin-bottom: 0;
        font-size: 1.8vw;
    }

    .section-primary .section__entry h5 {
        font-size: 24px
    }

    .section-primary .section__entry--small {
        font-size: 24px;
        max-width: 635px;
        margin-inline: auto;
        margin-bottom: 41px
    }

    .section-primary .section__entry--offset {
        margin-block: 52px 99px;
        max-width: 900px
    }
}

@media(min-width: 1400px) {
    .section-primary .section__entry p {
        font-size: 24px;
    }

    .section-primary .section__entry p:last-child {
        margin-bottom: 0;
        font-size: 24px;
    }

    .section-primary {
        padding: 50px 0 87px 0;
    }

    .section-primary .section__entry p {
        font-size: 36px;
        line-height: 1.5;
    }

}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #5a5c60;
    border: 1px solid #5a5c60;
    padding: 8px 35px 8px 35px;
    font-size: 3.2vw;
    text-transform: uppercase;
    /*font-family: "BrownBold";*/
    letter-spacing: .14em;
    transition: color, background-color;
    transition-duration: .3s;
    font-weight: 600;
    text-decoration: none;
}

.btn:hover {
    color: #fff;
    background-color: #5a5c60
}

@media(min-width: 768px) {
    .btn {
        font-size: 18px
    }

    .mb {
        display: none;
    }
}

@media(min-width: 1024px) {
    .btn {
        padding: 10px 64px 10px 64px;
        font-size: 18px
    }
}

.box-content-image+.box-content-image {
    margin-top: 48px
}

.box-content-image .box__intro-text {
    display: flex;
    align-items: center;
    gap: 5px;

}

.box-content-image .box__intro h4 {
    font-size: 15px;
    letter-spacing: .15em;
    line-height: 1;
    padding-top: 2px
}

.box-content-image .box__count {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    border: 2px solid currentColor;
    border-radius: 50%
}

body.mac .box-content-image .box__count {
    padding-top: 4px;
    padding-bottom: 4px
}

.box-content-image .box__title {
    text-transform: uppercase;
    font-size: 38px;
    font-size: clamp(20px, 9.8vw, 38px);
    color: #ff780b;
    letter-spacing: 0;
    letter-spacing: .15em;
    line-height: 1;
    margin-bottom: 14px;
    font-weight: 600;
}


.box-content-image .box__title span {
    /*font-family: "Century Gothic", "Arial", "微軟正黑體", "Microsoft JhengHei", "Noto Sans", sans-serif;*/
    display: block;
    color: #fff;
    position: relative;
    z-index: 0;
    letter-spacing: 0.04em;
    line-height: 1.2;
    margin-top: 0.1em;
    font-weight: 600;
}

.box-content-image .box__title span:after {
    content: "維他命C活膚日間精華";
    font-size: 100%;
    position: absolute;
    top: 0;
    left: 0;
    color: #fff;
    -webkit-text-stroke: 0.05em #ff780b;
    z-index: -1;
}

.box-content-image .box__title--orange span {
    width: 70%;
}


.box-content-image .box__title--yellow {
    color: #ffb800
}

.box-content-image .box__title--yellow span {
    /*font-family: "Century Gothic", "Arial", "微軟正黑體", "Microsoft JhengHei", "Noto Sans", sans-serif;*/
    display: block;
    width: 100% !important;
    color: #fff;
    position: relative;
    z-index: 0;
    letter-spacing: 0.04em;
    line-height: 1.2;
    margin-top: 0.1em;
}

.box-content-image .box__title--yellow span:after {
    content: "綜合維他命眼霜";
    font-size: 100%;
    position: absolute;
    top: 0;
    left: 0;
    color: #fff;
    -webkit-text-stroke: 0.05em #ffb800;
    z-index: -1;
}

.box-content-image .box__image {
    border-radius: 20px;
    margin-bottom: 20vw;
    position: relative;
    isolation: isolate;
    z-index: 1;
}

.research-result-image {
    position: relative;
    z-index: 1;
}

.box-content-image .box__image.box__image--offset {
    margin-bottom: 45px
}

.box-contante-image .box__image:last-child {
    margin-bottom: 0
}

.box-content-image .box__image img {
    width: 100%;
    height: auto;
    object-fit: cover;
    aspect-ratio: 1/1;
    border-radius: 5px
}

.box-content-image .box__image .bal-after img,
.box-content-image .box__image .bal-before img {
    height: 100%;
}


.box-content-image .box__image--shadow-blue {
    padding-bottom: 16px
}

.box-content-image .box__image--shadow-blue img {
    box-shadow: 14px 16px 0px #c6e3ff
}

.box-content-image .box__image--shadow-yellow img {
    box-shadow: 14px 16px 0px #d3ff00
}

.box-content-image .box__image--shadow-light-blue img {
    box-shadow: 14px 16px 0px #adefff
}

.box-content-image .box__image .box__image-decoration {
    position: absolute;
    bottom: -113px;
    right: -82px;
    aspect-ratio: unset;
    width: auto;
    height: auto;
    z-index: 0;
    max-width: 243px;
}

.box-content-image .box__content {
    margin-bottom: 32px
}

.box-content-image .box__content .h3 {
    font-size: 5.2vw;
    letter-spacing: .01em;
    line-height: 1.3;
    margin-bottom: 25px
}

.box-content-image .box__content .h3.text-regular {
    line-height: 1.5;
}

.box-content-image .box__list {
    padding-left: 10%;
    list-style: none;
    margin-bottom: 30px
}

.box-content-image .box__list li {
    position: relative;
    padding-left: 20px;
    line-height: 1.5;
}

.box-content-image .box__list li:before {
    content: "";
    position: absolute;
    left: 0;
    top: 7px;
    width: 8px;
    height: 2px;
    background-color: #83baff
}

.box-content-image .box__list--yellow {
    margin-bottom: 40px
}

.box-content-image .box__list--yellow li:before {
    background-color: #ffcc8b;
}

.box-content-image .box__list--orange li:before {
    background-color: #ff780b;
}

.box-content-image .box__list li+li {
    margin-top: 22px
}

.box-content-image .box__info {
    display: flex;
    align-items: center
}

.box-content-image .box__info img {
    width: auto;
    max-width: 21px;
    margin-right: 8px
}

.box-content-image .box__actions {
    text-align: center;
    margin-top: 30px;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-left: 10px
}

.box-content-image .box__btn {
    margin-bottom: 10px;
    text-decoration: none;
}

.box-content-image .box__actions p {
    margin-bottom: 7px
}


@media(min-width: 768px) {
    .box-content-image .box__row {
        display: flex;
        align-items: center;
        gap: 24px;
        justify-content: space-between
    }

    .box-content-image .box__row--alt {
        align-items: flex-start
    }

    .box-content-image .box__image {
        flex: 0 0 48.3%;
        margin-bottom: 0
    }

    .box-content-image .box__content {
        margin-bottom: 0
    }

    .box-conten-image .box__intro {
        padding-top: 20px
    }

    .box-content-image .box__row+.box__row {
        margin-top: 83px
    }
}

@media(min-width: 1024px) {

    .box-content-image .box__title--orange span {
        width: 70%;
    }

    .box-content-image .box__count {
        width: 42px;
        height: 42px;
        border-width: 3px
    }

    body.mac .box-content-image .box__count {
        padding-top: 0
    }

    .box-content-image .box__content .h3 {
        font-size: 24px;
    }

    .box-content-image .box__image--shadow-blue img {
        box-shadow: 24px 20px 0px #c6e3ff
    }

    .box-content-image .box__intro-text {
        font-size: 28px;
        gap: 14px
    }

    .box-content-image .box__intro .h4 {
        font-size: 28px;
        letter-spacing: .145em;
        padding-top: 6px
    }

    .box-content-image .box__title {
        font-size: 50px
    }

    .box-content-image .box__row+.box__row {
        margin-top: 80px
    }
}

@media(min-width: 1280px) {

    .box-content-image .box__title--orange span {
        width: 68%;
    }

    .box-content-image .box__content .h3 {
        font-size: 32px;
    }
}

@media(min-width: 1400px) {

    .box-content-image .box__title {
        font-size: 70px;
        letter-spacing: .14em
    }

    .box-content-image .box__intro {
        margin-left: -73px
    }

    .box-content-image .box__content .h3 {
        font-size: 33px;
        letter-spacing: .01em;
        margin-bottom: 46px
    }

    .box-content-image .box__actions--offset-right {
        padding-right: 77px
    }

    .box-content-image .box__content {
        padding-right: 2%;
        padding-left: 3px
    }

    .box-content-image .box__list {
        margin-bottom: 50px
    }

    .box-content-image .box__list li:before {
        width: 12px;
        top: 12px
    }

    .box-content-image .box__list li+li {
        margin-top: 32px
    }

    .box-content-image .box__info img {
        max-width: 38px;
        margin-right: 11px
    }

    .box-content-image .box__image {
        margin-bottom: 0
    }

    .box-content-image .box__image .box__image-decoration {
        bottom: -155px;
        right: -170px;
        max-width: 455px
    }

    .box-content-image .box__image .box__image-decoration--small {
        max-width: 286px;
        bottom: -72px;
        right: -97px
    }

    .box-content-image .box__image .box__image-decoration--alt {
        bottom: -166px;
        right: -94px;
        max-width: 384px
    }

    .box-content-image .box__actions {
        margin-top: 46px;
        padding-left: 0
    }

    .box-content-image .box__actions p {
        margin-bottom: 16px
    }

    .box-content-image .box__btn {
        margin-bottom: 14px
    }

    .box-content-image .box__content--offset {
        padding-right: 0
    }
}

.box-content-image--alt {
    font-size: 11px;
    position: relative
}


.box-content-image--alt .h4 {
    color: #fff;
    font-size: 24px;
    position: absolute;
    top: 10px;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
    text-transform: none;
    margin-bottom: 10px
}

.box-content-image--alt .box__entry {
    position: absolute;
    top: -2vw;
    left: -2vw;
    width: 100%;
    aspect-ratio: 1/1;
    display: flex;
    justify-content: flex-end;
    align-items: flex-end;
    text-align: center;
    padding: 6px 18px
}

.box-content-image--alt p {
    max-width: 122px
}

.box-content-image--alt .box__actions {
    margin-top: 0
}


@media(min-width: 768px) {
    .box-content-image--alt {
        font-size: 20px
    }

    .box-content-image--alt .box__entry {
        position: static;
        transform: none;
        aspect-ratio: unset;
        text-align: left;
        padding: 0;
        margin-bottom: 36px
    }

    .box-content-image--alt .box__image {
        margin-bottom: 0
    }

    .box-content-image--alt .h4 {
        position: static;
        transform: none;
        text-align: left;
        font-size: 24px
    }

    .box-content-image--alt p {
        max-width: none
    }

    .box-content-image--alt .c-orange {
        color: #ff780b
    }

    .box-content-image--alt .c-green {
        color: #00d500
    }

    .box-content-image--alt .box__actions {
        align-items: flex-start;
        padding: 0
    }

    .box-content-image--alt-reversed .box__entry {
        padding: 0
    }
}

@media(min-width: 1024px) {
    .section-primary .h2 {
        margin-bottom: 6%;
    }

    .box-content-image--alt {
        font-size: 24px
    }

    .box-content-image--alt .h4 {
        font-size: 48px
    }

    .box-content-image--alt .box__row {
        gap: 48px
    }

    .box-content-image--alt .box__entry {
        padding-right: 93px
    }

    .box-content-image--alt .box__content {
        padding-top: 27px
    }

    .box-content-image--alt+.box-content-image {
        margin-top: 110px
    }
}

.box-content-image--alt-reversed .h4 {
    top: 18px;
    left: auto;
    right: 21px;
    transform: none
}

.box-content-image--alt-reversed .box__entry {
    justify-content: flex-start;
    padding: 12px 16px
}

@media(min-width: 768px) {
    .box-content-image--alt-reversed .box__entry {
        padding: 0
    }
}

@media(min-width: 1024px) {
    .box-content-image--alt-reversed .box__entry {
        padding-right: 98px
    }
}

.link {
    display: inline-block;
    text-transform: uppercase;
    text-decoration: none;
    font-size: 12px;
    font-family: "BrownBold";
    letter-spacing: .14em;
    position: relative;
    color: #5a5c60;
    ;
}

.link:before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: currentColor
}

@media(min-width: 768px) {
    .link {
        font-size: 18px
    }
}


.section-products {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    padding-bottom: 40px
}

.section-products .section__head:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100vw;
    left: 50%;
    transform: translateX(-50%);
    height: calc(100% + 150px);
    background-color: #84baff;
    z-index: -1
}

.section-products .section__head {
    color: #fff;
    text-align: center;
    padding: 28px 0;
    position: relative;
    max-width: 964px;
    margin-inline: auto
}

.ticker {
    padding: 15px 0 11px 0;
    background-color: #c6e4ff;
    width: 100%;
    overflow: hidden;
    text-transform: uppercase;
    letter-spacing: .14em
}

.ticker li.push-space {
    margin-right: 50px
}

@media(min-width: 768px) {
    .ticker li.push-space {
        margin-right: 100px
    }
}

.ticker--green {
    background-color: #d3ff00
}

.ticker--light-blue {
    background-color: #adefff
}

.ticker .ticker__inner {
    display: flex;
    gap: 2rem;
    flex-wrap: nowrap;
    width: max-content
}

.ticker ul {
    list-style: none;
    display: flex;
    align-items: center;
    gap: 14px
}

.ticker .ticker__text-outline {
    color: #fff;
    font-size: 44px;
    -webkit-text-stroke: 1px #ff780b;
    letter-spacing: .04em;
    /* font-family: "BrownBold";*/
    font-weight: 700;
    margin-top: -11px
}

.ticker .ticker__text-outline--pink {
    -webkit-text-stroke: 1px #ff7fff
}

.ticker.is-animated .ticker__inner {
    animation: ticker 12s linear infinite
}

@keyframes ticker {
    0% {
        transform: translateZ(0)
    }

    to {
        transform: translate3d(var(--ticker-width), 0, 0)
    }
}

@media(min-width: 1400px) {
    .ticker {
        padding: 21px 0 18px 0
    }

    .ticker .ticker__text-outline {
        font-size: 72px;
        margin-top: -17.5px
    }

    .ticker .ticker__text-outline--medium {
        font-size: 74px;
        letter-spacing: .12em
    }
}


.section-products .section__head p {
    line-height: 1.5;
}

.section-products .section__head .h2 {
    font-size: 8vw;
    margin-bottom: 10px;
    font-weight: 600;
   /* font-family: "Century Gothic", "Arial", "微軟正黑體", "Microsoft JhengHei", "Noto Sans", sans-serif;*/
    display: block;
    width: 100%;
    color: #fff;
    position: relative;
    z-index: 0;
    letter-spacing: 0.04em;
    line-height: 1.2;
}

.section-products .section__head .h2:after {
    content: "解鎖更多透亮好點子";
    font-size: 100%;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    color: #fff;
    -webkit-text-stroke: 0.03em #00f3e9;
    z-index: -1;
}

.section-products .section__products {
    margin-bottom: 45px;
    position: relative
}

.section-products .section__products:last-child {
    margin-bottom: 0
}

.section-products .section__entry {
    text-align: center;
    margin-bottom: 16px;
    max-width: 800px;
    margin-inline: auto
}

.section-products .section__entry p {
    margin-bottom: 8px
}

.section-products .section__entry .h2 {
    font-size: 32px
}


@media(min-width: 768px) {
    .section-products .section__head .h2 {
        font-size: 40px
    }

    .section-products .section__head:before {
        height: calc(100% + 200px)
    }

    .section-products .section__entry .h2 {
        font-size: 40px
    }
}

@media(min-width: 1024px) {
    .section-products .section__head {
        padding: 42px 0 34px 0
    }

    .section-products .section__head .h2 {
        font-size: 68px
    }

    .section-products .section__products-wrapper {
        display: flex;
        margin: 0 -9px
    }

    .section-products .section__products-wrapper--alt {
        max-width: 1070px;
        margin-inline: auto
    }

    .section-products .section__product {
        flex: 0 0 50%;
        padding: 0 9px
    }

    .section-products .section__products {
        margin-bottom: 94px
    }

    .section-products .section__entry {
        margin-bottom: 38px;
        line-height: 1.25
    }

    .section-products .section__entry .h2 {
        font-size: 60px
    }

    .section-products .section__entry p {
        margin-bottom: 18px
    }

    .section-products .section__product--1of3 {
        flex: 0 0 33.33%;
        padding: 0 9px
    }
}

.product {
    text-align: center
}

.product .product__image {
    aspect-ratio: 1/.8;
    margin: 0 auto;
    margin-bottom: 22px;
    max-width: 350px
}

.product .h4 {
    font-size: 15px;
    text-transform: unset;
    /*font-family: "BrownRegular";*/
    font-weight: 400;
    letter-spacing: .01em;
    margin-bottom: 8px
}

.product .product__image img {
    width: 100%;
    height: 100%;
    object-fit: contain
}

.product .product__actions {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px
}


@media(min-width: 768px) {
    .product .product__image {
        max-width: 435px
    }

    .product .h4 {
        font-size: 20px
    }
}

@media(min-width: 1024px) {
    .product .h4 {
        font-size: 24px;
        margin-bottom: 18px
    }

    .product .product__image {
        margin-bottom: 46px
    }
}


.product--alt .product__image {
    aspect-ratio: 1/1;
    margin-bottom: 10px;
    border-radius: 5px;
    overflow: hidden
}

.product--alt .product__image img {
    object-fit: cover
}

@media(min-width: 1024px) {
    .product--alt .product__image {
        margin-bottom: 22px
    }

    .product--alt .product__actions {
        gap: 16px
    }
}

slider .slider__actions {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 2;
    height: 100%;
    transform: translate(-50%, -50%);
    pointer-events: none
}

.slider .slider__actions button {
    width: 21px;
    height: 21px;
    opacity: 1;
    position: static;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(209, 211, 212, .5);
    pointer-events: auto
}


.slider .slider__actions button:after {
    display: none
}

.slider .slider__actions svg {
    width: 100%;
    height: 100%;
    object-fit: contain;
    max-width: 15px;
    /*font-family: "Century Gothic", "Arial", "sans-serif";*/
}

.slider .slider__actions {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    z-index: 2;
    height: 100%;
    transform: translate(-50%, -50%);
    pointer-events: none;
}

.slider--products .slider__actions {
    top: 0;
    transform: translateX(-50%);
    aspect-ratio: 4/4.15;
    max-width: 311px;
    width: 95%;
    height: auto
}


@media(min-width: 768px) {
    .slider--products .slider__actions {
        aspect-ratio: 4/4.95;
        max-width: 350px
    }
}

@media(min-width: 1024px) {
    .slider--products .slider__actions {
        display: none
    }
}


.slider--products-alt .slider__actions {
    top: 0;
    transform: translateX(-50%);
    aspect-ratio: 4/4.45;
    max-width: 311px;
    width: 100%;
    height: auto
}

@media(min-width: 768px) {
    .slider--products-alt .slider__actions {
        aspect-ratio: 4/4.45;
        max-width: 427px
    }
}

@media(min-width: 1024px) {
    .slider--products-alt .slider__actions {
        display: none
    }
}


.bal-container {
    position: relative;
    width: 100%;
    height: 100%;
    overflow: hidden;
    height: 430px;
    z-index: 1;
}

@media(min-width: 768px) {
    .bal-container {
        height: 565px
    }
}

.bal-container .slider {
    position: absolute;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%;
    height: 100%;
    outline: none;
    margin: 0;
    transition: all .2s;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    justify-content: center;
    -ms-flex-align: center;
    align-items: center;
    border: none;
    padding: 0;
    z-index: 2;
    opacity: 0;
}

.bal-container .slider::-webkit-slider-container, .bal-container .slider::-webkit-slider-runnable-track {
    height: 100%
}

.bal-container .slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    background-color: rgba(0, 0, 0, 0);
    border-radius: 50%;
    box-shadow: none;
    width: 2.03874rem;
    height: 100%
}

@media(min-width: 768px) {
    .bal-container .slider::-webkit-slider-thumb {
        width: 4.07747rem
    }
}

.bal-after {
    right: 0
}

.bal-after, .bal-before {
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden
}

.bal-before {
    z-index: 1;
    border-right: 1px solid #000
}

.bal-after img,
.bal-before-inset,
.bal-before img {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0
}

.bal-after img, .bal-before img {
    width: 100%;
    height: 100%;
    object-position: 50% 50%;
    -webkit-user-select: none;
    -moz-user-select: none;
    -o-user-select: none;
    -ms-user-select: none;
    user-select: none
}

.bal-beforePosition {
    left: 0
}


.bal-afterPosition, .bal-beforePosition {
    pointer-events: none;
    border-radius: .30581rem;
    background: hsla(0, 0%, 100%, .501961);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    display: -ms-inline-flexbox;
    display: inline-flex;
    padding: .50968rem 1.01937rem;
    -ms-flex-align: start;
    align-items: flex-start;
    gap: 1.01937rem
}

.bal-afterPosition {
    right: 0
}

.afterLabel, .beforeLabel {
    position: absolute;
    bottom: 0;
    margin: 1rem;
    -webkit-user-select: none;
    -moz-user-select: none;
    -o-user-select: none;
    -ms-user-select: none;
    user-select: none;
    color: #45474a;
    font-family: "BrownBold", "sans-serif";
    font-size: 1.22324rem;
    line-height: 1.2;
    letter-spacing: .6px;
    font-weight: 700;
    text-transform: uppercase
}

.bal-handle {
    height: 4.07747rem;
    width: 4.07747rem;
    color: hsla(0, 0%, 100%, .501961);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -2.03874rem;
    margin-top: -2.03874rem;
    border: .10194rem solid #45474a;
    border-radius: 101.9368rem;
    z-index: 20;
    pointer-events: none
}

@media(max-width: 767px) {
    .bal-handle {
        height: 2.03874rem;
        width: 2.03874rem;
        margin-left: -1.01937rem;
        margin-top: -1.01937rem
    }
}

li.lg-spacer {
    margin-right: 8rem
}

.swiper-wrapper {
    height: auto !important;
}

.btn-no-hov {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #5a5c60;
    border: 1px solid #5a5c60;
    padding: 8px 35px 8px 35px;
    font-size: 12px;
    text-transform: uppercase;
    font-family: 'BrownBold';
    letter-spacing: 0.14em;
    transition: color, background-color;
    transition-duration: .3s;
}

@media (min-width: 768px) {
    .btn-no-hov {
        font-size: 18px;
    }
}

@media (min-width: 1024px) {
    .btn-no-hov {
        padding: 10px 64px 10px 64px;
    }
}