/*
Theme Name: Flatsome Child
Description: This is a child theme for Flatsome Theme
Author: UX Themes
Template: flatsome
Version: 3.0
*/

/*************** ADD CUSTOM CSS HERE.   ***************/
:root {
    --color-01: #57b23b;
}

.nav>li>a {
    font-size: 1rem;
}

.section-title-normal,
.section-title-normal span {
    border-bottom: 0;
}

.text-capp span {
    text-transform: inherit;
}

.sub-home-title .section-title-main {
    position: relative;
    padding-right: 70px;
    padding-bottom: 0;
}

.sub-home-title .section-title-main:before {
    content: "";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 2px;
    width: 50px;
    background-color: var(--color-01);
}

.mb-0 .section-title,
.mb-0 .section-title-main {
    margin-bottom: 0;
    padding-bottom: 0;
}

.title-home h3 {
    line-height: 1;
}

.left-block {
    position: relative;
    display: flex;
    align-self: stretch;
    min-height: 100%;
    padding: 0 !important;
    overflow: hidden;
}

.left-block .col-inner,
.left-block .img,
.left-block .img-inner {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
}

.left-block .img {
    margin-bottom: 0;
}

.left-block .img-inner {
    overflow: hidden;
}

.left-block .img-inner img {
    display: block;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
}

.section:has(.left-block) {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.section:has(.left-block) .section-content>.row {
    align-items: stretch !important;
}

.btn--primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 200px;
    padding: 0 15px;
    height: 50px;
    font-weight: bold;
    background: linear-gradient(90deg, var(--color-01) 0%, var(--color-02) 100%);
    position: relative;
    z-index: 1;
    overflow: hidden;
    border-bottom-right-radius: 15px;
    border-top-left-radius: 15px;
    color: #fff;
}

.icon-box-scadel .icon-box-img {
    width: 70px !important;
    height: 70px !important;
    margin: 0 auto;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--color-01);
    border-top-left-radius: 15px;
    border-bottom-right-radius: 15px;
}

.icon-box-scadel h3 {
    margin-bottom: 0;
    font-size: 30px;
    line-height: 45px;
}

.secBlockIntroduce .logo {
    width: 300px;
    height: 300px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-85%, -50%);
    opacity: 0.4;
    pointer-events: none;
}

.left-block .img-inner {
    padding-right: 100px;
}

.icon-box-home .icon-box-img {
    background:#005d22;
    border-width: 1px;
    color: var(--color-01);
    border-radius: 100%;
    height: 77px;
    padding: 15px;
}

.dichvu {
    -webkit-box-shadow: 0 1px 3px -2px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24);
    box-shadow: 0 1px 3px -2px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24);
    border-radius: 21px;
    padding: 25px 10px;
    margin-top: -80px;
    background: #fff;
}

.col {
    padding-bottom: 0 !important;
}

h3.section-title.section-title-center {
    justify-content: center;
}

.is-divider {
    display: none;
}

@media screen and (max-width: 849px) {

    .left-block,
    .left-block .col-inner,
    .left-block .img,
    .left-block .img-inner {
        position: relative;
        inset: auto;
        height: auto !important;
    }

    .left-block .img-inner img {
        height: auto !important;
    }
}

/* Service card UX Builder shortcode */
.mp-service-card {
    --mp-service-card-bg: #d9edc5;
    --mp-service-card-accent: #86c13d;
    --mp-service-card-button: #7ea354;
    position: relative;
    width: 100%;
    max-width: 263px;
    min-height: 412px;
    margin: 32px auto 0;
    padding: 48px 15px 44px;
    color: #222;
    background: var(--mp-service-card-bg);
    border-radius: 12px;
    text-align: center;
}

.mp-service-card__number {
    position: absolute;
    top: -24px;
    left: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    color: #fff;
    background: #005d22;
    border-radius: 50%;
    font-size: 25px;
    font-weight: 700;
    line-height: 1;
    transform: translateX(-50%);
}

.mp-service-card__body {
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: 320px;
}

.mp-service-card__title {
    margin: 0 0 12px;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.35;
}

.mp-service-card__desc {
    width: 100%;
    font-size: 16px;
    line-height: 1.6;
    text-align: justify;
    margin-bottom:1rem;
}

.mp-service-card__desc p:last-child {
    margin-bottom: 0;
}

.mp-service-card__button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 94px;
    min-height: 39px;
    margin-top: auto;
    padding: 9px 18px;
    color: #fff;
    background: #005d22;
    border-radius: 8px;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.2;
    text-decoration: none;
}

.mp-service-card__button:hover {
    color: #fff;
    filter: brightness(0.95);
}

@media screen and (max-width: 549px) {
    .mp-service-card {
        max-width: 100%;
        min-height: 0;
        padding-right: 22px;
        padding-left: 22px;
    }

    .mp-service-card__body {
        min-height: 240px;
    }
}

/* Timeline UX Builder shortcode */
.mp-timeline {
    --mp-timeline-accent: #8bc641;
    --mp-timeline-line: #9a9a9a;
    --mp-timeline-heading: #777777;
    --mp-timeline-text: #333333;
    position: relative;
    max-width: 560px;
    padding: 60px 0 16px 64px;
    color: var(--mp-timeline-text);
}

.mp-timeline::before {
    content: "";
    position: absolute;
    top: 20px;
    bottom: 18px;
    left: 29px;
    width: 2px;
    background: var(--mp-timeline-line);
}

.mp-timeline::after {
    content: "";
    position: absolute;
    top: 17px;
    left: 14px;
    width: 30px;
    height: 30px;
    background: var(--mp-timeline-accent);
    border: 8px solid #666666;
    border-radius: 50%;
    box-sizing: border-box;
}

.mp-timeline__item {
    position: relative;
    min-height: 88px;
    padding: 11px 0 18px;
}

.mp-timeline__item:last-child {
    min-height: 0;
    padding-bottom: 22px;
}

.mp-timeline__dot {
    position: absolute;
    top: 20px;
    left: -35px;
    width: 16px;
    height: 16px;
    background: var(--mp-timeline-accent);
    border-radius: 50%;
    transform: translateX(-50%);
}

.mp-timeline__content {
    font-size: 16px;
    line-height: 1.55;
}

.mp-timeline__title {
    margin-bottom: 2px;
    color: var(--mp-timeline-heading);
    font-size: 16px;
    font-style: italic;
    font-weight: 700;
    line-height: 1.35;
}

.mp-timeline__text {
    color: var(--mp-timeline-text);
    font-size: 16px;
    font-weight: 700;
    line-height: 1.55;
}

.mp-timeline__text p {
    margin-bottom: 0;
}

.mp-timeline__green {
    color: var(--mp-timeline-accent);
}

.mp-timeline__blue {
    color: #294866;
}

.border-image {
    padding: 15px 15px 15px 15px;
    border-radius: 10px;
    background: rgb(170, 197, 144);
}

.color-white a {
    color: #fff
}

.absolute-footer {
    display: none !important
}

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

@media screen and (max-width: 549px) {
    .mp-timeline {
        padding-left: 52px;
    }

    .mp-timeline::before {
        left: 24px;
    }

    .mp-timeline::after {
        left: 9px;
    }

    .mp-timeline__dot {
        left: -28px;
    }

    .mp-timeline__item {
        min-height: 0;
        padding-bottom: 24px;
    }
}


.mp-timeline__item:last-child::after {
    content: "";
    position: absolute;
    bottom: -6px;
    left: -50px;
    width: 30px;
    height: 30px;
    background: var(--mp-timeline-accent);
    border: 8px solid #666666;
    border-radius: 50%;
    box-sizing: border-box;
}

.service-s .icon-box-text {
    position: relative;
    top: 3px;
    padding-left: 10px !important;
}

.mb-1 {
    margin-bottom: 0;
}

td:first-child,
th:first-child {
    padding-left: .5em;
}

.mp-service-card__image img {
    height: 140px;
    object-fit: cover;
}

@media(max-width:749px) {
    .dichvu {
        margin-top: 0;
    }

    .icon-box-home .icon-box-img {
        height: 60px !important;
        width: 60px !important;
        padding: 10px;
    }

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

    .order-0 {
        order: 1;
    }

    .order-1 {
        order: 2;
    }
}

@media screen and (max-width: 549px) {
    .mp-timeline__dot {
        left: -28px;
    }

    .mp-timeline__item:last-child::after {
        left: -43px;
    }
}