/* global */
body {
    font-family: 'Noto Sans TC', '微軟正黑體';
    overflow-x: hidden;
}
h1, h2, h3, h4, h5, h6, p, a {
    font-family: 'Noto Sans TC', '微軟正黑體';
    margin: 0;
}
iframe {
    border: 0;
}
.mainwrapper {
    padding-top: 186px;
}
.common__container {
    position: relative;
    width: 100%;
    padding: 0 15px;
    margin: 0 auto;
}
.header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 100;
    width: 100%;
    background-color: #fff;
    -webkit-box-shadow: 0 0 3px rgba(0,0,0,.2);
    -moz-box-shadow: 0 0 3px rgba(0,0,0,.2);
    box-shadow: 0 0 3px rgba(0,0,0,.2);
}
.header__info {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    padding: 25px 0;
    border-bottom: 1px solid #ddd;
}
.header__logo {
    display: block;
    max-width: 150px;
}
.header__contact {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.header__contact-item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.header__contact-item:nth-child(n + 2) {
    margin-left: 25px;
}
.header__contact-item .fa {
    color: #8a8a8a;
    font-size: 21px;
    margin-right: 10px;
}
.header__contact-item h6 {
    color: #2c57ac;
    font-size: 12px;
    font-weight: 300;
    line-height: 1.2;
}
.header__contact-item p {
    font-family: 'Lato', 'Noto Sans TC', '微軟正黑體';
    color: #333;
    font-size: 14px;
    line-height: 1.2;
    margin-top: 3px;
}
.header__contact-item p a {
    font-family: 'Lato', 'Noto Sans TC', '微軟正黑體';
    color: #333;
}
.nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    padding: 25px 0;
}
.nav__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.nav__list a {
    position: relative;
    color: #333;
    font-size: 17px;
    font-weight: 300;
    line-height: 1.2;
    padding: 0 15px;
    -webkit-transition: color .4s;
    -moz-transition: color .4s;
    transition: color .4s;
}
.nav__list a.active {
    color: #2c57ac;
}
.nav__list a.active::after {
    content: '';
    position: absolute;
    top: calc(100% + 9px);
    left: 0;
    width: 100%;
    border-bottom: 2px solid #2c57ac;
}
.nav__list a:hover {
    color: #2c57ac;
}
.nav__contact {
    display: block;
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.25;
    padding: 15px 35px;
    background-color: #265fb4;
    border-radius: 25px;
    -webkit-transition: opacity .4s;
    -moz-transition: opacity .4s;
    transition: opacity .4s;
}
.nav__contact:hover {
    color: #fff;
    opacity: .8;
}
.common__section {
    padding: 70px 0;
}
.titlebox {
    text-align: center;
    margin-bottom: 45px;
}
.common__subtitle {
    color: #2c57ac;
    font-size: 14px;
    font-weight: 300;
    line-height: 1.2;
}
.common__title {
    color: #131d46;
    font-size: 30px;
    font-weight: 500;
    line-height: 1.2;
    margin-top: 12px;
}
.common__singletitle {
    color: #131d46;
    font-size: 30px;
    font-weight: 500;
    line-height: 1.2;
    margin-bottom: 35px;
}
.footer__itembox {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
}
.footer__item:first-child {
    width: 55%;
}
.footer__item:nth-child(2) {
    width: 30%;
}
.footer__item:nth-child(3) {
    width: 15%;
}
.footer__title {
    color: #fff;
    font-size: 17px;
    font-weight: 400;
    line-height: 1.35;
    margin-bottom: 25px;
}
.footer__text {
    max-width: 590px;
    color: #fff;
    font-size: 14px;
    font-weight: 300;
    line-height: 1.8;
    opacity: .8;
    padding-right: 15px;
    margin-bottom: 10px;
}
.footer__community {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
@media (min-width:992px) {
    .footer__community {
        display: none;
    }
}
.footer__community-item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    color: #333;
    font-size: 15px;
    line-height: 1.2;
    /*opacity: .7;*/
    -webkit-transition: opacity .4s;
    -moz-transition: opacity .4s;
    transition: opacity .4s;
}
.footer__community-item:hover {
    color: #333;
}
.footer .footer__community-item {
    color: #fff;
}
.footer__community-item:nth-child(n + 2) {
    margin-left: 25px;
}
.footer__community-item img {
    width: 30px;
    margin-right: 10px;
}
.footer__contact-item {
    display: block;
    color: #fff;
    font-size: 15px;
    line-height: 1.2;
    opacity: .8;
}
.footer__contact-item .fa {
    width: 20px;
    font-size: 18px;
    text-align: center;
    margin-right: 8px;
}
.footer__contact-item:nth-child(n + 2) {
    margin-top: 13px;
}
.footer__links {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
}
.footer__links div {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
}
.footer__links div:first-child {
    align-items: flex-start;
}
.footer__links div:last-child {
    align-items: flex-end;
}
.footer__link {
    color: #fff;
    font-size: 15px;
    line-height: 1.2;
    opacity: .8;
}
.footer__link:nth-child(n + 2) {
    margin-top: 10px;
}
.copyright {
    text-align: center;
    padding: 15px 0;
    background-color: #222;
}
.copyright p {
    color: #fff;
    font-size: 13px;
    line-height: 1.5;
    opacity: .7;
}
.copyright a {
    color: #fff;
}
.pagetitle {
    height: 170px;
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
/*.pagetitle::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #2c57ac;
    opacity: .9;
}*/
.pagetitle__box {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}
.pagetitle__box h1 {
    font-family: 'Lato', 'Noto Sans TC', '微軟正黑體';
    color: #fff;
    font-size: 30px;
    line-height: 1.2;
}
.bread {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.bread div {
    font-family: 'Lato', 'Noto Sans TC', '微軟正黑體';
    color: #fff;
    font-size: 16px;
    line-height: 1.2;
}
.bread a {
    color: #fff;
    opacity: .7;
}
.bread a::after {
    content: '/';
    margin: 0 5px;
}
.bread a:hover {
    color: #fff;
    opacity: 1;
}
.paging {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 60px;
}
.paging__box {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.paging__btn {
    position: relative;
    display: block;
    width: 38px;
    height: 38px;
    font-family: 'Lato', 'Noto Sans TC', '微軟正黑體';
    color: #999;
    font-size: 15px;
    text-align: center;
    line-height: 38px;
    border: 1px solid #ddd;
    -webkit-transition: color .4s, background-color .4s, border-color .4s;
    -moz-transition: color .4s, background-color .4s, border-color .4s;
    transition: color .4s, background-color .4s, border-color .4s;
}
.paging__btn:hover,
.paging__btn--active {
    z-index: 2;
    color: #fff;
    background-color: #131d46;
    border-color: #131d46;
}
.paging__btn:nth-child(n + 2) {
    margin-left: -1px;
}
@media (min-width:1280px) {
    .common__container {
        max-width: 1230px;
    }
}
@media (max-width:1279px) and (min-width:1024px) {
    .common__container {
        max-width: 1000px;
    }
}
@media (max-width:1199px) {
    .footer__item:nth-child(3) {
        display: none;
    }
}
@media (max-width:1199px) and (min-width:768px) {
    .footer__item:first-child {
        width: 60%;
    }
    .footer__item:nth-child(2) {
        width: 40%;
    }
}
@media (max-width:1023px) and (min-width:992px) {
    .common__container {
        max-width: 950px;
    }
}
@media (max-width:991px) and (min-width:768px) {
    .common__container {
        max-width: 750px;
    }
}
@media (min-width:992px) {
    .nav .header__logo {
        display: none;
    }
    .burger {
        display: none;
    }
    .burger__block {
        display: none;
    }
}
@media (max-width:991px) {
    .mainwrapper {
        padding-top: 65px;
    }
    .common__section {
        padding: 40px 0;
    }
    .header__info {
        display: none;
    }
    .nav {
        padding: 15px 0;
    }
    .nav__list {
        display: none;
    }
    .nav__contact {
        display: none;
    }
    .burger {
        display: flex;
        flex-wrap: wrap;
        align-content: space-between;
        width: 30px;
        height: 20px;
    }
    .burger::before,
    .burger::after {
        content: '';
        display: block;
        width: 100%;
        height: 2px;
        background-color: #000;
    }
    .burger__line {
        width: 100%;
        height: 2px;
        background-color: #000;
    }
    .burger__block {
        display: none;
        width: 100%;
        background-color: #fff;
        padding: 0 0 15px;
    }
    .burger__block--open {
        display: block;
    }
    .burger__block a {
        display: block;
        color: #333;
        font-size: 16px;
        line-height: 1.2;
        padding: 10px 0;
    }
    .titlebox {
        margin-bottom: 20px;
    }
    .common__title {
        font-size: 24px;
    }
    .common__singletitle {
        font-size: 26px;
        margin-bottom: 20px;
    }
    .paging {
        margin-top: 30px;
    }
}
@media (max-width:767px) {
    .footer__item {
        text-align: center;
    }
    .footer__item:first-child {
        width: 100%;
    }
    .footer__item:nth-child(2) {
        width: 100%;
        margin-top: 20px;
    }
    .footer__title {
        margin-bottom: 15px;
    }
    .footer__text {
        max-width: 100%;
        padding: 0;
    }
    .footer__community {
        justify-content: center;
    }
}
@media (max-width:575px) {
    .pagetitle__box {
        flex-direction: column;
    }
    .bread {
        justify-content: center;
        margin-top: 15px;
    }
}
/* global end */

/* index */
.indexslider__slide {
    height: 30vw;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.indexslider .indexslider__slide {
    display: flex;
}
.indexslider__slide h2 {
    color: #fff;
    font-size: 40px;
    line-height: 1.2;
    margin: 10px 0 0;
}
.indexslider__slide h3 {
    color: #6ec61a;
    font-size: 25px;
    font-weight: 500;
    line-height: 1.2;
    margin: 0;
}
.indexslider__slide a {
    font-family: 'Lato', 'Noto Sans TC', '微軟正黑體';
    color: #fff;
    font-size: 16px;
    background-color: #6ec61a;
    padding: 8px 15px;
    margin: 35px 0 0;
    border: 0;
}
.indexslider__slide a:empty {
    display: none;
}
.service {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0;
}
.service__item {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
}
.service__item img {
    width: 50px;
}
.service__item div {
    width: calc(100% - 50px);
    padding-left: 30px;
}
.service__item h4 {
    color: #2c57ac;
    font-size: 20px;
    font-weight: 400;
    line-height: 1.2;
}
.service__item p {
    color: #777;
    font-size: 14px;
    font-weight: 300;
    line-height: 1.8;
    margin-top: 8px;
}
.product {
    display: flex;
    flex-wrap: wrap;
}
.product__item {
    display: block;
    margin: 30px 15px 0 0;
}
.product__pic {
    position: relative;
    background-color: #fff;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
}
.product__pic::before {
    content: '';
    display: block;
    padding-top: 64%;
}
.product__pic::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(180deg, rgba(38,95,180,.45), rgba(38,95,180,1));
    opacity: .55;
    -webkit-transition: opacity .4s;
    -moz-transition: opacity .4s;
    transition: opacity .4s;
}
.product__item:hover .product__pic::after {
    opacity: 0;
}
.product__item-box {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 2;
    width: 100%;
    padding: 20px 35px;
}
.product__item-box h3 {
    color: #fff;
    font-size: 20px;
    font-weight: 400;
    line-height: 1.2;

    -webkit-transform: translateY(20px);
    -moz-transform: translateY(20px);
    transform: translateY(20px);

    -webkit-transition: transform .4s, color .4s;
    -moz-transition: transform .4s, color .4s;
    transition: transform .4s, color .4s;
}
.product__item:hover .product__item-box h3 {
    color: #265fb4;
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    transform: translateY(0);
}
.product__item-box p {
    color: #fff;
    font-size: 14px;
    font-weight: 300;
    line-height: 1;

    height: 1em;
    overflow: hidden;

    opacity: 0;
    -webkit-transform: translateY(100%);
    -moz-transform: translateY(100%);
    transform: translateY(100%);

    -webkit-transition: opacity .4s, transform .4s, color .4s;
    -moz-transition: opacity .4s, transform .4s, color .4s;
    transition: opacity .4s, transform .4s, color .4s;
}
.product__item:hover .product__item-box p {
    color: #265fb4;
    opacity: 1;
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    transform: translateY(0);
}
.indexabout {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
}
.indexabout__block {
    width: calc(50% - 20px);
}
.indexabout__block h6 {
    color: #777;
    font-size: 14px;
    font-weight: 300;
    line-height: 1.6;
    margin-bottom: 25px;
}
.indexabout__block iframe {
    position: absolute;
    top: 0;
    left: 0;

    width: 100%;
    height: 100%;
}
.indexabout__block .video {
    position: relative;
    width: 100%;
}
.indexabout__block .video::before {
    content: "";

    display: block;

    width: 100%;
    padding-top: 56.25%;
}
.indexabout__item:nth-child(n + 2) {
    margin-top: 10px;
}
.indexabout__btn {
    position: relative;
    display: block;
    color: #555;
    font-size: 17px;
    line-height: 1.35;
    padding: 10px 10px 10px 45px;
    border: 1px solid #ddd;
    border-radius: 22.5px;
    -webkit-transition: color .4s, background-color .4s, border-color .4s;
    -moz-transition: color .4s, background-color .4s, border-color .4s;
    transition: color .4s, background-color .4s, border-color .4s;
}
.indexabout__btn:hover {
    color: #333;
    border-color: #999;
}
.indexabout__item--open .indexabout__btn {
    color: #fff;
    background-color: #2c57ac;
    border-color: #2c57ac;
}
.indexabout__btn img {
    position: absolute;
    left: 20px;
    top: calc(50% - 7px);
    width: 15px;
}
.indexabout__btn img:last-child {
    display: none;
}
.indexabout__item--open .indexabout__btn img:first-child {
    display: none;
}
.indexabout__item--open .indexabout__btn img:last-child {
    display: block;
}
.indexabout__text {
    display: none;
}
.indexabout__item--open .indexabout__text {
    display: block;
    color: #777;
    font-size: 14px;
    font-weight: 300;
    line-height: 1.65;
    margin: 12px 0;
}
@media (min-width:1200px) {
    .service__item {
        width: calc((100% - 60px) / 3);
    }
    .service__item:nth-child(n + 4) {
        margin-top: 60px;
    }
}
@media (max-width:1199px) {
    .indexabout {
        align-items: center;
        flex-direction: column;
    }
    .indexabout__block {
        width: 100%;
    }
    .indexabout__block:nth-child(n + 2) {
        margin-top: 20px;
    }
}
@media (max-width:1199px) and (min-width:576px) {
    .service__item {
        width: calc((100% - 30px) / 2);
    }
    .service__item:nth-child(n + 3) {
        margin-top: 30px;
    }
}
@media (min-width:992px) {
    .indexslider-mobile {
        display: none;
    }
    .product__item {
        width: calc((100% - 30px) / 3);
    }
    .product__item:nth-child(-n + 3) {
        margin-top: 0;
    }
    .product__item:nth-child(3n) {
        margin-right: 0;
    }
}
@media (max-width:991px) {
    .indexslider-pc {
        display: none;
    }
    .indexslider__slide {
        height: 80vw;
        text-align: center;
    }
    .indexslider__slide h3 {
        font-size: 20px;
    }
    .indexslider__slide h2 {
        font-size: 30px;
    }
}
@media (max-width:991px) and (min-width:576px) {
    .product__item {
        width: calc((100% - 15px) / 2);
    }
    .product__item:nth-child(-n + 2) {
        margin-top: 0;
    }
    .product__item:nth-child(2n) {
        margin-right: 0;
    }
}
@media (max-width:575px) {
    .service__item {
        width: 100%;
        align-items: center;
        flex-direction: column;
    }
    .service__item:nth-child(n + 2) {
        margin-top: 20px;
    }
    .service__item div {
        width: 100%;
        text-align: center;
        padding: 15px 0 0;
    }
    .product__item {
        width: 100%;
        margin-right: 0;
    }
    .product__item:first-child {
        margin-top: 0;
    }
}
/* index end */

/* about */
.about {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
}
.about__main {
    width: 52%;
    padding-right: 40px;
}
.about__description {
    color: #777;
    font-size: 16px;
    font-weight: 300;
    line-height: 1.625;
    margin-bottom: 30px;
}
.purpose__item {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
}
.purpose__item:nth-child(n + 2) {
    margin-top: 25px;
}
.purpose__item img {
    width: 25px;
}
.purpose__item div {
    width: 100%;
    max-width: calc(100% - 25px);
    padding-left: 10px;
}
.purpose__item h4 {
    color: #2c57ac;
    font-size: 20px;
    font-weight: 400;
    line-height: 1.2;
}
.purpose__item p {
    color: #777;
    font-size: 16px;
    font-weight: 300;
    line-height: 1.625;
    margin-top: 7px;
}
.about__text-end {
    color: #777;
    font-size: 16px;
    font-weight: 300;
    line-height: 1.625;
    margin-top: 20px;
}
.about__banner {
    width: 48%;
}
@media (max-width:1199px) {
    .about {
        align-items: center;
        flex-direction: column;
    }
    .about__main {
        width: 100%;
        padding: 0 0 20px;
    }
    .about__banner {
        width: 100%;
        max-width: 600px;
    }
}
/* about end */

/* cases */
.cases {
    display: flex;
    flex-wrap: wrap;
}
.cases__item {
    display: block;
}
.cases__item-img {
    position: relative;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}
.cases__item-img::before {
    content: '';
    display: block;
    padding-top: 38%;
}
.date {
    position: absolute;
    right: 0;
    bottom: 0;
    font-family: 'Lato', 'Noto Sans TC', '微軟正黑體';
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    line-height: 40px;
    padding: 0 7px;
    background-color: #2c57ac;
}
.cases__item-title {
    color: #2c57ac;
    font-size: 20px;
    font-weight: 400;
    line-height: 1.2;
    margin-top: 17px;

    max-height: 1.2em;
    overflow: hidden;
}
.cases__item-text {
    color: #777777;
    font-size: 14px;
    font-weight: 300;
    line-height: 1.5;
    margin-top: 15px;

    height: 4.5em;
    overflow: hidden;
}
.detail {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    font-family: 'Lato', 'Noto Sans TC', '微軟正黑體';
    color: #6cd31d;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.2;
    margin-top: 14px;
    -webkit-transition: color .4s;
    -moz-transition: color .4s;
    transition: color .4s;
}
.cases__item:hover .detail {
    color: #1c4075;
}
.detail .fa {
    margin-left: 10px;
}
@media (min-width:992px) {
    .cases__item {
        width: calc((100% - 120px) / 3);
        margin: 60px 60px 0 0;
    }
    .cases__item:nth-child(-n + 3) {
        margin-top: 0;
    }
    .cases__item:nth-child(3n) {
        margin-right: 0;
    }
}
@media (max-width:991px) and (min-width:575px) {
    .cases__item {
        width: calc((100% - 30px) / 2);
        margin: 30px 30px 0 0;
    }
    .cases__item:nth-child(-n + 2) {
        margin-top: 0;
    }
    .cases__item:nth-child(2n) {
        margin-right: 0;
    }
}
@media (max-width:575px) {
    .cases__item {
        width: 100%;
    }
    .cases__item:nth-child(n + 2) {
        margin-top: 20px;
    }
}
/* cases end */

/* cases */
.editor {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
}
.editor__banner {
    width: 54%;
}
.editor__main {
    width: 46%;
    padding-left: 40px;
}
.editor__main h2 {
    color: #333;
    font-size: 25px;
    font-weight: 400;
    margin-bottom: 24px;
    line-height: 1.2;
}
.editor__date {
    color: #777;
    font-size: 16px;
    line-height: 1.4375;
    margin-bottom: 25px;
}
.editor__date .fa {
    color: #2c57ac;
    margin-right: 10px;
}
.editor__date span {
    color: #555;
    font-size: 17px;
    font-weight: 500;
}
.return {
    display: flex;
    flex-wrap: wrap;
    padding-top: 50px;
    margin-top: 20px;
    border-top: 1px solid #ddd;
}
.return__btn {
    display: block;
    width: 120px;
    color: #999;
    font-size: 16px;
    line-height: 38px;
    text-align: center;
    border: 1px solid #ddd;
    -webkit-transition: color .4s, background-color .4s, border-color .4s;
    -moz-transition: color .4s, background-color .4s, border-color .4s;
    transition: color .4s, background-color .4s, border-color .4s;
}
.return__btn:hover {
    color: #fff;
    background-color: #265fb4;
    border-color: #265fb4;
}
@media (max-width:991px) {
    .editor {
        align-items: center;
        flex-direction: column;
    }
    .editor__banner {
        width: 100%;
        text-align: center;
    }
    .editor__main {
        width: 100%;
        padding: 20px 0 0;
    }
    .editor__main h2 {
        font-size: 22px;
        text-align: center;
        margin-bottom: 15px;
    }
    .editor__date {
        text-align: center;
        margin-bottom: 15px;
    }
    .return {
        justify-content: center;
        padding-top: 20px;
        margin-top: 10px;
    }
}
/* cases end */

/* product */
.product__tabs {
    font-size: 0;
    text-align: center;
    margin-bottom: 45px;
}
.product__tab {
    color: #777;
    font-size: 17px;
    font-weight: 300;
    line-height: 1.2;
}
.product__tab:nth-child(n + 2) {
    margin-left: 30px;
}
.product__tab--active {
    color: #6ec61a;
}

/* product end */

/* product_detail */
.product__detail {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
}
.product__detail-banner {
    width: 46%;
    text-align: center;
    border: 1px solid #ddd;
}
.product__main {
    width: 54%;
    padding-left: 40px;
}
.product__main h2 {
    color: #333;
    font-size: 25px;
    font-weight: 400;
    line-height: 1.2;
    margin-bottom: 15px;
}
.product__type {
    color: #777;
    font-size: 16px;
    font-weight: 300;
    line-height: 1.4375;
    margin-bottom: 25px;
}
.product__type .fa {
    color: #2c57ac;
    margin-right: 10px;
}
.product__description p {
    color: #777;
    font-size: 16px;
    font-weight: 300;
    line-height: 1.75;
}
.product__description + .indexabout__item {
    margin-top: 25px;
}
.product__description + .indexabout__item .indexabout__btn {
    margin-bottom: 25px;
}
@media (max-width:991px) {
    .product__detail {
        align-items: center;
        flex-direction: column;
    }
    .product__detail-banner {
        width: auto;
    }
    .product__main {
        width: 100%;
        padding: 20px 0 0;
    }
    .product__main h2 {
        font-size: 22px;
        text-align: center;
        margin-bottom: 15px;
    }
    .product__type {
        text-align: center;
        margin-bottom: 15px;
    }
    .product__description + .indexabout__item {
        margin-top: 15px;
    }
    .product__description + .indexabout__item .indexabout__btn {
        margin-bottom: 15px;
    }
}
/* product_detail end */

/* contact */
.contact {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
}
.contact__box {
    width: 48%;
}
.contact__title {
    color: #2c57ac;
    font-size: 28px;
    font-weight: 500;
    line-height: 1.2;
    margin-bottom: 20px;
}
.contact__title + p {
    color: #555;
    font-size: 16px;
    font-weight: 300;
    line-height: 1.75;
    margin-bottom: 25px;
}
.contact__info-item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}
.contact__info-item:nth-child(n + 2) {
    margin-top: 30px;
}
.contact__info-item .fa {
    display: block;
    width: 40px;
    color: #0579da;
    opacity: .6;
}
.contact__info-text {
    font-family: 'Lato' ,'Noto Sans TC', '微軟正黑體';
    color: #555;
    font-size: 15px;
    font-weight: 300;
    line-height: 1.2;
    margin-top: 2px;
}
.contact__info-text span {
    font-weight: 400;
}
.contact__form {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}
.input__box {
    margin-bottom: 15px;
}
.input__box-half {
    width: calc(50% - 12px);
}
.input__box-full {
    width: 100%;
}
.contact__label {
    color: #777;
    font-size: 16px;
    font-weight: 300;
    line-height: 1.2;
    padding: 0;
    margin-bottom: 10px;
}
input.contact__input {
    font-size: 16px;
    width: 100%;
    height: 45px;
    padding: 0 15px;
    margin: 0;
    border: 1px solid #ccc;
    border-radius: 3px;
}
textarea.contact__textarea {
    font-size: 16px;
    width: 100%;
    height: 135px;
    padding: 10px 15px;
    border: 1px solid #ccc;
    border-radius: 3px;
    resize: none;
}
.contact__submit {
    display: block;
    width: 120px;
    height: 45px;
    color: #fff;
    font-size: 15px;
    text-align: center;
    line-height: 45px;
    margin-top: 10px;
    background-color: #2c57ac;
    border-radius: 22px;
}
.contact__submit:hover {
    color: #fff;
    opacity: .8;
}
.map {
    margin-top: 55px;
    height: 315px;
}
@media (max-width:991px) {
    .contact {
        flex-direction: column;
    }
    .contact__box {
        width: 100%;
    }
    .contact__box:nth-child(n + 2) {
        margin-top: 20px;
    }
    .contact__title {
        font-size: 24px;
        margin-bottom: 10px;
    }
    .contact__title + p {
        margin-bottom: 15px;
    }
    .contact__info-item:nth-child(n + 2) {
        margin-top: 15px;
    }
    .map {
        margin-top: 25px;
    }
}
@media (max-width:575px) {
    .input__box {
        margin-bottom: 5px;
    }
    .input__box-half {
        width: 100%;
    }
    .contact__submit {
        margin: 15px auto 0;
    }
}
/* contact end */