@import url("https://fonts.googleapis.com/css2?family=Frank+Ruhl+Libre:wght@500;700&family=Noto+Sans+TC:wght@300;400;500;600;700&family=Oxygen:wght@300;400;500;700&display=swap");

a,
abbr,
acronym,
address,
applet,
article,
aside,
audio,
b,
big,
blockquote,
body,
canvas,
caption,
center,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header-brandoff,
hgroup,
html,
i,
iframe,
img,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strike,
strong,
summary,
table,
time,
tt,
u,
ul,
var,
video {
    margin: 0;
    padding: 0;
    border: 0;
    vertical-align: baseline;
    font: inherit;
    text-align: left
}

article,
aside,
details,
figcaption,
figure,
footer,
header-brandoff,
hgroup,
menu,
nav,
section {
    display: block
}

ol,
ul {
    list-style: none
}

*,
:after,
:before {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box
}

:root {
    font-size: 16px
}

@media (min-width:992px) and (max-width:1440px) {
    :root {
        font-size: 15px
    }
}

@media (min-width:768px) and (max-width:991px) {
    :root {
        font-size: 14px
    }
}

.openMenu {
    overflow: hidden
}

.openMenu .containerMenu .menu {
    opacity: 1;
    pointer-events: all
}

.openMenu .searchBox {
    opacity: 1;
    pointer-events: all
}

.openMenu .iconBox_mo {
    opacity: 1;
    pointer-events: all
}

.openMenu .contactBox {
    opacity: 1;
    pointer-events: all
}

/*
header-brandoff {
    font-family: "Oxygen", "Noto Sans TC", sans-serif;
    position: fixed;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1000;
    max-width: 1920px;
    height: 90px;
    padding: 0 64px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: calc(100% + 2px);
    background: #000
}*/

@media (max-width:991px) {
    header-brandoff {
        padding: 0 24px;
        height: 70px
    }
}

@media (max-width:767px) {
    header-brandoff {
        height: 58px
    }
}

header-brandoff.scrollMenu {
    height: 65px;
    background-color: rgb(0, 0, 0)
}

header-brandoff.scrollMenu .searchBox {
    top: 65px
}

header-brandoff.scrollMenu .containerMenu .menu .menuSec {
    top: 65px
}

header-brandoff.scrollMenu .container-logo {
    max-width: 176px
}

.menuBox {
    display: flex;
    align-items: center
}

.container-logo {
    display: block;
    max-width: 216px;
    margin-right: 45px;
    transition: opacity 0.75s
}

@media (min-width:768px) and (max-width:991px) {
    .container-logo {
        max-width: 180px;
        margin-right: 20px
    }
}

@media (max-width:767px) {
    .container-logo {
        max-width: 137px;
        margin-right: 0
    }
}

.container-logo img {
    height: 100%;
    object-fit: contain;
    object-position: center
}

@media (min-width:768px) {
    .container-logo:hover {
        opacity: 0.7
    }
}

.containerMenu {
    display: flex
}

@media (min-width:768px) {
    .containerMenu .menu {
        position: relative;
        z-index: 2;
        display: flex;
        align-items: center
    }
}

@media (max-width:767px) {
    .containerMenu .menu {
        opacity: 0;
        pointer-events: none;
        position: absolute;
        z-index: 2;
        top: 58px;
        left: 0;
        width: 100%;
        height: calc(100vh - 56px);
        overflow: hidden auto;
        transition: opacity 0.5s;
        padding: 162px 0 100px;
        background-color: #fff
    }
}

.containerMenu .menu>li {
    position: relative
}

@media (max-width:767px) {
    .containerMenu .menu>li {
        margin: 0 25px
    }
}

.containerMenu .menu>li:after {
    content: "";
    position: absolute;
    z-index: -1;
    bottom: -40px;
    left: 0;
    width: 100%;
    height: 100px
}

.containerMenu .menu>li.active .menuList {
    border: none;
    padding-bottom: 0px
}

.containerMenu .menu>li.active .menuList:after {
    transform: translateY(-50%) rotate(180deg)
}

.containerMenu .menu>li.active .menuSec {
    max-height: 700px;
    opacity: 1;
    pointer-events: all
}

@media (min-width:768px) {
    .containerMenu .menu>li:hover .menuSec {
        opacity: 1;
        pointer-events: all
    }
}

.containerMenu .menu .menuList {
    position: relative;
    padding: 10px 18px;
    letter-spacing: 1.6px;
    color: #fff;
    font-weight: 500;
    transition: opacity 0.75s
}

@media (max-width:767px) {
    .containerMenu .menu .menuList {
        display: block;
        font-size: 20px;
        color: #000;
        border-bottom: 1px solid #000;
        padding: 20px 0;
        letter-spacing: 0.25em
    }
}

@media (max-width:767px) {
    .containerMenu .menu .menuList:not(.menuOutLink):after {
        content: "";
        position: absolute;
        top: 50%;
        right: 0;
        transform: translateY(-50%);
        width: 17px;
        height: 11px;
        background: url("../../Contents/images/common/arrow_mo.png") center/contain no-repeat;
        transition: transform 0.75s
    }
}

@media (min-width:768px) {
    .containerMenu .menu .menuList:hover {
        opacity: 0.7
    }
}

.containerMenu .menu .menuSec {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.75s
}

@media (min-width:768px) {
    .containerMenu .menu .menuSec {
        padding: 50px 18.4% 20px;
        position: fixed;
        top: 90px;
        left: 0;
        width: 100%;
        transform: none;
        display: flex;
        flex-wrap: wrap;
        background-color: rgba(0, 0, 0, 0.88)
    }
}

@media (min-width:1441px) and (max-width:1600px) {
    .containerMenu .menu .menuSec {
        padding: 50px 10% 20px
    }
}

@media (min-width:992px) and (max-width:1440px) {
    .containerMenu .menu .menuSec {
        padding: 40px 8% 15px
    }
}

@media (min-width:768px) and (max-width:991px) {
    .containerMenu .menu .menuSec {
        top: 70px;
        padding: 30px 6% 10px
    }
}

@media (max-width:767px) {
    .containerMenu .menu .menuSec {
        max-height: 0;
        transition: all 0.75s
    }
}

.containerMenu .menu .menuSec li {
    position: relative;
    z-index: 1;
    text-align: center
}

@media (min-width:1201px) {
    .containerMenu .menu .menuSec li {
        width: calc((100% - 120px) / 5);
        margin: 0 30px 30px 0
    }

    .containerMenu .menu .menuSec li:nth-child(5n) {
        margin-right: 0
    }
}

@media (min-width:992px) and (max-width:1200px) {
    .containerMenu .menu .menuSec li {
        width: calc((100% - 90px) / 4);
        margin: 0 30px 25px 0
    }

    .containerMenu .menu .menuSec li:nth-child(4n) {
        margin-right: 0
    }
}

@media (min-width:768px) and (max-width:991px) {
    .containerMenu .menu .menuSec li {
        width: calc((100% - 60px) / 3);
        margin: 0 30px 20px 0
    }

    .containerMenu .menu .menuSec li:nth-child(3n) {
        margin-right: 0
    }
}

@media (max-width:767px) {
    .containerMenu .menu .menuSec li {
        font-size: 16px;
        flex: 0 0 50%;
        text-align: left
    }
}

@media (min-width:768px) {
    .containerMenu .menu .menuSec li:hover a {
        opacity: 0.7
    }
}

.containerMenu .menu .menuSec li a {
    position: relative;
    z-index: 2;
    display: block;
    transition: opacity 0.75s
}

@media (min-width:768px) {
    .containerMenu .menu .menuSec li a {
        font-size: 16px;
        font-weight: 700;
        letter-spacing: 1.6px;
        color: #949494
    }
}

@media (max-width:767px) {
    .containerMenu .menu .menuSec li a {
        color: #5C5C5C;
        width: 100%;
        font-size: 18px;
        padding: 10px 0;
        border-bottom: 1.5px solid rgb(158, 158, 158);
        letter-spacing: 0.1em
    }
}

.iconBox {
    display: flex;
    align-items: center
}

.iconBox ul {
    display: flex;
    align-items: center
}

.iconBox .iconList {
    margin-left: 32px
}

@media (min-width:768px) and (max-width:991px) {
    .iconBox .iconList {
        margin-left: 20px
    }
}

@media (max-width:767px) {
    .iconBox .iconList {
        margin: 0 18px 0 0
    }
}

@media (max-width:767px) {
    .iconBox .iconList.iconListCart {
        margin: 0 22px 0 0
    }
}

.iconBox .iconList a {
    position: relative;
    display: block;
    height: 24px;
    transition: opacity 0.75s
}

.iconBox .iconList a img {
    display: block;
    max-height: 100%
}

@media (min-width:768px) {
    .iconBox .iconList a:hover {
        opacity: 0.7
    }
}

.iconBox .iconList a.cart {
    overflow: visible
}

.iconBox .iconList a.cart:after {
    content: attr(data-num);
    position: absolute;
    top: -13px;
    right: -12px;
    background-color: #D3132C;
    color: #fff;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    font-size: 13px;
    font-weight: 700;
    text-align: center;
    line-height: 22px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: "Oxygen", "Noto Sans TC", sans-serif;
    padding-bottom: 1px
}

@media (max-width:767px) {
    .iconBox .iconList a.cart:after {
        top: -10px;
        right: -10px;
        width: 20px;
        height: 20px;
        line-height: 20px;
        font-size: 12px
    }
}

.searchBox {
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.75s;
    position: absolute;
    top: 90px;
    left: 0;
    width: 100%;
    height: 76px;
    background: #E4EBE8;
    display: flex;
    align-items: center;
    justify-content: center
}

@media (min-width:768px) and (max-width:991px) {
    .searchBox {
        top: 70px;
        height: 60px
    }
}

@media (max-width:767px) {
    .searchBox {
        z-index: 10;
        top: 58px;
        height: 80px
    }
}

.searchBox .inputBox {
    width: 80%;
    max-width: 1200px;
    display: flex;
    align-items: center
}

@media (max-width:767px) {
    .searchBox .inputBox {
        width: 100%;
        padding: 0 25px
    }
}

.searchBox .inputBox .input {
    position: relative;
    flex: 1;
    height: 42px;
    margin-right: 20px
}

@media (min-width:768px) and (max-width:991px) {
    .searchBox .inputBox .input {
        height: 30px
    }
}

@media (max-width:767px) {
    .searchBox .inputBox .input {
        margin-right: 0
    }
}

.searchBox .inputBox .input input {
    width: 100%;
    height: 100%;
    border: none;
    border-radius: 0;
    border-bottom: 1px solid #000;
    background: rgba(255, 255, 255, 0);
    font-size: 16px;
    font-family: "Oxygen", "Noto Sans TC", sans-serif;
    letter-spacing: 1px
}

@media (min-width:768px) and (max-width:991px) {
    .searchBox .inputBox .input input {
        font-size: 15px
    }
}

@media (max-width:767px) {
    .searchBox .inputBox .input input {
        padding-bottom: 8px
    }
}

.searchBox .inputBox .input input::placeholder {
    font-size: 16px;
    letter-spacing: 1px;
    font-family: "Oxygen", "Noto Sans TC", sans-serif;
    color: rgb(158, 158, 158)
}

@media (max-width:767px) {
    .searchBox .inputBox .input input::placeholder {
        font-size: 14px;
        letter-spacing: 2.1px
    }
}

.searchBox .inputBox .input .btnSearchIcon {
    position: absolute;
    top: 40%;
    right: 12px;
    transform: translateY(-50%);
    width: 20px
}

@media (min-width:768px) and (max-width:991px) {
    .searchBox .inputBox .input .btnSearchIcon {
        width: 16px
    }
}

.searchBox .inputBox .inputIcon {
    display: block;
    flex: 0 0 25px;
    width: 25px
}

.searchBox.active {
    opacity: 1;
    pointer-events: all
}

.iconBox_mo {
    display: none;
    position: absolute;
    z-index: 10;
    top: 136px;
    left: 0;
    width: 100%
}

@media (max-width:767px) {
    .iconBox_mo {
        display: block;
        background: #fff;
        opacity: 0;
        pointer-events: none
    }
}

.iconBox_mo ul {
    display: flex;
    align-items: center;
    padding: 14px 0
}

.iconBox_mo ul li {
    position: relative;
    flex: 0 0 50%;
    text-align: center
}

.iconBox_mo ul li:first-child:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    width: 1px;
    height: 100%;
    background-color: #000
}

.iconBox_mo ul li:first-child .icon {
    width: 23px;
    margin: 0 auto 8px
}

@media (max-width:767px) {
    .iconBox_mo ul li:first-child .icon {
        width: 21px
    }
}

.iconBox_mo ul li:last-child .icon {
    width: 20px;
    margin: 0 auto 7px
}

@media (max-width:767px) {
    .iconBox_mo ul li:last-child .icon {
        width: 23px
    }
}

.iconBox_mo ul li a {
    display: block
}

.iconBox_mo ul li .txt {
    font-size: 15px;
    letter-spacing: 1px;
    color: #000
}

@media (max-width:767px) {
    .iconBox_mo ul li .txt {
        text-align: center;
        font-size: 18px;
        letter-spacing: 2.7px
    }
}

.contactBox {
    position: fixed;
    z-index: 1001
}

@media (min-width:768px) {
    .contactBox {
        width: 60px;
        bottom: 78px;
        right: 0;
        opacity: 0;
        pointer-events: none;
        transition: opacity 0.75s
    }
}

@media (max-width:767px) {
    .contactBox {
        bottom: 0;
        left: 0;
        width: 100%;
        height: 66px;
        line-height: 66px;
        opacity: 0;
        pointer-events: none;
        background-color: #000
    }
}

.contactBox.show {
    opacity: 1;
    pointer-events: all
}

.contactBox.change {
    position: absolute;
    bottom: auto
}

@media (max-width:767px) {
    .contactBox ul {
        display: flex;
        align-items: center
    }
}

.contactBox ul li {
    position: relative;
    background-color: #000;
    transition: opacity 0.75s
}

@media (min-width:768px) {
    .contactBox ul li {
        height: 87px;
        border-radius: 5px 0 0 5px;
        overflow: hidden;
        display: flex;
        align-items: center;
        justify-content: center
    }
}

@media (max-width:767px) {
    .contactBox ul li {
        flex: 0 0 50%
    }
}

@media (min-width:768px) {
    .contactBox ul li:hover {
        opacity: 0.7
    }
}

.contactBox ul li:first-child {
    margin-bottom: 12px
}

@media (max-width:767px) {
    .contactBox ul li:first-child {
        margin-bottom: 0
    }
}

@media (max-width:767px) {
    .contactBox ul li:first-child:after {
        content: "";
        position: absolute;
        top: 0;
        right: 0;
        width: 1px;
        height: 100%;
        background-color: #fff
    }
}

.contactBox ul li:first-child .img {
    width: 32px;
    margin-right: 10px
}

@media (min-width:768px) {
    .contactBox ul li:first-child .img {
        width: 25px
    }
}

.contactBox ul li:first-child .img img {
    padding-bottom: 2px
}

.contactBox ul li:last-child .img {
    width: 23px;
    margin-right: 15px
}

@media (min-width:768px) {
    .contactBox ul li:last-child .img {
        width: 18px
    }
}

.contactBox ul li:last-child .img img {
    padding-bottom: 4px
}

@media (min-width:768px) {
    .contactBox ul li a {
        display: block
    }
}

@media (max-width:767px) {
    .contactBox ul li a {
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0 10px
    }
}

@media (min-width:768px) {
    .contactBox ul li a .img {
        margin: 0 15px
    }
}

.contactBox ul li a .txt {
    color: #fff;
    text-align: center
}

@media (max-width:767px) {
    .contactBox ul li a .txt {
        font-size: 20px;
        letter-spacing: 2px
    }
}

@media (min-width:768px) {
    .contactBox ul li a .txt {
        line-height: 20px;
        margin-top: 4px
    }
}

@media (min-width:768px) {
    .contactBox ul li a .txt i {
        display: block
    }
}

.marquee {
    height: 60px
}

@media (min-width:768px) and (max-width:1440px) {
    .marquee {
        height: 55px
    }
}

@media (max-width:767px) {
    .marquee {
        height: 50px
    }
}

.marquee img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center
}

footer {
    background-color: #000;
    padding: 100px 200px 50px
}

@media (min-width:992px) and (max-width:1200px) {
    footer {
        padding: 80px 100px 50px
    }
}

@media (min-width:768px) and (max-width:991px) {
    footer {
        padding: 60px 50px 40px
    }
}

@media (max-width:767px) {
    footer {
        padding: 42px 24px 35px
    }
}

footer .top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 70px;
    border-bottom: 1px solid #949494
}

@media (max-width:767px) {
    footer .top {
        flex-direction: column;
        align-items: flex-start;
        justify-content: start;
        padding-bottom: 33px
    }
}

@media (max-width:767px) {
    footer .footerLeft {
        margin-bottom: 61px
    }
}

footer .footer-logo {
    max-width: 400px;
    margin-bottom: 40px
}

@media (min-width:992px) and (max-width:1200px) {
    footer .footer-logo {
        max-width: 320px;
        margin-bottom: 36px
    }
}

@media (min-width:768px) and (max-width:991px) {
    footer .footer-logo {
        max-width: 260px;
        margin-bottom: 34px
    }
}

@media (max-width:767px) {
    footer .footer-logo {
        max-width: 200px;
        margin-bottom: 26px
    }
}

footer .footer-logo img {
    width: 100%
}

footer .footer-logo a {
    transition: opacity 0.75s
}

@media (min-width:768px) {
    footer .footer-logo a:hover {
        opacity: 0.7
    }
}

footer .introBox {
    display: flex;
    align-items: center;
    margin-right: 40px;
    max-width: 980px
}

@media (max-width:1440px) {
    footer .introBox {
        flex-direction: column;
        align-items: flex-start;
        margin-right: 0px
    }
}

footer .introBox .txt {
    line-height: 1.75;
    letter-spacing: 1.6px;
    color: #fff;
    margin-right: 36px
}

@media (min-width:768px) and (max-width:1440px) {
    footer .introBox .txt {
        margin: 0 40px 20px 0
    }
}

@media (max-width:767px) {
    footer .introBox .txt {
        font-size: 15px;
        letter-spacing: 1.5px;
        line-height: 1.93;
        margin: 0 0 13px
    }
}

footer .img {
    display: flex;
    align-items: center;
    flex: 0 0 172px
}

@media (max-width:1440px) {
    footer .img {
        flex: 0 0 auto
    }
}

footer .img img {
    height: 46px
}

@media (max-width:767px) {
    footer .img img {
        height: 49px
    }
}

footer .img a {
    display: inline-block;
    margin-right: 15px;
    flex: 0 0 112px;
    transition: opacity 0.75s
}

@media (min-width:768px) {
    footer .img a:hover {
        opacity: 0.7
    }
}

footer .img>img {
    flex: 0 0 45px
}

footer .footerRight {
    flex: 0 0 300px
}

@media (min-width:992px) and (max-width:1440px) {
    footer .footerRight {
        flex: 0 0 250px
    }
}

@media (min-width:768px) and (max-width:991px) {
    footer .footerRight {
        flex: 0 0 200px
    }
}

@media (max-width:767px) {
    footer .footerRight {
        flex: 0 0 auto
    }
}

footer .overseas {
    text-align: right;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 1.6px;
    margin-bottom: 10px
}

@media (max-width:767px) {
    footer .overseas {
        text-align: left;
        font-size: 15px;
        letter-spacing: 1.5px;
        margin-bottom: 8px
    }
}

footer .overseas a {
    color: rgba(255, 255, 255, 0.7);
    transition: opacity 0.75s
}

@media (min-width:768px) {
    footer .overseas a:hover {
        opacity: 0.7
    }
}

footer .stronghold {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 1.6px;
    text-align: right;
    margin-bottom: 40px
}

@media (max-width:767px) {
    footer .stronghold {
        justify-content: flex-start;
        font-size: 15px;
        letter-spacing: 1.5px;
        margin-bottom: 24px
    }
}

footer .stronghold li {
    margin-left: 24px
}

@media (min-width:768px) and (max-width:991px) {
    footer .stronghold li {
        margin-left: 16px
    }
}

@media (max-width:767px) {
    footer .stronghold li {
        margin: 0 22px 0 0
    }
}

footer .stronghold li:first-child {
    margin-left: 0
}

@media (min-width:768px) {
    footer .stronghold li:first-child a:after {
        content: none
    }
}

@media (max-width:767px) {
    footer .stronghold li:last-child a:after {
        content: none
    }
}

footer .stronghold li a {
    position: relative;
    padding-left: 24px;
    color: rgba(255, 255, 255, 0.7);
    transition: opacity 0.75s
}

@media (min-width:768px) and (max-width:991px) {
    footer .stronghold li a {
        padding-left: 16px
    }
}

@media (max-width:767px) {
    footer .stronghold li a {
        padding: 0 22px 0 0
    }
}

@media (min-width:768px) {
    footer .stronghold li a:hover {
        opacity: 0.7
    }
}

footer .stronghold li a:after {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%);
    width: 1px;
    height: 80%;
    background-color: rgba(255, 255, 255, 0.7)
}

@media (max-width:767px) {
    footer .stronghold li a:after {
        left: auto;
        right: 0
    }
}

footer .socialIcon {
    display: flex;
    align-items: center;
    justify-content: flex-end
}

@media (max-width:767px) {
    footer .socialIcon {
        justify-content: start
    }
}

footer .socialIcon li {
    margin-left: 29px
}

footer .socialIcon li:first-child,
footer .socialIcon li:nth-child(2) {
    width: 35px
}

@media (max-width:767px) {

    footer .socialIcon li:first-child,
    footer .socialIcon li:nth-child(2) {
        width: 32px
    }
}

@media (max-width:767px) {
    footer .socialIcon li:first-child {
        margin-left: 0
    }
}

footer .socialIcon li:nth-child(3) {
    width: 42px
}

@media (max-width:767px) {
    footer .socialIcon li:nth-child(3) {
        width: 39px
    }
}

footer .socialIcon li a {
    transition: opacity 0.75s
}

@media (min-width:768px) {
    footer .socialIcon li a:hover {
        opacity: 0.7
    }
}

footer .footerMenu {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 50px 0 30px
}

@media (max-width:767px) {
    footer .footerMenu {
        flex-wrap: wrap;
        justify-content: start;
        padding: 36px 0 2px
    }
}

@media (max-width:767px) {
    footer .footerMenu li {
        margin-bottom: 17px
    }

    footer .footerMenu li:first-child a,
    footer .footerMenu li:last-child a {
        padding-left: 0px
    }

    footer .footerMenu li:last-child {
        display: block;
        width: 100%
    }

    footer .footerMenu li:nth-child(4) a {
        padding-right: 0px
    }

    footer .footerMenu li:nth-child(4) a:after {
        content: none
    }
}

footer .footerMenu li:last-child a:after {
    content: none
}

footer .footerMenu a {
    position: relative;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 1.6px;
    color: #fff;
    padding: 0 49px;
    transition: opacity 0.75s
}

@media (min-width:992px) and (max-width:1366px) {
    footer .footerMenu a {
        padding: 0 30px
    }
}

@media (min-width:768px) and (max-width:991px) {
    footer .footerMenu a {
        padding: 0 20px
    }
}

@media (max-width:767px) {
    footer .footerMenu a {
        padding: 0 10px;
        font-size: 15px;
        letter-spacing: 1.5px
    }
}

@media (min-width:768px) {
    footer .footerMenu a:hover {
        opacity: 0.7
    }
}

footer .footerMenu a:after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: 1px;
    height: 90%;
    background-color: #fff
}

footer .copyright {
    font-size: 12px;
    letter-spacing: 1.2px;
    text-align: center;
    color: #fff;
    line-height: 1.75
}

@media (max-width:767px) {
    footer .copyright {
        text-align: left
    }
}

.gotop {
    position: fixed;
    z-index: 100;
    right: 0px;
    bottom: 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 60px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.75s
}

@media (max-width:767px) {
    .gotop {
        width: 73px;
        bottom: 9px
    }
}

.gotop.show {
    opacity: 1;
    pointer-events: all
}

.gotop.change {
    position: absolute;
    bottom: auto
}

@media (min-width:768px) {
    .gotop:hover {
        opacity: 0.7
    }

    .gotop:hover .arrow {
        transform: translateY(-4px)
    }
}

.gotop .arrow {
    width: 14px;
    height: 7px;
    margin-bottom: 15px;
    transition: transform 0.75s
}

@media (max-width:767px) {
    .gotop .arrow {
        width: 18px;
        height: 9px;
        margin-bottom: 14px
    }
}

.gotop .txt {
    font-family: "Frank Ruhl Libre", serif;
    font-weight: 500;
    letter-spacing: 1.6px
}

@media (max-width:767px) {
    .gotop .txt {
        font-size: 20px;
        letter-spacing: 2px
    }
}

*,
body,
html {
    font-family: "Oxygen", "Noto Sans TC", sans-serif;
    font-weight: 400;
    margin: 0 auto;
    color: #000;
    word-break: break-word
}

body,
html {
    position: relative;
    overflow: hidden auto;
    max-width: 1920px
}

.porel {
    position: relative
}

.center {
    text-align: center
}

.m0a {
    margin: 0 auto
}

.d_none {
    display: none !important
}

input,
select,
textarea {
    font-family: "Oxygen", "Noto Sans TC", sans-serif !important;
    width: 100%;
    resize: none;
    border-radius: 0;
    border: 1px solid rgb(221, 221, 221);
    background-color: #F5F5F5;
    font-size: 16px;
    letter-spacing: 1.6px;
    padding: 10px
}

@media (max-width:767px) {

    input,
    select,
    textarea {
        font-size: 15px;
        letter-spacing: 1.5px
    }
}

input:focus,
select:focus,
textarea:focus {
    outline: none
}

input::placeholder,
select::placeholder,
textarea::placeholder {
    font-family: "Oxygen", "Noto Sans TC", sans-serif !important;
    color: #949494;
    font-size: 16px;
    letter-spacing: 1.6px
}

@media (max-width:767px) {

    input::placeholder,
    select::placeholder,
    textarea::placeholder {
        font-size: 15px;
        letter-spacing: 1.5px
    }
}

.error_input {
    background-color: #F5F5F5 !important;
    border: 1px solid #D3132C
}

input {
    height: 50px;
    line-height: 50px
}

select {
    height: 50px;
    appearance: none;
    background: #F5F5F5 url("../../Contents/images/common/select_down.png") center right 10px/17px 10px no-repeat
}

@media (max-width:767px) {
    select {
        background: #F5F5F5 url("../../Contents/images/common/select_down.png") center right 10px/17px 10px no-repeat
    }
}

#Contents {
    margin: 0
}

::selection {
    background-color: #000;
    color: #fff
}

* {
    box-sizing: border-box
}

img {
    max-width: 100%
}

@media (max-width:767px) {
    .pc {
        display: none !important
    }
}

.mo {
    display: none !important
}

@media (max-width:767px) {
    .mo {
        display: block !important
    }
}

@media (max-width:991px) {
    .pc_991 {
        display: none !important
    }
}

.mo_991 {
    display: none !important
}

@media (max-width:991px) {
    .mo_991 {
        display: block !important
    }
}

a,
a:hover,
a:visited {
    text-decoration: none;
    outline: none;
    color: inherit
}

:focus {
    outline: none
}

.warningTxt {
    color: #D3132C !important;
    letter-spacing: 1.2px;
    font-size: 16px;
    letter-spacing: 1.6px;
    margin-bottom: 20px
}

@media (max-width:767px) {
    .warningTxt {
        font-size: 15px;
        letter-spacing: 1.5px;
        margin-bottom: 16px
    }
}

.error_inline {
    color: #D3132C !important;
    letter-spacing: 1.2px;
    font-size: 16px;
    letter-spacing: 1.6px
}

@media (max-width:767px) {
    .error_inline {
        font-size: 15px;
        letter-spacing: 1.5px
    }
}

.container {
    width: 80%;
    max-width: 1200px;
    margin: 0 auto
}

@media (min-width:768px) and (max-width:991px) {
    .container {
        width: 90%
    }
}

@media (max-width:767px) {
    .container {
        width: 100%;
        max-width: 100%;
        padding: 0 25px
    }
}

.container_swiper {
    width: 95%;
    max-width: 1440px;
    margin: 0 auto
}

@media (min-width:768px) and (max-width:991px) {
    .container_swiper {
        width: 100%
    }
}

@media (max-width:767px) {
    .container_swiper {
        width: 100%;
        max-width: 100%;
        padding: 0 25px
    }
}

.wrap {
    overflow-x: hidden;
    margin-top: 90px
}

@media (max-width:991px) {
    .wrap {
        margin-top: 70px
    }
}

@media (max-width:767px) {
    .wrap {
        margin-top: 58px
    }
}

.wrap.scrollMenu {
    margin-top: 65px
}

@media (max-width:767px) {
    .wrap.scrollMenu {
        margin-top: 58px
    }
}

#Foot {
    border: none;
    padding: 0
}

#pagination {
    margin: 37px 0
}

#pagination ul {
    text-align: center
}

#pagination li {
    display: inline-block;
    padding: 4px 3px;
    font-size: 16px;
    letter-spacing: 1.6px;
    line-height: 1.25;
    border-bottom: 1px solid #000
}

.pageTitle {
    padding-top: 100px
}

@media (max-width:767px) {
    .pageTitle {
        padding-top: 55px
    }
}

.pageTitle h1 {
    font-size: 40px;
    font-weight: 700;
    font-family: "Frank Ruhl Libre", serif;
    letter-spacing: 4px;
    line-height: 1.3;
    color: #000;
    text-align: center
}

@media (min-width:768px) and (max-width:1200px) {
    .pageTitle h1 {
        font-size: 36px;
        letter-spacing: 3px
    }
}

@media (max-width:767px) {
    .pageTitle h1 {
        font-size: 31px;
        letter-spacing: 2.5px
    }
}

.pageTitle h2 {
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 10px;
    line-height: 1.45;
    text-align: center;
    color: #949494;
    margin-top: -1px
}

@media (max-width:767px) {
    .pageTitle h2 {
        margin-top: -3px;
        letter-spacing: 9.3px
    }
}

.m_txt {
    font-size: 16px;
    letter-spacing: 1.6px;
    line-height: 1.5
}

@media (max-width:767px) {
    .m_txt {
        font-size: 15px;
        letter-spacing: 1.5px;
        line-height: 1.43
    }
}

.btnLine {
    position: relative;
    display: inline-block;
    font-size: 20px;
    font-weight: 500;
    letter-spacing: 2px;
    font-family: "Frank Ruhl Libre", serif;
    overflow: hidden;
    padding-bottom: 12px;
    width: max-content;
    width: 130px;
    display: block;
    white-space: nowrap
}

@media (max-width:767px) {
    .btnLine {
        padding-bottom: 8px
    }
}

@media (min-width:768px) {
    .btnLine:hover:after {
        animation: animateLine 0.75s
    }
}

.btnLine:after {
    content: "";
    position: absolute;
    bottom: 2px;
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #000;
    transition: transform 0.3s
}

@keyframes animateLine {
    0% {
        transform: translateX(0)
    }

    50% {
        transform: translateX(100%)
    }

    51% {
        transform: translateX(-100%)
    }

    to {
        transform: translateX(0)
    }
}

.btnBig {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    padding: 25px 50px;
    background-color: #000;
    transition: opacity 0.75s
}

@media (max-width:767px) {
    .btnBig {
        padding: 18px 37px
    }
}

@media (min-width:768px) {
    .btnBig:hover {
        opacity: 0.7
    }
}

.btnBig .txt {
    font-size: 20px;
    letter-spacing: 2px;
    font-weight: 500;
    color: #fff;
    margin-right: 78px
}

@media (max-width:767px) {
    .btnBig .txt {
        margin-right: 25px;
        letter-spacing: 1.5px
    }
}

.btnBig .arrow {
    width: 8px;
    height: 14px
}

.btnBig .arrow img {
    display: block
}

.btnBox {
    display: flex;
    align-items: center;
    justify-content: center
}

@media (max-width:767px) {
    .btnBox {
        flex-direction: column-reverse
    }
}

.btnBox .btnUse {
    position: relative;
    display: inline-block;
    width: 274px;
    height: 63px;
    line-height: 63px;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 1.6px;
    text-align: center;
    transition: opacity 0.75s;
    margin: 0 10px
}

@media (max-width:767px) {
    .btnBox .btnUse {
        width: 240px;
        height: 56px;
        line-height: 56px;
        margin: 0
    }
}

@media (min-width:768px) {
    .btnBox .btnUse:hover {
        opacity: 0.7
    }
}

.btnBox .btn_w {
    background-color: #fff;
    color: #000;
    border: 1px solid #000
}

.btnBox .btn_w.arrow:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 30px;
    transform: translateY(-50%);
    width: 8px;
    height: 14px;
    background: url("../../Contents/images/common/arrow_btn.png") center/contain no-repeat
}

@media (max-width:767px) {
    .btnBox .btn_w.arrow:before {
        left: 26px
    }
}

.btnBox .btn_b {
    background-color: #000;
    color: #fff
}

@media (max-width:767px) {
    .btnBox .btn_b {
        margin: 0 0 16px
    }
}

.btnBox .btn_b.arrow:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 30px;
    transform: translateY(-50%);
    width: 8px;
    height: 14px;
    background: url("../../Contents/images/common/arrow_btn_w.png") center/contain no-repeat
}

@media (max-width:767px) {
    .btnBox .btn_b.arrow:before {
        left: 26px
    }
}

.btnBox .btn_b.arrow_r:before {
    content: "";
    position: absolute;
    top: 50%;
    right: 30px;
    transform: translateY(-50%) scale(-1);
    width: 8px;
    height: 14px;
    background: url("../../Contents/images/common/arrow_btn_w.png") center/contain no-repeat
}

@media (max-width:767px) {
    .btnBox .btn_b.arrow_r:before {
        right: 26px
    }
}

.btnBox .buyCart img {
    display: inline-block;
    width: 29px;
    height: 24px;
    margin-right: 12px
}

@media (max-width:767px) {
    .btnBox .buyCart img {
        width: 25px;
        height: 22px;
        margin-right: 10px
    }
}

.btnBox .truck img {
    display: inline-block;
    width: 27px;
    height: 19px;
    margin-right: 12px
}

@media (max-width:767px) {
    .btnBox .truck img {
        width: 24px;
        height: 17px;
        margin-right: 10px
    }
}

.errorPage {
    position: relative
}

.errorPage:after {
    content: "";
    z-index: -1;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 420px;
    background-color: #E4EBE8
}

@media (max-width:767px) {
    .errorPage:after {
        height: 261px
    }
}

.errorPage .whiteBox {
    margin: 63px 0 81px;
    padding: 81px 78px 79px;
    background-color: #fff
}

@media (min-width:992px) and (max-width:1200px) {
    .errorPage .whiteBox {
        margin: 40px 0;
        padding: 50px 40px
    }
}

@media (min-width:768px) and (max-width:991px) {
    .errorPage .whiteBox {
        margin: 40px 0;
        padding: 45px 40px
    }
}

@media (max-width:767px) {
    .errorPage .whiteBox {
        margin: 36px 0;
        padding: 40px
    }
}

.errorPage .completeTxt {
    text-align: center;
    padding-bottom: 51px
}

@media (max-width:767px) {
    .errorPage .completeTxt {
        padding-bottom: 40px
    }
}

.hamMenu {
    display: none;
    overflow: hidden
}

@media (max-width:767px) {
    .hamMenu {
        display: block
    }
}

.menu-ham,
.menu-ham span {
    display: inline-block;
    transition: all 0.75s;
    box-sizing: border-box
}

.menu-ham {
    position: relative;
    background: none;
    border: none;
    appearance: none;
    cursor: pointer;
    width: 25px;
    height: 24px
}

.menu-ham span {
    position: absolute;
    width: 25px;
    height: 2px;
    background-color: #fff;
    text-align: center;
    transition: transform 0.75s
}

.menu-ham span:first-of-type {
    top: 6px
}

.menu-ham span:nth-of-type(2) {
    top: 14px
}

.menu-ham span:nth-of-type(3) {
    top: 22px
}

#menu-ham.hamActive span:first-of-type {
    transform: translate(0px, 8px) rotate(-45deg)
}

#menu-ham.hamActive span:nth-of-type(2) {
    transform: translateX(150%)
}

#menu-ham.hamActive span:nth-of-type(3) {
    transform: translate(0px, -8px) rotate(45deg)
}

.pageList {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 73px
}

@media (max-width:767px) {
    .pageList {
        margin-top: 42px
    }
}

.pageList a {
    position: relative;
    display: block;
    font-size: 16px;
    line-height: 1.25;
    letter-spacing: 1.6px
}

@media (min-width:768px) {
    .pageList a:hover span {
        color: #949494
    }
}

.pageList a span {
    display: inline-block;
    padding: 3px;
    letter-spacing: 1px;
    color: #000;
    transition: color 0.75s
}

.pageList a.active span {
    border-bottom: 1px solid #000
}

.pageList .next_btn,
.pageList .prev_btn {
    position: relative;
    width: 20px;
    height: 20px
}

.pageList .next_btn:before,
.pageList .prev_btn:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

@media (min-width:768px) {

    .pageList .next_btn:hover:before,
    .pageList .prev_btn:hover:before {
        opacity: 0.7
    }
}

.pageList .next_btn.nopage,
.pageList .prev_btn.nopage {
    opacity: 0.3;
    pointer-events: none
}

.pageList .prev_btn {
    margin-right: 9px;
    margin-top: 2px
}

@media (max-width:767px) {
    .pageList .prev_btn {
        margin-right: 7px
    }
}

.pageList .prev_btn:before {
    background: url("../../Contents/images/common/prev.png") center/contain no-repeat;
    opacity: 1;
    transition: opacity 0.5s
}

.pageList .next_btn {
    margin-left: 9px
}

@media (max-width:767px) {
    .pageList .next_btn {
        margin-left: 7px
    }
}

.pageList .next_btn:before {
    background: url("../../Contents/images/common/next.png") center/contain no-repeat;
    opacity: 1;
    transition: opacity 0.5s
}

.pageList .numList {
    padding: 5px 15px
}

@media (max-width:767px) {
    .pageList .numList {
        padding: 5px 12px
    }
}

#pagination_count {
    font-size: 16px;
    letter-spacing: 0.8px;
    line-height: 2
}

