.absolute-footer, html {
    background-color: #fff !important;
}

@font-face {
    src: url("../fonts/SFUBaskervilleBookItalic.TTF");
    font-family: "SFUBaskervilleBookItalic";
}

@font-face {
    src: url("../fonts/SFUFuturaHeavy.TTF");
    font-family: "SFUFuturaHeavy";
}

ul, li {
    list-style: none;
    margin-bottom: 0px !important;
}


.row-0 {
    padding: 0px 15px !important;
}

.pd-0 {
    padding: 0px !important;
}

.row-5 {
    padding: 0px 10px !important;
}

.pd-5 {
    padding: 0px 5px 10px 5px !important;
}

.row-7 {
    padding: 0px 7px !important;
}

.pd-7 {
    padding: 0px 7px 7px 7px !important;
}

.noPadding {
    padding-bottom: 0px !important;
}

.clearfix:after {
    visibility: hidden;
    display: block;
    font-size: 0;
    content: " ";
    clear: both;
    height: 0
}

.fl {
    float: left
}

.fr {
    float: right
}

.mr-0 {
    margin-right: 0 !important
}

.mr-20 {
    margin-right: 20px
}

.mr-30 {
    margin-right: 30px
}

.mr-40 {
    margin-right: 40px
}

.ml-0 {
    margin-left: 0 !important
}

.ml-20 {
    margin-left: 20px
}

.ml-30 {
    margin-left: 30px
}

.ml-40 {
    margin-left: 40px
}

.mt-0 {
    margin-top: 0 !important
}

.mt-10 {
    margin-top: 10px
}

.mt-20 {
    margin-top: 20px
}

.mt-30 {
    margin-top: 30px
}

.mt-40 {
    margin-top: 40px
}

.mt-60 {
    margin-top: 60px
}

.mt-80 {
    margin-top: 80px
}

.mb-0 {
    margin-bottom: 0 !important
}

.mb-10 {
    margin-bottom: 10px
}

.mb-20 {
    margin-bottom: 20px
}

.mb-30 {
    margin-bottom: 30px
}

.mb-40 {
    margin-bottom: 40px
}

.mb-60 {
    margin-bottom: 60px
}

header#header {
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

/**header**/
ul.header-nav.header-nav-main.nav.nav-right.nav-uppercase li {
    margin: 0px !important;
}

ul.header-nav.header-nav-main.nav.nav-right.nav-uppercase li a {
    color: #fff;
    font-size: 14px;
    padding: 0px 15px;
}

ul.sub-menu.nav-dropdown.nav-dropdown-default {
    border: 0px !important;
    padding: 0px !important;
    background: #000;
    top: 35px !important;
    border-top: 2px solid #fff !important;
}

li.header-search.header-search-lightbox.has-icon a {
    padding: 0px 15px !important;
    width: 80px;
    text-align: center;
    display: block;
}

ul.sub-menu.nav-dropdown.nav-dropdown-default li a {
    padding: 10px 0 !important;
}

ul.sub-menu.nav-dropdown.nav-dropdown-default li {
    margin: 0px !important;
}

.nav-dropdown-has-arrow li.has-dropdown:before {
    display: none !important;
}

.nav-dropdown-has-arrow li.has-dropdown:after {
    display: none !important;
}

div#masthead {
    position: relative;
    z-index: 999999999 !important;
}

.header.show-on-scroll, .stuck .header-main {
    height: 70px !important;
    background: #000;
}

div#masthead #logo img {
    max-height: 120px !important;
    position: absolute;
    top: -20px;
}

.opacity-header {
    background: rgba(0, 20, 59, 0.5) !important;
}

.opacity-header .header-bg-color, .opacity-header .header-wrapper {
    background: transparent !important;
}

.bk-language {
    height: 70px;
    border-left: 1px solid rgba(255, 255, 255, 0.2);
    border-right: 1px solid rgba(255, 255, 255, 0.2);
    padding: 17px 20px;
}

.bk-language select {
    box-shadow: unset !important;
    background: transparent !important;
    border: 0px !important;
    color: #fff;
    font-size: 14px;
    text-transform: uppercase;
    font-weight: 700;
    margin: 0px !important;
}

.bk-language select option {

}

.bk-language select#lang_choice_1 option[value="vi"] {
    background-image: url('../images/vn.png');
}

.bk-language select#lang_choice_1 option[value="en"] {
    background-image: url('../images/en_1.png');
}

.bk-language select#lang_choice_1 option[value="ja"] {
    background-image: url('../images/jp.png');
}

.bk-language select option {
    color: #fff;
}

/**slide**/
.home-slider {
    margin-top: -70px;
}

/*8footer**/
footer#footer {
    width: 100%;
    display: inline-block;
    padding: 50px 0 40px 0;
    background: #212121;
}

footer#footer .footer-top, footer#footer .footer-top .footer-title {
    width: 100%;
    display: inline-block;
}

footer#footer .footer-top .footer-title {
    margin-bottom: 15px;
}

footer#footer .footer-top .footer-title h3 {
    color: #fff;
    text-transform: uppercase;
    line-height: 25px;
    font-size: 16px;
    margin: 0px;
}

footer#footer .footer-top .footer-menu ul li {
    border: 0px !important;
    margin: 0px !important;
}

footer#footer .footer-top .footer-menu ul li a {
    padding: 0px !important;
    font-size: 14px;
    color: #9f9f9f;
}

footer#footer .footer-top .footer-menu ul li:not(:first-child) a {
    margin-top: 10px;
}

footer#footer .footer-top .footer-address p {
    color: #9f9f9f;
    font-size: 14px;
}

footer#footer .footer-top .footer-address p:not(:last-child) {
    margin-bottom: 10px;
}

footer#footer .footer-top .footer-address p b {
    font-size: 15px;
    margin-bottom: 5px;
}

.backUp {
    position: fixed;
    width: 40px;
    height: 40px;
    color: #fff;
    text-align: center;
    bottom: 30px;
    right: 30px;
    background: #000000;
    border-radius: 50px;
    border: 1px solid #fff;
    cursor: pointer;
    font-size: 20px;
    line-height: 40px;
}

footer#footer .footer-top input.wpcf7-form-control.wpcf7-text.wpcf7-email.wpcf7-validates-as-email.input-footer {
    box-shadow: unset !important;
    background: transparent !important;
    border: 0px !important;
    border-radius: 0px !important;
    color: #fff;
    font-size: 14px;
    border-bottom: 2px solid #fff !important;
}

footer#footer .footer-top input.wpcf7-form-control.wpcf7-text.wpcf7-email.wpcf7-validates-as-email.input-footer::placeholder {
    color: #fff;
}

footer#footer input.wpcf7-form-control.wpcf7-submit.btnRegister {
    background: #14477c;
    border: 0px !important;
    border-radius: 0px !important;
    display: inline-block;
    width: 100px;
    font-weight: normal;
    font-size: 14px;
    margin: 0px !important;
}

footer#footer .footer-social ul li {
    width: 30px;
    height: 30px;
    float: left;
    border: 1px solid #fff;
    border-radius: 50%;
    margin-right: 10px;
    transition: 0.3s ease-in-out;
}

footer#footer .footer-social ul li a {
    color: #fff;
    font-size: 14px;
    text-align: center;
    display: block;
    line-height: 30px;
    padding: 0px !important;
}

footer#footer .footer-social ul li:hover {
    transition: 0.3s ease-in-out;
    transform: translateY(-5px);
}

.footer-copyright a {
    color: #fff;
    font-weight: 700;
}

.footer-copyright {
    background: #000000;
    text-align: center;
    color: #fff;
    padding: 15px 0;
    font-size: 14px;
}

/**partner**/
article.bk-company {
    width: 100%;
    background: #000000;
    padding: 40px 0;
    position: relative;
    margin-top: 100px;
}

.home-title {
    width: 100%;
    margin-bottom: 20px;
}

.home-title h3 {
    color: #fff;
    text-transform: uppercase;
    font-weight: normal;
    font-size: 25px;
    margin: 0px !important;
}

article.bk-company .company-items img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

article.bk-company .company-items {
    width: 100%;
    display: inline-block;
    border-top: 1px solid rgba(255, 255, 255, 0.5);
    border-left: 1px solid rgba(255, 255, 255, 0.5);
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
    padding: 20px;
}

article.bk-company .owl-item.active:nth-child(6n) .company-items {
    border-right: 1px solid rgba(255, 255, 255, 0.5);
}

.owl-dots {
    display: none !important;
}

.owl-nav button {
    margin: 0px !important;
    position: absolute;
    top: 50% !important;
    transform: translateY(-50%) !important;
}

article.bk-company .owl-nav button i {
    color: #fff;
    font-size: 30px;
}

.owl-nav button.owl-prev {
    left: -50px;
}

.owl-nav button.owl-next {
    right: -50px;
}

article.bk-company .company-number {
    width: 97.5%;
    background: #14477c;
    padding: 20px;
    position: absolute;
    top: -100px;
}

article.bk-company .company-body {
    margin-top: 60px;
}

article.bk-company .company-nb-item {
    text-align: center;
    border-right: 1px solid #fff;
}

article.bk-company .noBorder {
    border-right: 0px;
}

article.bk-company .company-nb-item .number-int {
    color: #2191cb;
    font-weight: 700;
    font-size: 40px;
}

article.bk-company .company-nb-item .mumber_title {
    color: #fff;
    text-transform: uppercase;
    font-size: 16px;
}

/**title**/
.home-title.dark h3 {
    color: #000;
}

/**what we do**/
.what-we-do {
    font-size: 15px;
}

.whatBtn {
    padding: 8px 20px;
    border: 1px solid #14477c;
    display: inline-block;
    margin-top: 20px;
    border-radius: 10px;
    position: relative;
}

.whatBtn a {
    color: #14477c;
    font-size: 15px;
}

.whatBtn a:after {
    content: '\f105';
    font-family: 'FontAwesome';
    position: absolute;
    right: 7px;
    top: 10px;
}

/**slide-sector**/
.slide-sector .owl-stage {
    padding-left: 0px !important;
}

.sector-item {
    width: 100%;
    height: 200px;
    position: relative;
    overflow: hidden;
    transition: 0.3s ease-in-out;
}

.sector-item .sector-thumbnail {
    width: 100%;
    height: 100%;
}

.sector-item .sector-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.sector-item .sector-title {
    width: 100%;
    position: absolute;
    bottom: 0px;
    z-index: 9;
    background: rgba(0, 0, 0, 0.4);
    text-align: center;
    padding: 5px 10px;
}

.sector-item .sector-title h3 {
    color: #fff;
    text-transform: uppercase;
    font-weight: normal;
    margin: 0px !important;
    font-size: 15px;
}

.slide-sector button i {
    font-size: 30px;
}

.sector-item:after {
    content: '';
    background: rgba(20, 71, 124, 0.3);
    position: absolute;
    bottom: -100%;
    width: 100%;
    height: 100%;
    transition: 0.3s ease-in-out;
}

.sector-item:hover:after {
    transition: 0.3s ease-in-out;
    bottom: 0px;
}

.sector-item:hover .sector-title {
    background: rgba(20, 71, 124, 0.8);
}

/**project**/
.project-item {
    width: 100%;
    display: block;
    position: relative;
    overflow: hidden;
    transition: 0.3s ease-in-out;
}

.project-item .project-thumbnail {
    width: 100%;
    height: 200px;
}

.project-item .project-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.project-item .project-content {
    width: 100%;
    position: absolute;
    padding: 10px 15px;
    bottom: -100%;
    transition: 0.3s ease-in-out;
    background: rgba(0, 0, 0, 0.4);
}

.project-item .project-content h4 {
    color: #fff;
    font-size: 14px;
    margin: 0px !important;
    -webkit-line-clamp: 1;
    text-overflow: ellipsis;
    -webkit-box-orient: vertical;
    overflow: hidden;
    display: -webkit-box;
}

.project-item .project-btn {
    color: #fff;
    font-size: 13px;
}

.project-item:hover .project-content {
    transition: 0.3s ease-in-out;
    bottom: 0px;
}

/**single project**/
section#project-gallery {
    width: 100%;
    display: inline-block;
    margin-top: -75px !important;
}

section#project-gallery .project-gl-item {
    width: 100%;
    height: 500px;
}

section#project-gallery .project-gl-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

section#page-content {
    width: 100%;
    display: inline-block;
    margin: 30px 0;
}

header#header-single .header-category span:last-child {
    display: none;
}

header#header-single .header-category {
    text-transform: uppercase;
    font-size: 16px;
}

header#header-single .header-title h2 {
    margin: 10px 0 30px 0;
    font-size: 25px;
}

article.entry-content {
    padding-top: 0px !important;
    font-size: 16px;
}

.project-info table tr td {
    border: 0px !important;
    color: #fff;
    font-size: 15px;
}

.project-info {
    background: #14477c;
    padding: 20px 30px;
}

.project-info table tr td.info-td {
    text-transform: uppercase;
    font-weight: 700;
}

/**project related**/
.bg-dark {
    background: #000000;
    padding: 40px 0;
}

section#project-related .project-thumbnail {
    height: 200px;
}

/**project cat**/
section#page-category {
    width: 100%;
    display: inline-block;
    background: #000;
    padding: 40px 0;
}

section#page-category article.category-header h2 {
    color: #fff;
    text-align: center;
    text-transform: uppercase;
    font-size: 30px;
    margin-bottom: 30px;
}

.project-item.category-item .project-thumbnail {
    height: 500px;
}

.project-item.category-item .project-content {
    bottom: 0px;
}

.project-item.category-item .project-content {
    background: rgba(0, 0, 0, 0.6);
    z-index: 9;
}

.project-item.category-item .project-overlay {
    background: rgba(20, 71, 124, 0.7);
    width: 100%;
    height: 100%;
    position: absolute;
    padding: 40px 15px 60px 15px;
    color: #fff;
    display: flex;
    justify-content: end;
    align-items: end;
    flex-basis: 100%;
    flex-flow: column-reverse;
    bottom: -100%;
    transition: 0.3s ease-in-out;
}

.project-item.category-item:hover .project-content {
    background: rgba(20, 71, 124, 0.7) !important;
}

.project-item.category-item:hover .project-overlay {
    transition: 0.3s ease-in-out;
    bottom: 0px !important;
}

/**who**/
.home-bottom h3:before {
    content: '';
    display: block;
    height: 2px;
    width: 100px;
    background: #13467b;
    position: absolute;
    bottom: -5px;
    left: 50%;
    transform: translateX(-50%);
}

.home-bottom h3 {
    font-size: 30px;
    text-transform: uppercase;
    color: #13467b;
}

.home-bottom {
    margin-bottom: 20px;
    text-align: center;
}

.about-video {
    width: 600px;
    height: 400px;
    margin: auto;
    position: relative;
}

.about-video img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.about-video:before {
    content: '';
    background: rgba(20, 71, 124, 0.4);
    width: 100%;
    height: 100%;
    display: block;
    position: absolute;
}

.about-video p {
    margin: 0px !important;
}

.about-video .video-icon {
    background: #2291cb;
    width: 55px;
    height: 55px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    box-shadow: 0px 2px 16px rgba(0, 0, 0, 0.1);
}

.about-video .video-icon:before {
    content: '\f04b';
    font-family: 'FontAwesome';
    color: #fff;
    text-align: center;
    width: 100%;
    height: 100%;
    display: block;
    line-height: 55px;
    font-size: 20px;
}

.about-list-group {
    width: 100%;
    display: inline-block;
}

.about-list-group ul li img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.about-list-group ul li {
    margin: 0px !important;
    width: calc(100% / 5);
    float: left;
    height: 100px;
    margin-bottom: 10px !important;
}

/*8contact**/
.formContact label b {
    color: #ff3333;
}

.formContact label {
    font-weight: normal;
    font-size: 15px;
}

.formContact .input-contact {
    box-shadow: unset !important;
    margin: 10px 0 15px 0 !important;
}

textarea.wpcf7-form-control.wpcf7-textarea.textarea-contact {
    box-shadow: unset !important;
    height: 150px;
}

input.wpcf7-form-control.wpcf7-submit.btnContact {
    display: inline-block;
    background: #fff;
    color: #000;
    border: 1px solid #000;
    width: 100px;
}

.cat-2 .project-thumbnail {
    height: 300px !important;
}

.about-video.video-service {
    width: 100%;
    height: 370px;
    margin-top: 30px;
}

/**people**/
.tabbed-content.tab-header ul {
    margin: 0px !important;
    background: #14477c;
    padding: 15px 0;
}

.tabbed-content.tab-header ul li a {
    color: #fff;
    font-weight: normal;
    font-size: 15px;
    padding: 5px 15px;
}

.tabbed-content.tab-header ul li a:before {
    background: #fff !important;
}

.tabbed-content.tab-header ul li a:before {
    background: #fff !important;
    top: unset !important;
    bottom: -5px;
}

.people-entry .people-text {
    font-size: 16px;
}

.people-entry h4 {
    color: #14477c;
    font-size: 25px;
}

.people-entry {
    width: 100%;
    display: inline-block;
    padding: 30px 0;
}

/**category**/
article.bk-category {
    width: 100%;
    padding: 40px 0;
}

article.bk-category .bk-cat-item {
    width: 100%;
    display: inline-block;
    background: #2291cb;
    padding: 30px;
    transition: 0.3s ease-in-out;
}

article.bk-category .bk-cat-item h3 {
    margin: 20px 0 0 0;
    text-align: center;
    font-weight: normal;
    color: #fff;
    font-size: 18px;
}

article.bk-category .bk-cat-item img {
    width: 100px;
    margin: auto;
    height: 100px;
    object-fit: contain;
    display: block;
}

article.bk-category .bk-cat-item {
    width: 100%;
    display: inline-block;
    background: #2291cb;
    padding: 30px;
}

article.bk-category .bk-cat-item:hover {
    transition: 0.3s ease-in-out;
    box-shadow: 0px 2px 16px rgba(255, 255, 255, 0.05);
}

.bg-white {
    width: 100%;
    background: #fff;
    margin-top: 20px !important;
    display: inline-block;
    padding: 30px 0;
}

.post-item .post-content h3 {
    color: #14477c;
    font-size: 20px;
    line-height: 25px;
    margin: 0px !important;
}

.post-item .post-content .post-meta {
    font-size: 15px;
    color: #333;
    margin: 10px 0;
}

.post-item {
    width: 100%;
    display: inline-block;
}

.post-item .post-thumbnail {
    width: 100%;
    height: 300px;
}

.post-item .post-thumbnail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.post-item .post-content .post-excerpt p {
    font-size: 15px;
    color: #333;
    margin: 0px !important;
}

.post-item .post-content .postBtn {
    margin: 20px 0 0 0;
    text-transform: uppercase;
    color: #444444;
    font-weight: 700;
    font-size: 15px;
}

.slide-post-category .owl-dots {
    display: block !important;
}

.slide-post-category .owl-dots {
    display: block !important;
    position: absolute;
    bottom: 0px;
    width: 100%;
    text-align: right;
    right: 0px;
}

.slide-post-category .owl-dots button {
    width: 15px;
    height: 15px;
    background: #000 !important;
    min-height: 15px !important;
    border-radius: 50%;
    margin: 0px 3px;
}

.slide-post-category .owl-dots button.active {
    background: #14477c !important;
}

.slide-post-category .owl-nav button i {
    font-size: 30px;
}

.category-contact form {
    margin: 0px !important;
}

.category-contact {
    background: #14477c;
    width: 100%;
    display: inline-block;
    padding: 40px 0;
}

.category-form {
    width: 500px;
    margin: auto;
}

.category-form span.wpcf7-form-control-wrap.email {
    width: 60%;
    float: left;
}

.category-form span.wpcf7-form-control-wrap.email input {
    margin: 0px !important;
    background: transparent !important;
    border: 0px !important;
    border-bottom: 1px solid #fff !important;
    box-shadow: unset !important;
    border-radius: 0px !important;
    color: #fff !important;
}

.category-form span.wpcf7-form-control-wrap.email input::placeholder {
    color: #fff !important;
}

.category-form input.wpcf7-form-control.wpcf7-submit.btnCategory {
    width: 19%;
    float: left;
    padding: 0px !important;
    background: #fff !important;
    color: #14477c;
    font-weight: normal;
    border-radius: 0px !important;
    margin-left: 5px;
    margin-bottom: 0px !important;
    margin-right: 0px !important;
    font-size: 15px;
    height: 40px;
    border: 1px solid #fff;
}

.category-form button.wpcf7-submit.btnReset {
    margin: 0px !important;
    width: 19%;
    float: left;
    margin-left: 5px !important;
    background: transparent !important;
    color: #fff !important;
    box-shadow: unset !important;
    border: 1px solid #fff !important;
    border-radius: 0px !important;
    font-weight: normal;
    font-size: 15px;
    height: 40px;
}

div#wpdcom {
    width: 100% !important;
    max-width: 100%;
}

.pll-parent-menu-item a {
    line-height: 70px !important;
}

.pll-parent-menu-item {
    border-left: 1px solid rgba(255, 255, 255, 0.3);
    height: 70px;
    border-right: 1px solid rgba(255, 255, 255, 0.3);
}

.pll-parent-menu-item ul.sub-menu.nav-dropdown.nav-dropdown-default li a {
    line-height: unset !important;
}

ul.sub-menu.nav-dropdown.nav-dropdown-default li a {
    border-color: rgba(255, 255, 255, 0.05) !important;
}

.pll-parent-menu-item ul.sub-menu.nav-dropdown.nav-dropdown-default {
    top: 50px !important;
    min-width: 150px !important;
}

.pll-parent-menu-item ul.sub-menu.nav-dropdown.nav-dropdown-default li a img {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px;
    border-radius: 50%;
    object-fit: cover;
}

.pll-parent-menu-item.current-menu-parent a img {
    width: 20px !important;
    height: 20px !important;
    min-width: 20px !important;
    min-height: 20px;
    border-radius: 50%;
    object-fit: cover;
}