/*********** 前後台編輯器區塊共用的CSS設定 ***********/
/* ------- about ------- */
/* content */
.a_layout {
    position: relative;
    box-sizing: border-box;
    width: 100%;
    max-width: 1100px;
    margin: 0 auto;
}
.a_layout span {
    position: relative;
    box-sizing: border-box;
    font-size: 50px;
    font-weight: 600;
    color: #52A9A4;
    letter-spacing: 0.2px;
    line-height: 1.2;
    font-family: 'Cormorant Garamond', serif;
}
.a_layout h2 {
    position: relative;
    box-sizing: border-box;
    display: block;
    font-size: 26px;
    font-weight: normal;
    color: #333333;
    letter-spacing: 2px;
    line-height: 1.2;
    margin: 0;
}
.a_layout h3 {
    position: relative;
    box-sizing: border-box;
    display: block;
    text-align: left;
    font-size: 28px;
    font-weight: normal;
    color: #444444;
    letter-spacing: 5px;
    line-height: 1.2;
    margin: 0 0 20px;
}
.a_layout p{
    margin: 0;
    color: #666666;
    letter-spacing: 1.5px;
    line-height: 2.2;
}
.a_layout .a_item,
.a_layout .a_item .a_col {
    position: relative;
    box-sizing: border-box;
}
.a_layout .a_item:first-of-type {
    display: flex;
}
.a_layout .a_item:last-of-type {
    display: flex;
    align-items: center;
    padding: 0 55px 0 25px;
    margin: -82px 0 0;
}
.a_layout .a_item:last-of-type .a_col {
    width: 30%;
    padding: 50px 0 0;
}
.a_layout .a_item:last-of-type .a_col:first-of-type:before{
    content: '';
    position: absolute;
    top: 57%;
    transform: translateY(-50%);
    right: -30px;
    width: 60px;
    height: 1px;
    background: #52A9A4;
    z-index: 1;
}
.a_layout .a_item:last-of-type .a_col:last-of-type {
    width: 70%;
    background: #F5F5F5;
    padding: 50px 80px;
}
@media screen and (max-width: 1280px) {
    .a_layout .a_item:last-of-type {
        padding: 0 15px;
        margin: -80px 0 0;
    }
    .a_layout .a_item:last-of-type .a_col:first-of-type:before {
        right: -20px;
        width: 40px;
    }
    .a_layout span {
        font-size: 45px;
    }
    .a_layout h2{
        font-size: 23px;
    }
    .a_layout h3 {
        font-size: 23px;
        margin: 0 0 5px;
    }
}
@media screen and (max-width: 1000px) {
    .a_layout .a_item:first-of-type {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
    }
    .a_layout .a_item:last-of-type{
        margin: 0;
        padding: 0;
        flex-direction: column;
    }
    .a_layout .a_item:last-of-type .a_col {
        width: 100%;
        padding: 30px 0;
        text-align: center;
    }
    .a_layout .a_item:last-of-type .a_col:last-of-type {
        width: 100%;
    }
    .a_layout .a_item:last-of-type .a_col:first-of-type:before {
        width: 1px;
        height: 30px;
        bottom: -15px;
        top: unset;
        left: 0;
        right: 0;
        margin: 0 auto;
        transform: unset;
    }
    .a_layout h3{
        text-align: center;
    }
    .a_layout p {
        line-height: 1.75;
    }
}
@media screen and (max-width: 767px) {
    .a_layout .a_item:last-of-type .a_col:last-of-type {
        padding: 30px;
    }
    .a_layout h3 {
        font-size: 22px;
    }
}
/* index */
.service-sect .editor h3,
.about-sect .editor h3 {
    position: relative;
    box-sizing: border-box;
    display: block;
    text-align: center;
    font-size: 28px;
    font-weight: normal;
    color: #444444;
    letter-spacing: 5px;
    line-height: 1.2;
    margin: 0 0 20px;
}
.service-sect .editor h3{
    text-align: left;
}
.about-sect .editor p {
    width: 100%;
    max-width: 530px;
    margin: 0 auto;
}
.service-sect .editor p{
    text-align: left;
}
.service-sect .editor .stxt{
    position: relative;
    z-index: 1;
    margin: 0;
}
.service-sect .editor .stxt .en_stxt{
    position: absolute;
    top: -180%;
    left: 20%;
    z-index: -1;
    opacity: 0.1;
    color: #fff;
    font-size: 150px;
    font-family: "Pinyon Script", cursive;
    white-space: nowrap;
    line-height: 0.5;
}
@media screen and (max-width: 1000px) {
    .service-sect .editor h3{
        text-align: center;
        font-size: 23px;
        margin: 0 0 5px;
    }
    .service-sect .editor .stxt{
        text-align: center;
    }
    .service-sect .editor .stxt .en_stxt{
        top: -112px;
        left: 0;
    }
}
/* 跑馬燈 */
.marquee {
    width: 100%;
    position: absolute;
    left: -49rem;
    right: -49rem;
    top: 0;
    height: auto; 
    white-space: nowrap;
}
@keyframes marqueeAnimation {
    0% { transform: translateX(0%); }
    100% { transform: translateX(100%); }
}
@keyframes marqueeAnimation2 {
    0% { transform: translateX(-100%); }
    100% { transform: translateX(0%); }
}
.marquee-content ul{
    list-style: none;
    margin: 0;
    padding: 0;
    flex-shrink: 0;
    position: absolute;
    top: 0;
}
.marquee-content ul:first-child{
    display: flex;
    animation: marqueeAnimation 70s linear infinite;
}
.marquee-content ul:last-child{
    display: flex;
    animation: marqueeAnimation2 70s linear infinite;
    animation-delay: -70s;
}
.marquee-content ul > li{
    margin: 0 16px;
    width: 880px;
}
@media screen and (max-width: 1000px){
    .about-sect .editor h3 {
        font-size: 23px;
        margin: 0 0 5px;
    }
}
/* ------- /about ------- */
.editor-title {
    color: #44D6E7;
    font-size: 28px;
    font-weight: bold;
    text-align: center;
    line-height: 1.4;
    margin: 0;
}
.editor-title2{
    text-align: center;
    margin-bottom: 25px;
    position: relative;
}
.editor-title2:before{
    content: '';
    position: absolute;
    width: 600px;
    height: 1px;
    top: 50%;
    left: 0;
    right: 0;
    margin:-0.5px auto 0;
    background:#BFF8FF;
}
.editor-title2 span{
    display: inline-block;
    background: #fff;
    padding: 0 10px;
    font-size: 25px;
    color: #44D6E7;
    position: relative;
    z-index: 2;
}
.editor-title-img {
    display: inline-block;
    vertical-align: middle;
    margin-bottom: 5px;
}
.about-editor-circle {
    text-align: center;
    max-width: 550px;
    margin: 0 auto;
}
.about-editor-circle .col {
    float: left;
    width: 33.33%;
    padding: 0 5px;
}
.about-editor-circle-pic {
    display: inline-block;
    vertical-align: middle;
    background: url('../../images/common/about/circle_bg.png');
    border-radius: 100%;
    padding: 8px;
}
.about-editor-circle-pic.bg2 {
    background: url('../../images/common/index/about_circle_bg.png');
}
.about-editor-circle-pic img {
    border-radius: 100%;
}
.about-editor-pics {
    max-width: 1110px;
    margin: 0 auto;
}
.about-editor-pics .col {
    float: left;
    width: 33.33%;
    padding: 0 1.5%;
}
.products-editor-pics {
    margin: 0 -6px;
}
.products-editor-pics .col {
    float: left;
    width: 25%;
    padding: 0 6px;
    margin-bottom: 10px;
    text-align: center;
}
.service-editor-list {
    list-style-type: none;
    padding: 0;
    margin: 0;
}
.service-editor-list .item {
    width: 33.33%;
    padding: 0 2%;
    float: left;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
.service-editor-list .item:nth-child(3n+1) {
    clear: left;
}
.service-editor-list .box {
    max-width: 411px;
    margin: 0 auto 50px;
}
.service-editor-list .name {
    color: #333;
    font-size: 18px;
    margin: 10px 0 6px;   
}
.service-editor-list .description {
    color: #535353;
    font-size: 14px;
    letter-spacing: 0.8px;
    line-height: 1.5;
}
.index-service-editor-list {
    list-style-type: none;
    padding: 0;
    margin: 0 -10px;
}
.index-service-editor-list .item {
    width: 33.33%;
    padding: 0 10px;
    float: left;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}
.index-service-editor-list .box {
    overflow: hidden;
}
.index-service-editor-list .pic {
    float: left;
    width: 183px;
}
.index-service-editor-list .txt {
    margin-left: 200px;
}
.index-service-editor-list .name {
    color: #006CD8;
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 8px;
    line-height: 1.2;
}
.index-service-editor-list .description {
    color: #000;
    font-size: 15px;
    line-height: 1.5;
}
.contact-info-list {
    list-style-type: none;
    padding: 0;
    margin: 0;
}
.contact-info-list li,
.contact-info-list i,
.contact-info-list span {
    display: inline-block;
    vertical-align: middle;
}
.contact-info-list li {
    width: calc(100% / 4);
    padding: 0;
    font-size: 18px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    float: left;
}
.contact-info-list i {
    position: relative;
    box-sizing: border-box;
    width: 55px;
    height: 55px;
    background: rgb(51, 226, 246, 0.2);
    border-radius: 100%;
}
.contact-info-list i::after{
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: calc(100% - 10px);
    height: calc(100% - 10px);
    background: #52A9A4;
    z-index: -1;
    border-radius: 100%;
}
.contact-info-list i::before{
    display: inline-block;
    font-family: 'icon-font-5' !important;
    speak: none;
    font-style: normal;
    font-weight: normal;
    font-variant: normal;
    text-transform: none;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #fff;
    font-size: 18px;
    width: 55px;
    height: 55px;
    line-height: 55px;
    text-align: center;
}
.contact-info-list span,
.contact-info-list a {
    position: relative; 
    width: calc(100% - 70px); 
    display: inline-block; 
    vertical-align: middle; 
    margin-left: 10px;
    font-size: 15px;
}
.terms-title {
    color: #52A9A4;
    font-size: 17px;
    font-weight: normal;
    margin: 0 0 0.3em;
}
@media screen and (max-width: 1280px) {
    .index-service-editor-list .box {
        max-width: 411px;
        margin: 0 auto;
    }
    .index-service-editor-list .pic {
        float: none;
        width: auto;
    }
    .index-service-editor-list .txt {
        margin: 10px 0 0;
    }
}
@media screen and (max-width: 1000px) {
    .products-editor-pics .col {
        width: 50%;
    }
    .contact-info-list li {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        margin-bottom: 5px;
        padding: 0;
        width: auto;
        float: none;
    }
    .contact-info-list .ic-wrap {
        width: 60px;
    }
}
@media screen and (max-width: 960px) {
    .service-editor-list .item {
        width: 50%;
    }
    .service-editor-list .item:nth-child(3n+1) {
        clear: none;
    }
    .service-editor-list .item:nth-child(2n+1) {
        clear: left;
    }
}
@media screen and (max-width: 767px) {
    .about-editor-pics .col {
        width: 100%;
        padding: 0 0 10px;
        text-align: center;
    }
    .index-service-editor-list .item {
        width: 100%;
    }
    .index-service-editor-list .box {
        max-width: none;
        margin-bottom: 15px;
    }
    .index-service-editor-list .pic {
        float: left;
        width: 200px;
    }
    .index-service-editor-list .txt {
        margin: 0 0 0 220px;
    }
}
@media screen and (max-width: 600px) {
    .service-editor-list .item {
        width: 100%;
        padding: 0;
    }
    .service-editor-list .item:nth-child(n) {
        clear: none;
    }
    .service-editor-list .box {
        margin-bottom: 30px;
    }
}
@media screen and (max-width: 500px) {
    .products-editor-pics .col {
        width: 100%;
    }
    .index-service-editor-list .box {
        max-width: 360px;
        margin-bottom: 30px;
    }
    .index-service-editor-list .pic {
        float: none;
        width: auto;
    }
    .index-service-editor-list .txt {
        margin: 10px 0 0;
    }
}
@media screen and (max-width: 420px) {
    .about-editor-circle .col {
        padding: 0 3px;
    }
    .about-editor-circle-pic {
        padding: 5px;
    }
}