@charset "UTF-8";

:root {
    --blue: #3498db;
    --pink: #c16ca0;
    --ftblue: #4fa0ca;
}

@media (min-width: 769px) {
    .mb-s {
        display: none;
    }
}

@media (max-width: 768px) {
    .pc-s {
        display: none;
    }
}

.header .logo {
    position: unset;
    left: unset;
    -webkit-transform: unset;
    -ms-transform: unset;
    transform: unset;
    top: unset;
    z-index: unset;
    width: unset;
    flex: 0 0 20%;
    margin-right: unset;

}

.header .logo img {
    display: block;
}

.header-f {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

@media (max-width: 768px) {
    .header .logo {
        flex: 0 0 40%;
    }
}

.header .top-header .top-menu .navbar-toggler {
    top: 50%;
    transform: translateY(-50%);
    right: 15px;
    background-color: var(--blue);
}

.header.stick .top-header .top-menu .navbar-toggler {
    top: 50%;
    transform: translateY(-50%);
    right: 15px;

}

.header .top-header .top-menu nav .navbar-collapse.show {
    top: 46px;
    background-color: var(--blue);
}


.header .top-header {
    padding: 0px;
    background-color: unset;
}

.header .top-header .top-menu .collapse li a {
    margin-right: 15px;
    margin-left: 15px;
    padding: 25px 0px;
    color: #707070;
    font-size: 16px;
}

.header .top-header .top-menu .collapse li:last-child a {
    margin-right: 0px;
}

.header .top-header .top-menu .collapse li:hover a,
.header .top-header .top-menu .collapse li.active a {
    color: var(--pink);
}

.header .top-header .top-menu .collapse li.active a::before,
.header .top-header .top-menu .collapse li:hover a::before {
    height: 3px;
    width: 100%;
    top: unset;
    bottom: 0px;
    background-color: var(--blue);
}

@media (min-width: 769px) {
    .header .top-header .nav {
        padding-top: 25px;
    }

}

@media (max-width: 768px) {
    .header .top-header .top-menu .collapse li.active a {
        color: #ff0000;
    }
}


.footer {
    background-color: #caebfc;
    padding-top: 120px;
    padding-bottom: 70px;
}

.ftbot-r {
    display: flex;
    width: 100%;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;

}

.footer .cpyright {
    background-color: unset;
    padding: unset;
}

.ftbot-r .cpyright {
    color: var(--ftblue);
    font-size: 11px;
    margin-bottom: 0px;
}

.ftbot-r .ft-soc {
    display: flex;
    align-items: center;
}

.ftbot-r .ft-soc a {
    display: block;
    margin-left: 3px;
    margin-right: 3px;
    transition: 0.4;
}

.ftbot-r .ft-soc a img {
    display: block;
}

.ftbot-r .ft-soc a:hover {
    opacity: 0.7;
}

.ft-top {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-wrap: wrap;
    padding-bottom: 70px;
    margin: 0 auto;
}

.ft-top .ft-logo {
    max-width: 248px;
    margin-right: 20px;
    margin-left: 53px;
}

.ft-top .ft-cont {
    padding-top: 2px;
    margin-left: 20px;
}

.ft-top .ft-cont h4 {
    margin-bottom: 0px;
    line-height: 2em;
    border-bottom: 1px solid var(--ftblue);
    font-size: 20px;
    font-weight: bold;
    color: var(--ftblue);

}

.ft-top .ft-cont p {
    margin-bottom: 0px;
    line-height: 2em;
    font-size: 14px;
    color: var(--ftblue);

}

@media (max-width: 768px) {
    .ft-top {
        padding-bottom: 30px;
    }

    .ft-top .ft-logo {
        margin-right: 0px;
        margin-left: 0px;
        margin-bottom: 20px;
        max-width: 200px;
    }

    .ftbot-r {
        justify-content: center;
    }

    .footer .cpyright {
        text-align: center;
        margin-bottom: 10px;
    }
}

.slick-dots li button:before {
    width: 10px;
    height: 10px;
    border: unset;
    box-shadow: unset;
}

.slick-dots li.slick-active button:before {
    width: 10px;
    height: 10px;
    border: unset;
    box-shadow: unset;
    background-color: var(--blue);
}

.container-c {
    padding-left: 5%;
    padding-right: 5%;
}

.container-c2 {
    padding-left: 7%;
    padding-right: 7%;
}

@media (max-width: 768px) {
    .container-c {
        padding-left: 20px;
        padding-right: 20px;
    }

    .container-c2 {
        padding-left: 30px;
        padding-right: 30px;
    }
}

.ids1 {
    padding-top: 120px;
    padding-bottom: 120px;
}

.s1-r {
    flex-direction: row-reverse;
}


.s1-r .s1-img {
    padding-left: 40px;
}

.s1-r .s1-img img {
    width: 100%;
}

.s1-r .s1-text {
    padding-right: 40px;
}

.s1-r .s1-text h2 {
    margin-bottom: 25px;
    padding-bottom: 20px;
    position: relative;
    font-size: 30px;
    color: var(--blue);
}

.s1-r .s1-text h2:before {
    bottom: 0px;
    left: 0px;
    height: 2px;
    width: 2em;
    content: "";
    position: absolute;
    background-color: var(--blue);
}

.s1-r .s1-text img {
    display: block;
    margin-bottom: 30px;
}

.s1-r .s1-text p {
    font-size: 16px;
    margin-bottom: 0px;
    color: #898989;
}

@media (max-width: 768px) {
    .ids1 {
        padding-top: 60px;
        padding-bottom: 60px;
    }

    .s1-r .s1-img {
        padding-left: 15px;
        margin-bottom: 20px;
    }

    .s1-r .s1-text {
        padding-right: 15px;
    }
}


.ids-ti {
    display: flex;
    justify-content: center;
}

.ids-ti img {
    margin-right: 18px;
}

.ids-ti h2 {
    font-size: 30px;
    font-weight: normal;
    margin-bottom: 0px;
    position: relative;
    color: var(--blue);
    padding-top: 10px;
}

.ids-ti h2:before {
    content: "";
    bottom: -20px;
    left: 5px;
    background-color: var(--blue);
    width: 2em;
    height: 2px;
    position: absolute;

}

.ids2 {
    padding-top: 65px;
    padding-bottom: 65px;
    background-color: #f9f9f9;
}

.ids2 .ids-ti {
    margin-bottom: 90px;
}

.ids2 .s2-r {
    margin-right: -30px;
    margin-left: -30px;
}

.ids2 .s2-r .ids2-c {
    padding-left: 30px;
    padding-right: 30px;
    margin-bottom: 35px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;

}

.ids2 .s2-r .ids2-c .img-wrap {
    flex: 0 0 26%;
}
@media (max-width: 768px){
    .ids2 .s2-r .ids2-c .img-wrap {
        flex: 0 0 35%;
    }
}

.ids2 .s2-r .ids2-c .img-wrap .img-item{
    padding-top: 100%;
    border-radius: 50%;
}

.ids2 .s2-r .ids2-c .ids2-text {
    flex: 0 0 68%;
}

.ids2 .s2-r .ids2-c .ids2-text h3 {
    color: #898989;
    font-size: 22px;
    margin-bottom: 3px;
}

.ids2 .s2-r .ids2-c .ids2-text p {
    margin-bottom: 0px;
    font-size: 14px;
    color: #898989;
    overflow: hidden;
    -o-text-overflow: ellipsis;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    height: 2.4em;
    line-height: 1.2em;
}

.amore {
    text-align: right;
    padding: 2px 15px;
    font-size: 15px;
    color: var(--blue);
    border-radius: 90px;
    border: 1px solid var(--blue);

}

.amore:hover {
    background-color: var(--blue);
    color: #fff;
}

.ids2 .s2-r .ids2-c .ids2-text p+div {
    text-align: right;
}

@media (max-width: 768px) {
    .ids2 .s2-r {
        margin-right: -15px;
        margin-left: -15px;
    }

    .ids2 .s2-r .ids2-c {
        justify-content: center;
        flex-wrap: wrap;
        padding-left: 15px;
        padding-right: 15px;
    }

    .ids2 .s2-r .ids2-c img {
        flex: 0 0 50%;
        margin-bottom: 10px;
    }

    .ids2 .s2-r .ids2-c .ids2-text {
        flex: 0 0 100%;
    }

    .ids2 .s2-r .ids2-c .ids2-text p+div {
        text-align: center;
    }

}

.s3-img {
    min-height: 500px;
    background-image: url(../images/s3-1.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;

}

.ids3 .s3-c {
    background-color: #8ebeed;
    padding-top: 70px;
    padding-left: 50px;
    padding-right: calc(50% - 600px);
}

.ids3 .s3-c .ids-ti h2 {
    color: #fff;
}

.ids3 .s3-c .ids-ti h2:before {
    background-color: #fff;
}

.ids3 .s3-c .s3-text p {
    color: #fff;
    font-size: 26px;
    margin-bottom: 20px;
    border-radius: 90px;
    line-height: 30px;
    padding-left: 40px;
}

.ids3 .s3-c .s3-text p:nth-child(even) {
    background-color: #add0f200;
}

.ids3 .ids-ti {
    margin-bottom: 60px;
    justify-content: start;
}

@media (max-width: 768px) {
    .s3-img {
        min-height: 300px;
    }

    .ids3 .s3-c {
        background-color: #8ebeed;
        padding: 40px 15px;

    }

    .ids3 .s3-c .s3-text p {
        padding-left: 20px;
    }
}
.ids4{
  padding-top: 80px;
  padding-bottom: 120px;
}

.ids4 .ids-ti{
  margin-bottom: 80px;
}
.ids4 .s4-r {
    margin-right: -30px;
    margin-left: -30px;
}

.ids4 .s4-r .ids4-c {
    padding-left: 30px;
    padding-right: 30px;
    margin-bottom: 60px;

}

.s4-img .img-wrap .img-item {
    padding-top: 110.82%;
}

.s4-text {
    background-color: #fbfbfb;
    padding: 30px 30px 15px;
}

.s4-text .s4-name {
    padding-bottom: 15px;
    margin-bottom: 20px;
    border-bottom: 1px solid #898989;

}

 .s4-text .s4-name h4 {
    color: #898989;
    font-size: 20px;
    margin-bottom: 0px;
}

 .s4-text .s4-name p {
    color: #898989;
    font-size: 15px;
    margin-bottom: 0px;
}

 .s4-text .s4-des p{
color: #898989;
    font-size: 15px;
    margin-bottom: 0px;
    line-height: 1.5em;
}

 .s4-text .s4-des p.s4-subti{
  color: var(--blue);
}
 .s4-text .s4-des p + p.s4-subti{
    margin-top: 10px;
 }

@media (max-width: 768px){

  .ids4{
  padding-top: 60px;
  padding-bottom: 60px;
}
.ids4 .ids-ti{
  margin-bottom: 40px;
}
.ids4 .s4-r {
    margin-right: -15px;
    margin-left: -15px;
}

.ids4 .s4-r .ids4-c {
    padding-left: 15px;
    padding-right: 15px;
    margin-bottom: 20px;

}
.ids4 .s4-r .ids4-c .s4-text{
  padding: 10px;
}
 .s4-text .s4-name{
  flex-wrap: wrap;
  padding-bottom: 10px;
  margin-bottom: 10px;
} .s4-text .s4-name h4{
  flex: 0 0 100%;
  margin-bottom: 0px;
}
    .s4-text .s4-name p{
        margin-left: 0px;
        flex: 0 0 100%;
    }
}

.ids5{
  padding-top: 80px;
  padding-bottom: 110px;
  background-color: #8ebeed;
}
.ids5 .ids-ti{
  margin-bottom: 120px;
}
.ids5 .ids-ti h2{
  color: #fff;
}
.ids5 .ids-ti h2:before{
  background-color: #fff;
}

.s5-c{
  margin-bottom: 50px;
}

.cus-s{
  position: relative;
  background-color: #fbfbfb;
  padding: 35px 15px 25px;
}

.cus-s:before{
    position: absolute;
    content: "";
    top: 0;
    height: 20px;
    width: 100%;
    left: 0;
}

.cus-con .s5-c:nth-child(5n+1) .cus-s:before{
    background-color: #da6ca3;
}
.cus-con .s5-c:nth-child(5n+2) .cus-s:before{
    background-color: #8867aa;
}
.cus-con .s5-c:nth-child(5n+3) .cus-s:before{
    background-color: #93bde5;
}
.cus-con .s5-c:nth-child(5n+4) .cus-s:before{
    background-color: #ece86d;
}
.cus-con .s5-c:nth-child(5n) .cus-s:before{
    background-color: #6cdaaa;
}



.cus-s .cus-name{
  font-size: 28px;
  color: #707070;
  letter-spacing: 2px;
  font-weight: bold;
  text-align: left;
}

.cus-s .cus-des{
  font-size: 18x;
  line-height: 1.5em;
  margin-bottom: 0px;
  color: #707070;
  letter-spacing: 2px;
}

.cus-s .cus-text .cus-more{
    margin-top: 25px;
    text-align: right;

}


.ids5 .amore{
  background-color: #fff;
}

.ids5 .amore:hover{
  background-color: var(--blue);
}

@media (max-width: 768px){
  .ids5 .ids-ti{
  margin-bottom: 60px;
}
.ids5{
  padding-bottom: 60px;
}
.s5-c{
  margin-bottom: 25px;
}
}
.ids6{
  padding-top: 105px;
  padding-bottom: 135px;
}
.ids6 .ids-ti{
  margin-bottom: 80px;
}

.news-c .img-wrap .img-item{
  padding-top: 75%;
}

.news-c .word-item{
  border: 2px solid #fff;
  padding: 25px 20px 10px;
  background-color: #fff;
}

.news-c .word-item h3{
  font-size: 19px;
  margin-bottom:15px ;
  color: #898989;
  padding-bottom: 15px;
  line-height: 1.2em;
  overflow: hidden;
  -o-text-overflow: ellipsis;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  height: 2.4em;
}

.news-c .word-item p{
  font-size: 16px;
  line-height: 1.5em;
  margin-bottom: 0px;
  color: #898989;
  overflow: hidden;
  -o-text-overflow: ellipsis;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  height: 4.5em;
}

@media (max-width: 768px){
  .news-c{
    margin-bottom: 30px;
  }
}


.content-70200{
  padding-top: 70px;
  padding-bottom: 200px;
}

.content-70{
  padding-top: 70px;
}

.cont-kv{
    position: relative;
    padding-top: 36.76%;
    background-size: cover;
    background-position: center;
    background-image: url(../images/news-bg.jpg);
    z-index: -1;

}

.cont-kv .conkvb{
    position: absolute;
    top: 0px;
    left: 0px;
    width: 46%;
}

.cont-kv .conkva{
    position: absolute;
    right: 0px;
    bottom: 0px;
    transform: translateY(52%);
    width: 13.53%;
}

.cont-kv .conkv-text{
    position: absolute;
    left: calc(50% - 600px);
    top: 50%;
    transform: translateY(-34%);
    z-index: 2;
}
.cont-kv .conkv-text h1{
    font-size: 46px;
    margin-bottom: 0px;
    font-weight: normal;
    line-height: 1.5em;
    text-shadow: 0 0 5px #000;
    color: #fff;
}
.cont-kv .conkv-text p{
    font-size: 46px;
    margin-bottom: 0px;
    font-weight: bold;
    color: #fff;
}

@media (max-width: 1360px){
    .cont-kv .conkv-text{
    position: absolute;
    left: 15px;
}
}
@media (max-width: 768px){
    .cont-kv{
        padding-top: 75%;
        overflow: hidden;
    }
    .cont-kv .conkv-text{
    width: 100%;
    transform: translatey(-75%);
}
.cont-kv .conkv-text h1{
    font-size: 24px;
    line-height: 1.2em;
}
.cont-kv .conkv-text p{
    font-size: 24px;
}
.cont-kv .conkva{
    display: none;
}
.cont-kv .conkvb{
    width: 72%;
}
}

.content-70200 .ids-ti{
    margin-bottom: 95px;
}
.content-70 .ids-ti{
    margin-bottom: 75px;
}
.newsimg .nav-tabs {
    border: none;
    -webkit-box-pack: flex-start;
    -ms-flex-pack: flex-start;
    justify-content: flex-start;
}

.newsimg .nav-tabs .nav-link {
    text-align: center;
    font-size: 17px;
    padding: 10px 20px;
    color: var(--blue);
    border-color: var(--blue);
    border-radius: 10px;
    border-right: 1px solid var(--blue);
    font-weight: bold;
    letter-spacing: 1px;
}

.newsimg .nav-tabs .nav-link + .nav-link {
    margin-left: 20px;
}

@media (max-width: 768px) {
    .newsimg .tm_shadow_tab .tm_shadow_dropdown .tm_shadow_tab_title{
        background-color: var(--blue);
        color: #fff;
        font-size: 16px;
    }
    .newsimg .nav-tabs .nav-link {
        padding: 5px 10px;
        border: 0px;
        font-weight: normal;
        font-size: 16px;
    }
    .newsimg .nav-tabs .nav-link + .nav-link {
    margin-left: 0px;
}
}

.newsimg .nav-tabs .nav-link:last-child {
    border: solid 1px;

}

.newsimg .nav-tabs .nav-link.active,
.newsimg .nav-tabs .nav-link:hover {
    color: #fff;
    background-color: var(--blue);
}

.word-f{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 10px;
}

.news-c .word-item .word-f p{
    margin-bottom: 0px;
    height: auto;
}
.news-c:hover .word-item .word-f .amore{
    background-color: var(--blue);
    color: #fff;
}

.cus-con{
    column-count: 3;
   /*欄數*/
   column-gap: 50px;
  
}
.cus-con .s5-c {
     break-inside: avoid-column;
}


@media (max-width: 768px) {
    .cus-con{
    column-count: 1;
   /*欄數*/
   column-gap: 15px;
  
}
}

.team-r1{
    display: flex;
    flex-direction: row-reverse;
    flex-wrap: wrap;
    width: 75%;
    margin: 0 auto;
    align-items: flex-start;
}

.team-r1c-img img{
    width: 100%;
}

.team-r1c.s4-text{
    background-color: unset;
}

/*.team-r1c.s4-text .s4-name{
    border-bottom: 0px;
}*/

.team-r1c.s4-text .s4-name h4{
    position: relative;
    font-size: 39px;

}

/*.team-r1c.s4-text .s4-name h4:before{
    content: "";
    width: 3em;
    position: absolute;
    height: 3px;
    bottom: -17px;
    left: 2px;
    background-color: var(--blue);
}*/

.team-r1c.s4-text .s4-name p{
    font-size: 19px;
}
.team-f{
    display: flex;
    flex-wrap: wrap;
}

.team-f .s4-des{
    flex: 0 0 50%;
    padding-left: 5px;
    padding-right: 5px;
}

@media (max-width: 768px){

.team-r1{
    width: 100%;

}
.team-f .s4-des{
    flex: 0 0 100%;
}
.team-f .s4-des + .s4-des{
    margin-top: 10px;
}
.team-con .row{
    padding-left: 15px;
    padding-right: 15px;
}
.team-con .s4-text{
    background-color: unset;
    padding-left: 30px;
    padding-right: 30px;
}
}

.ab-slick .img-wrap .img-item{
    padding-top: 56.25%;
}

.abs2{
    padding-top: 80px;
}

.abs2 .abs2-f{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-top: 80px;
}
.abs2 .abs2-f:first-child{
    margin-top: unset;
}

.abs2 .abs2-f .s2-img{
    flex: 0 0 45%;
}

.abs2 .abs2-f .s2-img .img-wrap .img-item{
    padding-top: 56.25%;
}

.abs2 .abs2-f .s2-text{
    flex: 0 0 50%;
}
.abs2 .abs2-f .s2-text h3{
    font-size: 30px;
    color: var(--blue);
    margin-bottom: 30px;
}

.abs2 .abs2-f .s2-text p{
    font-size: 16px;
    margin-bottom: 0px;
    color: #898989;
}

@media (max-width: 768px){
    .abs2 .abs2-f{
        margin-top: 30px;
        justify-content: center;
    }
    .abs2 .abs2-f .s2-text{
    flex: 0 0 100%;
}
.abs2 .abs2-f .s2-img{
    flex: 0 0 100%;
    margin-bottom: 10px;
}
}

.cd-top{
    visibility: hidden;
}

.cd-top.cd-fade-out {
  visibility: visible;
  opacity: .8
}

.cd-top.cd-fade-out:hover {
  opacity: 1
}

.service-img.content-70200{
    padding-bottom: 0px;
    margin-bottom: 0px;
}

.footer .fx-btn-g {
    position: fixed;
    right: 3px;
    top: calc(25% + 120px);
    z-index: 999999;
}

.footer .fx-btn-g .fx-btn {
    display: block;
    margin-bottom: 10px;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    box-shadow: 0px 2px 4px #0d0409;
    transition: .4s;


}

.footer .fx-btn-g .fx-btn img{
    width: 100%;
}

.footer .fx-btn-g .fx-btn:hover {
    transform: translateY(-3px);
    box-shadow: 0px 2px 6px #0d0409;
}

.contact-map iframe{
    width: 100%!important;
    height: 450px!important;
}
.fx-addline{
    position: relative;
    width: 90vw;
    bottom: 5px;
    left: 5vw;
    background-color: #00c854;
    border-radius: 15px;
    padding: 15px;
    z-index: 9999;
    
    
}

.fx-addline.stick{
    -webkit-animation: 500ms ease-in-out 0s normal none 1 running fadeInUp;
    animation: 500ms ease-in-out 0s normal none 1 running fadeInUp;
    position: fixed;
}

.fx-addline a{
    font-size: 20px;
    font-weight: bold;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.fx-addline a img{
    width: 40px;
}

.fx-addline a p{
    font-size: 28px;
    color: #000;
    font-weight: bold;
}

@media (min-width: 991px){

.fx-addline{
    left: calc(50% - 200px);
    max-width: 400px;
}

}