@charset "utf-8";
/* ---- banner ---- */
.banner .slick-dots {
    position: absolute;
    top: 50%;
    left: 80px;
    width: auto;
    height: auto;
    list-style: none;
    padding: 0;
}
.banner .slick-dots li {
    width: auto;
    height: auto;
    padding: 5px 0;
}
.banner .slick-dots li button {
    text-align: center;
    white-space: normal;
    text-indent: unset;
    overflow: hidden;
    border: 0;
    padding: 0;
    font-size: 18px;
    color: #46392C;
    background: transparent;
    border: 1px solid transparent;
    border-radius: 100%;
    width: 35px;
    height: 35px;
    line-height: 35px;
    font-family: 'Marcellus SC', serif;
    cursor: pointer;
}
.banner .slick-dots li.slick-active button {
    border-color: rgb(70, 57, 44, 0.5);
}
/* ---- /banner ---- */
/* ---- common ---- */
.title {
    position: relative;
    box-sizing: border-box;
    display: block;
    margin: 0 0 30px;
}
.title span {
    position: relative;
    box-sizing: border-box;
    color: #46392C;
    font-size: 55px;
    font-weight: normal;
    letter-spacing: 0;
    line-height: 1;
    font-family: 'Marcellus SC', serif;
}
.title span i {
    font-style: unset;
    display: block;
}
.title b {
    position: relative;
    box-sizing: border-box;
    color: #46392C;
    font-size: 24px;
    font-weight: normal;
    letter-spacing: 1.5px;
    line-height: 1.2;
}
section .more {
    position: relative;
    box-sizing: border-box;
    display: block;
    text-align: left;
    width: 114px;
    height: 22px;
    color: #46392C;
    font-size: 15px;
    font-family: 'Marcellus SC', sans-serif;
    transition: all .3s ease;
    margin: 30px 35px 0 auto;
}
section .more::before {
    content: '';
    position: absolute;
    bottom: 3px;
    right: 5px;
    width: 26px;
    height: 5px;
    background: url(../../images/common/index/btn_arr.svg) no-repeat;
    transition: all .3s ease;
}
section .more:hover {
    opacity: 0.5;
}
section .more:hover:before {
    right: 0;
}
/* ---- /common ---- */
/* ---- sect5-ad ---- */
.sect5 {
    position: relative;
    padding: 64px 0 45px;
    background: #fff;
}
/* ---- about-sect ---- */
.about-sect {
    position: relative;
    padding: 45px 0 134px;
    background: url(../../images/common/index/bg.jpg) no-repeat 50% 100%;
    background-size: cover;
}
.about-sect::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
    height: 50%;
    background: -webkit-linear-gradient(top, rgba(255, 255, 255, 1) 0, rgba(255, 255, 255, 0) 100%);
}
.about-sect .container {
    padding: 0 15px;
    max-width: 1085px;
    margin: 0 auto;
    display: flex;
    align-items: center;
}
.about-sect .title {
    text-align: left;
    display: flex;
    align-items: end;
    margin: 0;
}
.about-sect .title span {
    line-height: 0.8;
}
.about-sect .title b {
    padding-left: 30px;
}
.about-sect .title b::before {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 12px;
    width: 6px;
    height: 6px;
    border-radius: 100%;
    background: rgb(70, 57, 44, 0.6);
}
.about-sect .about-pic {
    width: 58.7%;
    padding-right: 63.5px;
    position: relative;
    box-sizing: border-box;
}
.about-sect .about-txt {
    width: 41.3%;
    padding-left: 63.5px;
    padding-right: 21px;
    position: relative;
    box-sizing: border-box;
}
.about-sect .editor {
    width: 100%;
    position: relative;
    box-sizing: border-box;
    color: #555555;
    letter-spacing: 1px;
    line-height: 2;
}
.about-sect .pic {
    margin: 50px 0 0;
    font-size: 0;
}
.about-sect .pic img {
    margin-right: -4px;
    width: calc((100% / 3) - 0.1px);
}
/* ---- products ---- */
.products-sect {
    position: relative;
    padding: 0 0 120px;
    background: url('../../images/common/index/products_bg.jpg');
}
.products-sect::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
    height: 400px;
    background: url(../../images/common/index/products_pic.jpg) no-repeat fixed;
    background-size: cover;
}
.products-sect .title {
    display: flex;
    justify-content: center;
    flex-direction: column-reverse;
    align-items: center;
    padding: 150px 0 0;
    margin: 0 0 42px;
}
.products-sect .title::after {
    content: '';
    position: relative;
    display: block;
    width: 6px;
    height: 6px;
    border-radius: 100%;
    background: rgba(255, 255, 255, 0.6);
    margin: 0 auto 13px;
}
.products-sect .title b,
.products-sect .title span {
    color: #fff;
}
/* 點點 */
.products-list .slick-dots {
    position: absolute;
    text-align: right;
    top: -35px;
    right: 20px;
    width: 100%;
}
.products-list .slick-dots li {
    display: inline-block;
    width: auto;
    padding: 0;
}
.products-list .slick-dots li button {
    white-space: nowrap;
    text-indent: 101%;
    overflow: hidden;
    padding: 0;
    border: 0;
    background: rgba(255, 255, 255, 0.3);
    width: 10px;
    height: 10px;
    opacity: 1;
    margin: 0 5px;
    border-radius: 100%;
    cursor: pointer;
}
.products-list .slick-dots li.slick-active button {
    background: rgba(255, 255, 255, 0.6);
}
.products-sect .more {
    position: relative;
    margin: 30px auto 0;
}
.products-sect .more i {
    display: none;
}
/* ---- news ---- */
.sect3 {
    position: relative;
    padding: 96px 0 93px;
    background: url(../../images/common/index/bg.jpg) no-repeat;
    background-size: cover;
}
.news-sect .title b {
    display: block;
    padding-left: 30px;
}
.news-sect .title b::before {
    content: '';
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 12px;
    width: 6px;
    height: 6px;
    border-radius: 100%;
    background: rgb(70, 57, 44, 0.6);
}
.news-sect .more {
    position: absolute;
    top: 60px;
    right: 0;
    margin: 0;
}
.news-sect {
    position: relative;
    box-sizing: border-box;
    float: left;
    width: 48.5%;
    padding-left: 80px;
}
.news-list li {
    position: relative;
    box-sizing: border-box;
}
.news-list li+li {
    border-top: 1px solid rgb(70, 57, 44, 0.3);
}
.news-list li .box {
    position: relative;
    box-sizing: border-box;
    padding: 15px;
    transition: all .3s ease;
}
.news-list li .box:hover {
    background: #fff;
}
.news-list li .box .cover {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 30;
    font-size: 0;
}
.news-list li .date {
    position: relative;
    box-sizing: border-box;
    display: inline-block;
    vertical-align: middle;
    text-align: center;
    color: #46392C;
    font-size: 45px;
    line-height: 50px;
    width: 70px;
    font-family: 'Marcellus SC', serif;
    border-right: 1px solid rgb(70, 57, 44, 0.3);
}
.news-list li .date b {
    display: block;
    font-size: 16px;
    font-weight: normal;
    letter-spacing: 0.2px;
    line-height: 1;
}
.news-list li .text {
    display: inline-block;
    vertical-align: middle;
    margin: 0 0 0 15px;
    width: calc(100% - 100px);
}
.news-list li .name {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    color: #46392C;
    height: 25px;
    font-size: 18px;
    margin: 0 0 5px;
    letter-spacing: 0.8px;
    line-height: 1.2;
}
.news-list li .description {
    position: relative;
    box-sizing: border-box;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 14px;
    color: #777777;
    letter-spacing: 0.5px;
    line-height: 1.5;
}
/* ---- ad ---- */
.ad-sect {
    float: right;
    width: 44.5%;
    padding-right: 54px;
}
.ad-sect img {
    width: 100%;
}
.ad-sect .col {
    margin-right: -4px;
    display: inline-block;
    vertical-align: top;
    position: relative;
    width: 66%;
    height: 100%;
    min-height: 420px;
    max-width: 420px;
}
.ad-sect .col .txt {
    font-family: 'Petrona', serif;
    font-size: 18px;
    color: #A98865;
    line-height: 1.6;
    position: absolute;
    margin: 75px 0 0 30px;
}
.ad-sect .col .txt a {
    font-size: 14px;
    color: #918680;
    line-height: 28px;
    width: 122px;
    text-align: center;
    display: block;
    border: 1px solid #918680;
    transition: all .2s;
}
.ad-sect .col .txt a:hover {
    opacity: .7;
    transition: all .2s;
}
.ad-sect .col.small {
    max-width: 205px;
    float: right;
    width: 33%;
}
.ad-sect .col.small img {
    margin-bottom: 10px;
}
/* ---- rwd ---- */
@media screen and (max-width: 1440px) {
    .news-sect {
        width: 62%;
        padding: 0;
    }
    .ad-sect {
        width: 30.8%;
        padding: 0;
    }
    .ad-sect .col,
    .ad-sect .col.small {
        display: block;
        width: 100%;
        float: none;
        height: auto;
        max-width: 100%;
        min-height: auto;
    }
    .ad-sect .col .txt {
        padding: 30px;
        margin: 0;
        position: relative;
    }
    .ad-sect .col.small {
        margin: 10px 0 0 0;
    }
    .ad-sect .col.small img {
        width: 50%;
        margin-right: -5px;
    }
    .ad-sect .col.small img+img {
        margin: 0;
    }
}
@media screen and (max-width: 1280px) {
    .sect5 {
        padding: 40px 0 30px;
    }
    .about-sect .about-pic {
        width: 55.7%;
        padding-right: 30px;
    }
    .about-sect .about-txt {
        width: 44.3%;
        padding-left: 30px;
        padding-right: 21px;
    }
}
@media screen and (max-width: 1000px) {
    .title{
        margin: 0 0 20px;
    }
    .title span{
        font-size: 45px;
    }
    section .more {
        margin: 20px auto 0;
    }
    .about-sect {
        padding: 30px 0 60px;
    }
    .about-sect .container{
        flex-direction: column;
    }
    .about-sect .title {
        justify-content: center;
    }
    .about-sect .about-pic {
        width: 100%;
        padding: 0;
        text-align: center;
    }
    .about-sect .about-txt{
        width: 100%;
        padding: 20px 15px 0;
    }
    .about-sect .editor span {
        font-size: 22px;
        text-align: center;
        width: fit-content;
        margin: 0 auto;
        padding: 5px 35px 30px;
    }
    .about-sect .editor span::before{
        top: 30%;
    }
    .products-sect{
        padding: 0 0 30px;
    }
    .products-sect .title {
        padding: 60px 0 0;
        margin: 0 0 20px;
    }
    .products-sect .title::after{
        margin: 0 auto 30px
    }
    .products-list li {
        width: calc((100% / 2) - 3px);
    }
    .products-sect .more{
        margin: 0 auto 0;
    }
    .sect3 {
        padding: 30px 0 60px;
    }
    .news-sect .more {
        top: 50px;
    }
    .news-sect {
        float: none;
        width: 100%;
    }
    .ad-sect {
        float: none;
        width: 100%;
        display: block;
        margin: 30px auto 0;
    }
    .news-list li .name {
        font-size: 16px;
        height: 22px;
    }
    .ad-sect .col .txt {
        padding: 10px;
        font-size: 16px;
    }
    .ad-sect .col,
    .ad-sect .col.small {
        background-size: cover;
    }
    .ad-sect .col {
        display: block;
        width: 66.64%;
        float: left;
        height: auto;
        max-width: 100%;
        min-height: auto;
    }
    .ad-sect .col.small {
        display: block;
        width: 33.36%;
        float: left;
        height: auto;
        max-width: 100%;
        min-height: auto;
        margin: 0;
    }
    .ad-sect .col.small img {
        width: 100%;
        margin: 0;
    }
}
@media screen and (max-width: 767px) {
    .about-sect .title {
        margin-top: 5px;
        margin-bottom: 10px;
        font-size: 20px;
    }
    .products-sect::before{
        height: 250px;
        background-attachment: unset;
    }
    .news-sect .title {
        display: flex;
        flex-direction: column;
        margin: 0 auto 20px;
        align-items: center;
    }
    .news-list li .box{
        padding: 15px;
    }
    .news-list li .date {
        font-size: 35px;
        width: auto;
        position: relative;
        top: unset;
        transform: unset;
        border: 0;
        line-height: 1;
        display: flex;
        align-items: baseline;
    }
    .news-list li .date b::before {
        content: ' / ';
        padding-left: 5px;
    }
    .news-list li .date b {
        font-size: 15px;
    }
    .news-list li .text {
        display: block;
        margin: 10px 0 0;
        width: 100%;
    }
    .news-sect .more {
        position: relative;
        top: unset;
        left: 0;
        right: 0;
        margin: 20px auto 0;
    }
}
@media screen and (max-width: 400px) {
    .ad-sect .col,
    .ad-sect .col.small {
        display: block;
        width: 100%;
        float: left;
        height: auto;
        max-width: 100%;
        min-height: auto;
    }
    .ad-sect .col.small img {
        width: 50%;
        margin: 0;
        margin-right: -5px;
    }
}