@font-face {
    font-family: 'BHN Glow Better';
    src: url('/Content/homev3/bhn-glow-better-script.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}

:root {
    --red: #9f121b;
    --red-dark: #760710;
    --gold: #c59662;
    --gold-light: #efc892;
    --cream: #fff3df;
    --text: #222;
}

* {
    box-sizing: border-box
}

html {
    scroll-behavior: smooth
}

body {
    font-family: "Montserrat", serif;
    color: var(--text);
    line-height: 1.55;
    background: #fff;
    overflow-x: hidden
}

a {
    text-decoration: none
}

.fw-black {
    font-weight: 900
}

.text-red {
    color: var(--red) !important
}

.text-gold {
    color: var(--gold) !important
}

.main-nav {
    min-height: 68px
}

.navbar-brand img {
    height: 44px
}

.nav-link {
    font-size: 12px;
    color: #222 !important
}

    .nav-link:hover {
        color: var(--gold) !important
    }

.btn-gold {
    background: linear-gradient(90deg,#e8c194,#ba8a57);
    color: #240f05;
    border: 0;
    font-weight: 900
}

    .btn-gold:hover {
        background: #fff;
        color: var(--red);
        box-shadow: inset 0 0 0 1px var(--gold)
    }

.btn-red {
    background: linear-gradient(90deg, #022e50 0%, #0a4f7a 50%, #3f86b3 100%);
    color: #fff;
    border: 0
}

    .btn-red:hover {
        background: #fff;
        color: var(--red);
        box-shadow: inset 0 0 0 1px var(--red)
    }

/*.section-paper {
    background: linear-gradient(180deg,rgba(255,255,255,.96),rgba(255,255,255,.88)),url('https://w.ladicdn.com/s1440x1150/5c7362c6c417ab07e5196b05/1150-20250307025642-8jvam.jpg') center/cover fixed
}*/

.section-title {
    font-size: 34px;
    font-weight: 900;
    letter-spacing: 1px;
    color: var(--red);
    margin-bottom: 38px;
    text-transform: uppercase
}

    .section-title.text-white {
        color: #fff !important
    }

.min-vh-hero {
    min-height: 820px
}

.hero-section {
    padding-top: 76px
}

.hero-logo {
    width: 148px
}

.hero-title {
    font-size: 56px;
    font-weight: 900;
    color: var(--red);
    line-height: .95;
    text-shadow: 3px 3px 0 #000, 5px 5px 8px rgba(0,0,0,0.5);
}

.hero-script {
    font-family: 'BHN Glow Better', sans-serif;
    font-size: 38px;
    font-style: italic;
    color: var(--gold);
}

.quote-card {
    background: #fff2d8;
    border: 1px solid #efcf9a;
    border-radius: 10px;
    padding: 18px 22px;
    box-shadow: 0 14px 28px rgba(130,16,23,.12);
    max-width: 520px
}

.hero-thumbs img {
    width: 100%;
    height: 170px;
    object-fit: cover;
    clip-path: polygon(18% 0,100% 0,82% 100%,0 100%);
    border-radius: 8px;
    box-shadow: 0 14px 30px rgba(0,0,0,.18)
}

.hero-building {
    width: 100%;
    filter: drop-shadow(0 25px 28px rgba(0,0,0,.25));
    margin-top: -22px
}

.about-panel {
    background: rgba(255,255,255,.95);
    border: 1px solid #ead6bd;
    border-radius: 18px;
    box-shadow: 0 25px 55px rgba(117,7,15,.22)
}

    .about-panel p {
        font-size: 15px
    }

.mission-box {
    height: 100%;
    display: flex;
    gap: 18px;
    background: #fff9ee;
    border: 1px solid #edd2ad;
    border-radius: 16px;
    padding: 20px
}

    .mission-box i {
        width: 54px;
        height: 54px;
        border-radius: 50%;
        background: var(--gold);
        display: flex;
        align-items: center;
        justify-content: center;
        color: #6e0b12;
        font-size: 24px;
        flex: 0 0 auto
    }

    .mission-box h5 {
        font-weight: 900;
        color: #5b1115
    }

    .mission-box p {
        margin: 0
    }

.ribbon-brand {
    max-width: 700px;
    text-align: center;
    color: #fff;
    padding: 9px 22px;
    /* background: linear-gradient(90deg, #a3131e, #c99664, #a3131e); */
    font-weight: 900;
    border-color: rgb(232, 194, 148);
    background-image: radial-gradient(circle, rgb(121, 7, 14), rgba(234, 237, 238, 0));
    font-size: 36px;
}

    .ribbon-brand span {
        font-family: 'BHN Glow Better', sans-serif;
        font-style: italic;
        color: #ffe8bd
    }

    .ribbon-brand small {
        display: block;
        font-size: 18px
    }

.core-grid {
    align-items: stretch
}

.hex-card {
    height: 100%;
    padding: 10px;
    text-align: center
}

    .hex-card img {
        width: 140px;
        aspect-ratio: 1;
        object-fit: contain;
        filter: drop-shadow(0 12px 12px rgba(120,8,16,.16))
    }

    .hex-card h5 {
        font-size: 16px;
        font-weight: 900;
        color: #5b1115
    }

    .hex-card p {
        font-size: 12px;
        margin: 0
    }

.section-swiper {
    position: relative;
    overflow: hidden;
    padding-left: 58px;
    padding-right: 58px
}

    .section-swiper .swiper-button-next, .section-swiper .swiper-button-prev {
        width: 40px;
        height: 40px;
        border-radius: 50%;
        background: #fff;
        color: var(--red);
        box-shadow: 0 8px 24px rgba(0,0,0,.2)
    }

        .section-swiper .swiper-button-next:after, .section-swiper .swiper-button-prev:after {
            font-size: 17px;
            font-weight: 900
        }

    .section-swiper .swiper-pagination-bullet-active {
        background: var(--red)
    }

.project-card {
    height: 100%;
    min-height: 560px;
    background: linear-gradient(135deg,#efc993 0%,#c99a63 58%,#bb854d 100%);
    border-radius: 26px 26px 12px 12px;
    box-shadow: 0 18px 36px rgba(94,41,7,.22);
    padding: 108px 34px 28px;
    position: relative;
}

    .project-card:after {
        content: "";
        position: absolute;
        right: -80px;
        top: 42px;
        width: 310px;
        height: 310px;
        background: rgba(255,255,255,.08);
        border-radius: 50%;
        pointer-events: none
    }

.project-ear-title {
    position: absolute;
    left: -35px;
    right: 65px;
    top: 15px;
    min-height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-weight: 900;
    z-index: 1;
}
    .project-ear-title:before {
        content: "";
        position: absolute;
        left: 0px;
        right: 20px;
        top: 8px;
        min-height: 100px;
        background: url(https://w.ladicdn.com/s900x450/5c7362c6c417ab07e5196b05/khung-do-1-20250306080859-riwug.png) center / 100% 100% no-repeat;
        z-index: -1;
    }

.project-content {
    position: relative;
    z-index: 1;
    color: #111;
    font-size: 17px
}

    .project-content p {
        margin-bottom: 9px
    }

.project-card img {
    position: relative;
    z-index: 1;
    width: 100%;
    height: 245px;
    object-fit: cover;
    border-radius: 12px;
    margin-top: 16px;
    box-shadow: 0 12px 25px rgba(80,30,0,.18)
}

.deployed-section {
    padding-top: 70px
}

.brand-tabs .nav-link {
    border-radius: 10px 10px 0 0;
    background: #e8c194;
    color: #fff !important;
    font-weight: 900;
    min-width: 230px;
    margin: 0 5px;
    padding: 14px 42px
}

    .brand-tabs .nav-link.active {
        background: var(--red);
        color: #fff !important
    }

.white-frame {
    background: #fff;
    border-radius: 14px;
    padding: 32px 56px 58px;
    box-shadow: 0 25px 65px rgba(80,7,13,.3);
    min-height: 430px
}

    .white-frame h5 {
        font-weight: 900;
        color: var(--red);
        margin-bottom: 18px
    }

    .white-frame img {
        width: 100%;
        height: 285px;
        object-fit: cover;
        border-radius: 10px
    }

.tab-pane:not(.show) .section-swiper {
    height: 0;
    overflow: hidden
}

.red-project-section, .service-section {
    /*background: radial-gradient(circle at 16% 20%,rgba(255,255,255,.12),transparent 24%),linear-gradient(180deg,#a6121c 0%,#8d0c15 74%,#b41923 100%)*/
    background: radial-gradient(circle at 18% 18%, rgba(255, 255, 255, .08), transparent 24%), linear-gradient(180deg, #022e50 0%, #0a4f7a 50%, rgba(255, 255, 255, .95) 100%);
}

.sale-tabs .nav-link {
    border-radius: 999px;
    color: #fff !important;
    background: rgba(255,255,255,.14);
    border: 1px solid rgba(255,255,255,.35);
    font-weight: 900;
    margin: 4px 6px;
    padding: 10px 24px
}

    .sale-tabs .nav-link.active {
        background: linear-gradient(90deg,#e8c194,#ba8a57);
        color: #4b080d !important
    }

.sale-swiper {
    padding-bottom: 56px
}

.sale-item {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 28px;
    align-items: center;
    background: rgba(255,255,255,.06);
    border-radius: 18px;
    padding: 22px;
    color: #fff;
    min-height: 420px
}

    .sale-item img {
        width: 100%;
        height: 335px;
        object-fit: cover;
        border-radius: 12px;
        box-shadow: 0 18px 38px rgba(0,0,0,.28)
    }

    .sale-item h4 {
        font-weight: 900;
        color: #ffd6a0
    }

    .sale-item li {
        margin-bottom: 7px
    }

.service-section {
    /*background: radial-gradient(circle at 18% 18%,rgba(255,255,255,.08),transparent 24%),linear-gradient(180deg,#98111a 0%,#a3131e 58%,rgba(255,255,255,.95) 100%);*/
    padding-bottom: 90px !important
}
.service-card {
    background: #f7f7f7;
    border-radius: 30px 30px 12px 12px;
    box-shadow: 0 24px 46px rgba(72, 0, 0, .3);
    border-bottom: 12px solid #870b13;
    position: relative;
    padding: 50px 30px 15px;
    min-height: 515px;
}

.service-head {
    background: linear-gradient(90deg,#e9c28f,#c4935b);
    border-radius: 12px;
    text-align: center;
    font-weight: 900;
    color: #000;
    font-size: 22px;
    line-height: 1.35;
    padding: 22px 26px;
    margin-bottom: 32px
}

.service-number {
    position: absolute;
    top: 35px;
    width: 136px;
    height: 136px;
    border-radius: 50%;
    background: #eec58f;
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 48px;
    font-weight: 900;
    border: 2px solid rgba(255,255,255,.75);
    box-shadow: inset 0 0 0 12px #e7bd82,0 10px 25px rgba(0,0,0,.17);
    z-index: 3
}

.service-left .service-number {
    left: -58px
}

.service-right .service-number {
    right: -58px
}

.service-body h4 {
    font-size: 22px;
    font-weight: 900;
    color: var(--red);
    margin-top: 18px
}

.service-body li {
    margin-bottom: 10px
}

    .service-body li::marker {
        color: var(--red)
    }

.partner-row {
    display: flex;
    flex-wrap: wrap;
    gap: 50px;
    align-items: center;
    justify-content: center;
    color: #b38a5d;
    font-size: 22px;
    font-weight: 700;
    font-family: 'BHN Glow Better', sans-serif;
    margin-bottom: 100px;
}
.partner-row span {
    height: 90px;
}
.partner-row span img {
    height: 90px;
    width: 100%;
}

.career-swiper {
    padding-bottom: 58px
}

.career-card {
    height: 100%;
    min-height: 735px;
    background: #fff;
    border: 8px solid #b18452;
    border-radius: 18px;
    padding: 30px;
    box-shadow: 0 18px 34px rgba(89,31,0,.22);
    text-align: left
}

    .career-card h4 {
        color: var(--red);
        font-weight: 900;
        text-transform: uppercase
    }

    .career-card h6 {
        font-weight: 900
    }

    .career-card li {
        margin-bottom: 10px
    }

        .career-card li::marker {
            color: var(--red)
        }

.intro-text {
    max-width: 760px
}

.ai-diagram {
    /*max-width: 620px;*/
    width: 100%;
    /*filter: drop-shadow(0 25px 30px rgba(0,0,0,.2))*/
}

.contact-people-wrap img {
    max-width: 100%;
    object-fit: contain;
    filter: drop-shadow(0 20px 22px rgba(0,0,0,.22))
}

.form-panel {
    margin: auto;
    background: #fff;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 25px 50px rgba(91,17,21,.23)
}

    .form-panel h3 {
        text-align: center;
        color: var(--red);
        font-weight: 900;
        margin-top: 26px
    }

.form-control {
    height: 50px;
    border-radius: 0;
    border: 0;
    border-bottom: 1px solid #ddd
}

.news-feature-img {
    width: 100%;
    height: 420px;
    object-fit: cover
}

.news-feature {
    background: #fff;
    padding: 15px;
    min-height: 420px;
    box-shadow: 0 12px 30px rgba(0,0,0,.08)
}

    .news-feature h4 {
        font-weight: 900;
        color: var(--red);
        text-transform: uppercase
    }

.small-news {
    height: 100%;
    background: #fff;
    padding: 10px;
    box-shadow: 0 10px 24px rgba(0,0,0,.08)
}

    .small-news img {
        width: 100%;
        height: 140px;
        object-fit: cover
    }

    .small-news h6 {
        font-size: 13px;
        font-weight: 800;
        margin: 10px 0 0
    }

.footer {
    background: #870b13
}
    .footer .small a {
        color: #fff;
    }

.call-btn {
    border: 2px solid #870b13;
    width: 54px;
    height: 54px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #870b13;
    position: fixed;
    right: 100px;
    bottom: 30px;
    z-index: 99;
}

@media(max-width:1199px) {
    .project-ear-title {
        font-size: 28px
    }

    .service-head {
        font-size: 19px
    }

    .service-number {
        width: 116px;
        height: 116px;
        font-size: 42px
    }

    .service-left .service-number {
        left: -36px
    }

    .service-right .service-number {
        right: -36px
    }
}

@media(max-width:991px) {
    .min-vh-hero {
        min-height: auto;
        padding: 70px 0
    }

    .hero-title {
        font-size: 50px
    }

    .hero-thumbs img {
        height: 120px
    }

    .section-title {
        font-size: 28px
    }

    .section-swiper {
        padding-left: 44px;
        padding-right: 44px
    }

    .project-card {
        min-height: auto
    }

        .project-card img {
            height: 250px
        }

    .sale-item {
        grid-template-columns: 1fr
    }

        .sale-item img {
            height: 260px
        }

    .service-card {
        min-height: auto;
        margin-top: 44px
    }

    .service-left .service-number, .service-right .service-number {
        left: 50%;
        right: auto;
        transform: translateX(-50%);
        top: -48px
    }

    .service-card {
        padding-top: 74px
    }

    .white-frame {
        padding: 26px 46px 58px
    }

        .white-frame img {
            height: 220px
        }

    .contact-people-wrap img {
        /*max-height: 330px*/
    }
}

@media(max-width:575px) {
    .main-nav .container-xl {
        padding-left: 16px;
        padding-right: 16px
    }
    .call-btn{
        right: 15px;
    }

    .hero-title {
        font-size: 36px
    }

    .hero-script {
        font-size: 30px
    }

    .section-title {
        font-size: 23px
    }

    .section-swiper {
        padding-left: 15px;
        padding-right: 15px
    }

    .hero-building{
        width: 100%;
    }
    .project-ear-title {
        font-size: 15px;
        left: -15px;
        right: 0px;
        top: 0px;
    }
    .brand-tabs{
        gap: 25px;
    }

    .project-card {
        padding: 92px 20px 24px
    }

        .project-card img {
            height: 210px
        }

    .project-content {
        font-size: 14px
    }

    .brand-tabs .nav-link {
        width: 100%;
        min-width: auto;
        margin: 3px 0
    }

    .white-frame {
        padding: 20px 38px 52px
    }

        .white-frame img {
            height: 190px
        }

    .sale-item {
        padding: 16px
    }

        .sale-item img {
            height: 220px
        }

    .service-head {
        font-size: 16px;
        padding: 18px 16px
    }

    .service-body h4 {
        font-size: 18px
    }

    .partner-row {
        font-size: 18px
    }

    .news-feature-img, .news-feature {
        height: auto;
        min-height: auto
    }
}
